Skip to main content

BibParseError

Struct BibParseError 

Source
pub struct BibParseError {
    kind: BibParseErrorKind,
    offset: usize,
}
Expand description

A recoverable BibTeX parse error: a BibParseErrorKind plus the byte offset into the original input where the problem was detected.

The offset is a byte index, matching the convention mos-core SourceSpans use, so a future citation slice can turn one of these into a compiler Diagnostic without re-deriving positions. Use line_col for a 1-based line/column pair.

§Examples

use mos_bib::{BibParseErrorKind, parse_bibtex};

let err = parse_bibtex("article{x}").unwrap_err();
assert_eq!(err.kind(), BibParseErrorKind::ExpectedAt);
assert_eq!(err.offset(), 0);

Fields§

§kind: BibParseErrorKind§offset: usize

Implementations§

Source§

impl BibParseError

Source

pub(crate) const fn new(kind: BibParseErrorKind, offset: usize) -> Self

Construct an error of kind at byte offset. Crate-internal: the parser is the only place that mints these.

Source

pub const fn kind(&self) -> BibParseErrorKind

The kind of parse failure.

Source

pub const fn offset(&self) -> usize

The byte offset into the parsed input where the error was detected.

Source

pub fn line_col(&self, src: &str) -> (usize, usize)

The 1-based (line, column) of this error within src.

src must be the input passed to parse_bibtex; columns count Unicode scalar values. Use to_diagnostic or From<BibParseError> for CoreError to bridge into mos-core diagnostics.

§Examples
use mos_bib::parse_bibtex;

let src = "@article{ok}\n@bad";
let err = parse_bibtex(src).unwrap_err();
assert_eq!(err.line_col(src), (2, 5));
Source

pub fn to_diagnostic(&self, file: impl Into<PathBuf>) -> Diagnostic

Convert this error into a mos-core [Diagnostic] anchored in file.

The diagnostic carries the MOS0043 code and a zero-width [SourceSpan] at offset, so a malformed .bib reported here renders through the standard compiler pipeline. The infallible From<BibParseError> for CoreError conversion is the span-less equivalent for boundaries without a source path.

§Examples
use mos_bib::parse_bibtex;

let err = parse_bibtex("oops").unwrap_err();
let diagnostic = err.to_diagnostic("refs.bib");
assert_eq!(diagnostic.def().code().to_string(), "MOS0043");

Trait Implementations§

Source§

impl Clone for BibParseError

Source§

fn clone(&self) -> BibParseError

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for BibParseError

Source§

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

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

impl Display for BibParseError

Source§

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

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

impl Error for BibParseError

1.30.0 · 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<BibParseError> for CoreError

Source§

fn from(err: BibParseError) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for BibParseError

Source§

fn eq(&self, other: &BibParseError) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for BibParseError

Source§

impl StructuralPartialEq for BibParseError

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