Skip to content

Latest commit

 

History

History
 
 

rust

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: