hierr
原来的名字为hun_error. 包装OS的错误码, 统一错误码的查询和获取接口
错误码有两种使用场景:
- 需要区分具体错误码: 比如底层
target提供接口,需要调用者显示区分target. - 无需区分具体错误码: 一般有高层次,粗粒度的容错处理机制,错误码用于日志输出.
对于后一种场景,调用者决定日志输出方式,因此接口的返回值也多使用
Result<T, Error>. 这里就会存在Error具体取值的构造尽可能和Target无关,因此为此场景定义了几个常用业务下需要使用到的错误码(v0.2.4): - Error::inval
- Error::noent
- Error::perm
- Error::nomem
- Error::busy
- Error::timedout
- Error::general
借用
Target定义的错误码来表达业务层的常见错误. 因为此场景并不鼓励基于具体错误码进行容错处理,因此并不提供对应的is_***接口.
版本更新说明
0.2.4版本: 针对无需细分错误码场景提供常见错误构造函数0.2.3版本: 支持mingw(target_os = "windows", target_env = "gnu"), 同linux.0.2.2版本: 解决widows下无法正确输出中文信息的bug
接口和使用样例
1. ;
2. ;
3. ;
封装i32为Error
Example
use hierr;
let err = last;
println!;
let mut buf = ;
println!;
set_errno;
let err = last;
assert_eq!;
assert_eq!;