| /** \file |
| * This OBJC source file was generated by $ANTLR version ${project.version} ${buildNumber} |
| * |
| * - From the grammar source file : SimpleC.g |
| * - On : 2011-05-06 15:09:17 |
| * - for the lexer : SimpleCLexerLexer |
| * |
| * 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} SimpleC.g 2011-05-06 15:09:17 |
| |
| |
| /* ----------------------------------------- |
| * Include the ANTLR3 generated header file. |
| */ |
| #import "SimpleCLexer.h" |
| /* ----------------------------------------- */ |
| |
| |
| /* ============================================================================= */ |
| /* ============================================================================= |
| * Start of recognizer |
| */ |
| |
| /** As per Terence: No returns for lexer rules! */ |
| @implementation SimpleCLexer // line 330 |
| |
| + (void) initialize |
| { |
| [ANTLRBaseRecognizer setGrammarFileName:@"SimpleC.g"]; |
| } |
| |
| + (NSString *) tokenNameForType:(NSInteger)aTokenType |
| { |
| return [[self getTokenNames] objectAtIndex:aTokenType]; |
| } |
| |
| + (SimpleCLexer *)newSimpleCLexerWithCharStream:(id<ANTLRCharStream>)anInput |
| { |
| return [[SimpleCLexer alloc] initWithCharStream:anInput]; |
| } |
| |
| - (id) initWithCharStream:(id<ANTLRCharStream>)anInput |
| { |
| self = [super initWithCharStream:anInput State:[[ANTLRRecognizerSharedState newANTLRRecognizerSharedStateWithRuleLen:18+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 "K_FOR" |
| - (void) mK_FOR |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_FOR; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:91:7: ( 'for' ) // ruleBlockSingleAlt |
| // SimpleC.g:91:9: 'for' // alt |
| { |
| [self matchString:@"for"]; |
| |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_FOR" */ |
| |
| // $ANTLR start "K_CHAR" |
| - (void) mK_CHAR |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_CHAR; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:92:7: ( 'char' ) // ruleBlockSingleAlt |
| // SimpleC.g:92:9: 'char' // alt |
| { |
| [self matchString:@"char"]; |
| |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_CHAR" */ |
| |
| // $ANTLR start "K_INT_TYPE" |
| - (void) mK_INT_TYPE |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_INT_TYPE; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:93:12: ( 'int' ) // ruleBlockSingleAlt |
| // SimpleC.g:93:14: 'int' // alt |
| { |
| [self matchString:@"int"]; |
| |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_INT_TYPE" */ |
| |
| // $ANTLR start "K_VOID" |
| - (void) mK_VOID |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_VOID; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:94:7: ( 'void' ) // ruleBlockSingleAlt |
| // SimpleC.g:94:9: 'void' // alt |
| { |
| [self matchString:@"void"]; |
| |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_VOID" */ |
| |
| // $ANTLR start "K_ID" |
| - (void) mK_ID |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_ID; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:96:7: ( ( 'a' .. 'z' | 'A' .. 'Z' | '_' ) ( 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' )* ) // ruleBlockSingleAlt |
| // SimpleC.g:96:11: ( 'a' .. 'z' | 'A' .. 'Z' | '_' ) ( 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' )* // alt |
| { |
| if ((([input LA:1] >= 'A') && ([input LA:1] <= 'Z'))||[input LA:1] == '_'||(([input LA:1] >= 'a') && ([input LA:1] <= 'z'))) { |
| [input consume]; |
| } else { |
| ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException newException:nil stream:input]; |
| [self recover:mse]; |
| @throw mse; |
| } |
| |
| |
| do { |
| NSInteger alt1=2; |
| NSInteger LA1_0 = [input LA:1]; |
| if ( ((LA1_0 >= '0' && LA1_0 <= '9')||(LA1_0 >= 'A' && LA1_0 <= 'Z')||LA1_0=='_'||(LA1_0 >= 'a' && LA1_0 <= 'z')) ) { |
| alt1=1; |
| } |
| |
| |
| switch (alt1) { |
| case 1 : ; |
| // SimpleC.g: // alt |
| { |
| if ((([input LA:1] >= '0') && ([input LA:1] <= '9'))||(([input LA:1] >= 'A') && ([input LA:1] <= 'Z'))||[input LA:1] == '_'||(([input LA:1] >= 'a') && ([input LA:1] <= 'z'))) { |
| [input consume]; |
| } else { |
| ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException newException:nil stream:input]; |
| [self recover:mse]; |
| @throw mse; |
| } |
| |
| |
| } |
| break; |
| |
| default : |
| goto loop1; |
| } |
| } while (YES); |
| loop1: ; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_ID" */ |
| |
| // $ANTLR start "K_INT" |
| - (void) mK_INT |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_INT; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| ANTLRCommonToken *anInt=nil; |
| AMutableArray *list_anInt=nil; |
| // SimpleC.g:99:7: ( (anInt+= ( '0' .. '9' ) )+ ) // ruleBlockSingleAlt |
| // SimpleC.g:99:9: (anInt+= ( '0' .. '9' ) )+ // alt |
| { |
| // SimpleC.g:99:14: (anInt+= ( '0' .. '9' ) )+ // positiveClosureBlock |
| NSInteger cnt2 = 0; |
| do { |
| NSInteger alt2 = 2; |
| NSInteger LA2_0 = [input LA:1]; |
| if ( ((LA2_0 >= '0' && LA2_0 <= '9')) ) { |
| alt2=1; |
| } |
| |
| |
| switch (alt2) { |
| case 1 : ; |
| // SimpleC.g:99:14: anInt+= ( '0' .. '9' ) // alt |
| { |
| anInt = [input LA:1]; |
| |
| if ((([input LA:1] >= '0') && ([input LA:1] <= '9'))) { |
| [input consume]; |
| } else { |
| ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException newException:nil stream:input]; |
| mse.c = anInt; |
| [self recover:mse]; |
| @throw mse; |
| } |
| |
| |
| } |
| break; |
| |
| default : |
| if ( cnt2 >= 1 ) |
| goto loop2; |
| ANTLREarlyExitException *eee = |
| [ANTLREarlyExitException newException:input decisionNumber:2]; |
| @throw eee; |
| } |
| cnt2++; |
| } while (YES); |
| loop2: ; |
| |
| |
| NSLog(@"%@", list_anInt); |
| |
| |
| } |
| |
| // token+rule list labels |
| [list_anInt release]; |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_INT" */ |
| |
| // $ANTLR start "K_LCURVE" |
| - (void) mK_LCURVE |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_LCURVE; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:102:10: ( '(' ) // ruleBlockSingleAlt |
| // SimpleC.g:102:12: '(' // alt |
| { |
| [self matchChar:'(']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_LCURVE" */ |
| |
| // $ANTLR start "K_RCURVE" |
| - (void) mK_RCURVE |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_RCURVE; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:103:10: ( ')' ) // ruleBlockSingleAlt |
| // SimpleC.g:103:12: ')' // alt |
| { |
| [self matchChar:')']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_RCURVE" */ |
| |
| // $ANTLR start "K_PLUS" |
| - (void) mK_PLUS |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_PLUS; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:104:8: ( '+' ) // ruleBlockSingleAlt |
| // SimpleC.g:104:10: '+' // alt |
| { |
| [self matchChar:'+']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_PLUS" */ |
| |
| // $ANTLR start "K_COMMA" |
| - (void) mK_COMMA |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_COMMA; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:105:9: ( ',' ) // ruleBlockSingleAlt |
| // SimpleC.g:105:11: ',' // alt |
| { |
| [self matchChar:',']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_COMMA" */ |
| |
| // $ANTLR start "K_SEMICOLON" |
| - (void) mK_SEMICOLON |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_SEMICOLON; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:106:13: ( ';' ) // ruleBlockSingleAlt |
| // SimpleC.g:106:15: ';' // alt |
| { |
| [self matchChar:';']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_SEMICOLON" */ |
| |
| // $ANTLR start "K_LT" |
| - (void) mK_LT |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_LT; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:107:8: ( '<' ) // ruleBlockSingleAlt |
| // SimpleC.g:107:10: '<' // alt |
| { |
| [self matchChar:'<']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_LT" */ |
| |
| // $ANTLR start "K_EQ" |
| - (void) mK_EQ |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_EQ; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:108:8: ( '=' ) // ruleBlockSingleAlt |
| // SimpleC.g:108:10: '=' // alt |
| { |
| [self matchChar:'=']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_EQ" */ |
| |
| // $ANTLR start "K_EQEQ" |
| - (void) mK_EQEQ |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_EQEQ; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:109:8: ( '==' ) // ruleBlockSingleAlt |
| // SimpleC.g:109:10: '==' // alt |
| { |
| [self matchString:@"=="]; |
| |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_EQEQ" */ |
| |
| // $ANTLR start "K_LCURLY" |
| - (void) mK_LCURLY |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_LCURLY; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:110:10: ( '{' ) // ruleBlockSingleAlt |
| // SimpleC.g:110:12: '{' // alt |
| { |
| [self matchChar:'{']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_LCURLY" */ |
| |
| // $ANTLR start "K_RCURLY" |
| - (void) mK_RCURLY |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = K_RCURLY; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:111:10: ( '}' ) // ruleBlockSingleAlt |
| // SimpleC.g:111:12: '}' // alt |
| { |
| [self matchChar:'}']; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "K_RCURLY" */ |
| |
| // $ANTLR start "WS" |
| - (void) mWS |
| { |
| // |
| /* my ruleScopeSetUp */ |
| /* Terence's stuff */ |
| |
| @try { |
| NSInteger _type = WS; |
| NSInteger _channel = ANTLRTokenChannelDefault; |
| // SimpleC.g:113:5: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ ) // ruleBlockSingleAlt |
| // SimpleC.g:113:9: ( ' ' | '\\t' | '\\r' | '\\n' )+ // alt |
| { |
| // SimpleC.g:113:9: ( ' ' | '\\t' | '\\r' | '\\n' )+ // positiveClosureBlock |
| NSInteger cnt3 = 0; |
| do { |
| NSInteger alt3 = 2; |
| NSInteger LA3_0 = [input LA:1]; |
| if ( ((LA3_0 >= '\t' && LA3_0 <= '\n')||LA3_0=='\r'||LA3_0==' ') ) { |
| alt3=1; |
| } |
| |
| |
| switch (alt3) { |
| case 1 : ; |
| // SimpleC.g: // alt |
| { |
| if ((([input LA:1] >= '\t') && ([input LA:1] <= '\n'))||[input LA:1] == '\r'||[input LA:1] == ' ') { |
| [input consume]; |
| } else { |
| ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException newException:nil stream:input]; |
| [self recover:mse]; |
| @throw mse; |
| } |
| |
| |
| } |
| break; |
| |
| default : |
| if ( cnt3 >= 1 ) |
| goto loop3; |
| ANTLREarlyExitException *eee = |
| [ANTLREarlyExitException newException:input decisionNumber:3]; |
| @throw eee; |
| } |
| cnt3++; |
| } while (YES); |
| loop3: ; |
| |
| |
| _channel=HIDDEN; |
| |
| |
| } |
| |
| // token+rule list labels |
| |
| state.type = _type; |
| state.channel = _channel; |
| } |
| @finally { |
| // |
| /* Terence's stuff */ |
| |
| } |
| return; |
| } |
| /* $ANTLR end "WS" */ |
| |
| - (void) mTokens |
| { |
| // SimpleC.g:1:8: ( K_FOR | K_CHAR | K_INT_TYPE | K_VOID | K_ID | K_INT | K_LCURVE | K_RCURVE | K_PLUS | K_COMMA | K_SEMICOLON | K_LT | K_EQ | K_EQEQ | K_LCURLY | K_RCURLY | WS ) //ruleblock |
| NSInteger alt4=17; |
| unichar charLA4 = [input LA:1]; |
| switch (charLA4) { |
| case 'f': ; |
| { |
| NSInteger LA4_1 = [input LA:2]; |
| |
| if ( (LA4_1=='o') ) { |
| NSInteger LA4_17 = [input LA:3]; |
| |
| if ( (LA4_17=='r') ) { |
| NSInteger LA4_23 = [input LA:4]; |
| |
| if ( ((LA4_23 >= '0' && LA4_23 <= '9')||(LA4_23 >= 'A' && LA4_23 <= 'Z')||LA4_23=='_'||(LA4_23 >= 'a' && LA4_23 <= 'z')) ) { |
| alt4=5; |
| } |
| else { |
| alt4 = 1; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| break; |
| case 'c': ; |
| { |
| NSInteger LA4_2 = [input LA:2]; |
| |
| if ( (LA4_2=='h') ) { |
| NSInteger LA4_18 = [input LA:3]; |
| |
| if ( (LA4_18=='a') ) { |
| NSInteger LA4_24 = [input LA:4]; |
| |
| if ( (LA4_24=='r') ) { |
| NSInteger LA4_28 = [input LA:5]; |
| |
| if ( ((LA4_28 >= '0' && LA4_28 <= '9')||(LA4_28 >= 'A' && LA4_28 <= 'Z')||LA4_28=='_'||(LA4_28 >= 'a' && LA4_28 <= 'z')) ) { |
| alt4=5; |
| } |
| else { |
| alt4 = 2; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| break; |
| case 'i': ; |
| { |
| NSInteger LA4_3 = [input LA:2]; |
| |
| if ( (LA4_3=='n') ) { |
| NSInteger LA4_19 = [input LA:3]; |
| |
| if ( (LA4_19=='t') ) { |
| NSInteger LA4_25 = [input LA:4]; |
| |
| if ( ((LA4_25 >= '0' && LA4_25 <= '9')||(LA4_25 >= 'A' && LA4_25 <= 'Z')||LA4_25=='_'||(LA4_25 >= 'a' && LA4_25 <= 'z')) ) { |
| alt4=5; |
| } |
| else { |
| alt4 = 3; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| break; |
| case 'v': ; |
| { |
| NSInteger LA4_4 = [input LA:2]; |
| |
| if ( (LA4_4=='o') ) { |
| NSInteger LA4_20 = [input LA:3]; |
| |
| if ( (LA4_20=='i') ) { |
| NSInteger LA4_26 = [input LA:4]; |
| |
| if ( (LA4_26=='d') ) { |
| NSInteger LA4_30 = [input LA:5]; |
| |
| if ( ((LA4_30 >= '0' && LA4_30 <= '9')||(LA4_30 >= 'A' && LA4_30 <= 'Z')||LA4_30=='_'||(LA4_30 >= 'a' && LA4_30 <= 'z')) ) { |
| alt4=5; |
| } |
| else { |
| alt4 = 4; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| else { |
| alt4 = 5; |
| } |
| } |
| break; |
| case 'A': ; |
| case 'B': ; |
| case 'C': ; |
| case 'D': ; |
| case 'E': ; |
| case 'F': ; |
| case 'G': ; |
| case 'H': ; |
| case 'I': ; |
| case 'J': ; |
| case 'K': ; |
| case 'L': ; |
| case 'M': ; |
| case 'N': ; |
| case 'O': ; |
| case 'P': ; |
| case 'Q': ; |
| case 'R': ; |
| case 'S': ; |
| case 'T': ; |
| case 'U': ; |
| case 'V': ; |
| case 'W': ; |
| case 'X': ; |
| case 'Y': ; |
| case 'Z': ; |
| case '_': ; |
| case 'a': ; |
| case 'b': ; |
| case 'd': ; |
| case 'e': ; |
| case 'g': ; |
| case 'h': ; |
| case 'j': ; |
| case 'k': ; |
| case 'l': ; |
| case 'm': ; |
| case 'n': ; |
| case 'o': ; |
| case 'p': ; |
| case 'q': ; |
| case 'r': ; |
| case 's': ; |
| case 't': ; |
| case 'u': ; |
| case 'w': ; |
| case 'x': ; |
| case 'y': ; |
| case 'z': ; |
| { |
| alt4=5; |
| } |
| break; |
| case '0': ; |
| case '1': ; |
| case '2': ; |
| case '3': ; |
| case '4': ; |
| case '5': ; |
| case '6': ; |
| case '7': ; |
| case '8': ; |
| case '9': ; |
| { |
| alt4=6; |
| } |
| break; |
| case '(': ; |
| { |
| alt4=7; |
| } |
| break; |
| case ')': ; |
| { |
| alt4=8; |
| } |
| break; |
| case '+': ; |
| { |
| alt4=9; |
| } |
| break; |
| case ',': ; |
| { |
| alt4=10; |
| } |
| break; |
| case ';': ; |
| { |
| alt4=11; |
| } |
| break; |
| case '<': ; |
| { |
| alt4=12; |
| } |
| break; |
| case '=': ; |
| { |
| NSInteger LA4_13 = [input LA:2]; |
| |
| if ( (LA4_13=='=') ) { |
| alt4=14; |
| } |
| else { |
| alt4 = 13; |
| } |
| } |
| break; |
| case '{': ; |
| { |
| alt4=15; |
| } |
| break; |
| case '}': ; |
| { |
| alt4=16; |
| } |
| break; |
| case '\t': ; |
| case '\n': ; |
| case '\r': ; |
| case ' ': ; |
| { |
| alt4=17; |
| } |
| break; |
| |
| default: ; |
| ANTLRNoViableAltException *nvae = [ANTLRNoViableAltException newException:4 state:0 stream:input]; |
| nvae.c = charLA4; |
| @throw nvae; |
| |
| } |
| |
| switch (alt4) { |
| case 1 : ; |
| // SimpleC.g:1:10: K_FOR // alt |
| { |
| [self mK_FOR]; |
| |
| |
| |
| } |
| break; |
| case 2 : ; |
| // SimpleC.g:1:16: K_CHAR // alt |
| { |
| [self mK_CHAR]; |
| |
| |
| |
| } |
| break; |
| case 3 : ; |
| // SimpleC.g:1:23: K_INT_TYPE // alt |
| { |
| [self mK_INT_TYPE]; |
| |
| |
| |
| } |
| break; |
| case 4 : ; |
| // SimpleC.g:1:34: K_VOID // alt |
| { |
| [self mK_VOID]; |
| |
| |
| |
| } |
| break; |
| case 5 : ; |
| // SimpleC.g:1:41: K_ID // alt |
| { |
| [self mK_ID]; |
| |
| |
| |
| } |
| break; |
| case 6 : ; |
| // SimpleC.g:1:46: K_INT // alt |
| { |
| [self mK_INT]; |
| |
| |
| |
| } |
| break; |
| case 7 : ; |
| // SimpleC.g:1:52: K_LCURVE // alt |
| { |
| [self mK_LCURVE]; |
| |
| |
| |
| } |
| break; |
| case 8 : ; |
| // SimpleC.g:1:61: K_RCURVE // alt |
| { |
| [self mK_RCURVE]; |
| |
| |
| |
| } |
| break; |
| case 9 : ; |
| // SimpleC.g:1:70: K_PLUS // alt |
| { |
| [self mK_PLUS]; |
| |
| |
| |
| } |
| break; |
| case 10 : ; |
| // SimpleC.g:1:77: K_COMMA // alt |
| { |
| [self mK_COMMA]; |
| |
| |
| |
| } |
| break; |
| case 11 : ; |
| // SimpleC.g:1:85: K_SEMICOLON // alt |
| { |
| [self mK_SEMICOLON]; |
| |
| |
| |
| } |
| break; |
| case 12 : ; |
| // SimpleC.g:1:97: K_LT // alt |
| { |
| [self mK_LT]; |
| |
| |
| |
| } |
| break; |
| case 13 : ; |
| // SimpleC.g:1:102: K_EQ // alt |
| { |
| [self mK_EQ]; |
| |
| |
| |
| } |
| break; |
| case 14 : ; |
| // SimpleC.g:1:107: K_EQEQ // alt |
| { |
| [self mK_EQEQ]; |
| |
| |
| |
| } |
| break; |
| case 15 : ; |
| // SimpleC.g:1:114: K_LCURLY // alt |
| { |
| [self mK_LCURLY]; |
| |
| |
| |
| } |
| break; |
| case 16 : ; |
| // SimpleC.g:1:123: K_RCURLY // alt |
| { |
| [self mK_RCURLY]; |
| |
| |
| |
| } |
| break; |
| case 17 : ; |
| // SimpleC.g:1:132: WS // alt |
| { |
| [self mWS]; |
| |
| |
| |
| } |
| break; |
| |
| } |
| |
| } |
| |
| @end /* end of SimpleCLexer implementation line 397 */ |