source: git/Singular/scanner.cc @ 341696

spielwiese
Last change on this file since 341696 was 341696, checked in by Hans Schönemann <hannes@…>, 14 years ago
Adding Id property to all files git-svn-id: file:///usr/local/Singular/svn/trunk@12231 2c84dea3-7e68-4137-9b89-c4e89433aadc
  • Property mode set to 100644
File size: 60.3 KB
Line 
1/* A lexical scanner generated by flex */
2
3/* Scanner skeleton version:
4 * $Header: /exports/cvsroot-2/cvsroot/Singular/scanner.cc,v 1.4 2008-07-16 12:51:26 Singular Exp $
5 */
6
7#define FLEX_SCANNER
8#define YY_FLEX_MAJOR_VERSION 2
9#define YY_FLEX_MINOR_VERSION 5
10
11#include <stdio.h>
12
13
14/* cfront 1.2 defines "c_plusplus" instead of "__cplusplus" */
15#ifdef c_plusplus
16#ifndef __cplusplus
17#define __cplusplus
18#endif
19#endif
20
21
22#ifdef __cplusplus
23
24#include <stdlib.h>
25#include <unistd.h>
26
27/* Use prototypes in function declarations. */
28#define YY_USE_PROTOS
29
30/* The "const" storage-class-modifier is valid. */
31#define YY_USE_CONST
32
33#else   /* ! __cplusplus */
34
35#if __STDC__
36
37#define YY_USE_PROTOS
38#define YY_USE_CONST
39
40#endif  /* __STDC__ */
41#endif  /* ! __cplusplus */
42
43#ifdef __TURBOC__
44 #pragma warn -rch
45 #pragma warn -use
46#include <io.h>
47#include <stdlib.h>
48#define YY_USE_CONST
49#define YY_USE_PROTOS
50#endif
51
52#ifdef YY_USE_CONST
53#define yyconst const
54#else
55#define yyconst
56#endif
57
58
59#ifdef YY_USE_PROTOS
60#define YY_PROTO(proto) proto
61#else
62#define YY_PROTO(proto) ()
63#endif
64
65/* Returned upon end-of-file. */
66#define YY_NULL 0
67
68/* Promotes a possibly negative, possibly signed char to an unsigned
69 * integer for use as an array index.  If the signed char is negative,
70 * we want to instead treat it as an 8-bit unsigned char, hence the
71 * double cast.
72 */
73#define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c)
74
75/* Enter a start condition.  This macro really ought to take a parameter,
76 * but we do it the disgusting crufty way forced on us by the ()-less
77 * definition of BEGIN.
78 */
79#define BEGIN yy_start = 1 + 2 *
80
81/* Translate the current start state into a value that can be later handed
82 * to BEGIN to return to the state.  The YYSTATE alias is for lex
83 * compatibility.
84 */
85#define YY_START ((yy_start - 1) / 2)
86#define YYSTATE YY_START
87
88/* Action number for EOF rule of a given start state. */
89#define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1)
90
91/* Special action meaning "start processing a new file". */
92#define YY_NEW_FILE yyrestart( yyin )
93
94#define YY_END_OF_BUFFER_CHAR 0
95
96/* Size of default input buffer. */
97#define YY_BUF_SIZE 16384
98
99typedef struct yy_buffer_state *YY_BUFFER_STATE;
100
101extern int yyleng;
102extern FILE *yyin, *yyout;
103
104#define EOB_ACT_CONTINUE_SCAN 0
105#define EOB_ACT_END_OF_FILE 1
106#define EOB_ACT_LAST_MATCH 2
107
108/* The funky do-while in the following #define is used to turn the definition
109 * int a single C statement (which needs a semi-colon terminator).  This
110 * avoids problems with code like:
111 *
112 *      if ( condition_holds )
113 *              yyless( 5 );
114 *      else
115 *              do_something_else();
116 *
117 * Prior to using the do-while the compiler would get upset at the
118 * "else" because it interpreted the "if" statement as being all
119 * done when it reached the ';' after the yyless() call.
120 */
121
122/* Return all but the first 'n' matched characters back to the input stream. */
123
124#define yyless(n) \
125        do \
126                { \
127                /* Undo effects of setting up yytext. */ \
128                *yy_cp = yy_hold_char; \
129                YY_RESTORE_YY_MORE_OFFSET \
130                yy_c_buf_p = yy_cp = yy_bp + n - YY_MORE_ADJ; \
131                YY_DO_BEFORE_ACTION; /* set up yytext again */ \
132                } \
133        while ( 0 )
134
135#define unput(c) yyunput( c, yytext_ptr )
136
137/* The following is because we cannot portably get our hands on size_t
138 * (without autoconf's help, which isn't available because we want
139 * flex-generated scanners to compile on their own).
140 */
141typedef unsigned int yy_size_t;
142
143
144struct yy_buffer_state
145        {
146        FILE *yy_input_file;
147
148        char *yy_ch_buf;                /* input buffer */
149        char *yy_buf_pos;               /* current position in input buffer */
150
151        /* Size of input buffer in bytes, not including room for EOB
152         * characters.
153         */
154        yy_size_t yy_buf_size;
155
156        /* Number of characters read into yy_ch_buf, not including EOB
157         * characters.
158         */
159        int yy_n_chars;
160
161        /* Whether we "own" the buffer - i.e., we know we created it,
162         * and can realloc() it to grow it, and should free() it to
163         * delete it.
164         */
165        int yy_is_our_buffer;
166
167        /* Whether this is an "interactive" input source; if so, and
168         * if we're using stdio for input, then we want to use getc()
169         * instead of fread(), to make sure we stop fetching input after
170         * each newline.
171         */
172        int yy_is_interactive;
173
174        /* Whether we're considered to be at the beginning of a line.
175         * If so, '^' rules will be active on the next match, otherwise
176         * not.
177         */
178        int yy_at_bol;
179
180        /* Whether to try to fill the input buffer when we reach the
181         * end of it.
182         */
183        int yy_fill_buffer;
184
185        int yy_buffer_status;
186#define YY_BUFFER_NEW 0
187#define YY_BUFFER_NORMAL 1
188        /* When an EOF's been seen but there's still some text to process
189         * then we mark the buffer as YY_EOF_PENDING, to indicate that we
190         * shouldn't try reading from the input source any more.  We might
191         * still have a bunch of tokens to match, though, because of
192         * possible backing-up.
193         *
194         * When we actually see the EOF, we change the status to "new"
195         * (via yyrestart()), so that the user can continue scanning by
196         * just pointing yyin at a new input file.
197         */
198#define YY_BUFFER_EOF_PENDING 2
199        };
200
201static YY_BUFFER_STATE yy_current_buffer = 0;
202
203/* We provide macros for accessing buffer states in case in the
204 * future we want to put the buffer states in a more general
205 * "scanner state".
206 */
207#define YY_CURRENT_BUFFER yy_current_buffer
208
209
210/* yy_hold_char holds the character lost when yytext is formed. */
211static char yy_hold_char;
212
213static int yy_n_chars;          /* number of characters read into yy_ch_buf */
214
215
216int yyleng;
217
218/* Points to current character in buffer. */
219static char *yy_c_buf_p = (char *) 0;
220static int yy_init = 1;         /* whether we need to initialize */
221static int yy_start = 0;        /* start state number */
222
223/* Flag which is used to allow yywrap()'s to do buffer switches
224 * instead of setting up a fresh yyin.  A bit of a hack ...
225 */
226static int yy_did_buffer_switch_on_eof;
227
228void yyrestart YY_PROTO(( FILE *input_file ));
229
230void yy_switch_to_buffer YY_PROTO(( YY_BUFFER_STATE new_buffer ));
231void yy_load_buffer_state YY_PROTO(( void ));
232YY_BUFFER_STATE yy_create_buffer YY_PROTO(( FILE *file, int size ));
233void yy_delete_buffer YY_PROTO(( YY_BUFFER_STATE b ));
234void yy_init_buffer YY_PROTO(( YY_BUFFER_STATE b, FILE *file ));
235void yy_flush_buffer YY_PROTO(( YY_BUFFER_STATE b ));
236#define YY_FLUSH_BUFFER yy_flush_buffer( yy_current_buffer )
237
238YY_BUFFER_STATE yy_scan_buffer YY_PROTO(( char *base, yy_size_t size ));
239YY_BUFFER_STATE yy_scan_string YY_PROTO(( yyconst char *yy_str ));
240YY_BUFFER_STATE yy_scan_bytes YY_PROTO(( yyconst char *bytes, int len ));
241
242static void *yy_flex_alloc YY_PROTO(( yy_size_t ));
243static void *yy_flex_realloc YY_PROTO(( void *, yy_size_t ));
244static void yy_flex_free YY_PROTO(( void * ));
245
246#define yy_new_buffer yy_create_buffer
247
248#define yy_set_interactive(is_interactive) \
249        { \
250        if ( ! yy_current_buffer ) \
251                yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \
252        yy_current_buffer->yy_is_interactive = is_interactive; \
253        }
254
255#define yy_set_bol(at_bol) \
256        { \
257        if ( ! yy_current_buffer ) \
258                yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \
259        yy_current_buffer->yy_at_bol = at_bol; \
260        }
261
262#define YY_AT_BOL() (yy_current_buffer->yy_at_bol)
263
264typedef unsigned char YY_CHAR;
265FILE *yyin = (FILE *) 0, *yyout = (FILE *) 0;
266typedef int yy_state_type;
267extern char *yytext;
268#define yytext_ptr yytext
269
270static yy_state_type yy_get_previous_state YY_PROTO(( void ));
271static yy_state_type yy_try_NUL_trans YY_PROTO(( yy_state_type current_state ));
272static int yy_get_next_buffer YY_PROTO(( void ));
273static void yy_fatal_error YY_PROTO(( yyconst char msg[] ));
274
275/* Done after the current pattern has been matched and before the
276 * corresponding action - sets up yytext.
277 */
278#define YY_DO_BEFORE_ACTION \
279        yytext_ptr = yy_bp; \
280        yytext_ptr -= yy_more_len; \
281        yyleng = (int) (yy_cp - yytext_ptr); \
282        yy_hold_char = *yy_cp; \
283        *yy_cp = '\0'; \
284        yy_c_buf_p = yy_cp;
285
286#define YY_NUM_RULES 65
287#define YY_END_OF_BUFFER 66
288static yyconst short int yy_accept[170] =
289    {   0,
290        0,    0,    0,    0,   30,   30,    0,    0,    0,    0,
291        0,    0,   20,   20,    0,    0,   66,   64,   40,   40,
292       50,   34,   63,   58,   64,   63,   64,   64,   64,   64,
293       64,   56,   64,   64,   64,   64,    6,   54,   63,   63,
294       63,   63,   63,   63,   63,   24,   64,   35,   63,   36,
295       39,   36,   30,   25,   30,   32,   33,   26,   29,   26,
296       13,   11,   12,   15,   14,   17,   16,   21,   20,   21,
297       18,   23,   19,    9,   65,   10,   51,   46,   63,   63,
298       63,   53,   44,   43,   41,   60,    3,    1,   60,    0,
299        0,   56,   42,   48,   52,   45,   49,    6,   63,   63,
300
301       63,   63,   63,   63,   63,   47,    2,   38,   37,   30,
302       30,   28,   27,   21,   20,   21,    0,   21,    9,    0,
303        1,   60,   62,   60,   62,   57,   63,   63,    5,   63,
304       63,   63,   63,   63,    2,   30,   31,   22,    0,    0,
305        0,   63,   59,    6,   63,   63,   63,   60,   61,    0,
306       63,   59,   59,   63,    0,    4,   63,   63,    0,    0,
307        7,   55,    0,    0,    8,    0,    0,    7,    0
308    } ;
309
310static yyconst int yy_ec[256] =
311    {   0,
312        1,    1,    1,    1,    1,    1,    1,    1,    2,    3,
313        1,    1,    4,    1,    1,    1,    1,    1,    1,    1,
314        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
315        1,    2,    5,    6,    7,    8,    1,    9,   10,   11,
316       12,   13,   14,   15,   16,   17,   18,   19,   19,   19,
317       19,   19,   19,   19,   19,   19,   19,   20,   21,   22,
318       23,   24,   25,   10,   10,   10,   10,   10,   10,   10,
319       10,   10,   10,   10,   10,   10,   10,   10,   10,   10,
320       10,   10,   10,   10,   10,   10,   10,   10,   10,   10,
321        1,   26,    1,    1,   27,    1,   28,   10,   29,   10,
322
323       30,   31,   10,   32,   33,   10,   10,   34,   35,   36,
324       37,   38,   39,   40,   10,   41,   42,   10,   43,   44,
325       10,   10,   45,   46,   47,   48,    1,    1,    1,    1,
326        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
327        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
328        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
329        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
330        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
331        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
332        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
333
334        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
335        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
336        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
337        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
338        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
339        1,    1,    1,    1,    1
340    } ;
341
342static yyconst int yy_meta[49] =
343    {   0,
344        1,    2,    3,    1,    1,    4,    1,    1,    1,    5,
345        6,    7,    1,    1,    7,    1,    8,    9,   10,    1,
346       11,    1,    1,    1,    1,    1,   12,    5,    5,    5,
347        5,    5,    5,    5,    5,    5,    5,    5,    5,    5,
348        5,    5,    5,    5,    4,    1,    4,    1
349    } ;
350
351static yyconst short int yy_base[191] =
352    {   0,
353        0,  395,   43,   44,   45,   46,   47,   48,   50,   54,
354      395,  394,   74,   92,   75,   76,  312,  555,  555,  555,
355      288,  555,  555,  555,  301,   40,  295,  289,  285,   38,
356       69,   82,  280,   60,  273,  272,  103,  555,   83,   89,
357       90,   92,   94,   96,  105,  555,  238,  555,  269,  555,
358      555,   62,    0,  555,  244,  555,  555,  555,  555,  119,
359      555,  555,  555,  555,  555,  555,  555,    0,  126,  137,
360      555,  555,  555,    0,  555,  555,  555,  555,  114,  117,
361      123,  555,  555,  555,  555,  116,  555,    0,  136,  128,
362      231,  142,  555,  555,  555,  555,  555,  128,  137,  144,
363
364      147,  148,  149,  129,  144,  555,    0,  555,  555,    0,
365      176,  555,  555,    0,  185,  187,  240,    0,    0,   98,
366        0,  177,  555,  150,  169,  186,  173,  179,  145,  181,
367      182,  189,  196,  197,    0,  194,    0,  555,  194,  173,
368      132,  200,  232,  224,  212,  230,  214,   99,   39,  237,
369      233,  266,  555,  215,  209,  231,  242,  243,  275,   70,
370      276,  252,  279,  280,  555,  286,  287,  290,  555,  314,
371      326,  338,  350,  362,  374,  386,  394,  402,  412,  424,
372      436,  448,  460,  472,  484,  496,  508,  520,  531,  542
373    } ;
374
375static yyconst short int yy_def[191] =
376    {   0,
377      169,    1,  170,  170,  171,  171,  172,  172,  173,  173,
378      174,  174,  175,  175,  176,  176,  169,  169,  169,  169,
379      169,  169,  169,  169,  169,  177,  169,  169,  169,  169,
380      169,  178,  169,  169,  169,  169,  169,  169,  177,  177,
381      177,  177,  177,  177,  177,  169,  169,  169,  169,  169,
382      169,  169,  179,  169,  179,  169,  169,  169,  169,  169,
383      169,  169,  169,  169,  169,  169,  169,  180,  169,  181,
384      169,  169,  169,  182,  169,  169,  169,  169,  177,  177,
385      177,  169,  169,  169,  169,  169,  169,  183,  178,  184,
386      169,  178,  169,  169,  169,  169,  169,  169,  177,  177,
387
388      177,  177,  177,   99,   99,  169,  185,  169,  169,  179,
389      186,  169,  169,  180,  169,  181,  187,  180,  182,  169,
390      183,  178,  169,  169,  169,  178,   99,   99,   99,   99,
391       99,   99,   99,   99,  185,  186,  188,  169,  169,  169,
392      169,   99,   99,   99,   99,   99,   99,  169,  169,  178,
393       99,  169,  169,   99,  189,   99,   99,   99,  190,  169,
394       99,   99,  169,  190,  169,  190,  190,  169,    0,  169,
395      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
396      169,  169,  169,  169,  169,  169,  169,  169,  169,  169
397    } ;
398
399static yyconst short int yy_nxt[604] =
400    {   0,
401       18,   19,   20,   19,   21,   22,   23,   24,   25,   26,
402       18,   18,   27,   28,   18,   29,   30,   31,   32,   33,
403       18,   34,   35,   36,   37,   38,   23,   26,   26,   39,
404       40,   41,   26,   26,   26,   42,   26,   43,   44,   26,
405       26,   26,   45,   26,   46,   47,   18,   48,   51,   51,
406       54,   54,   59,   59,   85,   62,   86,  149,   80,   62,
407       63,   64,   55,   55,   63,   64,   81,  108,   52,   52,
408       65,  163,   60,   60,   65,   69,   69,   75,   75,   70,
409      165,   87,   94,   95,   71,   72,   88,  109,   73,   56,
410       56,   57,   57,   69,   69,   76,   76,   70,   90,   91,
411
412       92,   80,   71,   72,   98,   98,   73,   80,   80,   81,
413       80,  139,   80,  139,   80,   81,   81,  148,   81,  101,
414       81,  102,   81,   80,  112,  100,   99,  115,  115,   98,
415       98,   81,   80,  103,   86,   80,  105,  104,  117,  117,
416       81,   80,  118,   81,  113,  120,  124,  117,  117,   81,
417      150,  117,  169,  169,  122,   80,   79,  125,   90,   91,
418       92,  133,   80,   81,  127,   80,   80,   80,   86,  128,
419       81,   79,   79,   81,   81,   81,  134,   79,  110,  120,
420      130,  137,  140,  129,  140,  132,  115,  115,  117,  117,
421      131,  149,  118,  169,  169,  122,  110,  117,  117,  137,
422
423       79,  117,  169,  141,  126,   79,   79,  142,   79,   79,
424      155,   79,  148,   79,   79,  145,   79,  146,  144,  143,
425      137,   79,  137,   79,   79,   98,   98,   79,   79,   79,
426      147,  155,   79,  152,  152,  160,  143,  151,  137,   79,
427      137,   79,   79,  156,  154,  138,   79,   79,  153,  126,
428      158,   79,  153,  169,  141,  150,   79,   79,   79,   79,
429       79,  111,   79,   79,   79,   79,  157,  152,  152,   79,
430       79,  161,  162,  107,   79,   79,  163,  168,  168,   79,
431      163,  163,  153,  106,   79,  165,  153,  163,  163,  165,
432      165,  168,  168,  166,   97,   96,  165,  165,  166,   93,
433
434       84,  167,   83,   79,  166,  166,  167,   82,   79,   78,
435       77,  169,  167,  167,   50,   50,   50,   50,   50,   50,
436       50,   50,   50,   50,   50,   50,   53,   53,   53,   53,
437       53,   53,   53,   53,   53,   53,   53,   53,   58,   58,
438       58,   58,   58,   58,   58,   58,   58,   58,   58,   58,
439       61,   61,   61,   61,   61,   61,   61,   61,   61,   61,
440       61,   61,   66,   66,   66,   66,   66,   66,   66,   66,
441       66,   66,   66,   66,   68,   68,   68,   68,   68,   68,
442       68,   68,   68,   68,   68,   68,   74,   74,   74,   74,
443       74,   74,   74,   74,   74,   74,   74,   74,   79,   67,
444
445       67,   49,  169,   79,  169,   79,   89,  169,  169,   89,
446       89,   89,  110,  110,  110,  169,  110,  110,  110,  110,
447      110,  110,  110,  110,  114,  169,  169,  114,  114,  169,
448      169,  114,  114,  114,  114,  114,  116,  116,  116,  116,
449      116,  116,  116,  116,  116,  116,  116,  116,  119,  119,
450      169,  119,  119,  119,  119,  119,  119,  119,  169,  119,
451      121,  121,  169,  121,  121,  121,  121,  121,  121,  121,
452      121,  121,  123,  123,  123,  123,  123,  123,  123,  169,
453      123,  123,  123,  123,  135,  135,  169,  135,  135,  135,
454      135,  135,  135,  135,  135,  135,  136,  136,  136,  136,
455
456      136,  136,  136,  136,  136,  136,  136,  136,  117,  117,
457      117,  117,  117,  117,  117,  117,  117,  117,  117,  117,
458      137,  137,  169,  137,  137,  137,  137,  137,  137,  137,
459      137,  137,  159,  169,  169,  159,  169,  169,  169,  169,
460      169,  169,  159,  164,  169,  169,  164,  164,  169,  169,
461      169,  164,  169,  164,   17,  169,  169,  169,  169,  169,
462      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
463      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
464      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
465      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
466
467      169,  169,  169
468    } ;
469
470static yyconst short int yy_chk[604] =
471    {   0,
472        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
473        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
474        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
475        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
476        1,    1,    1,    1,    1,    1,    1,    1,    3,    4,
477        5,    6,    7,    8,   30,    9,   30,  149,   26,   10,
478        9,    9,    5,    6,   10,   10,   26,   52,    3,    4,
479        9,  160,    7,    8,   10,   13,   13,   15,   16,   13,
480      160,   31,   34,   34,   13,   13,   31,   52,   13,    5,
481        6,    5,    6,   14,   14,   15,   16,   14,   32,   32,
482
483       32,   39,   14,   14,   37,   37,   14,   40,   41,   39,
484       42,  120,   43,  120,   44,   40,   41,  148,   42,   41,
485       43,   42,   44,   45,   60,   40,   39,   69,   69,   98,
486       98,   45,   79,   43,   86,   80,   45,   44,   70,   70,
487       79,   81,   70,   80,   60,   86,   90,   70,   70,   81,
488      141,   70,   89,   89,   89,   99,  104,   90,   92,   92,
489       92,  104,  100,   99,   99,  101,  102,  103,  124,   99,
490      100,  105,  129,  101,  102,  103,  105,  129,  111,  124,
491      101,  111,  125,  100,  125,  103,  115,  115,  116,  116,
492      102,  140,  116,  122,  122,  122,  136,  116,  116,  136,
493
494      127,  116,  126,  126,  126,  127,  128,  127,  130,  131,
495      155,  128,  139,  130,  131,  131,  132,  132,  130,  128,
496      111,  132,  111,  133,  134,  144,  144,  142,  133,  134,
497      134,  146,  142,  143,  143,  155,  133,  142,  136,  145,
498      136,  147,  154,  147,  145,  117,  147,  154,  143,   91,
499      154,  144,  143,  150,  150,  150,  144,  146,  156,  143,
500      151,   55,  146,  156,  143,  151,  151,  152,  152,  157,
501      158,  157,  158,   49,  157,  158,  159,  161,  161,  162,
502      163,  164,  152,   47,  162,  159,  152,  166,  167,  163,
503      164,  168,  168,  159,   36,   35,  166,  167,  164,   33,
504
505       29,  159,   28,  161,  166,  167,  164,   27,  161,   25,
506       21,   17,  166,  167,  170,  170,  170,  170,  170,  170,
507      170,  170,  170,  170,  170,  170,  171,  171,  171,  171,
508      171,  171,  171,  171,  171,  171,  171,  171,  172,  172,
509      172,  172,  172,  172,  172,  172,  172,  172,  172,  172,
510      173,  173,  173,  173,  173,  173,  173,  173,  173,  173,
511      173,  173,  174,  174,  174,  174,  174,  174,  174,  174,
512      174,  174,  174,  174,  175,  175,  175,  175,  175,  175,
513      175,  175,  175,  175,  175,  175,  176,  176,  176,  176,
514      176,  176,  176,  176,  176,  176,  176,  176,  177,   12,
515
516       11,    2,    0,  177,    0,  177,  178,    0,    0,  178,
517      178,  178,  179,  179,  179,    0,  179,  179,  179,  179,
518      179,  179,  179,  179,  180,    0,    0,  180,  180,    0,
519        0,  180,  180,  180,  180,  180,  181,  181,  181,  181,
520      181,  181,  181,  181,  181,  181,  181,  181,  182,  182,
521        0,  182,  182,  182,  182,  182,  182,  182,    0,  182,
522      183,  183,    0,  183,  183,  183,  183,  183,  183,  183,
523      183,  183,  184,  184,  184,  184,  184,  184,  184,    0,
524      184,  184,  184,  184,  185,  185,    0,  185,  185,  185,
525      185,  185,  185,  185,  185,  185,  186,  186,  186,  186,
526
527      186,  186,  186,  186,  186,  186,  186,  186,  187,  187,
528      187,  187,  187,  187,  187,  187,  187,  187,  187,  187,
529      188,  188,    0,  188,  188,  188,  188,  188,  188,  188,
530      188,  188,  189,    0,    0,  189,    0,    0,    0,    0,
531        0,    0,  189,  190,    0,    0,  190,  190,    0,    0,
532        0,  190,    0,  190,  169,  169,  169,  169,  169,  169,
533      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
534      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
535      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
536      169,  169,  169,  169,  169,  169,  169,  169,  169,  169,
537
538      169,  169,  169
539    } ;
540
541static yy_state_type yy_last_accepting_state;
542static char *yy_last_accepting_cpos;
543
544/* The intent behind this definition is that it'll catch
545 * any uses of REJECT which flex missed.
546 */
547#define REJECT reject_used_but_not_detected
548static int yy_more_flag = 0;
549static int yy_more_len = 0;
550#define yymore() (yy_more_flag = 1)
551#define YY_MORE_ADJ yy_more_len
552#define YY_RESTORE_YY_MORE_OFFSET
553char *yytext;
554#line 1 "scanner.l"
555#define INITIAL 0
556#line 2 "scanner.l"
557/****************************************
558*  Computer Algebra System SINGULAR     *
559****************************************/
560/* $Id$ */
561#include <stdio.h>
562#include <string.h>
563#include <stdlib.h>
564#include <ctype.h>
565
566#include "mod2.h"
567#include "omalloc.h"
568#include "tok.h"
569#include "stype.h"
570#include "ipshell.h"
571#include "febase.h"
572
573int feReadLine(char* b, int l);
574#define ALLOC(a) omAlloc((a))
575int yylineno  = 0;
576int blocknest = 0;
577extern char * yytext;
578//extern unsigned char * yytext;
579extern int yyleng;
580extern int inerror;
581
582// this is to  shadow the malloc/realloc
583// used by yy_flex_malloc/yy_flex_realloc
584// so that we can mark stuff as static
585static void* my_malloc(size_t size)
586{
587  void* addr = omAlloc(size);
588  omMarkAsStaticAddr(addr);
589  return addr;
590}
591
592static void* my_realloc(void* addr, size_t size)
593{
594  void* new_addr = omRealloc(addr, size);
595  omMarkAsStaticAddr(new_addr);
596  return new_addr;
597}
598static void my_free(void* addr)
599{
600  omFree(addr);
601}
602#undef malloc
603#define malloc my_malloc
604#undef realloc
605#define realloc my_realloc
606#undef free
607#define free my_free
608static char * dupyytext()
609{
610  char* s;
611  if (yyleng>0) yytext[yyleng-1] = '\0';
612  s = omStrDup((char *)yytext);
613  omMarkAsStaticAddr(s);
614  return s;
615}
616
617static char * dupyytextNL()
618{
619  int i = yyleng;//strlen((char *)yytext);
620  char * rc = (char*)omAlloc( 3 + i );
621  omMarkAsStaticAddr(rc);
622  if (i>0)
623  {
624    strncpy( rc, (char *)yytext, i-1 );
625  }
626  else
627  {
628    i++;
629  }
630  rc[i-1] = '\n';
631  rc[i] = '\n';
632  rc[i+1] = '\0';
633  return rc;
634}
635
636  #undef YY_DECL
637  #define YY_DECL int yylex(YYSTYPE* lvalp)
638
639  #undef yywrap
640  extern "C" {
641  int yywrap() { return exitVoice(); }
642  }
643
644  #undef YY_INPUT
645  #define YY_INPUT(buf,result,max_size) \
646          result = feReadLine( (char *) (buf), (max_size) )
647
648  #undef YY_USER_ACTION
649  #define YY_USER_ACTION \
650          if ((inerror==1)&&(*yytext>=' '))\
651          { Print("   skipping text from `%s`",yytext);inerror=2; }
652
653/* %start START */
654#define YY_ALWAYS_INTERACTIVE 1
655#define string 1
656
657#define block 2
658
659#define blockstr 3
660
661#define brace 4
662
663#define bracestr 5
664
665#define bracket 6
666
667#define asstring 7
668
669
670/* Macros after this point can all be overridden by user definitions in
671 * section 1.
672 */
673
674#ifndef YY_SKIP_YYWRAP
675#ifdef __cplusplus
676extern "C" int yywrap YY_PROTO(( void ));
677#else
678extern int yywrap YY_PROTO(( void ));
679#endif
680#endif
681
682#ifndef YY_NO_UNPUT
683static void yyunput YY_PROTO(( int c, char *buf_ptr ));
684#endif
685
686#ifndef yytext_ptr
687static void yy_flex_strncpy YY_PROTO(( char *, yyconst char *, int ));
688#endif
689
690#ifdef YY_NEED_STRLEN
691static int yy_flex_strlen YY_PROTO(( yyconst char * ));
692#endif
693
694#ifndef YY_NO_INPUT
695#ifdef __cplusplus
696static int yyinput YY_PROTO(( void ));
697#else
698static int input YY_PROTO(( void ));
699#endif
700#endif
701
702#if YY_STACK_USED
703static int yy_start_stack_ptr = 0;
704static int yy_start_stack_depth = 0;
705static int *yy_start_stack = 0;
706#ifndef YY_NO_PUSH_STATE
707static void yy_push_state YY_PROTO(( int new_state ));
708#endif
709#ifndef YY_NO_POP_STATE
710static void yy_pop_state YY_PROTO(( void ));
711#endif
712#ifndef YY_NO_TOP_STATE
713static int yy_top_state YY_PROTO(( void ));
714#endif
715
716#else
717#define YY_NO_PUSH_STATE 1
718#define YY_NO_POP_STATE 1
719#define YY_NO_TOP_STATE 1
720#endif
721
722#ifdef YY_MALLOC_DECL
723YY_MALLOC_DECL
724#else
725#if __STDC__
726#ifndef __cplusplus
727#include <stdlib.h>
728#endif
729#else
730/* Just try to get by without declaring the routines.  This will fail
731 * miserably on non-ANSI systems for which sizeof(size_t) != sizeof(int)
732 * or sizeof(void*) != sizeof(int).
733 */
734#endif
735#endif
736
737/* Amount of stuff to slurp up with each read. */
738#ifndef YY_READ_BUF_SIZE
739#define YY_READ_BUF_SIZE 8192
740#endif
741
742/* Copy whatever the last rule matched to the standard output. */
743
744#ifndef ECHO
745/* This used to be an fputs(), but since the string might contain NUL's,
746 * we now use fwrite().
747 */
748#define ECHO (void) fwrite( yytext, yyleng, 1, yyout )
749#endif
750
751/* Gets input and stuffs it into "buf".  number of characters read, or YY_NULL,
752 * is returned in "result".
753 */
754#ifndef YY_INPUT
755#define YY_INPUT(buf,result,max_size) \
756        if ( yy_current_buffer->yy_is_interactive ) \
757                { \
758                int c = '*', n; \
759                for ( n = 0; n < max_size && \
760                             (c = getc( yyin )) != EOF && c != '\n'; ++n ) \
761                        buf[n] = (char) c; \
762                if ( c == '\n' ) \
763                        buf[n++] = (char) c; \
764                if ( c == EOF && ferror( yyin ) ) \
765                        YY_FATAL_ERROR( "input in flex scanner failed" ); \
766                result = n; \
767                } \
768        else if ( ((result = fread( buf, 1, max_size, yyin )) == 0) \
769                  && ferror( yyin ) ) \
770                YY_FATAL_ERROR( "input in flex scanner failed" );
771#endif
772
773/* No semi-colon after return; correct usage is to write "yyterminate();" -
774 * we don't want an extra ';' after the "return" because that will cause
775 * some compilers to complain about unreachable statements.
776 */
777#ifndef yyterminate
778#define yyterminate() return YY_NULL
779#endif
780
781/* Number of entries by which start-condition stack grows. */
782#ifndef YY_START_STACK_INCR
783#define YY_START_STACK_INCR 25
784#endif
785
786/* Report a fatal error. */
787#ifndef YY_FATAL_ERROR
788#define YY_FATAL_ERROR(msg) yy_fatal_error( msg )
789#endif
790
791/* Default declaration of generated scanner - a define so the user can
792 * easily add parameters.
793 */
794#ifndef YY_DECL
795#define YY_DECL int yylex YY_PROTO(( void ))
796#endif
797
798/* Code executed at the beginning of each rule, after yytext and yyleng
799 * have been set up.
800 */
801#ifndef YY_USER_ACTION
802#define YY_USER_ACTION
803#endif
804
805/* Code executed at the end of each rule. */
806#ifndef YY_BREAK
807#define YY_BREAK break;
808#endif
809
810#define YY_RULE_SETUP \
811        if ( yyleng > 0 ) \
812                yy_current_buffer->yy_at_bol = \
813                                (yytext[yyleng - 1] == '\n'); \
814        YY_USER_ACTION
815
816YY_DECL
817        {
818        register yy_state_type yy_current_state;
819        register char *yy_cp = NULL, *yy_bp = NULL;
820        register int yy_act;
821
822#line 120 "scanner.l"
823
824
825        if ( yy_init )
826                {
827                yy_init = 0;
828
829#ifdef YY_USER_INIT
830                YY_USER_INIT;
831#endif
832
833                if ( ! yy_start )
834                        yy_start = 1;   /* first start state */
835
836                if ( ! yyin )
837                        yyin = stdin;
838
839                if ( ! yyout )
840                        yyout = stdout;
841
842                if ( ! yy_current_buffer )
843                        yy_current_buffer =
844                                yy_create_buffer( yyin, YY_BUF_SIZE );
845
846                yy_load_buffer_state();
847                }
848
849        while ( 1 )             /* loops until end-of-file is reached */
850                {
851                yy_more_len = 0;
852                if ( yy_more_flag )
853                        {
854                        yy_more_len = yy_c_buf_p - yytext_ptr;
855                        yy_more_flag = 0;
856                        }
857                yy_cp = yy_c_buf_p;
858
859                /* Support of yytext. */
860                *yy_cp = yy_hold_char;
861
862                /* yy_bp points to the position in yy_ch_buf of the start of
863                 * the current run.
864                 */
865                yy_bp = yy_cp;
866
867                yy_current_state = yy_start;
868                yy_current_state += YY_AT_BOL();
869yy_match:
870                do
871                        {
872                        register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)];
873                        if ( yy_accept[yy_current_state] )
874                                {
875                                yy_last_accepting_state = yy_current_state;
876                                yy_last_accepting_cpos = yy_cp;
877                                }
878                        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
879                                {
880                                yy_current_state = (int) yy_def[yy_current_state];
881                                if ( yy_current_state >= 170 )
882                                        yy_c = yy_meta[(unsigned int) yy_c];
883                                }
884                        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
885                        ++yy_cp;
886                        }
887                while ( yy_base[yy_current_state] != 555 );
888
889yy_find_action:
890                yy_act = yy_accept[yy_current_state];
891                if ( yy_act == 0 )
892                        { /* have to back up */
893                        yy_cp = yy_last_accepting_cpos;
894                        yy_current_state = yy_last_accepting_state;
895                        yy_act = yy_accept[yy_current_state];
896                        }
897
898                YY_DO_BEFORE_ACTION;
899
900
901do_action:      /* This label is used only to access EOF actions. */
902
903
904                switch ( yy_act )
905        { /* beginning of action switch */
906                        case 0: /* must back up */
907                        /* undo the effects of YY_DO_BEFORE_ACTION */
908                        *yy_cp = yy_hold_char;
909                        yy_cp = yy_last_accepting_cpos;
910                        yy_current_state = yy_last_accepting_state;
911                        goto yy_find_action;
912
913case 1:
914YY_RULE_SETUP
915#line 121 "scanner.l"
916{ }
917        YY_BREAK
918case 2:
919YY_RULE_SETUP
920#line 122 "scanner.l"
921{ }
922        YY_BREAK
923case 3:
924YY_RULE_SETUP
925#line 123 "scanner.l"
926{
927                           yy_noeof=noeof_comment;
928                           loop
929                           {
930                             register int c;
931                             while ( (c = yyinput()) != '*' && c != EOF );
932                             if ( c == '*' )
933                             {
934                               while ( (c = yyinput()) == '*' );
935                               if ( c == '/' ) break; /* found the end */
936                             }
937                             else
938                             {
939                               break;
940                             }
941                           }
942                           yy_noeof=0;
943                         }
944        YY_BREAK
945case 4:
946YY_RULE_SETUP
947#line 141 "scanner.l"
948{ prompt_char='.';
949                           blocknest = 0; yy_noeof = noeof_brace; BEGIN(brace);
950                           return WHILE_CMD;}
951        YY_BREAK
952case 5:
953YY_RULE_SETUP
954#line 144 "scanner.l"
955{ prompt_char='.';
956                           blocknest = 0; yy_noeof = noeof_brace; BEGIN(brace);
957                           return FOR_CMD;}
958        YY_BREAK
959case 6:
960YY_RULE_SETUP
961#line 148 "scanner.l"
962{ yy_noeof = noeof_asstring;
963                           BEGIN(asstring);
964                           return HELP_CMD;
965                         }
966        YY_BREAK
967case 7:
968YY_RULE_SETUP
969#line 153 "scanner.l"
970{ yy_noeof = noeof_asstring;
971                           BEGIN(asstring);
972                           return EXAMPLE_CMD;
973                         }
974        YY_BREAK
975case 8:
976YY_RULE_SETUP
977#line 158 "scanner.l"
978{
979                           char c; char *cp;
980                           lvalp->name = omStrDup(iiProcName((char *)yytext,c,cp));
981                           yy_noeof = noeof_procname;
982                           blocknest = 1;
983                           BEGIN(brace);
984                           return PROC_DEF;
985                         }
986        YY_BREAK
987case 9:
988YY_RULE_SETUP
989#line 166 "scanner.l"
990{
991                           lvalp->name = omStrDup((char *)yytext);
992                           yy_noeof = 0; BEGIN(INITIAL);
993                           return STRINGTOK;
994                         }
995        YY_BREAK
996case 10:
997YY_RULE_SETUP
998#line 171 "scanner.l"
999{
1000                           yy_noeof = 0; BEGIN(INITIAL);
1001                           return *yytext;
1002                         }
1003        YY_BREAK
1004case 11:
1005YY_RULE_SETUP
1006#line 176 "scanner.l"
1007{
1008                           yy_noeof = noeof_string;
1009                           BEGIN(bracestr);
1010                           yymore();
1011                         }
1012        YY_BREAK
1013case 12:
1014YY_RULE_SETUP
1015#line 181 "scanner.l"
1016{ if (blocknest++) yymore(); }
1017        YY_BREAK
1018case 13:
1019YY_RULE_SETUP
1020#line 182 "scanner.l"
1021{ if (blocknest) yymore(); }
1022        YY_BREAK
1023case 14:
1024YY_RULE_SETUP
1025#line 183 "scanner.l"
1026{
1027                           if (blocknest)
1028                           {
1029                             lvalp->name = dupyytext();
1030                             return STRINGTOK;
1031                           }
1032                         }
1033        YY_BREAK
1034case 15:
1035YY_RULE_SETUP
1036#line 190 "scanner.l"
1037{
1038                           if (--blocknest <= 0)
1039                           {
1040                             yy_noeof = 0;
1041                             BEGIN(INITIAL);
1042                             lvalp->name = dupyytext();
1043                             return STRINGTOK;
1044                           }
1045                           yymore();
1046                         }
1047        YY_BREAK
1048case 16:
1049YY_RULE_SETUP
1050#line 200 "scanner.l"
1051{
1052                           yy_noeof = noeof_brace;
1053                           BEGIN(brace);
1054                           yymore();
1055                         }
1056        YY_BREAK
1057case 17:
1058YY_RULE_SETUP
1059#line 205 "scanner.l"
1060{ yymore(); }
1061        YY_BREAK
1062case 18:
1063YY_RULE_SETUP
1064#line 206 "scanner.l"
1065{ return '('; }
1066        YY_BREAK
1067case 19:
1068YY_RULE_SETUP
1069#line 207 "scanner.l"
1070{ return ','; }
1071        YY_BREAK
1072case 20:
1073YY_RULE_SETUP
1074#line 208 "scanner.l"
1075{ ; }
1076        YY_BREAK
1077case 21:
1078YY_RULE_SETUP
1079#line 209 "scanner.l"
1080{
1081                           lvalp->name = omStrDup((char *)yytext);
1082                           return STRINGTOK;
1083                         }
1084        YY_BREAK
1085case 22:
1086YY_RULE_SETUP
1087#line 213 "scanner.l"
1088{
1089                           lvalp->name = omStrDup((char *)yytext);
1090                           return STRINGTOK;
1091                         }
1092        YY_BREAK
1093case 23:
1094YY_RULE_SETUP
1095#line 217 "scanner.l"
1096{
1097                           yy_noeof = 0; BEGIN(INITIAL);
1098                           return ')';
1099                         }
1100        YY_BREAK
1101case 24:
1102YY_RULE_SETUP
1103#line 222 "scanner.l"
1104{
1105                           yy_blocklineno = yylineno;
1106                           blocknest = 1;
1107                           yy_noeof = noeof_block;
1108                           BEGIN(block);
1109                         }
1110        YY_BREAK
1111case 25:
1112YY_RULE_SETUP
1113#line 228 "scanner.l"
1114{
1115                           yy_noeof = noeof_string;
1116                           BEGIN(blockstr);
1117                           yymore();
1118                         }
1119        YY_BREAK
1120case 26:
1121YY_RULE_SETUP
1122#line 233 "scanner.l"
1123{ yymore(); }
1124        YY_BREAK
1125case 27:
1126YY_RULE_SETUP
1127#line 234 "scanner.l"
1128{ yymore(); }
1129        YY_BREAK
1130case 28:
1131YY_RULE_SETUP
1132#line 235 "scanner.l"
1133{ yymore(); }
1134        YY_BREAK
1135case 29:
1136YY_RULE_SETUP
1137#line 236 "scanner.l"
1138{
1139                           yy_noeof = noeof_block;
1140                           BEGIN(block);
1141                           yymore();
1142                         }
1143        YY_BREAK
1144case 30:
1145YY_RULE_SETUP
1146#line 241 "scanner.l"
1147{ yymore(); }
1148        YY_BREAK
1149case 31:
1150YY_RULE_SETUP
1151#line 242 "scanner.l"
1152{ yymore(); }
1153        YY_BREAK
1154case 32:
1155YY_RULE_SETUP
1156#line 243 "scanner.l"
1157{ blocknest++; yymore(); }
1158        YY_BREAK
1159case 33:
1160YY_RULE_SETUP
1161#line 244 "scanner.l"
1162{
1163                           if (--blocknest <= 0)
1164                           {
1165                             BEGIN(INITIAL);
1166                             yy_noeof = 0;
1167                             lvalp->name = dupyytextNL();
1168                             return BLOCKTOK;
1169                           }
1170                           yymore();
1171                         }
1172        YY_BREAK
1173case 34:
1174YY_RULE_SETUP
1175#line 254 "scanner.l"
1176{ BEGIN(string); yy_noeof = noeof_string;}
1177        YY_BREAK
1178case 35:
1179YY_RULE_SETUP
1180#line 255 "scanner.l"
1181{ return SYS_BREAK; }
1182        YY_BREAK
1183case 36:
1184YY_RULE_SETUP
1185#line 256 "scanner.l"
1186{ yymore(); }
1187        YY_BREAK
1188case 37:
1189YY_RULE_SETUP
1190#line 257 "scanner.l"
1191{ yymore(); }
1192        YY_BREAK
1193case 38:
1194YY_RULE_SETUP
1195#line 258 "scanner.l"
1196{ yymore(); }
1197        YY_BREAK
1198case 39:
1199YY_RULE_SETUP
1200#line 259 "scanner.l"
1201{
1202                           char * s;
1203                           yy_noeof = 0;
1204                           BEGIN(INITIAL);
1205                           s = lvalp->name = dupyytext();
1206                           while (*yytext)
1207                           {
1208                             if (*yytext == '\\') yytext++;
1209                             *s++ = *yytext++;
1210                           }
1211                           *s++ = *yytext++;
1212                           return STRINGTOK;
1213                         }
1214        YY_BREAK
1215case 40:
1216YY_RULE_SETUP
1217#line 273 "scanner.l"
1218/* skip whitespace */
1219        YY_BREAK
1220case 41:
1221YY_RULE_SETUP
1222#line 274 "scanner.l"
1223{ return DOTDOT; }
1224        YY_BREAK
1225case 42:
1226YY_RULE_SETUP
1227#line 275 "scanner.l"
1228{ return COLONCOLON; }
1229        YY_BREAK
1230case 43:
1231YY_RULE_SETUP
1232#line 276 "scanner.l"
1233{ return MINUSMINUS; }
1234        YY_BREAK
1235case 44:
1236YY_RULE_SETUP
1237#line 277 "scanner.l"
1238{ return PLUSPLUS  ; }
1239        YY_BREAK
1240case 45:
1241YY_RULE_SETUP
1242#line 278 "scanner.l"
1243{ return EQUAL_EQUAL; }
1244        YY_BREAK
1245case 46:
1246YY_RULE_SETUP
1247#line 279 "scanner.l"
1248{ lvalp->i='&'; return LOGIC_OP; }
1249        YY_BREAK
1250case 47:
1251YY_RULE_SETUP
1252#line 280 "scanner.l"
1253{ lvalp->i='|'; return LOGIC_OP; }
1254        YY_BREAK
1255case 48:
1256YY_RULE_SETUP
1257#line 281 "scanner.l"
1258{ lvalp->i=LE; return COMP_OP; }
1259        YY_BREAK
1260case 49:
1261YY_RULE_SETUP
1262#line 282 "scanner.l"
1263{ lvalp->i=GE; return COMP_OP; }
1264        YY_BREAK
1265case 50:
1266YY_RULE_SETUP
1267#line 283 "scanner.l"
1268{ return NOT; }
1269        YY_BREAK
1270case 51:
1271YY_RULE_SETUP
1272#line 284 "scanner.l"
1273{ return NOTEQUAL; }
1274        YY_BREAK
1275case 52:
1276YY_RULE_SETUP
1277#line 285 "scanner.l"
1278{ return NOTEQUAL; }
1279        YY_BREAK
1280case 53:
1281YY_RULE_SETUP
1282#line 286 "scanner.l"
1283{ return '^'; }
1284        YY_BREAK
1285case 54:
1286YY_RULE_SETUP
1287#line 287 "scanner.l"
1288{ return '\\'; }
1289        YY_BREAK
1290case 55:
1291YY_RULE_SETUP
1292#line 288 "scanner.l"
1293{
1294                           lvalp->name = omStrDup("\n");
1295                           return STRINGTOK;
1296                         }
1297        YY_BREAK
1298case 56:
1299YY_RULE_SETUP
1300#line 292 "scanner.l"
1301{
1302                           lvalp->name = (char *)yytext;
1303                           return INT_CONST;
1304                         }
1305        YY_BREAK
1306case 57:
1307YY_RULE_SETUP
1308#line 296 "scanner.l"
1309{
1310                           lvalp->name = (char *)yytext;
1311                           return RINGVAR;
1312                         }
1313        YY_BREAK
1314case 58:
1315YY_RULE_SETUP
1316#line 300 "scanner.l"
1317{
1318                           m2_end(-1);
1319                         }
1320        YY_BREAK
1321case 59:
1322YY_RULE_SETUP
1323#line 303 "scanner.l"
1324{
1325                           #ifdef MM_STAT
1326                           mmStat(-500);
1327                           #endif
1328                           #ifdef OM_TRACK
1329                           #ifndef NDEBUG
1330                             omPrintUsedTrackAddrs(stdout, 1);
1331                           #endif
1332                           #endif
1333                           m2_end(0);
1334                         }
1335        YY_BREAK
1336case 60:
1337YY_RULE_SETUP
1338#line 315 "scanner.l"
1339{
1340                           lvalp->name = (char *)yytext;
1341                           return RINGVAR;
1342                         }
1343        YY_BREAK
1344case 61:
1345YY_RULE_SETUP
1346#line 319 "scanner.l"
1347{
1348                           lvalp->name = (char *)yytext;
1349                           return RINGVAR;
1350                         }
1351        YY_BREAK
1352case 62:
1353*yy_cp = yy_hold_char; /* undo effects of setting up yytext */
1354yy_c_buf_p = yy_cp -= 1;
1355YY_DO_BEFORE_ACTION; /* set up yytext again */
1356YY_RULE_SETUP
1357#line 323 "scanner.l"
1358{
1359                           lvalp->name = (char *)yytext;
1360                           return RINGVAR;
1361                         }
1362        YY_BREAK
1363case 63:
1364YY_RULE_SETUP
1365#line 328 "scanner.l"
1366{
1367                           /* {name} */
1368                           int rc=0;
1369                           if (yytext[strlen((char *)yytext)-1] == '\n')
1370                           {
1371                             yytext[strlen((char *)yytext)-1] = '\0';
1372                           }
1373                           if (yyleng > 1)
1374                           {
1375                             rc = IsCmd((char *)yytext,lvalp->i);
1376                             if (rc) return rc;
1377                           }
1378                           lvalp->name = omStrDup((char *)yytext);
1379                           return UNKNOWN_IDENT;
1380                         }
1381        YY_BREAK
1382case 64:
1383YY_RULE_SETUP
1384#line 344 "scanner.l"
1385{
1386                           /*if (*yytext == '\n') REJECT;*/
1387                           register char ch= *yytext;
1388                           lvalp->i = ch;
1389                           switch(ch)
1390                           {
1391                             /* case '&': */
1392                             case '|':
1393                               return LOGIC_OP;
1394                             /* case '/': */
1395                             case '%':
1396                             case '*':
1397                               return MULDIV_OP;
1398                             /* case '<': */
1399                             case '>':
1400                               return COMP_OP;
1401                             default:
1402                               break;
1403                            }
1404                            return ch;
1405                         }
1406        YY_BREAK
1407case 65:
1408YY_RULE_SETUP
1409#line 365 "scanner.l"
1410YY_FATAL_ERROR( "flex scanner jammed" );
1411        YY_BREAK
1412case YY_STATE_EOF(INITIAL):
1413case YY_STATE_EOF(string):
1414case YY_STATE_EOF(block):
1415case YY_STATE_EOF(blockstr):
1416case YY_STATE_EOF(brace):
1417case YY_STATE_EOF(bracestr):
1418case YY_STATE_EOF(bracket):
1419case YY_STATE_EOF(asstring):
1420        yyterminate();
1421
1422        case YY_END_OF_BUFFER:
1423                {
1424                /* Amount of text matched not including the EOB char. */
1425                int yy_amount_of_matched_text = (int) (yy_cp - yytext_ptr) - 1;
1426
1427                /* Undo the effects of YY_DO_BEFORE_ACTION. */
1428                *yy_cp = yy_hold_char;
1429                YY_RESTORE_YY_MORE_OFFSET
1430
1431                if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_NEW )
1432                        {
1433                        /* We're scanning a new file or input source.  It's
1434                         * possible that this happened because the user
1435                         * just pointed yyin at a new source and called
1436                         * yylex().  If so, then we have to assure
1437                         * consistency between yy_current_buffer and our
1438                         * globals.  Here is the right place to do so, because
1439                         * this is the first action (other than possibly a
1440                         * back-up) that will match for the new input source.
1441                         */
1442                        yy_n_chars = yy_current_buffer->yy_n_chars;
1443                        yy_current_buffer->yy_input_file = yyin;
1444                        yy_current_buffer->yy_buffer_status = YY_BUFFER_NORMAL;
1445                        }
1446
1447                /* Note that here we test for yy_c_buf_p "<=" to the position
1448                 * of the first EOB in the buffer, since yy_c_buf_p will
1449                 * already have been incremented past the NUL character
1450                 * (since all states make transitions on EOB to the
1451                 * end-of-buffer state).  Contrast this with the test
1452                 * in input().
1453                 */
1454                if ( yy_c_buf_p <= &yy_current_buffer->yy_ch_buf[yy_n_chars] )
1455                        { /* This was really a NUL. */
1456                        yy_state_type yy_next_state;
1457
1458                        yy_c_buf_p = yytext_ptr + yy_amount_of_matched_text;
1459
1460                        yy_current_state = yy_get_previous_state();
1461
1462                        /* Okay, we're now positioned to make the NUL
1463                         * transition.  We couldn't have
1464                         * yy_get_previous_state() go ahead and do it
1465                         * for us because it doesn't know how to deal
1466                         * with the possibility of jamming (and we don't
1467                         * want to build jamming into it because then it
1468                         * will run more slowly).
1469                         */
1470
1471                        yy_next_state = yy_try_NUL_trans( yy_current_state );
1472
1473                        yy_bp = yytext_ptr + YY_MORE_ADJ;
1474
1475                        if ( yy_next_state )
1476                                {
1477                                /* Consume the NUL. */
1478                                yy_cp = ++yy_c_buf_p;
1479                                yy_current_state = yy_next_state;
1480                                goto yy_match;
1481                                }
1482
1483                        else
1484                                {
1485                                yy_cp = yy_c_buf_p;
1486                                goto yy_find_action;
1487                                }
1488                        }
1489
1490                else switch ( yy_get_next_buffer() )
1491                        {
1492                        case EOB_ACT_END_OF_FILE:
1493                                {
1494                                yy_did_buffer_switch_on_eof = 0;
1495
1496                                if ( yywrap() )
1497                                        {
1498                                        /* Note: because we've taken care in
1499                                         * yy_get_next_buffer() to have set up
1500                                         * yytext, we can now set up
1501                                         * yy_c_buf_p so that if some total
1502                                         * hoser (like flex itself) wants to
1503                                         * call the scanner after we return the
1504                                         * YY_NULL, it'll still work - another
1505                                         * YY_NULL will get returned.
1506                                         */
1507                                        yy_c_buf_p = yytext_ptr + YY_MORE_ADJ;
1508
1509                                        yy_act = YY_STATE_EOF(YY_START);
1510                                        goto do_action;
1511                                        }
1512
1513                                else
1514                                        {
1515                                        if ( ! yy_did_buffer_switch_on_eof )
1516                                                YY_NEW_FILE;
1517                                        }
1518                                break;
1519                                }
1520
1521                        case EOB_ACT_CONTINUE_SCAN:
1522                                yy_c_buf_p =
1523                                        yytext_ptr + yy_amount_of_matched_text;
1524
1525                                yy_current_state = yy_get_previous_state();
1526
1527                                yy_cp = yy_c_buf_p;
1528                                yy_bp = yytext_ptr + YY_MORE_ADJ;
1529                                goto yy_match;
1530
1531                        case EOB_ACT_LAST_MATCH:
1532                                yy_c_buf_p =
1533                                &yy_current_buffer->yy_ch_buf[yy_n_chars];
1534
1535                                yy_current_state = yy_get_previous_state();
1536
1537                                yy_cp = yy_c_buf_p;
1538                                yy_bp = yytext_ptr + YY_MORE_ADJ;
1539                                goto yy_find_action;
1540                        }
1541                break;
1542                }
1543
1544        default:
1545                YY_FATAL_ERROR(
1546                        "fatal flex scanner internal error--no action found" );
1547        } /* end of action switch */
1548                } /* end of scanning one token */
1549        } /* end of yylex */
1550
1551
1552/* yy_get_next_buffer - try to read in a new buffer
1553 *
1554 * Returns a code representing an action:
1555 *      EOB_ACT_LAST_MATCH -
1556 *      EOB_ACT_CONTINUE_SCAN - continue scanning from current position
1557 *      EOB_ACT_END_OF_FILE - end of file
1558 */
1559
1560static int yy_get_next_buffer()
1561        {
1562        register char *dest = yy_current_buffer->yy_ch_buf;
1563        register char *source = yytext_ptr;
1564        register int number_to_move, i;
1565        int ret_val;
1566
1567        if ( yy_c_buf_p > &yy_current_buffer->yy_ch_buf[yy_n_chars + 1] )
1568                YY_FATAL_ERROR(
1569                "fatal flex scanner internal error--end of buffer missed" );
1570
1571        if ( yy_current_buffer->yy_fill_buffer == 0 )
1572                { /* Don't try to fill the buffer, so this is an EOF. */
1573                if ( yy_c_buf_p - yytext_ptr - YY_MORE_ADJ == 1 )
1574                        {
1575                        /* We matched a single character, the EOB, so
1576                         * treat this as a final EOF.
1577                         */
1578                        return EOB_ACT_END_OF_FILE;
1579                        }
1580
1581                else
1582                        {
1583                        /* We matched some text prior to the EOB, first
1584                         * process it.
1585                         */
1586                        return EOB_ACT_LAST_MATCH;
1587                        }
1588                }
1589
1590        /* Try to read more data. */
1591
1592        /* First move last chars to start of buffer. */
1593        number_to_move = (int) (yy_c_buf_p - yytext_ptr) - 1;
1594
1595        for ( i = 0; i < number_to_move; ++i )
1596                *(dest++) = *(source++);
1597
1598        if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_EOF_PENDING )
1599                /* don't do the read, it's not guaranteed to return an EOF,
1600                 * just force an EOF
1601                 */
1602                yy_current_buffer->yy_n_chars = yy_n_chars = 0;
1603
1604        else
1605                {
1606                int num_to_read =
1607                        yy_current_buffer->yy_buf_size - number_to_move - 1;
1608
1609                while ( num_to_read <= 0 )
1610                        { /* Not enough room in the buffer - grow it. */
1611#ifdef YY_USES_REJECT
1612                        YY_FATAL_ERROR(
1613"input buffer overflow, can't enlarge buffer because scanner uses REJECT" );
1614#else
1615
1616                        /* just a shorter name for the current buffer */
1617                        YY_BUFFER_STATE b = yy_current_buffer;
1618
1619                        int yy_c_buf_p_offset =
1620                                (int) (yy_c_buf_p - b->yy_ch_buf);
1621
1622                        if ( b->yy_is_our_buffer )
1623                                {
1624                                int new_size = b->yy_buf_size * 2;
1625
1626                                if ( new_size <= 0 )
1627                                        b->yy_buf_size += b->yy_buf_size / 8;
1628                                else
1629                                        b->yy_buf_size *= 2;
1630
1631                                b->yy_ch_buf = (char *)
1632                                        /* Include room in for 2 EOB chars. */
1633                                        yy_flex_realloc( (void *) b->yy_ch_buf,
1634                                                         b->yy_buf_size + 2 );
1635                                }
1636                        else
1637                                /* Can't grow it, we don't own it. */
1638                                b->yy_ch_buf = 0;
1639
1640                        if ( ! b->yy_ch_buf )
1641                                YY_FATAL_ERROR(
1642                                "fatal error - scanner input buffer overflow" );
1643
1644                        yy_c_buf_p = &b->yy_ch_buf[yy_c_buf_p_offset];
1645
1646                        num_to_read = yy_current_buffer->yy_buf_size -
1647                                                number_to_move - 1;
1648#endif
1649                        }
1650
1651                if ( num_to_read > YY_READ_BUF_SIZE )
1652                        num_to_read = YY_READ_BUF_SIZE;
1653
1654                /* Read in more data. */
1655                YY_INPUT( (&yy_current_buffer->yy_ch_buf[number_to_move]),
1656                        yy_n_chars, num_to_read );
1657
1658                yy_current_buffer->yy_n_chars = yy_n_chars;
1659                }
1660
1661        if ( yy_n_chars == 0 )
1662                {
1663                if ( number_to_move == YY_MORE_ADJ )
1664                        {
1665                        ret_val = EOB_ACT_END_OF_FILE;
1666                        yyrestart( yyin );
1667                        }
1668
1669                else
1670                        {
1671                        ret_val = EOB_ACT_LAST_MATCH;
1672                        yy_current_buffer->yy_buffer_status =
1673                                YY_BUFFER_EOF_PENDING;
1674                        }
1675                }
1676
1677        else
1678                ret_val = EOB_ACT_CONTINUE_SCAN;
1679
1680        yy_n_chars += number_to_move;
1681        yy_current_buffer->yy_ch_buf[yy_n_chars] = YY_END_OF_BUFFER_CHAR;
1682        yy_current_buffer->yy_ch_buf[yy_n_chars + 1] = YY_END_OF_BUFFER_CHAR;
1683
1684        yytext_ptr = &yy_current_buffer->yy_ch_buf[0];
1685
1686        return ret_val;
1687        }
1688
1689
1690/* yy_get_previous_state - get the state just before the EOB char was reached */
1691
1692static yy_state_type yy_get_previous_state()
1693        {
1694        register yy_state_type yy_current_state;
1695        register char *yy_cp;
1696
1697        yy_current_state = yy_start;
1698        yy_current_state += YY_AT_BOL();
1699
1700        for ( yy_cp = yytext_ptr + YY_MORE_ADJ; yy_cp < yy_c_buf_p; ++yy_cp )
1701                {
1702                register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1);
1703                if ( yy_accept[yy_current_state] )
1704                        {
1705                        yy_last_accepting_state = yy_current_state;
1706                        yy_last_accepting_cpos = yy_cp;
1707                        }
1708                while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1709                        {
1710                        yy_current_state = (int) yy_def[yy_current_state];
1711                        if ( yy_current_state >= 170 )
1712                                yy_c = yy_meta[(unsigned int) yy_c];
1713                        }
1714                yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1715                }
1716
1717        return yy_current_state;
1718        }
1719
1720
1721/* yy_try_NUL_trans - try to make a transition on the NUL character
1722 *
1723 * synopsis
1724 *      next_state = yy_try_NUL_trans( current_state );
1725 */
1726
1727#ifdef YY_USE_PROTOS
1728static yy_state_type yy_try_NUL_trans( yy_state_type yy_current_state )
1729#else
1730static yy_state_type yy_try_NUL_trans( yy_current_state )
1731yy_state_type yy_current_state;
1732#endif
1733        {
1734        register int yy_is_jam;
1735        register char *yy_cp = yy_c_buf_p;
1736
1737        register YY_CHAR yy_c = 1;
1738        if ( yy_accept[yy_current_state] )
1739                {
1740                yy_last_accepting_state = yy_current_state;
1741                yy_last_accepting_cpos = yy_cp;
1742                }
1743        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1744                {
1745                yy_current_state = (int) yy_def[yy_current_state];
1746                if ( yy_current_state >= 170 )
1747                        yy_c = yy_meta[(unsigned int) yy_c];
1748                }
1749        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1750        yy_is_jam = (yy_current_state == 169);
1751
1752        return yy_is_jam ? 0 : yy_current_state;
1753        }
1754
1755
1756#ifndef YY_NO_UNPUT
1757#ifdef YY_USE_PROTOS
1758static void yyunput( int c, register char *yy_bp )
1759#else
1760static void yyunput( c, yy_bp )
1761int c;
1762register char *yy_bp;
1763#endif
1764        {
1765        register char *yy_cp = yy_c_buf_p;
1766
1767        /* undo effects of setting up yytext */
1768        *yy_cp = yy_hold_char;
1769
1770        if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 )
1771                { /* need to shift things up to make room */
1772                /* +2 for EOB chars. */
1773                register int number_to_move = yy_n_chars + 2;
1774                register char *dest = &yy_current_buffer->yy_ch_buf[
1775                                        yy_current_buffer->yy_buf_size + 2];
1776                register char *source =
1777                                &yy_current_buffer->yy_ch_buf[number_to_move];
1778
1779                while ( source > yy_current_buffer->yy_ch_buf )
1780                        *--dest = *--source;
1781
1782                yy_cp += (int) (dest - source);
1783                yy_bp += (int) (dest - source);
1784                yy_current_buffer->yy_n_chars =
1785                        yy_n_chars = yy_current_buffer->yy_buf_size;
1786
1787                if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 )
1788                        YY_FATAL_ERROR( "flex scanner push-back overflow" );
1789                }
1790
1791        *--yy_cp = (char) c;
1792
1793
1794        yytext_ptr = yy_bp;
1795        yy_hold_char = *yy_cp;
1796        yy_c_buf_p = yy_cp;
1797        }
1798#endif  /* ifndef YY_NO_UNPUT */
1799
1800
1801#ifdef __cplusplus
1802static int yyinput()
1803#else
1804static int input()
1805#endif
1806        {
1807        int c;
1808
1809        *yy_c_buf_p = yy_hold_char;
1810
1811        if ( *yy_c_buf_p == YY_END_OF_BUFFER_CHAR )
1812                {
1813                /* yy_c_buf_p now points to the character we want to return.
1814                 * If this occurs *before* the EOB characters, then it's a
1815                 * valid NUL; if not, then we've hit the end of the buffer.
1816                 */
1817                if ( yy_c_buf_p < &yy_current_buffer->yy_ch_buf[yy_n_chars] )
1818                        /* This was really a NUL. */
1819                        *yy_c_buf_p = '\0';
1820
1821                else
1822                        { /* need more input */
1823                        int offset = yy_c_buf_p - yytext_ptr;
1824                        ++yy_c_buf_p;
1825
1826                        switch ( yy_get_next_buffer() )
1827                                {
1828                                case EOB_ACT_LAST_MATCH:
1829                                        /* This happens because yy_g_n_b()
1830                                         * sees that we've accumulated a
1831                                         * token and flags that we need to
1832                                         * try matching the token before
1833                                         * proceeding.  But for input(),
1834                                         * there's no matching to consider.
1835                                         * So convert the EOB_ACT_LAST_MATCH
1836                                         * to EOB_ACT_END_OF_FILE.
1837                                         */
1838
1839                                        /* Reset buffer status. */
1840                                        yyrestart( yyin );
1841
1842                                        /* fall through */
1843
1844                                case EOB_ACT_END_OF_FILE:
1845                                        {
1846                                        if ( yywrap() )
1847                                                return EOF;
1848
1849                                        if ( ! yy_did_buffer_switch_on_eof )
1850                                                YY_NEW_FILE;
1851#ifdef __cplusplus
1852                                        return yyinput();
1853#else
1854                                        return input();
1855#endif
1856                                        }
1857
1858                                case EOB_ACT_CONTINUE_SCAN:
1859                                        yy_c_buf_p = yytext_ptr + offset;
1860                                        break;
1861                                }
1862                        }
1863                }
1864
1865        c = *(unsigned char *) yy_c_buf_p;      /* cast for 8-bit char's */
1866        *yy_c_buf_p = '\0';     /* preserve yytext */
1867        yy_hold_char = *++yy_c_buf_p;
1868
1869        yy_current_buffer->yy_at_bol = (c == '\n');
1870
1871        return c;
1872        }
1873
1874
1875#ifdef YY_USE_PROTOS
1876void yyrestart( FILE *input_file )
1877#else
1878void yyrestart( input_file )
1879FILE *input_file;
1880#endif
1881        {
1882        if ( ! yy_current_buffer )
1883                yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE );
1884
1885        yy_init_buffer( yy_current_buffer, input_file );
1886        yy_load_buffer_state();
1887        }
1888
1889
1890#ifdef YY_USE_PROTOS
1891void yy_switch_to_buffer( YY_BUFFER_STATE new_buffer )
1892#else
1893void yy_switch_to_buffer( new_buffer )
1894YY_BUFFER_STATE new_buffer;
1895#endif
1896        {
1897        if ( yy_current_buffer == new_buffer )
1898                return;
1899
1900        if ( yy_current_buffer )
1901                {
1902                /* Flush out information for old buffer. */
1903                *yy_c_buf_p = yy_hold_char;
1904                yy_current_buffer->yy_buf_pos = yy_c_buf_p;
1905                yy_current_buffer->yy_n_chars = yy_n_chars;
1906                }
1907
1908        yy_current_buffer = new_buffer;
1909        yy_load_buffer_state();
1910
1911        /* We don't actually know whether we did this switch during
1912         * EOF (yywrap()) processing, but the only time this flag
1913         * is looked at is after yywrap() is called, so it's safe
1914         * to go ahead and always set it.
1915         */
1916        yy_did_buffer_switch_on_eof = 1;
1917        }
1918
1919
1920#ifdef YY_USE_PROTOS
1921void yy_load_buffer_state( void )
1922#else
1923void yy_load_buffer_state()
1924#endif
1925        {
1926        yy_n_chars = yy_current_buffer->yy_n_chars;
1927        yytext_ptr = yy_c_buf_p = yy_current_buffer->yy_buf_pos;
1928        yyin = yy_current_buffer->yy_input_file;
1929        yy_hold_char = *yy_c_buf_p;
1930        }
1931
1932
1933#ifdef YY_USE_PROTOS
1934YY_BUFFER_STATE yy_create_buffer( FILE *file, int size )
1935#else
1936YY_BUFFER_STATE yy_create_buffer( file, size )
1937FILE *file;
1938int size;
1939#endif
1940        {
1941        YY_BUFFER_STATE b;
1942
1943        b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) );
1944        if ( ! b )
1945                YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" );
1946
1947        b->yy_buf_size = size;
1948
1949        /* yy_ch_buf has to be 2 characters longer than the size given because
1950         * we need to put in 2 end-of-buffer characters.
1951         */
1952        b->yy_ch_buf = (char *) yy_flex_alloc( b->yy_buf_size + 2 );
1953        if ( ! b->yy_ch_buf )
1954                YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" );
1955
1956        b->yy_is_our_buffer = 1;
1957
1958        yy_init_buffer( b, file );
1959
1960        return b;
1961        }
1962
1963
1964#ifdef YY_USE_PROTOS
1965void yy_delete_buffer( YY_BUFFER_STATE b )
1966#else
1967void yy_delete_buffer( b )
1968YY_BUFFER_STATE b;
1969#endif
1970        {
1971        if ( ! b )
1972                return;
1973
1974        if ( b == yy_current_buffer )
1975                yy_current_buffer = (YY_BUFFER_STATE) 0;
1976
1977        if ( b->yy_is_our_buffer )
1978                yy_flex_free( (void *) b->yy_ch_buf );
1979
1980        yy_flex_free( (void *) b );
1981        }
1982
1983
1984#ifndef YY_ALWAYS_INTERACTIVE
1985#ifndef YY_NEVER_INTERACTIVE
1986extern int isatty YY_PROTO(( int ));
1987#endif
1988#endif
1989
1990#ifdef YY_USE_PROTOS
1991void yy_init_buffer( YY_BUFFER_STATE b, FILE *file )
1992#else
1993void yy_init_buffer( b, file )
1994YY_BUFFER_STATE b;
1995FILE *file;
1996#endif
1997
1998
1999        {
2000        yy_flush_buffer( b );
2001
2002        b->yy_input_file = file;
2003        b->yy_fill_buffer = 1;
2004
2005#if YY_ALWAYS_INTERACTIVE
2006        b->yy_is_interactive = 1;
2007#else
2008#if YY_NEVER_INTERACTIVE
2009        b->yy_is_interactive = 0;
2010#else
2011        b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0;
2012#endif
2013#endif
2014        }
2015
2016
2017#ifdef YY_USE_PROTOS
2018void yy_flush_buffer( YY_BUFFER_STATE b )
2019#else
2020void yy_flush_buffer( b )
2021YY_BUFFER_STATE b;
2022#endif
2023
2024        {
2025        if ( ! b )
2026                return;
2027
2028        b->yy_n_chars = 0;
2029
2030        /* We always need two end-of-buffer characters.  The first causes
2031         * a transition to the end-of-buffer state.  The second causes
2032         * a jam in that state.
2033         */
2034        b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR;
2035        b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR;
2036
2037        b->yy_buf_pos = &b->yy_ch_buf[0];
2038
2039        b->yy_at_bol = 1;
2040        b->yy_buffer_status = YY_BUFFER_NEW;
2041
2042        if ( b == yy_current_buffer )
2043                yy_load_buffer_state();
2044        }
2045
2046
2047#ifndef YY_NO_SCAN_BUFFER
2048#ifdef YY_USE_PROTOS
2049YY_BUFFER_STATE yy_scan_buffer( char *base, yy_size_t size )
2050#else
2051YY_BUFFER_STATE yy_scan_buffer( base, size )
2052char *base;
2053yy_size_t size;
2054#endif
2055        {
2056        YY_BUFFER_STATE b;
2057
2058        if ( size < 2 ||
2059             base[size-2] != YY_END_OF_BUFFER_CHAR ||
2060             base[size-1] != YY_END_OF_BUFFER_CHAR )
2061                /* They forgot to leave room for the EOB's. */
2062                return 0;
2063
2064        b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) );
2065        if ( ! b )
2066                YY_FATAL_ERROR( "out of dynamic memory in yy_scan_buffer()" );
2067
2068        b->yy_buf_size = size - 2;      /* "- 2" to take care of EOB's */
2069        b->yy_buf_pos = b->yy_ch_buf = base;
2070        b->yy_is_our_buffer = 0;
2071        b->yy_input_file = 0;
2072        b->yy_n_chars = b->yy_buf_size;
2073        b->yy_is_interactive = 0;
2074        b->yy_at_bol = 1;
2075        b->yy_fill_buffer = 0;
2076        b->yy_buffer_status = YY_BUFFER_NEW;
2077
2078        yy_switch_to_buffer( b );
2079
2080        return b;
2081        }
2082#endif
2083
2084
2085#ifndef YY_NO_SCAN_STRING
2086#ifdef YY_USE_PROTOS
2087YY_BUFFER_STATE yy_scan_string( yyconst char *yy_str )
2088#else
2089YY_BUFFER_STATE yy_scan_string( yy_str )
2090yyconst char *yy_str;
2091#endif
2092        {
2093        int len;
2094        for ( len = 0; yy_str[len]; ++len )
2095                ;
2096
2097        return yy_scan_bytes( yy_str, len );
2098        }
2099#endif
2100
2101
2102#ifndef YY_NO_SCAN_BYTES
2103#ifdef YY_USE_PROTOS
2104YY_BUFFER_STATE yy_scan_bytes( yyconst char *bytes, int len )
2105#else
2106YY_BUFFER_STATE yy_scan_bytes( bytes, len )
2107yyconst char *bytes;
2108int len;
2109#endif
2110        {
2111        YY_BUFFER_STATE b;
2112        char *buf;
2113        yy_size_t n;
2114        int i;
2115
2116        /* Get memory for full buffer, including space for trailing EOB's. */
2117        n = len + 2;
2118        buf = (char *) yy_flex_alloc( n );
2119        if ( ! buf )
2120                YY_FATAL_ERROR( "out of dynamic memory in yy_scan_bytes()" );
2121
2122        for ( i = 0; i < len; ++i )
2123                buf[i] = bytes[i];
2124
2125        buf[len] = buf[len+1] = YY_END_OF_BUFFER_CHAR;
2126
2127        b = yy_scan_buffer( buf, n );
2128        if ( ! b )
2129                YY_FATAL_ERROR( "bad buffer in yy_scan_bytes()" );
2130
2131        /* It's okay to grow etc. this buffer, and we should throw it
2132         * away when we're done.
2133         */
2134        b->yy_is_our_buffer = 1;
2135
2136        return b;
2137        }
2138#endif
2139
2140
2141#ifndef YY_NO_PUSH_STATE
2142#ifdef YY_USE_PROTOS
2143static void yy_push_state( int new_state )
2144#else
2145static void yy_push_state( new_state )
2146int new_state;
2147#endif
2148        {
2149        if ( yy_start_stack_ptr >= yy_start_stack_depth )
2150                {
2151                yy_size_t new_size;
2152
2153                yy_start_stack_depth += YY_START_STACK_INCR;
2154                new_size = yy_start_stack_depth * sizeof( int );
2155
2156                if ( ! yy_start_stack )
2157                        yy_start_stack = (int *) yy_flex_alloc( new_size );
2158
2159                else
2160                        yy_start_stack = (int *) yy_flex_realloc(
2161                                        (void *) yy_start_stack, new_size );
2162
2163                if ( ! yy_start_stack )
2164                        YY_FATAL_ERROR(
2165                        "out of memory expanding start-condition stack" );
2166                }
2167
2168        yy_start_stack[yy_start_stack_ptr++] = YY_START;
2169
2170        BEGIN(new_state);
2171        }
2172#endif
2173
2174
2175#ifndef YY_NO_POP_STATE
2176static void yy_pop_state()
2177        {
2178        if ( --yy_start_stack_ptr < 0 )
2179                YY_FATAL_ERROR( "start-condition stack underflow" );
2180
2181        BEGIN(yy_start_stack[yy_start_stack_ptr]);
2182        }
2183#endif
2184
2185
2186#ifndef YY_NO_TOP_STATE
2187static int yy_top_state()
2188        {
2189        return yy_start_stack[yy_start_stack_ptr - 1];
2190        }
2191#endif
2192
2193#ifndef YY_EXIT_FAILURE
2194#define YY_EXIT_FAILURE 2
2195#endif
2196
2197#ifdef YY_USE_PROTOS
2198static void yy_fatal_error( yyconst char msg[] )
2199#else
2200static void yy_fatal_error( msg )
2201char msg[];
2202#endif
2203        {
2204        (void) fprintf( stderr, "%s\n", msg );
2205        exit( YY_EXIT_FAILURE );
2206        }
2207
2208
2209
2210/* Redefine yyless() so it works in section 3 code. */
2211
2212#undef yyless
2213#define yyless(n) \
2214        do \
2215                { \
2216                /* Undo effects of setting up yytext. */ \
2217                yytext[yyleng] = yy_hold_char; \
2218                yy_c_buf_p = yytext + n; \
2219                yy_hold_char = *yy_c_buf_p; \
2220                *yy_c_buf_p = '\0'; \
2221                yyleng = n; \
2222                } \
2223        while ( 0 )
2224
2225
2226/* Internal utility routines. */
2227
2228#ifndef yytext_ptr
2229#ifdef YY_USE_PROTOS
2230static void yy_flex_strncpy( char *s1, yyconst char *s2, int n )
2231#else
2232static void yy_flex_strncpy( s1, s2, n )
2233char *s1;
2234yyconst char *s2;
2235int n;
2236#endif
2237        {
2238        register int i;
2239        for ( i = 0; i < n; ++i )
2240                s1[i] = s2[i];
2241        }
2242#endif
2243
2244#ifdef YY_NEED_STRLEN
2245#ifdef YY_USE_PROTOS
2246static int yy_flex_strlen( yyconst char *s )
2247#else
2248static int yy_flex_strlen( s )
2249yyconst char *s;
2250#endif
2251        {
2252        register int n;
2253        for ( n = 0; s[n]; ++n )
2254                ;
2255
2256        return n;
2257        }
2258#endif
2259
2260
2261#ifdef YY_USE_PROTOS
2262static void *yy_flex_alloc( yy_size_t size )
2263#else
2264static void *yy_flex_alloc( size )
2265yy_size_t size;
2266#endif
2267        {
2268        return (void *) malloc( size );
2269        }
2270
2271#ifdef YY_USE_PROTOS
2272static void *yy_flex_realloc( void *ptr, yy_size_t size )
2273#else
2274static void *yy_flex_realloc( ptr, size )
2275void *ptr;
2276yy_size_t size;
2277#endif
2278        {
2279        /* The cast to (char *) in the following accommodates both
2280         * implementations that use char* generic pointers, and those
2281         * that use void* generic pointers.  It works with the latter
2282         * because both ANSI C and C++ allow castless assignment from
2283         * any pointer type to void*, and deal with argument conversions
2284         * as though doing an assignment.
2285         */
2286        return (void *) realloc( (char *) ptr, size );
2287        }
2288
2289#ifdef YY_USE_PROTOS
2290static void yy_flex_free( void *ptr )
2291#else
2292static void yy_flex_free( ptr )
2293void *ptr;
2294#endif
2295        {
2296        free( ptr );
2297        }
2298
2299#if YY_MAIN
2300int main()
2301        {
2302        yylex();
2303        return 0;
2304        }
2305#endif
2306#line 365 "scanner.l"
2307
2308
2309void * myynewbuffer()
2310{
2311  void * oldb = yy_current_buffer;
2312  yy_switch_to_buffer(yy_create_buffer(NULL, YY_BUF_SIZE));
2313  return oldb;
2314}
2315
2316void myyoldbuffer(void * oldb)
2317{
2318  yy_delete_buffer(yy_current_buffer);
2319  yy_switch_to_buffer((YY_BUFFER_STATE)oldb);
2320  //yy_flush_buffer((YY_BUFFER_STATE)oldb);
2321}
Note: See TracBrowser for help on using the repository browser.