blob: 0d9d31ac637cf292dc369bf42d5187447990c3da [file] [log] [blame]
/** \file
* This OBJC source file was generated by $ANTLR version ${project.version} ${buildNumber}
*
* - From the grammar source file : TreeRewrite.g
* - On : 2011-05-06 18:56:28
* - for the lexer : TreeRewriteLexerLexer
*
* Editing it, at least manually, is not wise.
*
* ObjC language generator and runtime by Alan Condit, acondit|hereisanat|ipns|dotgoeshere|com.
*
*
*/
// $ANTLR ${project.version} ${buildNumber} TreeRewrite.g 2011-05-06 18:56:28
/* -----------------------------------------
* Include the ANTLR3 generated header file.
*/
#import "TreeRewriteLexer.h"
/* ----------------------------------------- */
/* ============================================================================= */
/* =============================================================================
* Start of recognizer
*/
/** As per Terence: No returns for lexer rules! */
@implementation TreeRewriteLexer // line 330
+ (void) initialize
{
[ANTLRBaseRecognizer setGrammarFileName:@"TreeRewrite.g"];
}
+ (NSString *) tokenNameForType:(NSInteger)aTokenType
{
return [[self getTokenNames] objectAtIndex:aTokenType];
}
+ (TreeRewriteLexer *)newTreeRewriteLexerWithCharStream:(id<ANTLRCharStream>)anInput
{
return [[TreeRewriteLexer alloc] initWithCharStream:anInput];
}
- (id) initWithCharStream:(id<ANTLRCharStream>)anInput
{
self = [super initWithCharStream:anInput State:[[ANTLRRecognizerSharedState newANTLRRecognizerSharedStateWithRuleLen:3+1] retain]];
if ( self != nil ) {
}
return self;
}
- (void) dealloc
{
[super dealloc];
}
/* ObjC Start of actions.lexer.methods */
/* ObjC end of actions.lexer.methods */
/* ObjC start methods() */
/* ObjC end methods() */
/* Start of Rules */
// $ANTLR start "INT"
- (void) mINT
{
//
/* my ruleScopeSetUp */
/* Terence's stuff */
@try {
NSInteger _type = INT;
NSInteger _channel = ANTLRTokenChannelDefault;
// TreeRewrite.g:15:5: ( ( '0' .. '9' )+ ) // ruleBlockSingleAlt
// TreeRewrite.g:15:7: ( '0' .. '9' )+ // alt
{
// TreeRewrite.g:15:7: ( '0' .. '9' )+ // positiveClosureBlock
NSInteger cnt1 = 0;
do {
NSInteger alt1 = 2;
NSInteger LA1_0 = [input LA:1];
if ( ((LA1_0 >= '0' && LA1_0 <= '9')) ) {
alt1=1;
}
switch (alt1) {
case 1 : ;
// TreeRewrite.g: // alt
{
if ((([input LA:1] >= '0') && ([input LA:1] <= '9'))) {
[input consume];
} else {
ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException newException:nil stream:input];
[self recover:mse];
@throw mse;
}
}
break;
default :
if ( cnt1 >= 1 )
goto loop1;
ANTLREarlyExitException *eee =
[ANTLREarlyExitException newException:input decisionNumber:1];
@throw eee;
}
cnt1++;
} while (YES);
loop1: ;
}
// token+rule list labels
state.type = _type;
state.channel = _channel;
}
@finally {
//
/* Terence's stuff */
}
return;
}
/* $ANTLR end "INT" */
// $ANTLR start "WS"
- (void) mWS
{
//
/* my ruleScopeSetUp */
/* Terence's stuff */
@try {
NSInteger _type = WS;
NSInteger _channel = ANTLRTokenChannelDefault;
// TreeRewrite.g:18:5: ( ' ' ) // ruleBlockSingleAlt
// TreeRewrite.g:18:9: ' ' // alt
{
[self matchChar:' '];
_channel=HIDDEN;
}
// token+rule list labels
state.type = _type;
state.channel = _channel;
}
@finally {
//
/* Terence's stuff */
}
return;
}
/* $ANTLR end "WS" */
- (void) mTokens
{
// TreeRewrite.g:1:8: ( INT | WS ) //ruleblock
NSInteger alt2=2;
NSInteger LA2_0 = [input LA:1];
if ( ((LA2_0 >= '0' && LA2_0 <= '9')) ) {
alt2=1;
}
else if ( (LA2_0==' ') ) {
alt2=2;
}
else {
ANTLRNoViableAltException *nvae = [ANTLRNoViableAltException newException:2 state:0 stream:input];
nvae.c = LA2_0;
@throw nvae;
}
switch (alt2) {
case 1 : ;
// TreeRewrite.g:1:10: INT // alt
{
[self mINT];
}
break;
case 2 : ;
// TreeRewrite.g:1:14: WS // alt
{
[self mWS];
}
break;
}
}
@end /* end of TreeRewriteLexer implementation line 397 */