use super::{abi, itron, net};
use crate::io::ErrorKind;
pub use self::itron::error::{expect_success, ItronError as SolidError};
pub fn error_name(er: abi::ER) -> Option<&'static str> {
match er {
er if er >= 0 => None,
er if er < abi::sockets::SOLID_NET_ERR_BASE => net::error_name(er),
abi::SOLID_ERR_NOTFOUND => Some("not found"),
abi::SOLID_ERR_NOTSUPPORTED => Some("not supported"),
abi::SOLID_ERR_EBADF => Some("bad flags"),
abi::SOLID_ERR_INVALIDCONTENT => Some("invalid content"),
abi::SOLID_ERR_NOTUSED => Some("not used"),
abi::SOLID_ERR_ALREADYUSED => Some("already used"),
abi::SOLID_ERR_OUTOFBOUND => Some("out of bounds"),
abi::SOLID_ERR_BADSEQUENCE => Some("bad sequence"),
abi::SOLID_ERR_UNKNOWNDEVICE => Some("unknown device"),
abi::SOLID_ERR_BUSY => Some("busy"),
abi::SOLID_ERR_TIMEOUT => Some("operation timed out"),
abi::SOLID_ERR_INVALIDACCESS => Some("invalid access"),
abi::SOLID_ERR_NOTREADY => Some("not ready"),
_ => itron::error::error_name(er),
}
}
pub fn decode_error_kind(er: abi::ER) -> ErrorKind {
match er {
er if er >= 0 => ErrorKind::Uncategorized,
er if er < abi::sockets::SOLID_NET_ERR_BASE => net::decode_error_kind(er),
abi::SOLID_ERR_NOTFOUND => ErrorKind::NotFound,
abi::SOLID_ERR_NOTSUPPORTED => ErrorKind::Unsupported,
abi::SOLID_ERR_EBADF => ErrorKind::InvalidInput,
abi::SOLID_ERR_INVALIDCONTENT => ErrorKind::InvalidData,
abi::SOLID_ERR_OUTOFBOUND => ErrorKind::InvalidInput,
abi::SOLID_ERR_UNKNOWNDEVICE => ErrorKind::NotFound,
abi::SOLID_ERR_TIMEOUT => ErrorKind::TimedOut,
_ => itron::error::decode_error_kind(er),
}
}