oxc/crates/oxc_parser/examples/visitor.rs
Ali Rezvani fc3878350f
refactor(ast): add walk_mut functions (#2776)
* move `visit` and `visit_mut` modules to a super module called `visit`
* add `walk_mut` module containing walk functions
* update `enter_node` and `leave_node` events to not pass a reference in the `VisitMut` trait
* add `AstType`, a non-referencing version of `AstKind` to use with `VisitMut` trait
* update the `VisitMut` trait's usages.
2024-03-25 20:40:13 +03:30

56 lines
1.5 KiB
Rust

use std::{env, path::Path};
use oxc_allocator::Allocator;
use oxc_ast::{
ast::{Class, Function},
visit::walk::{walk_class, walk_function},
Visit,
};
use oxc_parser::Parser;
use oxc_span::SourceType;
use oxc_syntax::scope::ScopeFlags;
// Instruction:
// create a `test.js`,
// run `cargo run -p oxc_parser --example visitor`
// or `cargo watch -x "run -p oxc_parser --example visitor"`
fn main() -> std::io::Result<()> {
let name = env::args().nth(1).unwrap_or_else(|| "test.js".to_string());
let path = Path::new(&name);
let source_text = std::fs::read_to_string(path)?;
let allocator = Allocator::default();
let source_type = SourceType::from_path(path).unwrap();
let ret = Parser::new(&allocator, &source_text, source_type).parse();
for error in ret.errors {
let error = error.with_source_code(source_text.clone());
println!("{error:?}");
}
let program = ret.program;
let mut ast_pass = ASTPass::default();
ast_pass.visit_program(&program);
println!("{ast_pass:?}");
Ok(())
}
#[derive(Debug, Default)]
struct ASTPass {
number_of_functions: usize,
number_of_classes: usize,
}
impl<'a> Visit<'a> for ASTPass {
fn visit_function(&mut self, func: &Function<'a>, flags: Option<ScopeFlags>) {
self.number_of_functions += 1;
walk_function(self, func, flags);
}
fn visit_class(&mut self, class: &Class<'a>) {
self.number_of_classes += 1;
walk_class(self, class);
}
}