/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ extern crate libc; use std::io; macro_rules! try_or { ($val:expr, $or:expr) => { match $val { Ok(v) => v, Err(e) => { #[allow(clippy::redundant_closure_call)] return $or(e); } } }; } pub trait Signed { fn is_negative(&self) -> bool; } impl Signed for i32 { fn is_negative(&self) -> bool { *self < 0 } } impl Signed for usize { fn is_negative(&self) -> bool { (*self as isize) < 0 } } #[cfg(all(target_os = "linux", not(test)))] pub fn from_unix_result(rv: T) -> io::Result { if rv.is_negative() { let errno = unsafe { *libc::__errno_location() }; Err(io::Error::from_raw_os_error(errno)) } else { Ok(rv) } } #[cfg(all(target_os = "freebsd", not(test)))] pub fn from_unix_result(rv: T) -> io::Result { if rv.is_negative() { let errno = unsafe { *libc::__error() }; Err(io::Error::from_raw_os_error(errno)) } else { Ok(rv) } } #[cfg(all(target_os = "openbsd", not(test)))] pub fn from_unix_result(rv: T) -> io::Result { if rv.is_negative() { Err(io::Error::last_os_error()) } else { Ok(rv) } } pub fn io_err(msg: &str) -> io::Error { io::Error::new(io::ErrorKind::Other, msg) } #[cfg(all(test, not(feature = "crypto_dummy")))] pub fn decode_hex(s: &str) -> Vec { (0..s.len()) .step_by(2) .map(|i| u8::from_str_radix(&s[i..i + 2], 16).unwrap()) .collect() }