pub struct CliError {
pub category: ErrorCategory,
pub source: Error,
}Expand description
A CLI error with a semantic category for exit code mapping.
Wraps an anyhow::Error with an ErrorCategory to enable proper
exit codes while preserving full error context and chains.
§Creating Categorized Errors
ⓘ
use blz_cli::error::{CliError, ErrorCategory};
use anyhow::anyhow;
// Explicit category
let err = CliError::new(
ErrorCategory::NotFound,
anyhow!("Source 'react' not found"),
);
// Using convenience constructors
let err = CliError::not_found("Source 'react' not found");
let err = CliError::usage("Invalid flag combination");Fields§
§category: ErrorCategoryThe semantic category of this error.
source: ErrorThe underlying error with full context.
Implementations§
Source§impl CliError
impl CliError
Sourcepub fn new(category: ErrorCategory, source: impl Into<Error>) -> Self
pub fn new(category: ErrorCategory, source: impl Into<Error>) -> Self
Create a new CLI error with explicit category.
Sourcepub fn inferred(source: impl Into<Error>) -> Self
pub fn inferred(source: impl Into<Error>) -> Self
Create a CLI error, inferring the category from the error message.
Sourcepub fn invalid_query(source: impl Into<Error>) -> Self
pub fn invalid_query(source: impl Into<Error>) -> Self
Create an invalid-query error.
Sourcepub fn as_exit_code(&self) -> ExitCode
pub fn as_exit_code(&self) -> ExitCode
Create an ExitCode from this error.
Trait Implementations§
Source§impl Error for CliError
impl Error for CliError
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()
Auto Trait Implementations§
impl Freeze for CliError
impl RefUnwindSafe for CliError
impl Send for CliError
impl Sync for CliError
impl Unpin for CliError
impl UnwindSafe for CliError
Blanket Implementations§
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> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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<E> IntoCliError for E
impl<E> IntoCliError for E
Source§fn into_cli_error(self) -> CliError
fn into_cli_error(self) -> CliError
Convert to a
CliError, inferring the category from the error message.Source§fn with_category(self, category: ErrorCategory) -> CliError
fn with_category(self, category: ErrorCategory) -> CliError
Convert to a
CliError with an explicit category.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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> ToStringFallible for Twhere
T: Display,
impl<T> ToStringFallible for Twhere
T: Display,
Source§fn try_to_string(&self) -> Result<String, TryReserveError>
fn try_to_string(&self) -> Result<String, TryReserveError>
ToString::to_string, but without panic on OOM.