This is a rust crate to help you with ECMAScript 2017 v9.0. It provides a parser and an AST (abstract syntax tree) implementation. We also provide some macros to construct the AST so you can do interesting things like optimization!
Add this to your Cargo.toml:
[dependencies]
ecmascript = "0.1"Then put this in your crate root:
extern crate ecmascript;This example reads a file, parses it, and then prints out a minified version.
The file reading is taken from the std::fs::File docs
extern crate ecmascript;
use std::fs::File;
use std::io::prelude::*;
fn main() -> std::io::Result<()> {
    // read foo.js
    let mut file = File::open("foo.js")?;
    let mut contents = String::new();
    file.read_to_string(&mut contents)?;
    // parse it
    let ast = ecmascript::parse(&contents).unwrap();
    println!("{:?}", ast);
}Docs are hosted on docs.rs.
ecmascript is used to parse a JavaScript module, and perform some operations
on it. For example, concatenating modules together, uglifying the variable names,
pretty printing uglified code, etc.
- ECMAScript 2017 v9.0 support (WIP)
- We are actively developing this library to be up to date!
 
- JSX Extended Support (WIP)
- JSX is meant to be an additive extension to the language
 
- AST Pretty Printer (WIP)
- This supports minification options, such as 0 whitespace
 
- AST rewrite rules (WIP)
- Eg. Constant folding, translating to older versions of the language, etc.
 
To test everything, just run this command:
cargo test
Or to run a single test,
cargo test --test <test_name>
To lint your code, use clippy. Its as easy as running once you have it installed!
cargo clippy
MIT © Nick Dujay