pub struct LeafNode<'input, Node: ParserNodeType<'input>, T: 'static> {
pub symbol: <Node::TF as TokenFactory<'input>>::Tok,
/* private fields */
}
Expand description
Generic leaf AST node
Fields§
§symbol: <Node::TF as TokenFactory<'input>>::Tok
Token, this leaf consist of
Implementations§
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> LeafNode<'input, Node, T>
Sourcepub fn new(symbol: <Node::TF as TokenFactory<'input>>::Tok) -> Self
pub fn new(symbol: <Node::TF as TokenFactory<'input>>::Tok) -> Self
creates new leaf node
Trait Implementations§
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> CustomRuleContext<'input> for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> CustomRuleContext<'input> for LeafNode<'input, Node, T>
type TF = <Node as ParserNodeType<'input>>::TF
Source§fn get_rule_index(&self) -> usize
fn get_rule_index(&self) -> usize
Rule index that corresponds to this context type
Source§fn get_node_text(&self, rule_names: &[&str]) -> String
fn get_node_text(&self, rule_names: &[&str]) -> String
Returns text representation of current node type,
rule name for context nodes and token text for terminal nodes
fn get_alt_number(&self) -> isize
fn set_alt_number(&self, _alt_number: isize)
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> Debug for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> Debug for LeafNode<'input, Node, T>
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> ParseTree<'input> for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> ParseTree<'input> for LeafNode<'input, Node, T>
Source§fn get_source_interval(&self) -> Interval
fn get_source_interval(&self) -> Interval
Return an {@link Interval} indicating the index in the
{@link TokenStream} of the first and last token associated with this
subtree. If this node is a leaf, then the interval represents a single
token and has interval i..i for token index i.
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> ParserRuleContext<'input> for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> ParserRuleContext<'input> for LeafNode<'input, Node, T>
fn set_exception(&self, _e: ANTLRError)
fn set_start(&self, _t: Option<<Self::TF as TokenFactory<'input>>::Tok>)
Source§fn start<'a>(&'a self) -> Ref<'a, <Self::TF as TokenFactory<'input>>::Inner>where
'input: 'a,
fn start<'a>(&'a self) -> Ref<'a, <Self::TF as TokenFactory<'input>>::Inner>where
'input: 'a,
Get the initial token in this context.
Note that the range from start to stop is inclusive, so for rules that do not consume anything
(for example, zero length or error productions) this token may exceed stop.
fn start_mut<'a>(
&'a self,
) -> RefMut<'a, <Self::TF as TokenFactory<'input>>::Tok>where
'input: 'a,
fn set_stop(&self, _t: Option<<Self::TF as TokenFactory<'input>>::Tok>)
Source§fn stop<'a>(&'a self) -> Ref<'a, <Self::TF as TokenFactory<'input>>::Inner>where
'input: 'a,
fn stop<'a>(&'a self) -> Ref<'a, <Self::TF as TokenFactory<'input>>::Inner>where
'input: 'a,
Get the final token in this context.
Note that the range from start to stop is inclusive, so for rules that do not consume anything
(for example, zero length or error productions) this token may precede start.
fn stop_mut<'a>(&'a self) -> RefMut<'a, <Self::TF as TokenFactory<'input>>::Tok>where
'input: 'a,
fn add_child(&self, _child: Rc<<Self::Ctx as ParserNodeType<'input>>::Type>)
fn remove_last_child(&self)
fn child_of_type<T>(&self, pos: usize) -> Option<Rc<T>>
fn children_of_type<T>(&self) -> Vec<Rc<T>>
fn get_token( &self, ttype: isize, pos: usize, ) -> Option<Rc<TerminalNode<'input, Self::Ctx>>>
fn get_tokens(&self, ttype: isize) -> Vec<Rc<TerminalNode<'input, Self::Ctx>>>
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> RuleContext<'input> for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> RuleContext<'input> for LeafNode<'input, Node, T>
Source§fn get_invoking_state(&self) -> isize
fn get_invoking_state(&self) -> isize
Internal parser state
Source§fn set_invoking_state(&self, _t: isize)
fn set_invoking_state(&self, _t: isize)
Sets internal parser state
Source§fn is_empty(&self) -> bool
fn is_empty(&self) -> bool
A context is empty if there is no invoking state; meaning nobody called
current context. Which is usually true for the root of the syntax tree
Source§fn get_parent_ctx(
&self,
) -> Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>
fn get_parent_ctx( &self, ) -> Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>
Get parent context
Source§fn set_parent(
&self,
_parent: &Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>,
)
fn set_parent( &self, _parent: &Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>, )
Set parent context
Source§impl<'input, Node: ParserNodeType<'input>, T: 'static> Tree<'input> for LeafNode<'input, Node, T>
impl<'input, Node: ParserNodeType<'input>, T: 'static> Tree<'input> for LeafNode<'input, Node, T>
fn get_parent(&self) -> Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>
fn has_parent(&self) -> bool
fn get_payload(&self) -> Box<dyn Any>
fn get_child( &self, _i: usize, ) -> Option<Rc<<Self::Ctx as ParserNodeType<'input>>::Type>>
fn get_child_count(&self) -> usize
fn get_children<'a>(
&'a self,
) -> Box<dyn Iterator<Item = Rc<<Self::Ctx as ParserNodeType<'input>>::Type>> + 'a>where
'input: 'a,
impl<'input, Node, T: 'static> TidAble<'input> for LeafNode<'input, Node, T>where
Node: ParserNodeType<'input> + TidAble<'input>,
Auto Trait Implementations§
impl<'input, Node, T> Freeze for LeafNode<'input, Node, T>
impl<'input, Node, T> RefUnwindSafe for LeafNode<'input, Node, T>where
<<Node as ParserNodeType<'input>>::TF as TokenFactory<'input>>::Tok: RefUnwindSafe,
T: RefUnwindSafe,
impl<'input, Node, T> Send for LeafNode<'input, Node, T>
impl<'input, Node, T> Sync for LeafNode<'input, Node, T>
impl<'input, Node, T> Unpin for LeafNode<'input, Node, T>
impl<'input, Node, T> UnwindSafe for LeafNode<'input, Node, T>where
<<Node as ParserNodeType<'input>>::TF as TokenFactory<'input>>::Tok: UnwindSafe,
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> AnyExt for T
impl<T> AnyExt for T
Source§fn downcast_ref<T>(this: &Self) -> Option<&T>where
T: Any,
fn downcast_ref<T>(this: &Self) -> Option<&T>where
T: Any,
Attempts to downcast this to
T
behind referenceSource§fn downcast_mut<T>(this: &mut Self) -> Option<&mut T>where
T: Any,
fn downcast_mut<T>(this: &mut Self) -> Option<&mut T>where
T: Any,
Attempts to downcast this to
T
behind mutable referenceSource§fn downcast_rc<T>(this: Rc<Self>) -> Result<Rc<T>, Rc<Self>>where
T: Any,
fn downcast_rc<T>(this: Rc<Self>) -> Result<Rc<T>, Rc<Self>>where
T: Any,
Attempts to downcast this to
T
behind Rc
pointerSource§fn downcast_arc<T>(this: Arc<Self>) -> Result<Arc<T>, Arc<Self>>where
T: Any,
fn downcast_arc<T>(this: Arc<Self>) -> Result<Arc<T>, Arc<Self>>where
T: Any,
Attempts to downcast this to
T
behind Arc
pointerSource§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
Source§impl<T, X> CoerceTo<T> for Xwhere
T: CoerceFrom<X> + ?Sized,
impl<T, X> CoerceTo<T> for Xwhere
T: CoerceFrom<X> + ?Sized,
fn coerce_rc_to(self: Rc<X>) -> Rc<T>
fn coerce_box_to(self: Box<X>) -> Box<T>
fn coerce_ref_to(&self) -> &T
fn coerce_mut_to(&mut self) -> &mut T
Source§impl<'input, T> RuleContextExt<'input> for Twhere
T: ParserRuleContext<'input> + 'input + ?Sized,
impl<'input, T> RuleContextExt<'input> for Twhere
T: ParserRuleContext<'input> + 'input + ?Sized,
Source§fn to_string<Z>(
self: &Rc<T>,
rule_names: Option<&[&str]>,
stop: Option<Rc<Z>>,
) -> Stringwhere
Z: ParserRuleContext<'input, Ctx = <T as CustomRuleContext<'input>>::Ctx, TF = <T as CustomRuleContext<'input>>::TF> + 'input + ?Sized,
<T as CustomRuleContext<'input>>::Ctx: ParserNodeType<'input, Type = Z>,
T: CoerceTo<Z>,
fn to_string<Z>(
self: &Rc<T>,
rule_names: Option<&[&str]>,
stop: Option<Rc<Z>>,
) -> Stringwhere
Z: ParserRuleContext<'input, Ctx = <T as CustomRuleContext<'input>>::Ctx, TF = <T as CustomRuleContext<'input>>::TF> + 'input + ?Sized,
<T as CustomRuleContext<'input>>::Ctx: ParserNodeType<'input, Type = Z>,
T: CoerceTo<Z>,
Prints list of parent rules
fn accept_children<V>(&self, visitor: &mut V)where
V: ParseTreeVisitor<'input, <T as CustomRuleContext<'input>>::Ctx> + ?Sized,
<<T as CustomRuleContext<'input>>::Ctx as ParserNodeType<'input>>::Type: VisitableDyn<V>,
Source§impl<'a, X> TidExt<'a> for X
impl<'a, X> TidExt<'a> for X
Source§fn is<T>(&self) -> boolwhere
T: Tid<'a>,
fn is<T>(&self) -> boolwhere
T: Tid<'a>,
Returns true if type behind self is equal to the type of T.
Source§fn downcast_ref<'b, T>(&'b self) -> Option<&'b T>where
T: Tid<'a>,
fn downcast_ref<'b, T>(&'b self) -> Option<&'b T>where
T: Tid<'a>,
Attempts to downcast self to
T
behind referenceSource§fn downcast_mut<'b, T>(&'b mut self) -> Option<&'b mut T>where
T: Tid<'a>,
fn downcast_mut<'b, T>(&'b mut self) -> Option<&'b mut T>where
T: Tid<'a>,
Attempts to downcast self to
T
behind mutable referenceSource§fn downcast_rc<T>(self: Rc<Self>) -> Result<Rc<T>, Rc<Self>>where
T: Tid<'a>,
fn downcast_rc<T>(self: Rc<Self>) -> Result<Rc<T>, Rc<Self>>where
T: Tid<'a>,
Attempts to downcast self to
T
behind Rc
pointerSource§fn downcast_arc<T>(self: Arc<Self>) -> Result<Arc<T>, Arc<Self>>where
T: Tid<'a>,
fn downcast_arc<T>(self: Arc<Self>) -> Result<Arc<T>, Arc<Self>>where
T: Tid<'a>,
Attempts to downcast self to
T
behind Arc
pointer