Go to file
Saif Eddin Gmati ac42958b4f chore: refactor project structure
- added `prelude`
- moved `ast` to `parser`
- moved `Lexer` from `crate::lexer::lexer::Lexer` to `crate::lexer::Lexer`
- renamed `LexerError` to `SyntaxError`
- moved `SyntaxError` to `token::error`
- implemented `Display` for `SyntaxError`
- add `tokens.txt` to integration tests
- removed all unit tests for `Lexer` ( everything is tested in integration tests )
- improved syntax error assertations
2022-12-04 08:56:53 +00:00
.github chore: refactor project structure 2022-12-04 08:56:53 +00:00
bin chore: refactor project structure 2022-12-04 08:56:53 +00:00
meta chore: refactor classish parsers (#141) 2022-11-30 14:38:07 +00:00
src chore: refactor project structure 2022-12-04 08:56:53 +00:00
tests chore: refactor project structure 2022-12-04 08:56:53 +00:00
.gitignore chore: better parser errors (#126) 2022-11-29 00:46:05 +00:00
build.rs chore: refactor project structure 2022-12-04 08:56:53 +00:00
Cargo.toml feat: add test generator (#134) 2022-11-29 23:19:51 +00: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: README 2022-11-30 14:43:25 +00: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::*;

let mut lexer = Lexer::new(None);
let tokens = lexer.tokenize(&source_code[..]).unwrap();

let mut parser = Parser::new(None);
let ast = parser.parse(tokens).unwrap();

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