Struct ErrorKind

Source
pub struct ErrorKind(pub &'static str, pub &'static str, pub u16, pub &'static str);
Expand description

Represents a categorized error kind with associated metadata.

The ErrorKind struct defines a specific type of error, providing a unique identifier, category, numeric code, and a message ID. This allows for structured and meaningful error classification.

§Example

let kind = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");

Tuple Fields§

§0: &'static str

A unique error identifier (name).

§1: &'static str

A message ID associated with the error.

§2: u16

A numeric error code.

§3: &'static str

A human-readable description of the error.

Implementations§

Source§

impl ErrorKind

Source

pub fn name(&self) -> &'static str

Returns the name of the error.

§Example
let error = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");
assert_eq!(error.name(), "NotFound");
Source

pub fn message_id(&self) -> &'static str

Returns the message ID of the error.

§Example
let error = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");
assert_eq!(error.message_id(), "MSG001");
Source

pub fn code(&self) -> u16

Returns the numerical error code.

§Example
let error = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");
assert_eq!(error.code(), 404);
Source

pub fn description(&self) -> &'static str

Returns the description of the error.

§Example
let error = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");
assert_eq!(error.description(), "Not Found");
Source

pub fn side(&self) -> &'static str

Determines whether the error originates from the client or the server.

  • Errors with codes in the range 0 to 499 are classified as Client errors.
  • Errors with codes 500 or higher are classified as Server errors.
§Example
let client_error = cdumay_error::ErrorKind("NotFound", "MSG001", 404, "Not Found");
assert_eq!(client_error.side(), "Client");

let server_error = cdumay_error::ErrorKind("InternalServerError", "MSG002", 500, "Internal Server Error");
assert_eq!(server_error.side(), "Server");

Trait Implementations§

Source§

impl Clone for ErrorKind

Source§

fn clone(&self) -> ErrorKind

Returns a copy 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 ErrorKind

Source§

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

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

impl PartialEq for ErrorKind

Source§

fn eq(&self, other: &ErrorKind) -> 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 StructuralPartialEq for ErrorKind

Auto Trait Implementations§

Blanket Implementations§

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> 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<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.