pub enum StorageError<NID>where
NID: NodeId,{
Defensive {
source: DefensiveError<NID>,
},
IO {
source: StorageIOError<NID>,
},
}Expand description
A storage error could be either a defensive check error or an error occurred when doing the actual io operation.
It indicates a data crash. An application returning this error will shutdown the Openraft node immediately to prevent further damage.
Variants§
Defensive
An error raised by defensive check.
Fields
§
source: DefensiveError<NID>IO
An error raised by io operation.
Fields
§
source: StorageIOError<NID>Implementations§
Source§impl<NID> StorageError<NID>where
NID: NodeId,
impl<NID> StorageError<NID>where
NID: NodeId,
pub fn into_defensive(self) -> Option<DefensiveError<NID>>
pub fn into_io(self) -> Option<StorageIOError<NID>>
pub fn from_io_error( subject: ErrorSubject<NID>, verb: ErrorVerb, io_error: Error, ) -> StorageError<NID>
Trait Implementations§
Source§impl<NID> Clone for StorageError<NID>
impl<NID> Clone for StorageError<NID>
Source§fn clone(&self) -> StorageError<NID>
fn clone(&self) -> StorageError<NID>
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<NID> Debug for StorageError<NID>
impl<NID> Debug for StorageError<NID>
Source§impl<'de, NID> Deserialize<'de> for StorageError<NID>where
NID: NodeId,
impl<'de, NID> Deserialize<'de> for StorageError<NID>where
NID: NodeId,
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<StorageError<NID>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<StorageError<NID>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<NID> Display for StorageError<NID>
impl<NID> Display for StorageError<NID>
impl<NID> Eq for StorageError<NID>
Source§impl<NID> Error for StorageError<NID>where
NID: NodeId,
DefensiveError<NID>: Error,
StorageIOError<NID>: Error,
StorageError<NID>: Debug + Display,
impl<NID> Error for StorageError<NID>where
NID: NodeId,
DefensiveError<NID>: Error,
StorageIOError<NID>: Error,
StorageError<NID>: Debug + Display,
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
👎Deprecated since 1.42.0:
use the Display impl or to_string()
Source§impl<NID> From<DefensiveError<NID>> for StorageError<NID>where
NID: NodeId,
impl<NID> From<DefensiveError<NID>> for StorageError<NID>where
NID: NodeId,
Source§fn from(source: DefensiveError<NID>) -> StorageError<NID>
fn from(source: DefensiveError<NID>) -> StorageError<NID>
Converts to this type from the input type.
Source§impl<C, E> From<StorageError<<C as RaftTypeConfig>::NodeId>> for StreamingError<C, E>where
C: RaftTypeConfig,
E: Error,
impl<C, E> From<StorageError<<C as RaftTypeConfig>::NodeId>> for StreamingError<C, E>where
C: RaftTypeConfig,
E: Error,
Source§fn from(
source: StorageError<<C as RaftTypeConfig>::NodeId>,
) -> StreamingError<C, E>
fn from( source: StorageError<<C as RaftTypeConfig>::NodeId>, ) -> StreamingError<C, E>
Converts to this type from the input type.
Source§impl<NID, E> From<StorageError<NID>> for RaftError<NID, E>where
NID: NodeId,
impl<NID, E> From<StorageError<NID>> for RaftError<NID, E>where
NID: NodeId,
Source§fn from(se: StorageError<NID>) -> RaftError<NID, E>
fn from(se: StorageError<NID>) -> RaftError<NID, E>
Converts to this type from the input type.
Source§impl<NID> From<StorageError<NID>> for Fatal<NID>where
NID: NodeId,
impl<NID> From<StorageError<NID>> for Fatal<NID>where
NID: NodeId,
Source§fn from(source: StorageError<NID>) -> Fatal<NID>
fn from(source: StorageError<NID>) -> Fatal<NID>
Converts to this type from the input type.
Source§impl<NID> From<StorageIOError<NID>> for StorageError<NID>where
NID: NodeId,
impl<NID> From<StorageIOError<NID>> for StorageError<NID>where
NID: NodeId,
Source§fn from(source: StorageIOError<NID>) -> StorageError<NID>
fn from(source: StorageIOError<NID>) -> StorageError<NID>
Converts to this type from the input type.
Source§impl<NID> PartialEq for StorageError<NID>
impl<NID> PartialEq for StorageError<NID>
Source§fn eq(&self, other: &StorageError<NID>) -> bool
fn eq(&self, other: &StorageError<NID>) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl<NID> Serialize for StorageError<NID>where
NID: NodeId,
impl<NID> Serialize for StorageError<NID>where
NID: NodeId,
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl<NID> StructuralPartialEq for StorageError<NID>where
NID: NodeId,
Auto Trait Implementations§
impl<NID> Freeze for StorageError<NID>where
NID: Freeze,
impl<NID> RefUnwindSafe for StorageError<NID>where
NID: RefUnwindSafe,
impl<NID> Send for StorageError<NID>
impl<NID> Sync for StorageError<NID>
impl<NID> Unpin for StorageError<NID>where
NID: Unpin,
impl<NID> UnsafeUnpin for StorageError<NID>where
NID: UnsafeUnpin,
impl<NID> UnwindSafe for StorageError<NID>where
NID: UnwindSafe,
Blanket Implementations§
impl<T> AppData for Twhere
T: OptionalSend + OptionalSync + 'static + OptionalSerde,
impl<T> AppDataResponse for Twhere
T: OptionalSend + OptionalSync + 'static + OptionalSerde,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more