Skip to main content

ConfigError

Enum ConfigError 

Source
#[non_exhaustive]
pub enum ConfigError { UnsupportedFormat(String), MissingExtension, MissingValue { field: String, span: Option<SourceSpan>, }, TypeMismatch { field: String, expected: String, found: String, span: Option<SourceSpan>, }, Nested { section: String, source: Box<dyn Diagnostic + Send + Sync>, span: Option<SourceSpan>, }, Io(Error), Toml { source: Error, span: Option<SourceSpan>, }, }
Expand description

Unified error returned by the runtime components.

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

UnsupportedFormat(String)

The format chosen by the caller or inferred from the extension is not supported.

§

MissingExtension

File paths without an extension cannot be parsed automatically.

§

MissingValue

Raised when a required value is not found during deserialization.

Fields

§field: String

The field name that is missing

§span: Option<SourceSpan>

Optional source span for where the error occurred

§

TypeMismatch

Raised when a value cannot be converted into the expected target type.

Fields

§field: String

The field name that has the wrong type

§expected: String

The expected type

§found: String

The found value or type

§span: Option<SourceSpan>

Optional source span highlighting the problematic value

§

Nested

Used to thread contextual errors when deserializing nested structs.

Fields

§section: String

The section name that failed

§source: Box<dyn Diagnostic + Send + Sync>

The underlying error

§span: Option<SourceSpan>

Optional source span for the section

§

Io(Error)

IO errors propagated from the filesystem.

§

Toml

TOML parsing failure.

Fields

§source: Error

The underlying toml error

§span: Option<SourceSpan>

Optional source span for where the parse error occurred

Implementations§

Source§

impl ConfigError

Source

pub fn mismatch( field: impl Into<String>, expected: impl Into<String>, found: impl Into<String>, ) -> Self

Helper to produce a TypeMismatch error.

Source

pub fn mismatch_at( field: impl Into<String>, expected: impl Into<String>, found: impl Into<String>, span: SourceSpan, ) -> Self

Helper to produce a TypeMismatch error with a source span.

Source

pub fn nested(section: impl Into<String>, source: ConfigError) -> Self

Helper to wrap nested errors with additional context.

Source

pub fn nested_at( section: impl Into<String>, source: ConfigError, span: SourceSpan, ) -> Self

Helper to wrap nested errors with additional context and a source span.

Source

pub fn missing(key: impl Into<String>) -> Self

Helper to surface missing values.

Source

pub fn missing_at(key: impl Into<String>, span: SourceSpan) -> Self

Helper to surface missing values with a source span.

Trait Implementations§

Source§

impl Debug for ConfigError

Source§

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

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

impl Diagnostic for ConfigError

Source§

fn code(&self) -> Option<Box<dyn Display + '_>>

Unique diagnostic code that can be used to look up more information about this Diagnostic. Ideally also globally unique, and documented in the toplevel crate’s documentation for easy searching. Rust path format (foo::bar::baz) is recommended, but more classic codes like E0123 or enums will work just fine.
Source§

fn help(&self) -> Option<Box<dyn Display + '_>>

Additional help text related to this Diagnostic. Do you have any advice for the poor soul who’s just run into this issue?
Source§

fn labels(&self) -> Option<Box<dyn Iterator<Item = LabeledSpan> + '_>>

Labels to apply to this Diagnostic’s Diagnostic::source_code
Source§

fn diagnostic_source(&self) -> Option<&dyn Diagnostic>

The cause of the error.
Source§

fn severity(&self) -> Option<Severity>

Diagnostic severity. This may be used by ReportHandlers to change the display format of this diagnostic. Read more
Source§

fn url<'a>(&'a self) -> Option<Box<dyn Display + 'a>>

URL to visit for a more detailed explanation/help about this Diagnostic.
Source§

fn source_code(&self) -> Option<&dyn SourceCode>

Source code to apply this Diagnostic’s Diagnostic::labels to.
Source§

fn related<'a>( &'a self, ) -> Option<Box<dyn Iterator<Item = &'a dyn Diagnostic> + 'a>>

Additional related Diagnostics.
Source§

impl Display for ConfigError

Source§

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

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

impl Error for ConfigError

Source§

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

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for ConfigError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.

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