pub struct Error<F: ErrorFormatter = DefaultFormatter> { /* private fields */ }
Expand description
Command Line Argument Parser Error
See Command::error
to create an error.
Implementations
sourceimpl<F: ErrorFormatter> Error<F>
impl<F: ErrorFormatter> Error<F>
sourcepub fn raw(kind: ErrorKind, message: impl Display) -> Self
pub fn raw(kind: ErrorKind, message: impl Display) -> Self
Create an unformatted error
This is for you need to pass the error up to
a place that has access to the Command
at which point you can call Error::format
.
Prefer Command::error
for generating errors.
sourcepub fn format(self, cmd: &mut Command) -> Self
pub fn format(self, cmd: &mut Command) -> Self
Format the existing message with the Command’s context
sourcepub fn apply<EF: ErrorFormatter>(self) -> Error<EF>
pub fn apply<EF: ErrorFormatter>(self) -> Error<EF>
Apply an alternative formatter to the error
Example
let cmd = Command::new("foo")
.arg(Arg::new("input").required(true));
let matches = cmd
.try_get_matches_from(["foo", "input.txt"])
.map_err(|e| e.apply::<KindFormatter>())
.unwrap_or_else(|e| e.exit());
sourcepub fn context(&self) -> impl Iterator<Item = (ContextKind, &ContextValue)>
pub fn context(&self) -> impl Iterator<Item = (ContextKind, &ContextValue)>
Additional information to further qualify the error
sourcepub fn get(&self, kind: ContextKind) -> Option<&ContextValue>
pub fn get(&self, kind: ContextKind) -> Option<&ContextValue>
Lookup a piece of context
sourcepub fn use_stderr(&self) -> bool
pub fn use_stderr(&self) -> bool
Should the message be written to stdout
or not?
sourcepub fn exit(&self) -> !
pub fn exit(&self) -> !
Prints the error and exits.
Depending on the error kind, this either prints to stderr
and exits with a status of 2
or prints to stdout
and exits with a status of 0
.
sourcepub fn print(&self) -> Result<()>
pub fn print(&self) -> Result<()>
Prints formatted and colored error to stdout
or stderr
according to its error kind
Example
use clap::Command;
match Command::new("Command").try_get_matches() {
Ok(matches) => {
// do_something
},
Err(err) => {
err.print().expect("Error writing Error");
// do_something
},
};
Trait Implementations
sourceimpl<F: ErrorFormatter> Debug for Error<F>
impl<F: ErrorFormatter> Debug for Error<F>
sourceimpl<F: ErrorFormatter> Display for Error<F>
impl<F: ErrorFormatter> Display for Error<F>
sourceimpl<F: ErrorFormatter> Error for Error<F>
impl<F: ErrorFormatter> Error for Error<F>
sourcefn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
The lower-level source of this error, if any. Read more
1.0.0 · sourcefn description(&self) -> &str
fn description(&self) -> &str
use the Display impl or to_string()
sourceimpl<F: ErrorFormatter> From<Error> for Error<F>
impl<F: ErrorFormatter> From<Error> for Error<F>
Auto Trait Implementations
impl<F = RichFormatter> !RefUnwindSafe for Error<F>
impl<F> Send for Error<F> where
F: Send,
impl<F> Sync for Error<F> where
F: Sync,
impl<F> Unpin for Error<F> where
F: Unpin,
impl<F = RichFormatter> !UnwindSafe for Error<F>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more