3 // Copyright (C) 1999 Allen Akin All Rights Reserved.
5 // Permission is hereby granted, free of charge, to any person
6 // obtaining a copy of this software and associated documentation
7 // files (the "Software"), to deal in the Software without
8 // restriction, including without limitation the rights to use,
9 // copy, modify, merge, publish, distribute, sublicense, and/or
10 // sell copies of the Software, and to permit persons to whom the
11 // Software is furnished to do so, subject to the following
14 // The above copyright notice and this permission notice shall be
15 // included in all copies or substantial portions of the
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
19 // KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
20 // WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
21 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL ALLEN AKIN BE
22 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
23 // AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
24 // OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25 // DEALINGS IN THE SOFTWARE.
32 // lex.h: Simple lexical analysis utilities
34 // Given a string containing C-style tokens, returns information about
35 // successive tokens. Doesn't support all C tokens; just the few that
45 // ERROR is already defined in some windows header file
63 Lex(const char* s
, bool ignoreCase
= false);
64 // Creates a lexer which will draw input from the given string.
68 struct Error
{ }; // Base class for errors.
69 struct Lexical
: public Error
{ // Lexical error in string.
72 Lexical(const char* e
, int p
) {
77 struct InternalError
: public Error
{ // Shouldn't happen.
83 ERROR
= 0, // erroneous token; must be zero
108 ICONST
, // signed integer constant
115 void next(); // fetch next token
117 Token token
; // current token
118 std::string id
; // most recent identifier
119 int iValue
; // most recent signed integer value
121 inline int position() { // current position in input string