6 releases (3 breaking)

0.3.0 Jan 7, 2025
0.2.0 Jul 3, 2024
0.1.2 Jun 7, 2024
0.1.1 Apr 12, 2024
0.0.0 Feb 2, 2024

#149 in Windows APIs

Download history 467364/week @ 2024-10-02 458408/week @ 2024-10-09 502092/week @ 2024-10-16 484066/week @ 2024-10-23 553087/week @ 2024-10-30 618861/week @ 2024-11-06 664326/week @ 2024-11-13 646922/week @ 2024-11-20 552002/week @ 2024-11-27 663246/week @ 2024-12-04 752301/week @ 2024-12-11 566840/week @ 2024-12-18 345800/week @ 2024-12-25 564619/week @ 2025-01-01 946493/week @ 2025-01-08 913509/week @ 2025-01-15

2,826,720 downloads per month
Used in 8,197 crates (12 directly)

MIT/Apache

35KB
653 lines

Windows error handling

The windows-result crate provides efficient Windows error handling and propagation with support for Win32, COM, and WinRT APIs.

Start by adding the following to your Cargo.toml file:

[dependencies.windows-result]
version = "0.2"

Use the HRESULT, Error, and specialized Result types as needed:

use windows_result::*;

const S_OK: HRESULT = HRESULT(0);
const ERROR_CANCELLED: u32 = 1223;
const E_CANCELLED: HRESULT = HRESULT::from_win32(ERROR_CANCELLED);

fn main() -> Result<()> {
    S_OK.ok()?;
    let e = Error::new(E_CANCELLED, "test message");
    assert_eq!(e.code(), E_CANCELLED);
    assert_eq!(e.message(), "test message");
    Ok(())
}

Dependencies

~0–8.5MB