2 releases
0.0.1 | Apr 7, 2020 |
---|---|
0.0.0 | Apr 7, 2020 |
#27 in #returning
Used in no_error
3KB
50 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); // takes in a c-string
fn print_with_len(x: const *u8, len usize); // takes in text and length
}
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(42) {
Ok(_) => (),
Err(a) => {
print(a.cstr_description());
let source = a.source();
print_with_len(source.as_ptr(),source.len());
if let Some(c) = a.code() {
if c == FAIL {
print("secret of life".as_ptr());
}
}
},
};
}
Dependencies
~5KB