712 lines
23 KiB
Python
712 lines
23 KiB
Python
|
# Generated from ArmControl.g4 by ANTLR 4.7.2
|
||
|
# encoding: utf-8
|
||
|
from antlr4 import *
|
||
|
from io import StringIO
|
||
|
from typing.io import TextIO
|
||
|
import sys
|
||
|
|
||
|
|
||
|
def serializedATN():
|
||
|
with StringIO() as buf:
|
||
|
buf.write("\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\3\20")
|
||
|
buf.write("W\4\2\t\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\4\b")
|
||
|
buf.write("\t\b\4\t\t\t\4\n\t\n\3\2\7\2\26\n\2\f\2\16\2\31\13\2\3")
|
||
|
buf.write("\2\3\2\3\3\3\3\3\3\7\3 \n\3\f\3\16\3#\13\3\3\3\5\3&\n")
|
||
|
buf.write("\3\3\3\5\3)\n\3\3\4\3\4\3\4\3\4\3\4\3\4\5\4\61\n\4\3\4")
|
||
|
buf.write("\3\4\3\4\3\4\5\4\67\n\4\3\4\5\4:\n\4\3\5\3\5\5\5>\n\5")
|
||
|
buf.write("\3\5\3\5\5\5B\n\5\7\5D\n\5\f\5\16\5G\13\5\3\5\3\5\3\6")
|
||
|
buf.write("\3\6\3\7\3\7\5\7O\n\7\3\b\3\b\3\t\3\t\3\n\3\n\3\n\2\2")
|
||
|
buf.write("\13\2\4\6\b\n\f\16\20\22\2\2\2[\2\27\3\2\2\2\4(\3\2\2")
|
||
|
buf.write("\2\69\3\2\2\2\b;\3\2\2\2\nJ\3\2\2\2\fN\3\2\2\2\16P\3\2")
|
||
|
buf.write("\2\2\20R\3\2\2\2\22T\3\2\2\2\24\26\5\4\3\2\25\24\3\2\2")
|
||
|
buf.write("\2\26\31\3\2\2\2\27\25\3\2\2\2\27\30\3\2\2\2\30\32\3\2")
|
||
|
buf.write("\2\2\31\27\3\2\2\2\32\33\7\2\2\3\33\3\3\2\2\2\34!\5\6")
|
||
|
buf.write("\4\2\35\36\7\3\2\2\36 \5\6\4\2\37\35\3\2\2\2 #\3\2\2\2")
|
||
|
buf.write("!\37\3\2\2\2!\"\3\2\2\2\"%\3\2\2\2#!\3\2\2\2$&\7\16\2")
|
||
|
buf.write("\2%$\3\2\2\2%&\3\2\2\2&)\3\2\2\2\')\7\16\2\2(\34\3\2\2")
|
||
|
buf.write("\2(\'\3\2\2\2)\5\3\2\2\2*\60\7\4\2\2+\61\5\b\5\2,-\5\n")
|
||
|
buf.write("\6\2-.\5\f\7\2.\61\3\2\2\2/\61\5\n\6\2\60+\3\2\2\2\60")
|
||
|
buf.write(",\3\2\2\2\60/\3\2\2\2\61:\3\2\2\2\62\63\7\5\2\2\63:\5")
|
||
|
buf.write("\16\b\2\64\66\7\6\2\2\65\67\5\16\b\2\66\65\3\2\2\2\66")
|
||
|
buf.write("\67\3\2\2\2\67:\3\2\2\28:\7\7\2\29*\3\2\2\29\62\3\2\2")
|
||
|
buf.write("\29\64\3\2\2\298\3\2\2\2:\7\3\2\2\2;=\7\b\2\2<>\5\f\7")
|
||
|
buf.write("\2=<\3\2\2\2=>\3\2\2\2>E\3\2\2\2?A\5\22\n\2@B\5\f\7\2")
|
||
|
buf.write("A@\3\2\2\2AB\3\2\2\2BD\3\2\2\2C?\3\2\2\2DG\3\2\2\2EC\3")
|
||
|
buf.write("\2\2\2EF\3\2\2\2FH\3\2\2\2GE\3\2\2\2HI\7\t\2\2I\t\3\2")
|
||
|
buf.write("\2\2JK\7\n\2\2K\13\3\2\2\2LO\5\16\b\2MO\5\20\t\2NL\3\2")
|
||
|
buf.write("\2\2NM\3\2\2\2O\r\3\2\2\2PQ\7\13\2\2Q\17\3\2\2\2RS\7\f")
|
||
|
buf.write("\2\2S\21\3\2\2\2TU\7\r\2\2U\23\3\2\2\2\r\27!%(\60\669")
|
||
|
buf.write("=AEN")
|
||
|
return buf.getvalue()
|
||
|
|
||
|
|
||
|
class ArmControlParser ( Parser ):
|
||
|
|
||
|
grammarFileName = "ArmControl.g4"
|
||
|
|
||
|
atn = ATNDeserializer().deserialize(serializedATN())
|
||
|
|
||
|
decisionsToDFA = [ DFA(ds, i) for i, ds in enumerate(atn.decisionToState) ]
|
||
|
|
||
|
sharedContextCache = PredictionContextCache()
|
||
|
|
||
|
literalNames = [ "<INVALID>", "';'", "'GO'", "'PAUSE'", "'WAIT'", "'PASS'",
|
||
|
"'{'", "'}'", "<INVALID>", "<INVALID>", "<INVALID>",
|
||
|
"','" ]
|
||
|
|
||
|
symbolicNames = [ "<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
|
||
|
"<INVALID>", "<INVALID>", "<INVALID>", "<INVALID>",
|
||
|
"NAME", "NUMBER", "HEX", "SEPERATOR", "NEWLINE", "WS",
|
||
|
"COMMENT" ]
|
||
|
|
||
|
RULE_prog = 0
|
||
|
RULE_statement = 1
|
||
|
RULE_command = 2
|
||
|
RULE_coords = 3
|
||
|
RULE_name = 4
|
||
|
RULE_value = 5
|
||
|
RULE_number = 6
|
||
|
RULE_hexidecimal = 7
|
||
|
RULE_seperator = 8
|
||
|
|
||
|
ruleNames = [ "prog", "statement", "command", "coords", "name", "value",
|
||
|
"number", "hexidecimal", "seperator" ]
|
||
|
|
||
|
EOF = Token.EOF
|
||
|
T__0=1
|
||
|
T__1=2
|
||
|
T__2=3
|
||
|
T__3=4
|
||
|
T__4=5
|
||
|
T__5=6
|
||
|
T__6=7
|
||
|
NAME=8
|
||
|
NUMBER=9
|
||
|
HEX=10
|
||
|
SEPERATOR=11
|
||
|
NEWLINE=12
|
||
|
WS=13
|
||
|
COMMENT=14
|
||
|
|
||
|
def __init__(self, input:TokenStream, output:TextIO = sys.stdout):
|
||
|
super().__init__(input, output)
|
||
|
self.checkVersion("4.7.2")
|
||
|
self._interp = ParserATNSimulator(self, self.atn, self.decisionsToDFA, self.sharedContextCache)
|
||
|
self._predicates = None
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
class ProgContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def EOF(self):
|
||
|
return self.getToken(ArmControlParser.EOF, 0)
|
||
|
|
||
|
def statement(self, i:int=None):
|
||
|
if i is None:
|
||
|
return self.getTypedRuleContexts(ArmControlParser.StatementContext)
|
||
|
else:
|
||
|
return self.getTypedRuleContext(ArmControlParser.StatementContext,i)
|
||
|
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_prog
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterProg" ):
|
||
|
listener.enterProg(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitProg" ):
|
||
|
listener.exitProg(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def prog(self):
|
||
|
|
||
|
localctx = ArmControlParser.ProgContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 0, self.RULE_prog)
|
||
|
self._la = 0 # Token type
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 21
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
while (((_la) & ~0x3f) == 0 and ((1 << _la) & ((1 << ArmControlParser.T__1) | (1 << ArmControlParser.T__2) | (1 << ArmControlParser.T__3) | (1 << ArmControlParser.T__4) | (1 << ArmControlParser.NEWLINE))) != 0):
|
||
|
self.state = 18
|
||
|
self.statement()
|
||
|
self.state = 23
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
|
||
|
self.state = 24
|
||
|
self.match(ArmControlParser.EOF)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class StatementContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def command(self, i:int=None):
|
||
|
if i is None:
|
||
|
return self.getTypedRuleContexts(ArmControlParser.CommandContext)
|
||
|
else:
|
||
|
return self.getTypedRuleContext(ArmControlParser.CommandContext,i)
|
||
|
|
||
|
|
||
|
def NEWLINE(self):
|
||
|
return self.getToken(ArmControlParser.NEWLINE, 0)
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_statement
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterStatement" ):
|
||
|
listener.enterStatement(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitStatement" ):
|
||
|
listener.exitStatement(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def statement(self):
|
||
|
|
||
|
localctx = ArmControlParser.StatementContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 2, self.RULE_statement)
|
||
|
self._la = 0 # Token type
|
||
|
try:
|
||
|
self.state = 38
|
||
|
self._errHandler.sync(self)
|
||
|
token = self._input.LA(1)
|
||
|
if token in [ArmControlParser.T__1, ArmControlParser.T__2, ArmControlParser.T__3, ArmControlParser.T__4]:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 26
|
||
|
self.command()
|
||
|
self.state = 31
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
while _la==ArmControlParser.T__0:
|
||
|
self.state = 27
|
||
|
self.match(ArmControlParser.T__0)
|
||
|
self.state = 28
|
||
|
self.command()
|
||
|
self.state = 33
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
|
||
|
self.state = 35
|
||
|
self._errHandler.sync(self)
|
||
|
la_ = self._interp.adaptivePredict(self._input,2,self._ctx)
|
||
|
if la_ == 1:
|
||
|
self.state = 34
|
||
|
self.match(ArmControlParser.NEWLINE)
|
||
|
|
||
|
|
||
|
pass
|
||
|
elif token in [ArmControlParser.NEWLINE]:
|
||
|
self.enterOuterAlt(localctx, 2)
|
||
|
self.state = 37
|
||
|
self.match(ArmControlParser.NEWLINE)
|
||
|
pass
|
||
|
else:
|
||
|
raise NoViableAltException(self)
|
||
|
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class CommandContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_command
|
||
|
|
||
|
|
||
|
def copyFrom(self, ctx:ParserRuleContext):
|
||
|
super().copyFrom(ctx)
|
||
|
|
||
|
|
||
|
|
||
|
class PauseContext(CommandContext):
|
||
|
|
||
|
def __init__(self, parser, ctx:ParserRuleContext): # actually a ArmControlParser.CommandContext
|
||
|
super().__init__(parser)
|
||
|
self.copyFrom(ctx)
|
||
|
|
||
|
def number(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.NumberContext,0)
|
||
|
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterPause" ):
|
||
|
listener.enterPause(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitPause" ):
|
||
|
listener.exitPause(self)
|
||
|
|
||
|
|
||
|
class PassContext(CommandContext):
|
||
|
|
||
|
def __init__(self, parser, ctx:ParserRuleContext): # actually a ArmControlParser.CommandContext
|
||
|
super().__init__(parser)
|
||
|
self.copyFrom(ctx)
|
||
|
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterPass" ):
|
||
|
listener.enterPass(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitPass" ):
|
||
|
listener.exitPass(self)
|
||
|
|
||
|
|
||
|
class GoContext(CommandContext):
|
||
|
|
||
|
def __init__(self, parser, ctx:ParserRuleContext): # actually a ArmControlParser.CommandContext
|
||
|
super().__init__(parser)
|
||
|
self.copyFrom(ctx)
|
||
|
|
||
|
def coords(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.CoordsContext,0)
|
||
|
|
||
|
def name(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.NameContext,0)
|
||
|
|
||
|
def value(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.ValueContext,0)
|
||
|
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterGo" ):
|
||
|
listener.enterGo(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitGo" ):
|
||
|
listener.exitGo(self)
|
||
|
|
||
|
|
||
|
class WaitContext(CommandContext):
|
||
|
|
||
|
def __init__(self, parser, ctx:ParserRuleContext): # actually a ArmControlParser.CommandContext
|
||
|
super().__init__(parser)
|
||
|
self.copyFrom(ctx)
|
||
|
|
||
|
def number(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.NumberContext,0)
|
||
|
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterWait" ):
|
||
|
listener.enterWait(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitWait" ):
|
||
|
listener.exitWait(self)
|
||
|
|
||
|
|
||
|
|
||
|
def command(self):
|
||
|
|
||
|
localctx = ArmControlParser.CommandContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 4, self.RULE_command)
|
||
|
self._la = 0 # Token type
|
||
|
try:
|
||
|
self.state = 55
|
||
|
self._errHandler.sync(self)
|
||
|
token = self._input.LA(1)
|
||
|
if token in [ArmControlParser.T__1]:
|
||
|
localctx = ArmControlParser.GoContext(self, localctx)
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 40
|
||
|
self.match(ArmControlParser.T__1)
|
||
|
self.state = 46
|
||
|
self._errHandler.sync(self)
|
||
|
la_ = self._interp.adaptivePredict(self._input,4,self._ctx)
|
||
|
if la_ == 1:
|
||
|
self.state = 41
|
||
|
self.coords()
|
||
|
pass
|
||
|
|
||
|
elif la_ == 2:
|
||
|
self.state = 42
|
||
|
self.name()
|
||
|
self.state = 43
|
||
|
self.value()
|
||
|
pass
|
||
|
|
||
|
elif la_ == 3:
|
||
|
self.state = 45
|
||
|
self.name()
|
||
|
pass
|
||
|
|
||
|
|
||
|
pass
|
||
|
elif token in [ArmControlParser.T__2]:
|
||
|
localctx = ArmControlParser.PauseContext(self, localctx)
|
||
|
self.enterOuterAlt(localctx, 2)
|
||
|
self.state = 48
|
||
|
self.match(ArmControlParser.T__2)
|
||
|
self.state = 49
|
||
|
self.number()
|
||
|
pass
|
||
|
elif token in [ArmControlParser.T__3]:
|
||
|
localctx = ArmControlParser.WaitContext(self, localctx)
|
||
|
self.enterOuterAlt(localctx, 3)
|
||
|
self.state = 50
|
||
|
self.match(ArmControlParser.T__3)
|
||
|
self.state = 52
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
if _la==ArmControlParser.NUMBER:
|
||
|
self.state = 51
|
||
|
self.number()
|
||
|
|
||
|
|
||
|
pass
|
||
|
elif token in [ArmControlParser.T__4]:
|
||
|
localctx = ArmControlParser.PassContext(self, localctx)
|
||
|
self.enterOuterAlt(localctx, 4)
|
||
|
self.state = 54
|
||
|
self.match(ArmControlParser.T__4)
|
||
|
pass
|
||
|
else:
|
||
|
raise NoViableAltException(self)
|
||
|
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class CoordsContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def value(self, i:int=None):
|
||
|
if i is None:
|
||
|
return self.getTypedRuleContexts(ArmControlParser.ValueContext)
|
||
|
else:
|
||
|
return self.getTypedRuleContext(ArmControlParser.ValueContext,i)
|
||
|
|
||
|
|
||
|
def seperator(self, i:int=None):
|
||
|
if i is None:
|
||
|
return self.getTypedRuleContexts(ArmControlParser.SeperatorContext)
|
||
|
else:
|
||
|
return self.getTypedRuleContext(ArmControlParser.SeperatorContext,i)
|
||
|
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_coords
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterCoords" ):
|
||
|
listener.enterCoords(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitCoords" ):
|
||
|
listener.exitCoords(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def coords(self):
|
||
|
|
||
|
localctx = ArmControlParser.CoordsContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 6, self.RULE_coords)
|
||
|
self._la = 0 # Token type
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 57
|
||
|
self.match(ArmControlParser.T__5)
|
||
|
self.state = 59
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
if _la==ArmControlParser.NUMBER or _la==ArmControlParser.HEX:
|
||
|
self.state = 58
|
||
|
self.value()
|
||
|
|
||
|
|
||
|
self.state = 67
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
while _la==ArmControlParser.SEPERATOR:
|
||
|
self.state = 61
|
||
|
self.seperator()
|
||
|
self.state = 63
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
if _la==ArmControlParser.NUMBER or _la==ArmControlParser.HEX:
|
||
|
self.state = 62
|
||
|
self.value()
|
||
|
|
||
|
|
||
|
self.state = 69
|
||
|
self._errHandler.sync(self)
|
||
|
_la = self._input.LA(1)
|
||
|
|
||
|
self.state = 70
|
||
|
self.match(ArmControlParser.T__6)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class NameContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def NAME(self):
|
||
|
return self.getToken(ArmControlParser.NAME, 0)
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_name
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterName" ):
|
||
|
listener.enterName(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitName" ):
|
||
|
listener.exitName(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def name(self):
|
||
|
|
||
|
localctx = ArmControlParser.NameContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 8, self.RULE_name)
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 72
|
||
|
self.match(ArmControlParser.NAME)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class ValueContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def number(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.NumberContext,0)
|
||
|
|
||
|
|
||
|
def hexidecimal(self):
|
||
|
return self.getTypedRuleContext(ArmControlParser.HexidecimalContext,0)
|
||
|
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_value
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterValue" ):
|
||
|
listener.enterValue(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitValue" ):
|
||
|
listener.exitValue(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def value(self):
|
||
|
|
||
|
localctx = ArmControlParser.ValueContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 10, self.RULE_value)
|
||
|
try:
|
||
|
self.state = 76
|
||
|
self._errHandler.sync(self)
|
||
|
token = self._input.LA(1)
|
||
|
if token in [ArmControlParser.NUMBER]:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 74
|
||
|
self.number()
|
||
|
pass
|
||
|
elif token in [ArmControlParser.HEX]:
|
||
|
self.enterOuterAlt(localctx, 2)
|
||
|
self.state = 75
|
||
|
self.hexidecimal()
|
||
|
pass
|
||
|
else:
|
||
|
raise NoViableAltException(self)
|
||
|
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class NumberContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def NUMBER(self):
|
||
|
return self.getToken(ArmControlParser.NUMBER, 0)
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_number
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterNumber" ):
|
||
|
listener.enterNumber(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitNumber" ):
|
||
|
listener.exitNumber(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def number(self):
|
||
|
|
||
|
localctx = ArmControlParser.NumberContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 12, self.RULE_number)
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 78
|
||
|
self.match(ArmControlParser.NUMBER)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class HexidecimalContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def HEX(self):
|
||
|
return self.getToken(ArmControlParser.HEX, 0)
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_hexidecimal
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterHexidecimal" ):
|
||
|
listener.enterHexidecimal(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitHexidecimal" ):
|
||
|
listener.exitHexidecimal(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def hexidecimal(self):
|
||
|
|
||
|
localctx = ArmControlParser.HexidecimalContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 14, self.RULE_hexidecimal)
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 80
|
||
|
self.match(ArmControlParser.HEX)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
class SeperatorContext(ParserRuleContext):
|
||
|
|
||
|
def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1):
|
||
|
super().__init__(parent, invokingState)
|
||
|
self.parser = parser
|
||
|
|
||
|
def SEPERATOR(self):
|
||
|
return self.getToken(ArmControlParser.SEPERATOR, 0)
|
||
|
|
||
|
def getRuleIndex(self):
|
||
|
return ArmControlParser.RULE_seperator
|
||
|
|
||
|
def enterRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "enterSeperator" ):
|
||
|
listener.enterSeperator(self)
|
||
|
|
||
|
def exitRule(self, listener:ParseTreeListener):
|
||
|
if hasattr( listener, "exitSeperator" ):
|
||
|
listener.exitSeperator(self)
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
def seperator(self):
|
||
|
|
||
|
localctx = ArmControlParser.SeperatorContext(self, self._ctx, self.state)
|
||
|
self.enterRule(localctx, 16, self.RULE_seperator)
|
||
|
try:
|
||
|
self.enterOuterAlt(localctx, 1)
|
||
|
self.state = 82
|
||
|
self.match(ArmControlParser.SEPERATOR)
|
||
|
except RecognitionException as re:
|
||
|
localctx.exception = re
|
||
|
self._errHandler.reportError(self, re)
|
||
|
self._errHandler.recover(self, re)
|
||
|
finally:
|
||
|
self.exitRule()
|
||
|
return localctx
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|