Parse and validate AIDL files and return for each one an AST and diagnostics.
To use it, you need to create a [Parser
] instance, add the content and
get the validation results.
For convenience, the returned AST can be traversed via the helper functions
available in the [traverse
] module.
Add to Cargo.toml
:
toml
[dependencies]
aidl-parser = "0.4.0"
Create parser, analyze results:
``` use aidl_parser::{traverse, Parser};
// Parse AIDL contents let mut parser = Parser::new(); parser.addcontent("id1", "package test.pkg; interface MyInterface { void hello(String); }"); parser.addcontent("id2", "package test.pkg; parcelable Parcelable { int myField; }"); let results = parser.validate();
// Display results for (id, res) in &results { println!("{}: AST = {:#?}", id, res.ast); println!("{}: Diagnostics = {:#?}", id, res.diagnostics); }
// Traverse AST let ast1 = results["id1"].ast.asref().expect("missing AST"); traverse::walksymbols(ast1, traverse::SymbolFilter::All, |s| println!("- Symbol: {:#?}", s)); ```
It is currently a best effort to provide good diagnostic and navigation based on AIDL documentation.
The code base is (much) simpler than the official implementation and (arguably) more readable, easier to understand and does not support legacy options. It is planned to gradually improve language support to cover most of the functionalities of the AIDL language.
To get more insight on the current grammar and validation, please refer to: - grammar (lalrpop): https://github.com/bwalter/rust-aidl-parser/blob/main/src/aidl.lalrpop - unit-tests for grammar: https://github.com/bwalter/rust-aidl-parser/blob/main/src/rules.rs - validation incl. unit-tests: https://github.com/bwalter/rust-aidl-parser/blob/main/src/validation.rs
If you need specific support, please do not hesitate to submit an issue or a pull request.
Link to AOSP AIDL implementation: https://android.googlesource.com/platform/system/tools/aidl/+/refs/heads/master
This project is licensed under the MIT license.