Skip to main content

Diagnostic

Struct Diagnostic 

Source
pub struct Diagnostic {
    pub rule: Cow<'static, str>,
    pub line: usize,
    pub column: usize,
    pub span: Range<usize>,
    pub message: String,
    pub fix: Option<Fix>,
    pub advisory: bool,
}
Expand description

One issue at one source location, optionally with an automatic Fix. Spans are byte ranges into the original source string.

Fields§

§rule: Cow<'static, str>

Kebab-case identifier of the rule that produced this diagnostic. Cow so stdlib rules can borrow &'static str names while user rules with runtime-built names own the buffer. The dispatcher stamps this field after each rule’s check returns, so rule implementations do not set it.

§line: usize

1-indexed line number of the diagnostic’s first byte.

§column: usize

1-indexed codepoint column.

§span: Range<usize>

Byte span within the source. source.get(span.clone()) is the substring the diagnostic refers to.

§message: String

One-line human-readable message.

§fix: Option<Fix>

Optional replacement covering span.

§advisory: bool

Whether this diagnostic is advisory (informational; does not fail --check). Set by the dispatcher from the rule’s is_advisory().

Implementations§

Source§

impl Diagnostic

Source

pub fn at( doc: &Document, byte_offset: usize, local: Range<usize>, message: String, fix: Option<Fix>, ) -> Option<Self>

Build a diagnostic at a position within a borrowed source slice. byte_offset is the absolute offset of the slice’s first byte; local is the match range within that slice.

Returns None if the line-index lookup fails — never observed for offsets produced by pulldown-cmark, but the safe-fallback behaviour is to drop the diagnostic rather than panic. The dispatcher fills in rule and advisory after the containing rule’s check returns.

Source

pub fn suppress_via(&self) -> String

Suppression marker text. The Markdown comment for muting this diagnostic on the next block is <!-- mdwright: allow rule-name -->.

Source

pub fn severity(&self) -> Severity

Diagnostic severity derived from Self::advisory. Used by the v2 JSON Lines emitter and the rustc-style pretty header.

Trait Implementations§

Source§

impl Clone for Diagnostic

Source§

fn clone(&self) -> Diagnostic

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Diagnostic

Source§

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

Formats the value using the given formatter. Read more

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more