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