BinaryNinja-rs
⚠️ These bindings are in a very early beta, only have partial support for the core APIs and are still actively under development. Compatibility will break and conventions will change! They are being used for core Binary Ninja features however, so we expect much of what is already there to be reliable enough to build on, just don't be surprised if your plugins/scripts need to hit a moving target.
⚠️ This project runs on Rust version
1.77.0
Contributing
⚠️ If you're thinking of contributing to the Rust API, we encourage you to join the #rust-api channel in our Slack: https://slack.binary.ninja, especially for large-effort PRs. Add a "Contributing" section to the Rust API readme
Dependencies
Having BinaryNinja installed (and your license registered) Clang Rust
How to use
See examples/template for more details.
To write a plugin:
Cargo.toml:
[lib]
crate-type = ["cdylib"]
[dependencies]
binaryninja = {git = "https://github.com/Vector35/binaryninja-api.git", branch = "dev"}
See the ./examples/. Plugin registration commands are in binaryninja::command::*
To write a standalone executable:
Cargo.toml:
[dependencies]
binaryninja = { git = "https://github.com/Vector35/binaryninja-api.git", branch = "dev"}
All standalone binaries should call both binaryninja::headless::init() and binaryninja::headless::shutdown().
All standalone binaries need to provide a build.rs.
See examples/template for details.
Docs
Docs can be found at https://dev-rust.binary.ninja/
Attribution
This project makes use of:
- log (log license - MIT)
- rayon (rayon license - MIT)