// Rust Bitcoin Library // Written in 2014 by // Andrew Poelstra // // To the extent possible under law, the author(s) have dedicated all // copyright and related and neighboring rights to this software to // the public domain worldwide. This software is distributed without // any warranty. // // You should have received a copy of the CC0 Public Domain Dedication // along with this software. // If not, see . // //! Network Support //! //! This module defines support for (de)serialization and network transport //! of Bitcoin data and network messages. //! use io; use core::fmt; #[cfg(feature = "std")] use std::error; pub mod constants; #[cfg(feature = "std")] pub mod address; #[cfg(feature = "std")] pub use self::address::Address; #[cfg(feature = "std")] pub mod message; #[cfg(feature = "std")] pub mod message_blockdata; #[cfg(feature = "std")] pub mod message_network; #[cfg(feature = "std")] pub mod message_filter; #[cfg(feature = "std")] pub mod stream_reader; /// Network error #[derive(Debug)] pub enum Error { /// And I/O error Io(io::Error), /// Socket mutex was poisoned SocketMutexPoisoned, /// Not connected to peer SocketNotConnectedToPeer, } impl fmt::Display for Error { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { match *self { Error::Io(ref e) => fmt::Display::fmt(e, f), Error::SocketMutexPoisoned => f.write_str("socket mutex was poisoned"), Error::SocketNotConnectedToPeer => f.write_str("not connected to peer"), } } } #[doc(hidden)] impl From for Error { fn from(err: io::Error) -> Self { Error::Io(err) } } #[cfg(feature = "std")] impl error::Error for Error { fn cause(&self) -> Option<&dyn error::Error> { match *self { Error::Io(ref e) => Some(e), Error::SocketMutexPoisoned | Error::SocketNotConnectedToPeer => None, } } }