Enum Code

Source
pub enum Code {
Show 17 variants Ok = 0, Cancelled = 1, Unknown = 2, InvalidArgument = 3, DeadlineExceeded = 4, NotFound = 5, AlreadyExists = 6, PermissionDenied = 7, ResourceExhausted = 8, FailedPrecondition = 9, Aborted = 10, OutOfRange = 11, Unimplemented = 12, Internal = 13, Unavailable = 14, DataLoss = 15, Unauthenticated = 16,
}
Expand description

Status codes for CEL errors.

These codes are based on the Google RPC status codes and provide standardized error categorization for different types of failures that can occur during CEL operations.

§Examples

use cel_cxx::Code;

let code = Code::InvalidArgument;
println!("Description: {}", code.description());
println!("Display: {}", code);

Variants§

§

Ok = 0

The operation completed successfully.

This is not typically used for errors, but may appear in some contexts.

§

Cancelled = 1

The operation was cancelled.

This typically indicates that the operation was cancelled by the caller or due to a timeout.

§

Unknown = 2

Unknown error.

This is used when the specific error category cannot be determined, often when converting from other error types.

§

InvalidArgument = 3

Client specified an invalid argument.

This indicates that the input provided to the operation was invalid. For CEL, this often means syntax errors or invalid expression structure.

§

DeadlineExceeded = 4

Deadline expired before operation could complete.

This indicates that the operation took too long to complete.

§

NotFound = 5

Some requested entity was not found.

This indicates that a referenced entity (like a variable or function) was not found in the current context.

§

AlreadyExists = 6

Some entity that we attempted to create already exists.

This indicates that an operation tried to create something that already exists.

§

PermissionDenied = 7

The caller does not have permission to execute the specified operation.

This indicates insufficient permissions to perform the operation.

§

ResourceExhausted = 8

Some resource has been exhausted.

This indicates that a resource limit has been exceeded, such as memory or computation limits.

§

FailedPrecondition = 9

The system is not in a state required for the operation’s execution.

This indicates that the operation cannot be performed in the current state.

§

Aborted = 10

The operation was aborted.

This indicates that the operation was aborted, typically due to a concurrency issue.

§

OutOfRange = 11

Operation was attempted past the valid range.

This indicates that the operation exceeded valid bounds, such as accessing an array out of bounds.

§

Unimplemented = 12

Operation is not implemented or not supported.

This indicates that the requested operation is not implemented or not supported in the current context.

§

Internal = 13

Internal error.

This indicates an internal error that should not normally occur. It often indicates a bug in the implementation.

§

Unavailable = 14

The service is currently unavailable.

This indicates that the service is temporarily unavailable and the operation should be retried later.

§

DataLoss = 15

Unrecoverable data loss or corruption.

This indicates that data has been lost or corrupted in an unrecoverable way.

§

Unauthenticated = 16

The request does not have valid authentication credentials.

This indicates that the operation requires authentication credentials that are missing or invalid.

Implementations§

Source§

impl Code

Source

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

Returns a human-readable description of this error code.

This method provides a detailed description of what the error code means.

§Examples
use cel_cxx::Code;

let code = Code::InvalidArgument;
println!("Description: {}", code.description());
// Output: Description: Client specified an invalid argument
§Note

If you only need the description for display purposes (such as in println!, format!, or logging), you can use the Display trait implementation instead, which is more concise.

Trait Implementations§

Source§

impl Clone for Code

Source§

fn clone(&self) -> Code

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

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Code

Source§

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

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

impl Display for Code

Source§

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

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

impl Hash for Code

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 PartialEq for Code

Source§

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

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

const 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 Copy for Code

Source§

impl Eq for Code

Source§

impl StructuralPartialEq for Code

Auto Trait Implementations§

§

impl Freeze for Code

§

impl RefUnwindSafe for Code

§

impl Send for Code

§

impl Sync for Code

§

impl Unpin for Code

§

impl UnwindSafe for Code

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> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more