Enum ErrorCode

Source
pub enum ErrorCode {
Show 31 variants Other = 10_000, NotALeader = 10_001, StorageCorrupted = 10_002, TermMismatch = 10_003, RaftLogUnavailable = 10_004, RaftLogCompacted = 10_005, CasNoSuchRaftIndex = 10_006, CasConflictFound = 10_007, CasEntryTermMismatch = 10_008, CasTableNotAllowed = 10_009, CasInvalidOpKind = 10_010, NoSuchService = 10_011, ServiceNotStarted = 10_012, ServicePoisoned = 10_013, ServiceNotAvailable = 10_014, WrongPluginVersion = 10_015, NoSuchInstance = 10_016, NoSuchReplicaset = 10_017, LeaderUnknown = 10_018, PluginError = 10_019, InstanceExpelled = 10_020, ReplicasetExpelled = 10_021, InstanceUnavaliable = 10_022, CasTableNotOperable = 10_023, Uninitialized = 10_024, ExpelNotAllowed = 10_025, CasConfigNotAllowed = 10_026, RaftProposalDropped = 10_027, SbroadError = 10_028, RaftSnapshotReadViewNotAvailable = 10_029, UserDefinedErrorCodesStart = 20_000,
}
Expand description

Error codes used with BoxError which are only generated by picodata.

Variants§

§

Other = 10_000

This is the first picodata error code. Use this for errors which are hard to categorize and for which there’s no specific way of handling.

Also please use a unique error message for these kinds of errors, so it’s easy to find where it was generated in code.

If your error instead should be handled in a specific way please add a new one if the existing ones don’t satisfy your needs.

§

NotALeader = 10_001

Requested instance is not a leader.

§

StorageCorrupted = 10_002

Contents of a builtin table has invalid format.

§

TermMismatch = 10_003

Operation request from different term.

§

RaftLogUnavailable = 10_004

Raft log is temporarily unavailable.

§

RaftLogCompacted = 10_005

Can’t check the predicate because raft log is compacted.

§

CasNoSuchRaftIndex = 10_006

Nearly impossible error indicating invalid request.

§

CasConflictFound = 10_007

Checking the predicate revealed a collision.

§

CasEntryTermMismatch = 10_008

Request expected raft entry to have a different term.

§

CasTableNotAllowed = 10_009

SpaceNotAllowed: space {space} is prohibited for use in a predicate

§

CasInvalidOpKind = 10_010

Unexpected traft operation kind.

§

NoSuchService = 10_011

§

ServiceNotStarted = 10_012

§

ServicePoisoned = 10_013

§

ServiceNotAvailable = 10_014

§

WrongPluginVersion = 10_015

§

NoSuchInstance = 10_016

§

NoSuchReplicaset = 10_017

§

LeaderUnknown = 10_018

§

PluginError = 10_019

§

InstanceExpelled = 10_020

§

ReplicasetExpelled = 10_021

§

InstanceUnavaliable = 10_022

§

CasTableNotOperable = 10_023

TableNotOperable: table {table} is prohibited for use in a predicate

§

Uninitialized = 10_024

Picodata machinery is not yet initialized on the instance.

§

ExpelNotAllowed = 10_025

Instance is not allowed to be expelled in the given situation for some reason. The most often solution is to use picodata expel --force.

§

CasConfigNotAllowed = 10_026

TableNotOperable: table {table} is prohibited for use in a predicate

§

RaftProposalDropped = 10_027

Raft proposal was dropped by the leader.

§

SbroadError = 10_028

Generic sbroad error

§

RaftSnapshotReadViewNotAvailable = 10_029

A raft snapshot read view is not available.

§

UserDefinedErrorCodesStart = 20_000

Not an actual error code, just designates the start of the range.

Implementations§

Source§

impl ErrorCode

Source

pub const VARIANTS: &'static [Self]

A slice of all possible enum variants.

These are ordered in the order of definition in the source code.

Source

pub const MIN: Self

The enum variant with the smallest discriminant.

Source

pub const MAX: Self

The enum variant with the largest discriminant.

Source

pub const DISCRIMINANTS_ARE_SUBSEQUENT: bool = false

If this is true then all of the enum variants have subsequent discriminants and converting from integer to enum type is going to use a more efficient implementation.

Source

pub const fn variant_name(&self) -> &'static str

Returns the name of the variant as it is spelled in the source code.

Source

pub const fn from_i64(n: i64) -> Option<Self>

Converts integer to enum.

Returns None if no variant of the enum has the corresponding discriminant.

Source§

impl ErrorCode

Source

pub fn is_retriable_for_cas(&self) -> bool

These types of errors signify different kinds of conflicts which can occur during a compare_and_swap RPC request. If such an error happens it’s safe to retry the request under the following conditions:

  • The raft read index operation is performed before each retry
  • The preconditions of the request are checked before each retry
  • The request is generated before each retry with an up to date raft index

Trait Implementations§

Source§

impl Clone for ErrorCode

Source§

fn clone(&self) -> ErrorCode

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ErrorCode

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl From<ErrorCode> for u32

Source§

fn from(code: ErrorCode) -> u32

Converts to this type from the input type.
Source§

impl Hash for ErrorCode

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Ord for ErrorCode

Source§

fn cmp(&self, other: &ErrorCode) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl PartialEq for ErrorCode

Source§

fn eq(&self, other: &ErrorCode) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for ErrorCode

Source§

fn partial_cmp(&self, other: &ErrorCode) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl TryFrom<i16> for ErrorCode

Source§

type Error = i16

The type returned in the event of a conversion error.
Source§

fn try_from(n: i16) -> Result<Self, i16>

Performs the conversion.
Source§

impl TryFrom<i32> for ErrorCode

Source§

type Error = i32

The type returned in the event of a conversion error.
Source§

fn try_from(n: i32) -> Result<Self, i32>

Performs the conversion.
Source§

impl TryFrom<i64> for ErrorCode

Source§

type Error = i64

The type returned in the event of a conversion error.
Source§

fn try_from(n: i64) -> Result<Self, i64>

Performs the conversion.
Source§

impl TryFrom<i8> for ErrorCode

Source§

type Error = i8

The type returned in the event of a conversion error.
Source§

fn try_from(n: i8) -> Result<Self, i8>

Performs the conversion.
Source§

impl TryFrom<isize> for ErrorCode

Source§

type Error = isize

The type returned in the event of a conversion error.
Source§

fn try_from(n: isize) -> Result<Self, isize>

Performs the conversion.
Source§

impl TryFrom<u16> for ErrorCode

Source§

type Error = u16

The type returned in the event of a conversion error.
Source§

fn try_from(n: u16) -> Result<Self, u16>

Performs the conversion.
Source§

impl TryFrom<u32> for ErrorCode

Source§

type Error = u32

The type returned in the event of a conversion error.
Source§

fn try_from(n: u32) -> Result<Self, u32>

Performs the conversion.
Source§

impl TryFrom<u64> for ErrorCode

Source§

type Error = u64

The type returned in the event of a conversion error.
Source§

fn try_from(n: u64) -> Result<Self, u64>

Performs the conversion.
Source§

impl TryFrom<u8> for ErrorCode

Source§

type Error = u8

The type returned in the event of a conversion error.
Source§

fn try_from(n: u8) -> Result<Self, u8>

Performs the conversion.
Source§

impl TryFrom<usize> for ErrorCode

Source§

type Error = usize

The type returned in the event of a conversion error.
Source§

fn try_from(n: usize) -> Result<Self, usize>

Performs the conversion.
Source§

impl Copy for ErrorCode

Source§

impl Eq for ErrorCode

Source§

impl StructuralPartialEq for ErrorCode

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> AlignerFor<1> for T

Source§

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<1024> for T

Source§

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<128> for T

Source§

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16> for T

Source§

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<16384> for T

Source§

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2> for T

Source§

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<2048> for T

Source§

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<256> for T

Source§

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32> for T

Source§

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<32768> for T

Source§

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4> for T

Source§

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<4096> for T

Source§

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<512> for T

Source§

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<64> for T

Source§

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8> for T

Source§

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> AlignerFor<8192> for T

Source§

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoClones<(T,)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<T> IntoClones<(T, T, T, T, T, T, T, T, T, T, T)> for T
where T: Clone,

Source§

impl<'a, T> RCowCompatibleRef<'a> for T
where T: Clone + 'a,

Source§

type RefC = &'a T

The (preferably) ffi-safe equivalent of &Self.
Source§

type ROwned = T

The owned version of Self::RefC.
Source§

fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC

Converts a reference to an FFI-safe type
Source§

fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T

Converts an FFI-safe type to a reference
Source§

impl<S> ROExtAcc for S

Source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
Source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
Source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
Source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
Source§

impl<S> ROExtOps<Aligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<S> ROExtOps<Unaligned> for S

Source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> SelfOps for T
where T: ?Sized,

Source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
Source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
Source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
Source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
Source§

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
Source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
Source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
Source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
Source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
Source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<This> TransmuteElement for This
where This: ?Sized,

Source§

unsafe fn transmute_element<T>(self) -> Self::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> TypeIdentity for T
where T: ?Sized,

Source§

type Type = T

This is always Self.
Source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
Source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
Source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
Source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
Source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
Source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
Source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
Source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
Source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
Source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.
Source§

impl<This> ValidTag_Bounds for This
where This: Debug + Clone + PartialEq,