Go to file
azjezz 4854c36d25
chore: update ci
Signed-off-by: azjezz <azjezz@protonmail.com>
2022-12-08 17:50:21 +01:00
.github chore: update ci 2022-12-08 17:50:21 +01:00
bin chore: remove Parser structure 2022-12-07 23:11:37 +01:00
src chore: refactor expression parser to avoid stack overflow issue (#177) 2022-12-08 15:49:54 +01:00
tests chore: test against more third party frameworks (#178) 2022-12-08 16:50:25 +01:00
.gitignore chore: remove build script 2022-12-05 18:36:04 +01:00
Cargo.toml chore: refactor ast (#162) 2022-12-06 09:33:29 +01:00
Justfile chore: test against more third party frameworks (#178) 2022-12-08 16:50:25 +01:00
LICENSE-APACHE re-license under MIT or APACHE-2.0 (#137) 2022-11-29 21:22:42 +00:00
LICENSE-MIT re-license under MIT or APACHE-2.0 (#137) 2022-11-29 21:22:42 +00:00
README.md chore: remove Parser structure 2022-12-07 23:11:37 +01:00

PHP-Parser

A handwritten recursive-descent parser for PHP written in Rust, for fun.

justforfunnoreally.dev badge

Warning

: This crate is not ready for any form of production use yet. There are still a lot of things missing from the parser, so please use at your own risk.


Usage

Add php-parser-rs in your Cargo.toml's dependencies section

[dependencies]
php-parser-rs = "0.0.0-b1"

or use cargo add

cargo add php-parser-rs

Example

use php_parser_rs::parse;
use php_parser_rs::lexer::Lexer;

fn main() -> ParseResult<()> {
    let lexer = Lexer::new();

    let code = "
<?php

function hello(): void {
    echo 'Hello, World!';
}

hello();
";

    let tokens = lexer.tokenize(code.as_bytes())?;
    let ast = parse(tokens)?;

    dbg!(ast);

    Ok(())
}

License

Licensed under either of

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.

Credits