1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
use std::hash::Hash;
use crate::lexer::Lexer;
use crate::parser_rule_context::empty_ctx;
pub(crate) const LEXER_ACTION_TYPE_CHANNEL: isize = 0;
pub(crate) const LEXER_ACTION_TYPE_CUSTOM: isize = 1;
pub(crate) const LEXER_ACTION_TYPE_MODE: isize = 2;
pub(crate) const LEXER_ACTION_TYPE_MORE: isize = 3;
pub(crate) const LEXER_ACTION_TYPE_POP_MODE: isize = 4;
pub(crate) const LEXER_ACTION_TYPE_PUSH_MODE: isize = 5;
pub(crate) const LEXER_ACTION_TYPE_SKIP: isize = 6;
pub(crate) const LEXER_ACTION_TYPE_TYPE: isize = 7;
#[derive(Clone, Eq, PartialEq, Debug, Hash)]
pub(crate) enum LexerAction {
LexerChannelAction(isize),
LexerCustomAction {
rule_index: isize,
action_index: isize,
},
LexerModeAction(isize),
LexerMoreAction,
LexerPopModeAction,
LexerPushModeAction(isize),
LexerSkipAction,
LexerTypeAction(isize),
LexerIndexedCustomAction {
offset: isize,
action: Box<LexerAction>,
},
}
impl LexerAction {
pub fn is_position_dependent(&self) -> bool {
match self {
LexerAction::LexerCustomAction { .. } |
LexerAction::LexerIndexedCustomAction { .. } => true,
_ => false
}
}
pub(crate) fn execute(&self, lexer: &mut dyn Lexer) {
match self {
&LexerAction::LexerChannelAction(channel) => lexer.set_channel(channel),
&LexerAction::LexerCustomAction { rule_index, action_index } => {
lexer.action(&*empty_ctx(), rule_index, action_index);
},
&LexerAction::LexerModeAction(mode) => lexer.set_mode(mode as usize),
&LexerAction::LexerMoreAction => lexer.more(),
&LexerAction::LexerPopModeAction => { lexer.pop_mode(); },
&LexerAction::LexerPushModeAction(mode) => lexer.push_mode(mode as usize),
&LexerAction::LexerSkipAction => lexer.skip(),
&LexerAction::LexerTypeAction(ty) => lexer.set_type(ty),
&LexerAction::LexerIndexedCustomAction { ref action, .. } => action.execute(lexer),
}
}
}