casa
$Rev:20696$
|
00001 // -*-C++-*- 00002 // FlexLexer.h -- define interfaces for lexical analyzer classes generated 00003 // by flex 00004 00005 // Copyright (c) 1993 The Regents of the University of California. 00006 // All rights reserved. 00007 // 00008 // This code is derived from software contributed to Berkeley by 00009 // Kent Williams and Tom Epperly. 00010 // 00011 // Redistribution and use in source and binary forms, with or without 00012 // modification, are permitted provided that the following conditions 00013 // are met: 00014 00015 // 1. Redistributions of source code must retain the above copyright 00016 // notice, this list of conditions and the following disclaimer. 00017 // 2. Redistributions in binary form must reproduce the above copyright 00018 // notice, this list of conditions and the following disclaimer in the 00019 // documentation and/or other materials provided with the distribution. 00020 00021 // Neither the name of the University nor the names of its contributors 00022 // may be used to endorse or promote products derived from this software 00023 // without specific prior written permission. 00024 00025 // THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR 00026 // IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED 00027 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00028 // PURPOSE. 00029 00030 // This file defines FlexLexer, an abstract class which specifies the 00031 // external interface provided to flex C++ lexer objects, and yyFlexLexer, 00032 // which defines a particular lexer class. 00033 // 00034 // If you want to create multiple lexer classes, you use the -P flag 00035 // to rename each yyFlexLexer to some other xxFlexLexer. You then 00036 // include <FlexLexer.h> in your other sources once per lexer class: 00037 // 00038 // #undef yyFlexLexer 00039 // #define yyFlexLexer xxFlexLexer 00040 // #include <FlexLexer.h> 00041 // 00042 // #undef yyFlexLexer 00043 // #define yyFlexLexer zzFlexLexer 00044 // #include <FlexLexer.h> 00045 // ... 00046 00047 #ifndef __FLEX_LEXER_H 00048 // Never included before - need to define base class. 00049 #define __FLEX_LEXER_H 00050 00051 #include <iostream> 00052 # ifndef FLEX_STD 00053 # define FLEX_STD std:: 00054 # endif 00055 00056 extern "C++" { 00057 00058 struct yy_buffer_state; 00059 typedef int yy_state_type; 00060 00061 class FlexLexer { 00062 public: 00063 virtual ~FlexLexer() { } 00064 00065 const char* YYText() const { return yytext; } 00066 int YYLeng() const { return yyleng; } 00067 00068 virtual void 00069 yy_switch_to_buffer( struct yy_buffer_state* new_buffer ) = 0; 00070 virtual struct yy_buffer_state* 00071 yy_create_buffer( FLEX_STD istream* s, int size ) = 0; 00072 virtual void yy_delete_buffer( struct yy_buffer_state* b ) = 0; 00073 virtual void yyrestart( FLEX_STD istream* s ) = 0; 00074 00075 virtual int yylex() = 0; 00076 00077 // Call yylex with new input/output sources. 00078 int yylex( FLEX_STD istream* new_in, FLEX_STD ostream* new_out = 0 ) 00079 { 00080 switch_streams( new_in, new_out ); 00081 return yylex(); 00082 } 00083 00084 // Switch to new input/output streams. A nil stream pointer 00085 // indicates "keep the current one". 00086 virtual void switch_streams( FLEX_STD istream* new_in = 0, 00087 FLEX_STD ostream* new_out = 0 ) = 0; 00088 00089 int lineno() const { return yylineno; } 00090 00091 int debug() const { return yy_flex_debug; } 00092 void set_debug( int flag ) { yy_flex_debug = flag; } 00093 00094 protected: 00095 char* yytext; 00096 int yyleng; 00097 int yylineno; // only maintained if you use %option yylineno 00098 int yy_flex_debug; // only has effect with -d or "%option debug" 00099 }; 00100 00101 } 00102 #endif // FLEXLEXER_H 00103 00104 #if defined(yyFlexLexer) || ! defined(yyFlexLexerOnce) 00105 // Either this is the first time through (yyFlexLexerOnce not defined), 00106 // or this is a repeated include to define a different flavor of 00107 // yyFlexLexer, as discussed in the flex manual. 00108 #define yyFlexLexerOnce 00109 00110 extern "C++" { 00111 00112 class yyFlexLexer : public FlexLexer { 00113 public: 00114 // arg_yyin and arg_yyout default to the cin and cout, but we 00115 // only make that assignment when initializing in yylex(). 00116 yyFlexLexer( FLEX_STD istream* arg_yyin = 0, FLEX_STD ostream* arg_yyout = 0 ); 00117 00118 virtual ~yyFlexLexer(); 00119 00120 void yy_switch_to_buffer( struct yy_buffer_state* new_buffer ); 00121 struct yy_buffer_state* yy_create_buffer( FLEX_STD istream* s, int size ); 00122 void yy_delete_buffer( struct yy_buffer_state* b ); 00123 void yyrestart( FLEX_STD istream* s ); 00124 00125 void yypush_buffer_state( struct yy_buffer_state* new_buffer ); 00126 void yypop_buffer_state(); 00127 00128 virtual int yylex(); 00129 virtual void switch_streams( FLEX_STD istream* new_in, FLEX_STD ostream* new_out = 0 ); 00130 virtual int yywrap(); 00131 00132 protected: 00133 virtual int LexerInput( char* buf, int max_size ); 00134 virtual void LexerOutput( const char* buf, int size ); 00135 virtual void LexerError( const char* msg ); 00136 00137 void yyunput( int c, char* buf_ptr ); 00138 int yyinput(); 00139 00140 void yy_load_buffer_state(); 00141 void yy_init_buffer( struct yy_buffer_state* b, FLEX_STD istream* s ); 00142 void yy_flush_buffer( struct yy_buffer_state* b ); 00143 00144 int yy_start_stack_ptr; 00145 int yy_start_stack_depth; 00146 int* yy_start_stack; 00147 00148 void yy_push_state( int new_state ); 00149 void yy_pop_state(); 00150 int yy_top_state(); 00151 00152 yy_state_type yy_get_previous_state(); 00153 yy_state_type yy_try_NUL_trans( yy_state_type current_state ); 00154 int yy_get_next_buffer(); 00155 00156 FLEX_STD istream* yyin; // input source for default LexerInput 00157 FLEX_STD ostream* yyout; // output sink for default LexerOutput 00158 00159 // yy_hold_char holds the character lost when yytext is formed. 00160 char yy_hold_char; 00161 00162 // Number of characters read into yy_ch_buf. 00163 int yy_n_chars; 00164 00165 // Points to current character in buffer. 00166 char* yy_c_buf_p; 00167 00168 int yy_init; // whether we need to initialize 00169 int yy_start; // start state number 00170 00171 // Flag which is used to allow yywrap()'s to do buffer switches 00172 // instead of setting up a fresh yyin. A bit of a hack ... 00173 int yy_did_buffer_switch_on_eof; 00174 00175 00176 size_t yy_buffer_stack_top; 00177 size_t yy_buffer_stack_max; 00178 struct yy_buffer_state ** yy_buffer_stack; 00179 void yyensure_buffer_stack(void); 00180 00181 // The following are not always needed, but may be depending 00182 // on use of certain flex features (like REJECT or yymore()). 00183 00184 yy_state_type yy_last_accepting_state; 00185 char* yy_last_accepting_cpos; 00186 00187 yy_state_type* yy_state_buf; 00188 yy_state_type* yy_state_ptr; 00189 00190 char* yy_full_match; 00191 int* yy_full_state; 00192 int yy_full_lp; 00193 00194 int yy_lp; 00195 int yy_looking_for_trail_begin; 00196 00197 int yy_more_flag; 00198 int yy_more_len; 00199 int yy_more_offset; 00200 int yy_prev_more_offset; 00201 }; 00202 00203 } 00204 00205 #endif // yyFlexLexer || ! yyFlexLexerOnce 00206