4 releases
0.2.0 | Jul 17, 2024 |
---|---|
0.1.2 | Sep 2, 2023 |
0.1.1 | Sep 2, 2023 |
0.1.0 | Sep 2, 2023 |
#121 in Windows APIs
156 downloads per month
8KB
76 lines
windows_safe_handle
Generate smart pointers for windows raw handles with ergonomic APIs.
safe_handle!
This crate doesn't offer pre-defined smart pointers. Instead, it provides a single safe_handle!
macro for generation:
Simple Smart Pointer, calling an unsafe Function on Drop
use windows_safe_handle::safe_handle;
use windows::Win32::Foundation::{HANDLE, CloseHandle};
safe_handle!(pub Handle(HANDLE), CloseHandle);
If you do not need to export the Handle
type, simply omit the pub
keyword.
Smart Pointer with additional Drop
logic
You can use a closure-based syntax:
use windows_safe_handle::safe_handle;
use windows::Win32::Foundation::{HANDLE, CloseHandle};
safe_handle!(pub Handle(HANDLE), |h| {
// Place your code here
unsafe { CloseHandle(h) }
});
Note that in this case you have to explicitly use unsafe
block.
Versions
v0.1.*
: Compatible withwindows
v0.48.0
.v0.2.*
: Compatible withwindows
v0.58.0
.
Example
Refer to tests/bcrypt_hash.rs
to see how to safely wrap Windows Cryptography Next Generation (CNG) APIs for calculating MD5 hashes.
Dependencies
~120MB
~2M SLoC