2 releases

0.0.1 Apr 7, 2020
0.0.0 Apr 7, 2020

#27 in #returning


Used in no_error

MIT/Apache

3KB
50 lines

no_error

docs.rs docs

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