2016-01-17 13:11:25 +01:00
|
|
|
//! General error types for use in ethcore.
|
|
|
|
|
|
|
|
use rustc_serialize::hex::FromHexError;
|
|
|
|
use network::NetworkError;
|
|
|
|
use rlp::DecoderError;
|
|
|
|
use io;
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error in database subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
pub enum BaseDataError {
|
2016-02-03 14:51:45 +01:00
|
|
|
/// An entry was removed more times than inserted.
|
2016-01-17 13:11:25 +01:00
|
|
|
NegativelyReferencedHash,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
/// General error type which should be capable of representing all errors in ethcore.
|
|
|
|
pub enum UtilError {
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the crypto utility subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
Crypto(::crypto::CryptoError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the Rust standard library's IO subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
StdIo(::std::io::Error),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning our IO utility subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
Io(io::IoError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the network address parsing subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
AddressParse(::std::net::AddrParseError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the network address resolution subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
AddressResolve(Option<::std::io::Error>),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the hex conversion logic.
|
2016-01-17 13:11:25 +01:00
|
|
|
FromHex(FromHexError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the database abstraction logic.
|
2016-01-17 13:11:25 +01:00
|
|
|
BaseData(BaseDataError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the network subsystem.
|
2016-01-17 13:11:25 +01:00
|
|
|
Network(NetworkError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error concerning the RLP decoder.
|
2016-01-17 13:11:25 +01:00
|
|
|
Decoder(DecoderError),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Miscellaneous error described by a string.
|
2016-01-18 12:41:31 +01:00
|
|
|
SimpleString(String),
|
2016-02-03 14:51:45 +01:00
|
|
|
/// Error from a bad input size being given for the needed output.
|
2016-01-17 13:11:25 +01:00
|
|
|
BadSize,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<FromHexError> for UtilError {
|
|
|
|
fn from(err: FromHexError) -> UtilError {
|
|
|
|
UtilError::FromHex(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<BaseDataError> for UtilError {
|
|
|
|
fn from(err: BaseDataError) -> UtilError {
|
|
|
|
UtilError::BaseData(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<NetworkError> for UtilError {
|
|
|
|
fn from(err: NetworkError) -> UtilError {
|
|
|
|
UtilError::Network(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<::std::io::Error> for UtilError {
|
|
|
|
fn from(err: ::std::io::Error) -> UtilError {
|
|
|
|
UtilError::StdIo(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<io::IoError> for UtilError {
|
|
|
|
fn from(err: io::IoError) -> UtilError {
|
|
|
|
UtilError::Io(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<::crypto::CryptoError> for UtilError {
|
|
|
|
fn from(err: ::crypto::CryptoError) -> UtilError {
|
|
|
|
UtilError::Crypto(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<::std::net::AddrParseError> for UtilError {
|
|
|
|
fn from(err: ::std::net::AddrParseError) -> UtilError {
|
|
|
|
UtilError::AddressParse(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<::rlp::DecoderError> for UtilError {
|
|
|
|
fn from(err: ::rlp::DecoderError) -> UtilError {
|
|
|
|
UtilError::Decoder(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-18 12:41:31 +01:00
|
|
|
impl From<String> for UtilError {
|
|
|
|
fn from(err: String) -> UtilError {
|
|
|
|
UtilError::SimpleString(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-17 13:11:25 +01:00
|
|
|
// TODO: uncomment below once https://github.com/rust-lang/rust/issues/27336 sorted.
|
|
|
|
/*#![feature(concat_idents)]
|
|
|
|
macro_rules! assimilate {
|
|
|
|
($name:ident) => (
|
|
|
|
impl From<concat_idents!($name, Error)> for Error {
|
|
|
|
fn from(err: concat_idents!($name, Error)) -> Error {
|
|
|
|
Error:: $name (err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
|
|
|
assimilate!(FromHex);
|
|
|
|
assimilate!(BaseData);*/
|