Skip to main content

ASTs

Abstract Syntax Trees (AST)s

Parsers such as those in ESLint and TypeScript read in the text of source code and parse it into a standard format they can reason about known as an Abstract Syntax Tree (AST). ASTs are called such because although they might contain information on the location of constructs within source code, they are an abstract representation that cares more about the semantic structure.

For example, given this line of code:

1 + 2;

ESLint would natively understand it as an object like:

{
"type": "ExpressionStatement",
"expression": {
"type": "BinaryExpression",
"left": {
"type": "Literal",
"value": 1,
"raw": "1"
},
"operator": "+",
"right": {
"type": "Literal",
"value": 2,
"raw": "2"
}
}
}

ESLint uses an AST format known as estree.

ESTree is more broadly used than just for ESLint -- it is the de facto community standard. ESLint's built-in parser that outputs an estree-shaped AST is also a separate package, called espree.

note

You can play more with various ASTs such as ESTree on astexplorer.net and read more details on their Wikipedia article.