From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- .../jsparagus-generated-parser/src/traits/mod.rs | 36 ++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 third_party/rust/jsparagus-generated-parser/src/traits/mod.rs (limited to 'third_party/rust/jsparagus-generated-parser/src/traits/mod.rs') diff --git a/third_party/rust/jsparagus-generated-parser/src/traits/mod.rs b/third_party/rust/jsparagus-generated-parser/src/traits/mod.rs new file mode 100644 index 0000000000..69e2c7daed --- /dev/null +++ b/third_party/rust/jsparagus-generated-parser/src/traits/mod.rs @@ -0,0 +1,36 @@ +use crate::error::Result; +use crate::parser_tables_generated::Term; + +/// This macro is pre-processed by the python grammar processor and generate +/// code out-side the current context. +#[macro_export] +macro_rules! grammar_extension { + ( $($_:tt)* ) => {}; +} + +/// Aggregate a Value (= StackValue or ()) and a nonterminal/terminal as a stack +/// element. The term is currently used for replaying the parse table when +/// handling errors and non-optimized reduced actions with lookahead. +#[derive(Debug)] +pub struct TermValue { + pub term: Term, + pub value: Value, +} + +/// The parser trait is an abstraction to define the primitive of an LR Parser +/// with variable lookahead which can be replayed. +pub trait ParserTrait<'alloc, Value> { + fn shift(&mut self, tv: TermValue) -> Result<'alloc, bool>; + fn shift_replayed(&mut self, state: usize); + fn unshift(&mut self); + fn rewind(&mut self, n: usize) { + for _ in 0..n { + self.unshift(); + } + } + fn pop(&mut self) -> TermValue; + fn replay(&mut self, tv: TermValue); + fn epsilon(&mut self, state: usize); + fn top_state(&self) -> usize; + fn check_not_on_new_line(&mut self, peek: usize) -> Result<'alloc, bool>; +} -- cgit v1.2.3