ink! intermediate representations (IRs) and abstractions for ink! analyzer.
This library implements types and utilities for parsing ink! smart contract code into ink! intermediate representations (IRs) and abstractions.
It uses rust-analyzer's raapsyntax crate for generating the syntax tree of the ink! smart contract code that it then converts into ink! entity intermediate representations and abstractions.
It's the main dependency for the semantic analyzer crate.
Run the following Cargo command in your project directory
shell
cargo add ink-analyzer-ir
Generate an IR of ink! smart contract code.
```rust use inkanalyzerir::{InkFile, quoteasstr};
fn generateir() { let file = InkFile::parse(quoteasstr! { #[ink::contract] mod mycontract {
#[ink(storage)]
pub struct MyContract {
value: bool,
}
#[ink(event)]
pub struct MyEvent {
#[ink(topic)]
value: bool,
}
// --snip--
}
});
dbg!(&file);
let contracts = file.contracts();
dbg!(&contracts);
if let Some(contract) = contracts.first() {
let events = contract.events();
dbg!(&events);
}
} ```
https://docs.rs/ink-analyzer-ir/latest/inkanalyzerir/
Or you can access documentation locally by running the following command from the project root
shell
cargo doc -p ink-analyzer-ir --open
You can run unit tests for all the core functionality by running the following command from the project root
shell
cargo test -p ink-analyzer-ir
This code is released under both MIT and Apache-2.0 licenses.