code, os 2:
impl fmt::Display for Error {
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
match self.repr {
Repr::Os(code) => {
let detail = sys::os::error_string(code);
write!(fmt, "{} (os error {})", detail, code)
}
Repr::Custom(ref c) => c.error.fmt(fmt),
Repr::Simple(kind) => write!(fmt, "{}", kind.as_str()),
}
}
}
, sys::os::error_string . .
extern crate libc;
use std::fs;
use std::io::Write;
use std::os::raw::{c_int, c_char};
use std::str;
use std::ffi::CStr;
const TMPBUF_SZ: usize = 128;
pub fn error_string(errno: i32) -> String {
extern {
link_name = "__xpg_strerror_r")]
fn strerror_r(errnum: c_int, buf: *mut c_char,
buflen: libc::size_t) -> c_int;
}
let mut buf = [0 as c_char; TMPBUF_SZ];
let p = buf.as_mut_ptr();
unsafe {
if strerror_r(errno as c_int, p, buf.len()) < 0 {
panic!("strerror_r failure");
}
let p = p as *const _;
str::from_utf8(CStr::from_ptr(p).to_bytes()).unwrap().to_owned()
}
}
fn main() {
let fl = "no such file";
if let Err(e) = fs::metadata(fl) {
writeln!(std::io::stderr(), "{}: {}", fl, e).unwrap();
writeln!(std::io::stderr(), "{}", &error_string(e.raw_os_error().unwrap())).unwrap();
}
}
:
no such file: No such file or directory (os error 2)
No such file or directory