idalib/lib.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
//! # idalib
//!
//! idalib is a Rust library providing idiomatic bindings for the IDA SDK, enabling the development
//! of standalone analysis tools using IDA v9.0’s idalib.
//!
//! ## Usage
//!
//! To use idalib, add it as a dependency in your `Cargo.toml` and include a `build.rs` file in
//! your project to properly link against IDA:
//!
//! ```toml
//! [dependencies]
//! idalib = "0.4"
//!
//! [build-dependencies]
//! idalib-build = "0.4"
//! ```
//!
//! Here is a basic example of a `build.rs` file:
//!
//! ```rust,ignore
//! fn main() -> Result<(), Box<dyn std::error::Error>> {
//! idalib_build::configure_linkage()?;
//! Ok(())
//! }
//! ```
//!
//! This script uses the `idalib-build` crate to automatically configure the linkage against IDA.
//! Ensure that the environment variables `IDASDKDIR` and optionally `IDADIR` are set to point to
//! your IDA SDK and installation directories, respectively.
//!
//! ## Setting Environment Variables
//!
//! ### On Linux/macOS
//!
//! You can set the environment variables in your terminal session or add them to your shell
//! configuration file (e.g., `.bashrc`, `.zshrc`):
//!
//! ```sh,ignore
//! export IDASDKDIR=/path/to/ida/sdk
//! export IDADIR=/path/to/ida/installation
//! ```
//!
//! ### On Windows
//!
//! Set environment variables using Command Prompt, PowerShell, or System Properties.
//!
//! **Command Prompt:**
//! ```cmd
//! set IDASDKDIR=C:\path\to\ida\sdk
//! set IDADIR=C:\path\to\ida\installation
//! ```
//!
//! **PowerShell:**
//! ```powershell,ignore
//! $env:IDASDKDIR = "C:\path\to\ida\sdk"
//! $env:IDADIR = "C:\path\to\ida\installation"
//! ```
//!
//! **System Properties:**
//! Go to "Environment Variables" in System Properties and add `IDASDKDIR` and `IDADIR`.
//!
//! ## Example
//!
//! Here's a simple example of how to use idalib:
//!
//! ```rust,ignore
//! use idalib::idb::IDB;
//!
//! fn main() -> Result<(), Box<dyn std::error::Error>> {
//! let idb = IDB::open("/path/to/binary")?;
//! // Perform analysis...
//! Ok(())
//! }
//! ```
//!
#![allow(clippy::needless_lifetimes)]
use std::ffi::c_char;
use std::sync::{Mutex, MutexGuard, OnceLock};
pub mod bookmarks;
pub mod decompiler;
pub mod func;
pub mod idb;
pub mod insn;
pub mod license;
pub mod meta;
pub mod plugin;
pub mod processor;
pub mod segment;
pub mod strings;
pub mod xref;
pub use idalib_sys as ffi;
pub use ffi::IDAError;
pub use license::{is_valid_license, license_id, LicenseId};
pub type Address = u64;
static INIT: OnceLock<Mutex<()>> = OnceLock::new();
#[cfg(not(target_os = "windows"))]
extern "C" {
static mut batch: c_char;
}
pub(crate) type IDARuntimeHandle = MutexGuard<'static, ()>;
pub fn force_batch_mode() {
#[cfg(not(target_os = "windows"))]
unsafe {
batch = 1;
}
}
pub fn init_library() -> &'static Mutex<()> {
INIT.get_or_init(|| {
force_batch_mode();
ffi::ida::init_library().expect("IDA initialised successfully");
Mutex::new(())
})
}
pub(crate) fn prepare_library() -> IDARuntimeHandle {
let mutex = init_library();
mutex.lock().unwrap()
}
pub fn enable_console_messages(enabled: bool) {
init_library();
ffi::ida::enable_console_messages(enabled);
}