Crates.io | minhook |
lib.rs | minhook |
version | 0.6.0 |
source | src |
created_at | 2023-04-11 08:01:23.755923 |
updated_at | 2024-09-10 11:40:50.054206 |
description | A Rust wrapper for MinHook, a minimalistic x86/x64 API hooking library for Windows. |
homepage | https://github.com/Jakobzs/minhook |
repository | https://github.com/Jakobzs/minhook |
max_upload_size | |
id | 835872 |
size | 331,795 |
A Rust wrapper for the MinHook library.
Add this to your Cargo.toml
:
[dependencies]
minhook = "0.6.0"
This example shows how to create a hook for a function, and also call the original function.
use minhook::{MinHook, MH_STATUS};
fn main() -> Result<(), MH_STATUS> {
// Create a hook for the return_0 function, detouring it to return_1
let return_0_address = unsafe { MinHook::create_hook(return_0 as _, return_1 as _)? };
// Enable the hook
unsafe { MinHook::enable_all_hooks()? };
// Call the detoured return_0 function, it should return 1
assert_eq!(return_0(), 1);
// Transmute the original return_0 function address to a function pointer
let return_0_original = unsafe { std::mem::transmute::<_, fn() -> i32>(return_0_address) };
// Call the original return_0 function
assert_eq!(return_0_original(), 0);
Ok(())
}
fn return_0() -> i32 {
0
}
fn return_1() -> i32 {
1
}
This project is licensed under the MIT license (LICENSE or http://opensource.org/licenses/MIT).
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the MIT license, shall be licensed as above, without any additional terms or conditions.