4 releases

0.1.3 Oct 7, 2022
0.1.2 Sep 30, 2022
0.1.1 Feb 21, 2022
0.1.0 Feb 21, 2022

#83 in Windows APIs

Download history 4/week @ 2023-11-27 1/week @ 2023-12-11 3/week @ 2023-12-18 1/week @ 2023-12-25 1/week @ 2024-01-01 3/week @ 2024-01-08 16/week @ 2024-01-15 9/week @ 2024-01-22 7/week @ 2024-01-29 7/week @ 2024-02-05 17/week @ 2024-02-12 13/week @ 2024-02-19 36/week @ 2024-02-26 28/week @ 2024-03-04 23/week @ 2024-03-11

102 downloads per month
Used in 6 crates

Apache-2.0 OR MIT

4MB
36K SLoC

🦀 winresult - windows result codes 🦀

Debug-friendly types for windows result codes.

GitHub crates.io docs.rs License

Why?

  • u32 error codes are annoying to dbg!(...). winresult has awesome Debug impls.

  • u32 error codes are annoying to view in your debugger. winresult has awesome *.natvis files. Use natvis-pdbs!

  • typoing ERROR_WHATEVER in a match is a mere warning. ERROR::WHATEVER is a hard error.
    (I'd still use #![deny(unreachable_patterns)] anyways.)

  • ERROR_INVALID_FUNCTION == S_FALSE (== 1.) Lame!

  • ERROR_FILE_NOT_FOUND (2) is a mess. A function or GetLastError might return:

    label value notes
    ERROR_FILE_NOT_FOUND 0x00000002 Not an HRESULT (would be "successful")
    HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND) 0x80070002 hresult.info "incorrectly" labels ERROR_* as this
    D3D10_ERROR_FILE_NOT_FOUND 0x88790002 Different facility, same code
    D3D11_ERROR_FILE_NOT_FOUND 0x887C0002 Different facility, same code
  • ERROR_* is a mixture of HRESULTs and non-HRESULTs. Can you keep them straight? No. No you cannot. Stop lying.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies