#[non_exhaustive]pub struct ValidationError {
pub code: ErrorCode,
pub message: String,
pub date: NaiveDate,
pub context: Option<String>,
pub note: Option<String>,
pub span: Option<Span>,
pub file_id: Option<u16>,
}Expand description
A validation error.
The Display impl emits just the message text (no [E1234] prefix).
CLI and IDE renderers are expected to prepend the error code themselves,
which avoids the double-tagging seen in older output like
error[E3001]: [E3001] ... (see issue #901).
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.code: ErrorCodeError code.
message: StringError message.
date: NaiveDateDate of the directive that caused the error.
context: Option<String>Additional context.
note: Option<String>Advisory note attached to the error — typically used to help users
diagnose the underlying cause (e.g. “this directive was synthesized
by a plugin”). Unlike Self::context, which describes data tied
to the error, the note describes something about its origin.
span: Option<Span>Source span (byte offsets within the file).
file_id: Option<u16>Source file ID (index into SourceMap).
Uses u16 to minimize struct size (max 65,535 files).
Implementations§
Source§impl ValidationError
impl ValidationError
Sourcepub fn new(code: ErrorCode, message: impl Into<String>, date: NaiveDate) -> Self
pub fn new(code: ErrorCode, message: impl Into<String>, date: NaiveDate) -> Self
Create a new validation error without source location.
Sourcepub fn with_location<T>(
code: ErrorCode,
message: impl Into<String>,
date: NaiveDate,
spanned: &Spanned<T>,
) -> Self
pub fn with_location<T>( code: ErrorCode, message: impl Into<String>, date: NaiveDate, spanned: &Spanned<T>, ) -> Self
Create a new validation error with source location from a spanned directive.
Sourcepub fn with_context(self, context: impl Into<String>) -> Self
pub fn with_context(self, context: impl Into<String>) -> Self
Add context to this error.
Sourcepub fn with_note(self, note: impl Into<String>) -> Self
pub fn with_note(self, note: impl Into<String>) -> Self
Attach an advisory note to this error (builder pattern).
Sourcepub const fn at_location<T>(self, spanned: &Spanned<T>) -> Self
pub const fn at_location<T>(self, spanned: &Spanned<T>) -> Self
Set the source location for this error (builder pattern).
Use this to add location info to an existing error. For creating
new errors with location, prefer Self::with_location instead.
Trait Implementations§
Source§impl Clone for ValidationError
impl Clone for ValidationError
Source§fn clone(&self) -> ValidationError
fn clone(&self) -> ValidationError
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for ValidationError
impl Debug for ValidationError
Source§impl Display for ValidationError
impl Display for ValidationError
Source§impl Error for ValidationError
impl Error for ValidationError
1.30.0 · Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
use the Display impl or to_string()
Auto Trait Implementations§
impl Freeze for ValidationError
impl RefUnwindSafe for ValidationError
impl Send for ValidationError
impl Sync for ValidationError
impl Unpin for ValidationError
impl UnsafeUnpin for ValidationError
impl UnwindSafe for ValidationError
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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>
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>
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.