Enum lrpar::LexParseError
source · pub enum LexParseError<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>>where
usize: AsPrimitive<StorageT>,{
LexError(LexerTypesT::LexErrorT),
ParseError(ParseError<LexerTypesT::LexemeT, StorageT>),
}
Expand description
A lexing or parsing error. Although the two are quite distinct in terms of what can be reported to users, both can (at least conceptually) occur at any point of the intertwined lexing/parsing process.
Variants§
LexError(LexerTypesT::LexErrorT)
ParseError(ParseError<LexerTypesT::LexemeT, StorageT>)
Implementations§
source§impl<StorageT: Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
impl<StorageT: Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
sourcepub fn pp<'a>(
&self,
lexer: &dyn NonStreamingLexer<'_, LexerTypesT>,
epp: &dyn Fn(TIdx<StorageT>) -> Option<&'a str>,
) -> String
pub fn pp<'a>( &self, lexer: &dyn NonStreamingLexer<'_, LexerTypesT>, epp: &dyn Fn(TIdx<StorageT>) -> Option<&'a str>, ) -> String
A pretty-printer of a lexer/parser error. This isn’t suitable for all purposes, but it’s often good enough. The output format is not guaranteed to be stable but is likely to be of the form:
Parsing error at line 3 column 8. Repair sequences found:
1: Insert ID
2: Delete +, Shift 3
If you are using the compile-time parse system, your grm_y
module exposes a suitable
epp
function; if you are
using the run-time system,
YaccGrammar
exposes a suitable
epp
function,
though you will have to wrap it in a closure e.g. &|t| grm.token_epp(t)
.
Trait Implementations§
source§impl<StorageT: Debug + 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: Debug + LexerTypes<StorageT = StorageT>> Debug for LexParseError<StorageT, LexerTypesT>
impl<StorageT: Debug + 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: Debug + LexerTypes<StorageT = StorageT>> Debug for LexParseError<StorageT, LexerTypesT>
source§impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> Display for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> Display for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
source§impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> Error for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> Error for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
1.30.0 · source§fn source(&self) -> Option<&(dyn Error + 'static)>
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
fn description(&self) -> &str
👎Deprecated since 1.42.0: use the Display impl or to_string()
source§impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> From<ParseError<<LexerTypesT as LexerTypes>::LexemeT, StorageT>> for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT>> From<ParseError<<LexerTypesT as LexerTypes>::LexemeT, StorageT>> for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
source§fn from(
err: ParseError<LexerTypesT::LexemeT, StorageT>,
) -> LexParseError<StorageT, LexerTypesT>
fn from( err: ParseError<LexerTypesT::LexemeT, StorageT>, ) -> LexParseError<StorageT, LexerTypesT>
Converts to this type from the input type.
source§impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT, LexErrorT = T>, T: LexError> From<T> for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
impl<StorageT: 'static + Debug + Hash + PrimInt + Unsigned, LexerTypesT: LexerTypes<StorageT = StorageT, LexErrorT = T>, T: LexError> From<T> for LexParseError<StorageT, LexerTypesT>where
usize: AsPrimitive<StorageT>,
source§fn from(err: T) -> LexParseError<StorageT, LexerTypesT>
fn from(err: T) -> LexParseError<StorageT, LexerTypesT>
Converts to this type from the input type.
Auto Trait Implementations§
impl<StorageT, LexerTypesT> Freeze for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: Freeze,
<LexerTypesT as LexerTypes>::LexemeT: Freeze,
StorageT: Freeze,
impl<StorageT, LexerTypesT> RefUnwindSafe for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: RefUnwindSafe,
<LexerTypesT as LexerTypes>::LexemeT: RefUnwindSafe,
StorageT: RefUnwindSafe,
impl<StorageT, LexerTypesT> Send for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: Send,
<LexerTypesT as LexerTypes>::LexemeT: Send,
StorageT: Send,
impl<StorageT, LexerTypesT> Sync for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: Sync,
<LexerTypesT as LexerTypes>::LexemeT: Sync,
StorageT: Sync,
impl<StorageT, LexerTypesT> Unpin for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: Unpin,
<LexerTypesT as LexerTypes>::LexemeT: Unpin,
StorageT: Unpin,
impl<StorageT, LexerTypesT> UnwindSafe for LexParseError<StorageT, LexerTypesT>where
usize: Sized,
<LexerTypesT as LexerTypes>::LexErrorT: UnwindSafe,
<LexerTypesT as LexerTypes>::LexemeT: UnwindSafe,
StorageT: UnwindSafe,
Blanket Implementations§
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
Mutably borrows from an owned value. Read more