Github.com Crates.io Documentation Github Actions

AIDL parser for Rust

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.

Usage

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)); ```

AIDL language support

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

TODO

License

This project is licensed under the MIT license.