/** \file * This OBJC source file was generated by $ANTLR version 3.2 Aug 24, 2010 10:45:57 * * - From the grammar source file : Combined.g * - On : 2010-08-24 13:53:42 * - for the lexer : CombinedLexerLexer * * Editing it, at least manually, is not wise. * * ObjC language generator and runtime by Alan Condit, acondit|hereisanat|ipns|dotgoeshere|com. * * */ // [The "BSD licence"] // Copyright (c) 2010 Alan Condit // // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions // are met: // 1. Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // 2. Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // 3. The name of the author may not be used to endorse or promote products // derived from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR // IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES // OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. // IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT // NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // $ANTLR 3.2 Aug 24, 2010 10:45:57 Combined.g 2010-08-24 13:53:42 /* ----------------------------------------- * Include the ANTLR3 generated header file. */ #import "CombinedLexer.h" /* ----------------------------------------- */ /* ============================================================================= */ /* ============================================================================= * Start of recognizer */ /** As per Terence: No returns for lexer rules! */ @implementation CombinedLexer // line 330 + (void) initialize { [ANTLRBaseRecognizer setGrammarFileName:@"Combined.g"]; } + (NSString *) tokenNameForType:(NSInteger)aTokenType { return [[self getTokenNames] objectAtIndex:aTokenType]; } + (CombinedLexer *)newCombinedLexerWithCharStream:(id<ANTLRCharStream>)anInput { return [[CombinedLexer alloc] initWithCharStream:anInput]; } - (id) initWithCharStream:(id<ANTLRCharStream>)anInput { if ((self = [super initWithCharStream:anInput State:[ANTLRRecognizerSharedState newANTLRRecognizerSharedStateWithRuleLen:4+1]]) != nil) { } return self; } - (void) dealloc { [super dealloc]; } /* Start of actions.lexer.methods */ /* start methods() */ /* Start of Rules */ // $ANTLR start "ID" - (void) mID { // /* ruleScopeSetUp */ @try { NSInteger _type = ID; NSInteger _channel = ANTLRTokenChannelDefault; // Combined.g:14:5: ( ( 'a' .. 'z' | 'A' .. 'Z' | '_' ) ( 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' )* ) // ruleBlockSingleAlt // Combined.g:14:9: ( '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 exceptionWithSet:nil stream:input]; [self recover:mse]; @throw mse;} /* element() */ 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 : ; // Combined.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 exceptionWithSet:nil stream:input]; [self recover:mse]; @throw mse;} /* element() */ /* elements */ } break; default : goto loop1; } } while (YES); loop1: ; /* element() */ /* elements */ } // token+rule list labels [state setType:_type]; state.channel = _channel; } @finally { // } return; } // $ANTLR end "ID" // $ANTLR start "INT" - (void) mINT { // /* ruleScopeSetUp */ @try { NSInteger _type = INT; NSInteger _channel = ANTLRTokenChannelDefault; // Combined.g:17:5: ( ( '0' .. '9' )+ ) // ruleBlockSingleAlt // Combined.g:17:9: ( '0' .. '9' )+ // alt { // Combined.g:17:9: ( '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 : ; // Combined.g:17:10: '0' .. '9' // alt { [self matchRangeFromChar:'0' to:'9']; /* element() */ /* elements */ } break; default : if ( cnt2 >= 1 ) goto loop2; ANTLREarlyExitException *eee = [ANTLREarlyExitException exceptionWithStream:input decisionNumber:2]; @throw eee; } cnt2++; } while (YES); loop2: ; /* element() */ /* elements */ } // token+rule list labels [state setType:_type]; state.channel = _channel; } @finally { // } return; } // $ANTLR end "INT" // $ANTLR start "WS" - (void) mWS { // /* ruleScopeSetUp */ @try { NSInteger _type = WS; NSInteger _channel = ANTLRTokenChannelDefault; // Combined.g:20:5: ( ( ' ' | '\\t' | '\\r' | '\\n' )+ ) // ruleBlockSingleAlt // Combined.g:20:9: ( ' ' | '\\t' | '\\r' | '\\n' )+ // alt { // Combined.g:20: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 : ; // Combined.g: // alt { if ((([input LA:1] >= '\t') && ([input LA:1] <= '\n'))||[input LA:1] == '\r'||[input LA:1] == ' ') { [input consume]; } else { ANTLRMismatchedSetException *mse = [ANTLRMismatchedSetException exceptionWithSet:nil stream:input]; [self recover:mse]; @throw mse;} /* element() */ /* elements */ } break; default : if ( cnt3 >= 1 ) goto loop3; ANTLREarlyExitException *eee = [ANTLREarlyExitException exceptionWithStream:input decisionNumber:3]; @throw eee; } cnt3++; } while (YES); loop3: ; /* element() */ _channel=99; /* element() */ /* elements */ } // token+rule list labels [state setType:_type]; state.channel = _channel; } @finally { // } return; } // $ANTLR end "WS" - (void) mTokens { // Combined.g:1:8: ( ID | INT | WS ) //ruleblock NSInteger alt4=3; switch ([input LA:1]) { 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 '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': ; { alt4=1; } break; case '0': ; case '1': ; case '2': ; case '3': ; case '4': ; case '5': ; case '6': ; case '7': ; case '8': ; case '9': ; { alt4=2; } break; case '\t': ; case '\n': ; case '\r': ; case ' ': ; { alt4=3; } break; default: ; ANTLRNoViableAltException *nvae = [ANTLRNoViableAltException newANTLRNoViableAltException:4 state:0 stream:input]; @throw nvae; } switch (alt4) { case 1 : ; // Combined.g:1:10: ID // alt { [self mID]; /* element() */ /* elements */ } break; case 2 : ; // Combined.g:1:13: INT // alt { [self mINT]; /* element() */ /* elements */ } break; case 3 : ; // Combined.g:1:17: WS // alt { [self mWS]; /* element() */ /* elements */ } break; } } @end /* end of CombinedLexer implementation line 397 */ /* End of code * ============================================================================= */