2022 @phenomnominal
I'm Craig (he/him)
I do JavaScript.
2022 @phenomnominal
Desktop + Web Player
Slides!
2022 @phenomnominal
DISCLAIMER!
TRANS RIGHTS ARE HUMAN RIGHTS
Today, I'm going to tell you a story!
2022 @phenomnominal
But first...
✨MAGIC✨
SpEC attendee!
Good Guy
You're a wizard!
2022 @phenomnominal
You went to Hogwarts!!
(School of Witchcraft and Wizardry)
Place where stuff happens
2022 @phenomnominal
You can do magic!!
This is a patronus
2022 @phenomnominal
You know Dumbledore!!!
Good Guy
2022 @phenomnominal
And Harry Potter is your Best Friend!!!!
Main Good Guy
2022 @phenomnominal
But there's a problem...
Maybe
Good?
Maybe Bad?
2022 @phenomnominal
Voldemort is back (again!)
Literally the
Worst Guy
2022 @phenomnominal
And he has put a curse on Harry!
2022 @phenomnominal
2022 @phenomnominal
If we don't save him in the next 25 minutes, Voldemort is going to kill him!
2022 @phenomnominal
Not good.
Our friend is gone.
Time is running out.
2022 @phenomnominal
But there is one bit of good news...
2022 @phenomnominal
Harry speaks Parseltongue!
He can talk to snakes!
2022 @phenomnominal
Which, as every magical being knows, is a
Turing-complete programming language!
(this is 100% canon, don't look it up)
2022 @phenomnominal
Weakly Typed
Functional
Interpreted
Garbage collected
Significant whitespace
Parseltongue 🐍🐍🐍
2022 @phenomnominal
Parseltongue 🐍🐍🐍
Variable Declarations
Parseltongue:
JavaScript:
Only one type of variable
Always start with
Assignment Operator is
<~
sss
2022 @phenomnominal
Function Expressions
Parameters are defined with an array
Return uses the assignment operator
Significant whitespace
Parseltongue 🐍🐍🐍
Parseltongue:
JavaScript:
2022 @phenomnominal
Call Expression
Passing arguments to a function also uses the Assignment operator
Arguments are declared with an array
Parseltongue 🐍🐍🐍
Parseltongue:
JavaScript:
2022 @phenomnominal
Control Flow
Use an empty array when you have no arguments
Parseltongue 🐍🐍🐍
Parseltongue:
JavaScript:
2022 @phenomnominal
Loops
Range operator is
~>
Parseltongue 🐍🐍🐍
Parseltongue:
JavaScript:
2022 @phenomnominal
Spells
Parseltongue 🐍🐍🐍
Parseltongue:
JavaScript:
is magic and becomes
sssCast
alert
2022 @phenomnominal
2022 @phenomnominal
Harry's spell ⭐️⭐️⭐️
2022 @phenomnominal
Internet browsers don't understand Parseltongue.
2022 @phenomnominal
We need to translate Harry's Parseltongue into JavaScript!
2022 @phenomnominal
Parseltongue
JavaScript
???
2022 @phenomnominal
Parseltongue
JavaScript
REGEX!?
2022 @phenomnominal
Let's go a line at a time:
RegEx:
(the most evil magic)
2022 @phenomnominal
That gives us:
RegEx:
2022 @phenomnominal
Converting variables
RegEx:
2022 @phenomnominal
Converting loops
Hmmm...
RegEx:
2022 @phenomnominal
Converting functions
Ruh roh!
RegEx:
2022 @phenomnominal
2022 @phenomnominal
What are we really trying to do?
Transform one language into another
2022 @phenomnominal
Transpiling
(aka transfiguration)
2022 @phenomnominal
"Transpiling is a specific term for taking source code written in one language and transforming into another language that has a similar level of abstraction"
Transpiling
2022 @phenomnominal
Where do we start?
String literal
Function call
Identifier
Expression
2022 @phenomnominal
ESTree
2022 @phenomnominal
Esprima
2022 @phenomnominal
Abstract
disassociated from any specific instance
the way in which linguistic elements are put together
Syntax
TREE
data structure made up of vertices and edges without any cycles
2022 @phenomnominal
Wat.
2022 @phenomnominal
Wat.
2022 @phenomnominal
a data structure that represents the structure of code, without any actual syntax.
An AST is:
Code:
2022 @phenomnominal
a data structure that represents the structure of code, without any actual syntax.
An AST is:
AST:
2022 @phenomnominal
Which means...
2022 @phenomnominal
If we can get from Parseltongue to an AST...
Then we can go from that AST to JavaScript!
2022 @phenomnominal
Parseltongue
JavaScript
REGEX!?
2022 @phenomnominal
Parseltongue
JavaScript
AST
2022 @phenomnominal
Parseltongue
JavaScript
AST
???
???
2022 @phenomnominal
2022 @phenomnominal
Target AST
var spell = 'Expecto Patronum';
function magic (spell, intensity) {
var intense = '';
for (var i = 0; i < intensity, i = i + 1) {
intense = intense + '!';
}
return spell + intense;
}
for (var i = 0; i < 10, i = i + 1) {
magic(spell, i);
}
Remember Esprima?
2022 @phenomnominal
import { parse } from 'esprima';
const AST = parse(`
var spell = 'Expecto Patronum';
function magic (spell, intensity) {
var intense = '';
for (var i = 0; i < intensity, i = i + 1) {
intense = intense + '!';
}
return spell + intense;
}
for (var i = 0; i < 10, i = i + 1) {
magic(spell, i);
}
`);
Remember Esprima?
Esprima takes code written in a specific language (JavaScript) and turns it into an AST!
2022 @phenomnominal
We need to make our own Esprima for Parseltongue!
2022 @phenomnominal
How do we do that?
2022 @phenomnominal
Parseltongue
JavaScript
AST
???
???
Tokens
Lexing
2022 @phenomnominal
Lexing/Tokenising
"Lexing is the process of breaking down source code into words that are relevant to the language, which are called tokens"
2022 @phenomnominal
Lexing/Tokenising
Tokens in JavaScript
Identifier
Keyword
Literal - bool, null, number, string
Punctuator
EOF
RegularExpression
Template
(we're getting a bit intense now - here's an owl)
2022 @phenomnominal
Lexing/Tokenising
Tokens in Parseltongue
Identifier
Keyword
Literal - bool, null, number, string
Punctuator
EOF
Indent
LineTerminator
Space
(we're getting a bit intense now - here's an owl)
2022 @phenomnominal
Identifier characters
Space
Punctuator characters
Space
Quote character
Lexing/Tokenising
Punctuator
Punctuator
String characters
Quote character
2022 @phenomnominal
2022 @phenomnominal
2022 @phenomnominal
Parseltongue
JavaScript
AST
Parsing
???
Tokens
Lexing
2022 @phenomnominal
Parsing
"Parsing is the process of taking the lexical tokens and applying the grammar of the language to them"
2022 @phenomnominal
Parsing
Variable Declaration
Identifier
Space
Punctuator -
Space
String literal
<~
2022 @phenomnominal
Identifier
Space
Punctuator -
Identifier
Punctuator -
Space
Identifier
Punctuator -
Parsing
Function Expression
Line Terminator
Indent
[
,
]
2022 @phenomnominal
Parsing
Function Expression
2022 @phenomnominal
Grammar
Function Expression
2022 @phenomnominal
Variable Declaration
For Statement
Binary Expression
Update Expression
Actual LOL
2022 @phenomnominal
2022 @phenomnominal
Now we just need to go from the AST to JavaScript...
2022 @phenomnominal
Parseltongue
JavaScript
AST
Parsing
Code Generating
Tokens
Lexing
2022 @phenomnominal
Code Generating
This is really hard to do by ourselves.
We can again stand on the shoulders of half-giants!
2022 @phenomnominal
ESCodeGen
2022 @phenomnominal
2022 @phenomnominal
JavaScript!
2022 @phenomnominal
Parseltongue
JavaScript
AST
Parsing
Code Generating
Tokens
Lexing
2022 @phenomnominal
We're almost ready to save Harry!
2022 @phenomnominal
But OH NO!
Voldemort can also speak Parseltongue!
2022 @phenomnominal
Voldemort will try to stop Harry from escaping!
He might even use the...
2022 @phenomnominal
Unforgivable Functions
2022 @phenomnominal
We need to come up with a way to stop Voldemort from using those functions!
2022 @phenomnominal
JavaScript
AST
Parsing
Code Generating
Tokens
Lexing
Parseltongue
???
2022 @phenomnominal
JavaScript
AST
Parsing
Code Generating
Tokens
Lexing
Parseltongue
Inspecting
2022 @phenomnominal
Inspecting
Transformation
Mutation
Validation
2022 @phenomnominal
ESQuery
2022 @phenomnominal
Linting
Detect bad stuff
2022 @phenomnominal
Linting
Fixing bad stuff
Tickling curse
2022 @phenomnominal
2022 @phenomnominal
JavaScript
AST
Parsing
Code Generating
Tokens
Lexing
Parseltongue
Inspection
2022 @phenomnominal
2022 @phenomnominal
We did it!
Harry is safe!
2022 @phenomnominal
All is well
(again)
2022 @phenomnominal
So...
2022 @phenomnominal
When do you actually use an AST?
2022 @phenomnominal
Ever had to change every file in your codebase?
2022 @phenomnominal
Ever had to generate boilerplate?
2022 @phenomnominal
Ever had to extract API documentation?
2022 @phenomnominal
You can use an AST for that!
(and probably should)
2022 @phenomnominal
ASTs help us with...
Performance
Maintenance
Consistency
Analysis
Robustness
Automation
2022 @phenomnominal
They're everywhere
2022 @phenomnominal
They're powerful
2022 @phenomnominal
They're useful
2022 @phenomnominal
Once you know where to find them
2022 @phenomnominal
⚡️ Thanks! ⚡️
Fantastic ASTs and Where To Find Them (SpEC)
By Craig Spence
Fantastic ASTs and Where To Find Them (SpEC)
SpEC 2022
- 2,624