Crates.io | php-parser-rs |
lib.rs | php-parser-rs |
version | 0.1.3 |
source | src |
created_at | 2022-11-28 17:27:56.221481 |
updated_at | 2023-05-10 18:04:20.93091 |
description | A handwritten recursive-descent parser for PHP written in Rust |
homepage | |
repository | https://github.com/ryangjchandler/php-parser-rs |
max_upload_size | |
id | 724616 |
size | 4,271,800 |
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.
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
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(())
}
Licensed under either of
at your option.
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.