3 releases
0.0.2 | Apr 7, 2020 |
---|---|
0.0.1 | Apr 7, 2020 |
0.0.0 | Apr 7, 2020 |
#2948 in Rust patterns
4KB
67 lines
no_error
An error library for no_std
+ no_alloc
Rust
- macro transforms string literals into C style character array
- no allocator required
- support for non-C string text (i.e. len + string)
- support for error codes if text isn't an option
use no_error::*;
extern "C" {
fn print(x: const *u8);
}
const FAIL:ErrorCode = 42;
fn can_fail(i:i32) -> Result<()> {
if i < 0 {
// programmatically appends a "/0" to end of static string
error_message!("a failure happened","it happened in can_fail()")
} else if i == 0 {
// don't like c strings? supports failure codes too
error_code!(FAIL)
} else {
// you don't have to specify the source if you don't want
error_message!("a failure happened")
}
}
fn main() {
match can_fail() {
Ok(_) => (),
Err(a) => {
print(a.cstr_description());
print(a.cstr_source();
if let Some(c) = a.code() {
if c == FAIL {
print("secret of life".as_ptr());
}
}
},
};
}
Dependencies
~5KB