ASTs & Ember.js
data:image/s3,"s3://crabby-images/f8541/f85410588a79f6d73fd142c8425520b7e8b64bba" alt=""
data:image/s3,"s3://crabby-images/1c0e0/1c0e0dcd12820568dc0c13124c55fb73a0ef5078" alt=""
data:image/s3,"s3://crabby-images/ae6ff/ae6ff29e588f342907c60b6a1f5c5991b5d8c2aa" alt=""
data:image/s3,"s3://crabby-images/92988/929886499eb34e89848fe3eb430349a8e2dc6a83" alt=""
data:image/s3,"s3://crabby-images/0d83c/0d83cde36bfff357f820912300cc36905ddab1e1" alt=""
data:image/s3,"s3://crabby-images/c2c55/c2c555fe6d0ccba6000614428c28362e95575edd" alt=""
data:image/s3,"s3://crabby-images/4ae1d/4ae1da02078ae5d528e146345967a6b769228775" alt=""
About me
twitter/rajasegar_c
Front-end Developer @ Freshworks
github/rajasegar
hangaroundtheweb.com
What is an AST?
a tree representation of the abstract syntactic structure of source code written in a programming language.
data:image/s3,"s3://crabby-images/3e3c5/3e3c5d3602521d7be45a30eecb5dc8faaa02d2c5" alt=""
An AST is basically a DOM for your code.
data:image/s3,"s3://crabby-images/a60b7/a60b78a0a9bf42d8f4604e33c9b7bdeecc4243e3" alt=""
data:image/s3,"s3://crabby-images/efe60/efe60de1e27859f0345a2d467ec319cf6272c6d5" alt=""
Lexical Analyzer
Scanner
function helloWorld() {
console.log('hello world');
}
data:image/s3,"s3://crabby-images/3d0c3/3d0c38c05ad3fc1b2fce0abdefea99ccbc6388b3" alt=""
Syntax Analyzer
Parser
data:image/s3,"s3://crabby-images/324d6/324d687c70daf2ba54b90770e9aa5b31ad12328f" alt=""
data:image/s3,"s3://crabby-images/3d0c3/3d0c38c05ad3fc1b2fce0abdefea99ccbc6388b3" alt=""
function helloWorld() {
console.log('hello world');
}
{
"type": "Program",
"start": 0,
"end": 44,
"body": [
{
"type": "FunctionDeclaration",
"start": 0,
"end": 44,
"id": {
"type": "Identifier",
"start": 9,
"end": 14,
"name": "hello"
},
"expression": false,
"generator": false,
"params": [],
"body": {
"type": "BlockStatement",
"start": 17,
"end": 44,
"body": [
{
"type": "ExpressionStatement",
"start": 21,
"end": 42,
"expression": {
"type": "CallExpression",
"start": 21,
"end": 41,
"callee": {
"type": "MemberExpression",
"start": 21,
"end": 32,
"object": {
"type": "Identifier",
"start": 21,
"end": 28,
"name": "console"
},
"property": {
"type": "Identifier",
"start": 29,
"end": 32,
"name": "log"
},
"computed": false
},
"arguments": [
{
"type": "Literal",
"start": 33,
"end": 40,
"value": "hello",
"raw": "'hello'"
}
]
}
}
]
}
}
],
"sourceType": "module"
}
AST
Where is it used?
- Syntax Highlighting
- Code Completion
- Static Analysis (aka ESLint, etc.,)
- Code Coverage
- Minification
- JIT Compilation
- Source Maps
- Compiling to JS languages
- Code Refactoring & Migrations
- And much more ...
data:image/s3,"s3://crabby-images/98af4/98af45788548baba601e5cd8456b9ab0d18520b3" alt=""
data:image/s3,"s3://crabby-images/7586a/7586a9f35bba143e3d60a1889d7f6c21c643e410" alt=""
data:image/s3,"s3://crabby-images/e42d9/e42d9dae1a32b1f7905667d68650e71fe667a9e5" alt=""
data:image/s3,"s3://crabby-images/5ec8d/5ec8d1682e4892f163af6b0f8a2c938a79ecae76" alt=""
data:image/s3,"s3://crabby-images/1592a/1592adfc40a39e43c05c14543c315b3a16f7fe1f" alt=""
data:image/s3,"s3://crabby-images/b8ee3/b8ee3f9b097fe473d4a3bce63f4cccb1459b8948" alt=""
data:image/s3,"s3://crabby-images/2273e/2273e96dd58897d49ce5e2ea6e2a142504b80dcb" alt=""
data:image/s3,"s3://crabby-images/511f9/511f93e27cde834baf764f03c924bf9d2fa62f69" alt=""
data:image/s3,"s3://crabby-images/99d00/99d0059f3b9bc157ae755bc30bd7d9223f5976ba" alt=""
data:image/s3,"s3://crabby-images/5f508/5f5085a705586800d48c84e9191865226540ed6e" alt=""
data:image/s3,"s3://crabby-images/f1786/f17864bf5c4a4d1d5f97d86e31c7d1a515591901" alt=""
data:image/s3,"s3://crabby-images/bc7a4/bc7a421930c356e355e43d4a6dfffc93cea2cfaa" alt=""
data:image/s3,"s3://crabby-images/5ba88/5ba889e921caa7827fcbbf1eed371394aef2dcae" alt=""
data:image/s3,"s3://crabby-images/76df9/76df9be6f19fe682bc1b4828f20043b7267b8a61" alt=""
data:image/s3,"s3://crabby-images/62491/62491e82ad6d6ae1ed4c5f8617bec8f75619261e" alt=""
data:image/s3,"s3://crabby-images/e5a51/e5a5166f62a152658f032f339aa2625802514042" alt=""
data:image/s3,"s3://crabby-images/2a688/2a688044421b397d414708ec5e5fa11d94868f3a" alt=""
Code Transformations
Babel
data:image/s3,"s3://crabby-images/c9f58/c9f5844e2c893226951dc8987f3043356785a377" alt=""
data:image/s3,"s3://crabby-images/404d0/404d08f1225ce0209bcf2b80fbea65128840f74e" alt=""
Glimmer Compiler
Codemods
data:image/s3,"s3://crabby-images/78cc6/78cc6aab30622a30311c8f6317c2dba88a9ad57e" alt=""
recast
const recast = require('recast');
const code = fs.readFileSync('code.js','utf-8');
const ast = recast.parse(code);
const faster = transform(ast);
const output = recast.print(faster).code;
/**
* This replaces every occurrence of variable "foo".
*/
module.exports = function(fileInfo, api) {
return api.jscodeshift(fileInfo.source)
.findVariableDeclarators('foo')
.renameTo('bar')
.toSource();
}
jscodeshift
AST Explorer
codemod-cli
a tool for generating, testing, and publishing codemods.
data:image/s3,"s3://crabby-images/89964/899646744d996b6a1e386bcb48643ed0bcdcd92b" alt=""
#topic-codemods
Ember Discord Channel
Time to
apply what we learned!
data:image/s3,"s3://crabby-images/dc647/dc647bea8e57687e6341aeb92a60f8e9ae94fd72" alt=""
The "D" word
data:image/s3,"s3://crabby-images/4f4a4/4f4a4639fc31d1545bc5b14e560e7b9ec9e99542" alt=""
DOCUMENTATION
data:image/s3,"s3://crabby-images/26177/261772bd29114e87b8d73f4a8b7796bf690de601" alt=""
Writing
react-docgen
react-styleguidist
?
ember-cli-addon-docs
Ember
React
react-docgen
react-styleguidist
ember-docgen
ember-cli-addon-docs
Ember
React
ember-docgen
data:image/s3,"s3://crabby-images/35dc3/35dc3e27f151b4aac6723eed9b9c2986fde370e5" alt=""
data:image/s3,"s3://crabby-images/35dc3/35dc3e27f151b4aac6723eed9b9c2986fde370e5" alt=""
data:image/s3,"s3://crabby-images/15524/15524b2b3db8d0a74ee9a23248f12a2fe2cde2a4" alt=""
DEMO
data:image/s3,"s3://crabby-images/91e77/91e77a014510043d71b96c9435a4a340af392bda" alt=""
Questions?
data:image/s3,"s3://crabby-images/10b1f/10b1f68ab28adcf9c3ae18edd870dbce171919c0" alt=""
Thank you
data:image/s3,"s3://crabby-images/12fd8/12fd8ba833a332e4ca6d2ff337ebb1bb971bcf24" alt=""
AST & Ember
By Rajasegar Chandiran
AST & Ember
A presentation about Abstract Syntax Trees and Ember.js in the first Ember.js Chennai meetup
- 1,503