pub struct ExitError<S: AsRef<str>> { /* private fields */ }Expand description
This struct contains an exit code and basic error information (from
PrintableErrno). Unless you unwrap the error on a Result containing
an ExitError, you probably won’t use this directly.
When printed, the error message will look like the following:
- If there is an associated errno:
$program_name: $message: ${errno.desc()} - If there is no errno (originally called from printable_error):
$program_name: $message
Printed error tries to follow perror(3p)’s format with the
addition of the program name.
eprint_and_exit and eprint_signal_safe_exit also call exit(exit_code)
and _exit(exit_code) respectively, exiting the process with the supplied
exit code.
Implementations§
Source§impl<S: AsRef<str>> ExitError<S>
impl<S: AsRef<str>> ExitError<S>
Sourcepub fn eprint_and_exit(self) -> !
pub fn eprint_and_exit(self) -> !
Print the error to stderr and exit with the supplied code.
§Safety
The caller must ensure that stderr (fd 2) is open.
Sourcepub unsafe fn eprint_signal_safe_exit(self) -> !
pub unsafe fn eprint_signal_safe_exit(self) -> !
Same as ExitError::eprint_and_exit, but attempts to write() directly to stderr
and not to call any non-signal-safe functions. Useful when one is the child
in a multi-threaded program after a call to fork().
§Safety
The caller must ensure that stderr (fd 2) remains open for the entirety of this function call.
_exit is safe to call from the fork()-ed child as it’s signal-safe. However, it
doesn’t call destructors (as opposed to exiting from main) nor does it call any exit
functions if they are set, so caller should only call this from a fork()-ed child.