PHP-Parser
A handwritten fault-tolerant, recursive-descent parser for PHP written in Rust.
Warning - this is still alpha software and the public API is still subject to change. Please use at your own risk.
Usage
Add php-parser-rs
in your Cargo.toml
's dependencies
section
[dependencies]
php-parser-rs = { git = "https://github.com/php-rust-tools/parser" }
or use cargo add
cargo add php-parser-rs --git https://github.com/php-rust-tools/parser
Example
use std::io::Result;
use php_parser_rs::parser;
const CODE: &str = r#"<?php
final class User {
public function __construct(
public readonly string $name,
public readonly string $email,
public readonly string $password,
) {
}
}
"#;
fn main() -> Result<()> {
match parser::parse(CODE) {
Ok(ast) => {
println!("{:#?}", ast);
}
Err(err) => {
println!("{}", err.report(CODE, None, true, false)?);
println!("parsed so far: {:#?}", err.partial);
}
}
Ok(())
}
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.