]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/amd/fsinfo/null_lex.c
Copy libevent sources to contrib
[FreeBSD/FreeBSD.git] / contrib / amd / fsinfo / null_lex.c
1
2 #line 3 "lex.null_.c"
3
4 #define  YY_INT_ALIGNED short int
5
6 /* A lexical scanner generated by flex */
7
8 #define yy_create_buffer null__create_buffer
9 #define yy_delete_buffer null__delete_buffer
10 #define yy_flex_debug null__flex_debug
11 #define yy_init_buffer null__init_buffer
12 #define yy_flush_buffer null__flush_buffer
13 #define yy_load_buffer_state null__load_buffer_state
14 #define yy_switch_to_buffer null__switch_to_buffer
15 #define yyin null_in
16 #define yyleng null_leng
17 #define yylex null_lex
18 #define yylineno null_lineno
19 #define yyout null_out
20 #define yyrestart null_restart
21 #define yytext null_text
22 #define yywrap null_wrap
23 #define yyalloc null_alloc
24 #define yyrealloc null_realloc
25 #define yyfree null_free
26
27 #define FLEX_SCANNER
28 #define YY_FLEX_MAJOR_VERSION 2
29 #define YY_FLEX_MINOR_VERSION 5
30 #define YY_FLEX_SUBMINOR_VERSION 35
31 #if YY_FLEX_SUBMINOR_VERSION > 0
32 #define FLEX_BETA
33 #endif
34
35 /* First, we deal with  platform-specific or compiler-specific issues. */
36
37 /* begin standard C headers. */
38 #include <stdio.h>
39 #include <string.h>
40 #include <errno.h>
41 #include <stdlib.h>
42
43 /* end standard C headers. */
44
45 /* flex integer type definitions */
46
47 #ifndef FLEXINT_H
48 #define FLEXINT_H
49
50 /* C99 systems have <inttypes.h>. Non-C99 systems may or may not. */
51
52 #if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
53
54 /* C99 says to define __STDC_LIMIT_MACROS before including stdint.h,
55  * if you want the limit (max/min) macros for int types. 
56  */
57 #ifndef __STDC_LIMIT_MACROS
58 #define __STDC_LIMIT_MACROS 1
59 #endif
60
61 #include <inttypes.h>
62 typedef int8_t flex_int8_t;
63 typedef uint8_t flex_uint8_t;
64 typedef int16_t flex_int16_t;
65 typedef uint16_t flex_uint16_t;
66 typedef int32_t flex_int32_t;
67 typedef uint32_t flex_uint32_t;
68 #else
69 typedef signed char flex_int8_t;
70 typedef short int flex_int16_t;
71 typedef int flex_int32_t;
72 typedef unsigned char flex_uint8_t; 
73 typedef unsigned short int flex_uint16_t;
74 typedef unsigned int flex_uint32_t;
75
76 /* Limits of integral types. */
77 #ifndef INT8_MIN
78 #define INT8_MIN               (-128)
79 #endif
80 #ifndef INT16_MIN
81 #define INT16_MIN              (-32767-1)
82 #endif
83 #ifndef INT32_MIN
84 #define INT32_MIN              (-2147483647-1)
85 #endif
86 #ifndef INT8_MAX
87 #define INT8_MAX               (127)
88 #endif
89 #ifndef INT16_MAX
90 #define INT16_MAX              (32767)
91 #endif
92 #ifndef INT32_MAX
93 #define INT32_MAX              (2147483647)
94 #endif
95 #ifndef UINT8_MAX
96 #define UINT8_MAX              (255U)
97 #endif
98 #ifndef UINT16_MAX
99 #define UINT16_MAX             (65535U)
100 #endif
101 #ifndef UINT32_MAX
102 #define UINT32_MAX             (4294967295U)
103 #endif
104
105 #endif /* ! C99 */
106
107 #endif /* ! FLEXINT_H */
108
109 #ifdef __cplusplus
110
111 /* The "const" storage-class-modifier is valid. */
112 #define YY_USE_CONST
113
114 #else   /* ! __cplusplus */
115
116 /* C99 requires __STDC__ to be defined as 1. */
117 #if defined (__STDC__)
118
119 #define YY_USE_CONST
120
121 #endif  /* defined (__STDC__) */
122 #endif  /* ! __cplusplus */
123
124 #ifdef YY_USE_CONST
125 #define yyconst const
126 #else
127 #define yyconst
128 #endif
129
130 /* Returned upon end-of-file. */
131 #define YY_NULL 0
132
133 /* Promotes a possibly negative, possibly signed char to an unsigned
134  * integer for use as an array index.  If the signed char is negative,
135  * we want to instead treat it as an 8-bit unsigned char, hence the
136  * double cast.
137  */
138 #define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c)
139
140 /* Enter a start condition.  This macro really ought to take a parameter,
141  * but we do it the disgusting crufty way forced on us by the ()-less
142  * definition of BEGIN.
143  */
144 #define BEGIN (yy_start) = 1 + 2 *
145
146 /* Translate the current start state into a value that can be later handed
147  * to BEGIN to return to the state.  The YYSTATE alias is for lex
148  * compatibility.
149  */
150 #define YY_START (((yy_start) - 1) / 2)
151 #define YYSTATE YY_START
152
153 /* Action number for EOF rule of a given start state. */
154 #define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1)
155
156 /* Special action meaning "start processing a new file". */
157 #define YY_NEW_FILE null_restart(null_in  )
158
159 #define YY_END_OF_BUFFER_CHAR 0
160
161 /* Size of default input buffer. */
162 #ifndef YY_BUF_SIZE
163 #ifdef __ia64__
164 /* On IA-64, the buffer size is 16k, not 8k.
165  * Moreover, YY_BUF_SIZE is 2*YY_READ_BUF_SIZE in the general case.
166  * Ditto for the __ia64__ case accordingly.
167  */
168 #define YY_BUF_SIZE 32768
169 #else
170 #define YY_BUF_SIZE 16384
171 #endif /* __ia64__ */
172 #endif
173
174 /* The state buf must be large enough to hold one state per character in the main buffer.
175  */
176 #define YY_STATE_BUF_SIZE   ((YY_BUF_SIZE + 2) * sizeof(yy_state_type))
177
178 #ifndef YY_TYPEDEF_YY_BUFFER_STATE
179 #define YY_TYPEDEF_YY_BUFFER_STATE
180 typedef struct yy_buffer_state *YY_BUFFER_STATE;
181 #endif
182
183 extern int null_leng;
184
185 extern FILE *null_in, *null_out;
186
187 #define EOB_ACT_CONTINUE_SCAN 0
188 #define EOB_ACT_END_OF_FILE 1
189 #define EOB_ACT_LAST_MATCH 2
190
191     #define YY_LESS_LINENO(n)
192     
193 /* Return all but the first "n" matched characters back to the input stream. */
194 #define yyless(n) \
195         do \
196                 { \
197                 /* Undo effects of setting up null_text. */ \
198         int yyless_macro_arg = (n); \
199         YY_LESS_LINENO(yyless_macro_arg);\
200                 *yy_cp = (yy_hold_char); \
201                 YY_RESTORE_YY_MORE_OFFSET \
202                 (yy_c_buf_p) = yy_cp = yy_bp + yyless_macro_arg - YY_MORE_ADJ; \
203                 YY_DO_BEFORE_ACTION; /* set up null_text again */ \
204                 } \
205         while ( 0 )
206
207 #define unput(c) yyunput( c, (yytext_ptr)  )
208
209 #ifndef YY_TYPEDEF_YY_SIZE_T
210 #define YY_TYPEDEF_YY_SIZE_T
211 typedef size_t yy_size_t;
212 #endif
213
214 #ifndef YY_STRUCT_YY_BUFFER_STATE
215 #define YY_STRUCT_YY_BUFFER_STATE
216 struct yy_buffer_state
217         {
218         FILE *yy_input_file;
219
220         char *yy_ch_buf;                /* input buffer */
221         char *yy_buf_pos;               /* current position in input buffer */
222
223         /* Size of input buffer in bytes, not including room for EOB
224          * characters.
225          */
226         yy_size_t yy_buf_size;
227
228         /* Number of characters read into yy_ch_buf, not including EOB
229          * characters.
230          */
231         int yy_n_chars;
232
233         /* Whether we "own" the buffer - i.e., we know we created it,
234          * and can realloc() it to grow it, and should free() it to
235          * delete it.
236          */
237         int yy_is_our_buffer;
238
239         /* Whether this is an "interactive" input source; if so, and
240          * if we're using stdio for input, then we want to use getc()
241          * instead of fread(), to make sure we stop fetching input after
242          * each newline.
243          */
244         int yy_is_interactive;
245
246         /* Whether we're considered to be at the beginning of a line.
247          * If so, '^' rules will be active on the next match, otherwise
248          * not.
249          */
250         int yy_at_bol;
251
252     int yy_bs_lineno; /**< The line count. */
253     int yy_bs_column; /**< The column count. */
254     
255         /* Whether to try to fill the input buffer when we reach the
256          * end of it.
257          */
258         int yy_fill_buffer;
259
260         int yy_buffer_status;
261
262 #define YY_BUFFER_NEW 0
263 #define YY_BUFFER_NORMAL 1
264         /* When an EOF's been seen but there's still some text to process
265          * then we mark the buffer as YY_EOF_PENDING, to indicate that we
266          * shouldn't try reading from the input source any more.  We might
267          * still have a bunch of tokens to match, though, because of
268          * possible backing-up.
269          *
270          * When we actually see the EOF, we change the status to "new"
271          * (via null_restart()), so that the user can continue scanning by
272          * just pointing null_in at a new input file.
273          */
274 #define YY_BUFFER_EOF_PENDING 2
275
276         };
277 #endif /* !YY_STRUCT_YY_BUFFER_STATE */
278
279 /* Stack of input buffers. */
280 static size_t yy_buffer_stack_top = 0; /**< index of top of stack. */
281 static size_t yy_buffer_stack_max = 0; /**< capacity of stack. */
282 static YY_BUFFER_STATE * yy_buffer_stack = 0; /**< Stack as an array. */
283
284 /* We provide macros for accessing buffer states in case in the
285  * future we want to put the buffer states in a more general
286  * "scanner state".
287  *
288  * Returns the top of the stack, or NULL.
289  */
290 #define YY_CURRENT_BUFFER ( (yy_buffer_stack) \
291                           ? (yy_buffer_stack)[(yy_buffer_stack_top)] \
292                           : NULL)
293
294 /* Same as previous macro, but useful when we know that the buffer stack is not
295  * NULL or when we need an lvalue. For internal use only.
296  */
297 #define YY_CURRENT_BUFFER_LVALUE (yy_buffer_stack)[(yy_buffer_stack_top)]
298
299 /* yy_hold_char holds the character lost when null_text is formed. */
300 static char yy_hold_char;
301 static int yy_n_chars;          /* number of characters read into yy_ch_buf */
302 int null_leng;
303
304 /* Points to current character in buffer. */
305 static char *yy_c_buf_p = (char *) 0;
306 static int yy_init = 0;         /* whether we need to initialize */
307 static int yy_start = 0;        /* start state number */
308
309 /* Flag which is used to allow null_wrap()'s to do buffer switches
310  * instead of setting up a fresh null_in.  A bit of a hack ...
311  */
312 static int yy_did_buffer_switch_on_eof;
313
314 void null_restart (FILE *input_file  );
315 void null__switch_to_buffer (YY_BUFFER_STATE new_buffer  );
316 YY_BUFFER_STATE null__create_buffer (FILE *file,int size  );
317 void null__delete_buffer (YY_BUFFER_STATE b  );
318 void null__flush_buffer (YY_BUFFER_STATE b  );
319 void null_push_buffer_state (YY_BUFFER_STATE new_buffer  );
320 void null_pop_buffer_state (void );
321
322 static void null_ensure_buffer_stack (void );
323 static void null__load_buffer_state (void );
324 static void null__init_buffer (YY_BUFFER_STATE b,FILE *file  );
325
326 #define YY_FLUSH_BUFFER null__flush_buffer(YY_CURRENT_BUFFER )
327
328 YY_BUFFER_STATE null__scan_buffer (char *base,yy_size_t size  );
329 YY_BUFFER_STATE null__scan_string (yyconst char *yy_str  );
330 YY_BUFFER_STATE null__scan_bytes (yyconst char *bytes,int len  );
331
332 void *null_alloc (yy_size_t  );
333 void *null_realloc (void *,yy_size_t  );
334 void null_free (void *  );
335
336 #define yy_new_buffer null__create_buffer
337
338 #define yy_set_interactive(is_interactive) \
339         { \
340         if ( ! YY_CURRENT_BUFFER ){ \
341         null_ensure_buffer_stack (); \
342                 YY_CURRENT_BUFFER_LVALUE =    \
343             null__create_buffer(null_in,YY_BUF_SIZE ); \
344         } \
345         YY_CURRENT_BUFFER_LVALUE->yy_is_interactive = is_interactive; \
346         }
347
348 #define yy_set_bol(at_bol) \
349         { \
350         if ( ! YY_CURRENT_BUFFER ){\
351         null_ensure_buffer_stack (); \
352                 YY_CURRENT_BUFFER_LVALUE =    \
353             null__create_buffer(null_in,YY_BUF_SIZE ); \
354         } \
355         YY_CURRENT_BUFFER_LVALUE->yy_at_bol = at_bol; \
356         }
357
358 #define YY_AT_BOL() (YY_CURRENT_BUFFER_LVALUE->yy_at_bol)
359
360 typedef unsigned char YY_CHAR;
361
362 FILE *null_in = (FILE *) 0, *null_out = (FILE *) 0;
363
364 typedef int yy_state_type;
365
366 extern int null_lineno;
367
368 int null_lineno = 1;
369
370 extern char *null_text;
371 #define yytext_ptr null_text
372
373 static yy_state_type yy_get_previous_state (void );
374 static yy_state_type yy_try_NUL_trans (yy_state_type current_state  );
375 static int yy_get_next_buffer (void );
376 static void yy_fatal_error (yyconst char msg[]  );
377
378 /* Done after the current pattern has been matched and before the
379  * corresponding action - sets up null_text.
380  */
381 #define YY_DO_BEFORE_ACTION \
382         (yytext_ptr) = yy_bp; \
383         null_leng = (size_t) (yy_cp - yy_bp); \
384         (yy_hold_char) = *yy_cp; \
385         *yy_cp = '\0'; \
386         (yy_c_buf_p) = yy_cp;
387
388 #define YY_NUM_RULES 1
389 #define YY_END_OF_BUFFER 2
390 /* This struct is not used in this scanner,
391    but its presence is necessary. */
392 struct yy_trans_info
393         {
394         flex_int32_t yy_verify;
395         flex_int32_t yy_nxt;
396         };
397 static yyconst flex_int16_t yy_accept[6] =
398     {   0,
399         0,    0,    2,    1,    0
400     } ;
401
402 static yyconst flex_int32_t yy_ec[256] =
403     {   0,
404         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
405         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
406         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
407         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
408         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
409         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
410         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
411         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
412         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
413         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
414
415         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
416         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
417         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
418         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
419         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
420         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
421         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
422         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
423         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
424         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
425
426         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
427         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
428         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
429         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
430         1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
431         1,    1,    1,    1,    1
432     } ;
433
434 static yyconst flex_int32_t yy_meta[2] =
435     {   0,
436         1
437     } ;
438
439 static yyconst flex_int16_t yy_base[7] =
440     {   0,
441         0,    0,    2,    3,    3,    0
442     } ;
443
444 static yyconst flex_int16_t yy_def[7] =
445     {   0,
446         6,    6,    5,    5,    0,    5
447     } ;
448
449 static yyconst flex_int16_t yy_nxt[5] =
450     {   0,
451         4,    5,    3,    5
452     } ;
453
454 static yyconst flex_int16_t yy_chk[5] =
455     {   0,
456         6,    3,    5,    5
457     } ;
458
459 static yy_state_type yy_last_accepting_state;
460 static char *yy_last_accepting_cpos;
461
462 extern int null__flex_debug;
463 int null__flex_debug = 0;
464
465 /* The intent behind this definition is that it'll catch
466  * any uses of REJECT which flex missed.
467  */
468 #define REJECT reject_used_but_not_detected
469 #define yymore() yymore_used_but_not_detected
470 #define YY_MORE_ADJ 0
471 #define YY_RESTORE_YY_MORE_OFFSET
472 char *null_text;
473 #line 1 "../../fsinfo/null_lex.l"
474 #line 2 "../../fsinfo/null_lex.l"
475 #include "null_gram.h"
476
477 void null_error(const char *fmt, ...) {}
478 int null_wrap(void) { return 0; }
479 #define YY_NO_INPUT 1
480 #line 481 "lex.null_.c"
481
482 #define INITIAL 0
483
484 #ifndef YY_NO_UNISTD_H
485 /* Special case for "unistd.h", since it is non-ANSI. We include it way
486  * down here because we want the user's section 1 to have been scanned first.
487  * The user has a chance to override it with an option.
488  */
489 #include <unistd.h>
490 #endif
491
492 #ifndef YY_EXTRA_TYPE
493 #define YY_EXTRA_TYPE void *
494 #endif
495
496 static int yy_init_globals (void );
497
498 /* Accessor methods to globals.
499    These are made visible to non-reentrant scanners for convenience. */
500
501 int null_lex_destroy (void );
502
503 int null_get_debug (void );
504
505 void null_set_debug (int debug_flag  );
506
507 YY_EXTRA_TYPE null_get_extra (void );
508
509 void null_set_extra (YY_EXTRA_TYPE user_defined  );
510
511 FILE *null_get_in (void );
512
513 void null_set_in  (FILE * in_str  );
514
515 FILE *null_get_out (void );
516
517 void null_set_out  (FILE * out_str  );
518
519 int null_get_leng (void );
520
521 char *null_get_text (void );
522
523 int null_get_lineno (void );
524
525 void null_set_lineno (int line_number  );
526
527 /* Macros after this point can all be overridden by user definitions in
528  * section 1.
529  */
530
531 #ifndef YY_SKIP_YYWRAP
532 #ifdef __cplusplus
533 extern "C" int null_wrap (void );
534 #else
535 extern int null_wrap (void );
536 #endif
537 #endif
538
539 #ifndef yytext_ptr
540 static void yy_flex_strncpy (char *,yyconst char *,int );
541 #endif
542
543 #ifdef YY_NEED_STRLEN
544 static int yy_flex_strlen (yyconst char * );
545 #endif
546
547 #ifndef YY_NO_INPUT
548
549 #ifdef __cplusplus
550 static int yyinput (void );
551 #else
552 static int input (void );
553 #endif
554
555 #endif
556
557 /* Amount of stuff to slurp up with each read. */
558 #ifndef YY_READ_BUF_SIZE
559 #ifdef __ia64__
560 /* On IA-64, the buffer size is 16k, not 8k */
561 #define YY_READ_BUF_SIZE 16384
562 #else
563 #define YY_READ_BUF_SIZE 8192
564 #endif /* __ia64__ */
565 #endif
566
567 /* Copy whatever the last rule matched to the standard output. */
568 #ifndef ECHO
569 /* This used to be an fputs(), but since the string might contain NUL's,
570  * we now use fwrite().
571  */
572 #define ECHO do { if (fwrite( null_text, null_leng, 1, null_out )) {} } while (0)
573 #endif
574
575 /* Gets input and stuffs it into "buf".  number of characters read, or YY_NULL,
576  * is returned in "result".
577  */
578 #ifndef YY_INPUT
579 #define YY_INPUT(buf,result,max_size) \
580         if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \
581                 { \
582                 int c = '*'; \
583                 size_t n; \
584                 for ( n = 0; n < max_size && \
585                              (c = getc( null_in )) != EOF && c != '\n'; ++n ) \
586                         buf[n] = (char) c; \
587                 if ( c == '\n' ) \
588                         buf[n++] = (char) c; \
589                 if ( c == EOF && ferror( null_in ) ) \
590                         YY_FATAL_ERROR( "input in flex scanner failed" ); \
591                 result = n; \
592                 } \
593         else \
594                 { \
595                 errno=0; \
596                 while ( (result = fread(buf, 1, max_size, null_in))==0 && ferror(null_in)) \
597                         { \
598                         if( errno != EINTR) \
599                                 { \
600                                 YY_FATAL_ERROR( "input in flex scanner failed" ); \
601                                 break; \
602                                 } \
603                         errno=0; \
604                         clearerr(null_in); \
605                         } \
606                 }\
607 \
608
609 #endif
610
611 /* No semi-colon after return; correct usage is to write "yyterminate();" -
612  * we don't want an extra ';' after the "return" because that will cause
613  * some compilers to complain about unreachable statements.
614  */
615 #ifndef yyterminate
616 #define yyterminate() return YY_NULL
617 #endif
618
619 /* Number of entries by which start-condition stack grows. */
620 #ifndef YY_START_STACK_INCR
621 #define YY_START_STACK_INCR 25
622 #endif
623
624 /* Report a fatal error. */
625 #ifndef YY_FATAL_ERROR
626 #define YY_FATAL_ERROR(msg) yy_fatal_error( msg )
627 #endif
628
629 /* end tables serialization structures and prototypes */
630
631 /* Default declaration of generated scanner - a define so the user can
632  * easily add parameters.
633  */
634 #ifndef YY_DECL
635 #define YY_DECL_IS_OURS 1
636
637 extern int null_lex (void);
638
639 #define YY_DECL int null_lex (void)
640 #endif /* !YY_DECL */
641
642 /* Code executed at the beginning of each rule, after null_text and null_leng
643  * have been set up.
644  */
645 #ifndef YY_USER_ACTION
646 #define YY_USER_ACTION
647 #endif
648
649 /* Code executed at the end of each rule. */
650 #ifndef YY_BREAK
651 #define YY_BREAK break;
652 #endif
653
654 #define YY_RULE_SETUP \
655         YY_USER_ACTION
656
657 /** The main scanner function which does all the work.
658  */
659 YY_DECL
660 {
661         register yy_state_type yy_current_state;
662         register char *yy_cp, *yy_bp;
663         register int yy_act;
664     
665 #line 9 "../../fsinfo/null_lex.l"
666
667 #line 668 "lex.null_.c"
668
669         if ( !(yy_init) )
670                 {
671                 (yy_init) = 1;
672
673 #ifdef YY_USER_INIT
674                 YY_USER_INIT;
675 #endif
676
677                 if ( ! (yy_start) )
678                         (yy_start) = 1; /* first start state */
679
680                 if ( ! null_in )
681                         null_in = stdin;
682
683                 if ( ! null_out )
684                         null_out = stdout;
685
686                 if ( ! YY_CURRENT_BUFFER ) {
687                         null_ensure_buffer_stack ();
688                         YY_CURRENT_BUFFER_LVALUE =
689                                 null__create_buffer(null_in,YY_BUF_SIZE );
690                 }
691
692                 null__load_buffer_state( );
693                 }
694
695         while ( 1 )             /* loops until end-of-file is reached */
696                 {
697                 yy_cp = (yy_c_buf_p);
698
699                 /* Support of null_text. */
700                 *yy_cp = (yy_hold_char);
701
702                 /* yy_bp points to the position in yy_ch_buf of the start of
703                  * the current run.
704                  */
705                 yy_bp = yy_cp;
706
707                 yy_current_state = (yy_start);
708 yy_match:
709                 do
710                         {
711                         register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)];
712                         if ( yy_accept[yy_current_state] )
713                                 {
714                                 (yy_last_accepting_state) = yy_current_state;
715                                 (yy_last_accepting_cpos) = yy_cp;
716                                 }
717                         while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
718                                 {
719                                 yy_current_state = (int) yy_def[yy_current_state];
720                                 if ( yy_current_state >= 6 )
721                                         yy_c = yy_meta[(unsigned int) yy_c];
722                                 }
723                         yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
724                         ++yy_cp;
725                         }
726                 while ( yy_base[yy_current_state] != 3 );
727
728 yy_find_action:
729                 yy_act = yy_accept[yy_current_state];
730                 if ( yy_act == 0 )
731                         { /* have to back up */
732                         yy_cp = (yy_last_accepting_cpos);
733                         yy_current_state = (yy_last_accepting_state);
734                         yy_act = yy_accept[yy_current_state];
735                         }
736
737                 YY_DO_BEFORE_ACTION;
738
739 do_action:      /* This label is used only to access EOF actions. */
740
741                 switch ( yy_act )
742         { /* beginning of action switch */
743                         case 0: /* must back up */
744                         /* undo the effects of YY_DO_BEFORE_ACTION */
745                         *yy_cp = (yy_hold_char);
746                         yy_cp = (yy_last_accepting_cpos);
747                         yy_current_state = (yy_last_accepting_state);
748                         goto yy_find_action;
749
750 case 1:
751 YY_RULE_SETUP
752 #line 10 "../../fsinfo/null_lex.l"
753 ECHO;
754         YY_BREAK
755 #line 756 "lex.null_.c"
756 case YY_STATE_EOF(INITIAL):
757         yyterminate();
758
759         case YY_END_OF_BUFFER:
760                 {
761                 /* Amount of text matched not including the EOB char. */
762                 int yy_amount_of_matched_text = (int) (yy_cp - (yytext_ptr)) - 1;
763
764                 /* Undo the effects of YY_DO_BEFORE_ACTION. */
765                 *yy_cp = (yy_hold_char);
766                 YY_RESTORE_YY_MORE_OFFSET
767
768                 if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_NEW )
769                         {
770                         /* We're scanning a new file or input source.  It's
771                          * possible that this happened because the user
772                          * just pointed null_in at a new source and called
773                          * null_lex().  If so, then we have to assure
774                          * consistency between YY_CURRENT_BUFFER and our
775                          * globals.  Here is the right place to do so, because
776                          * this is the first action (other than possibly a
777                          * back-up) that will match for the new input source.
778                          */
779                         (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
780                         YY_CURRENT_BUFFER_LVALUE->yy_input_file = null_in;
781                         YY_CURRENT_BUFFER_LVALUE->yy_buffer_status = YY_BUFFER_NORMAL;
782                         }
783
784                 /* Note that here we test for yy_c_buf_p "<=" to the position
785                  * of the first EOB in the buffer, since yy_c_buf_p will
786                  * already have been incremented past the NUL character
787                  * (since all states make transitions on EOB to the
788                  * end-of-buffer state).  Contrast this with the test
789                  * in input().
790                  */
791                 if ( (yy_c_buf_p) <= &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
792                         { /* This was really a NUL. */
793                         yy_state_type yy_next_state;
794
795                         (yy_c_buf_p) = (yytext_ptr) + yy_amount_of_matched_text;
796
797                         yy_current_state = yy_get_previous_state(  );
798
799                         /* Okay, we're now positioned to make the NUL
800                          * transition.  We couldn't have
801                          * yy_get_previous_state() go ahead and do it
802                          * for us because it doesn't know how to deal
803                          * with the possibility of jamming (and we don't
804                          * want to build jamming into it because then it
805                          * will run more slowly).
806                          */
807
808                         yy_next_state = yy_try_NUL_trans( yy_current_state );
809
810                         yy_bp = (yytext_ptr) + YY_MORE_ADJ;
811
812                         if ( yy_next_state )
813                                 {
814                                 /* Consume the NUL. */
815                                 yy_cp = ++(yy_c_buf_p);
816                                 yy_current_state = yy_next_state;
817                                 goto yy_match;
818                                 }
819
820                         else
821                                 {
822                                 yy_cp = (yy_c_buf_p);
823                                 goto yy_find_action;
824                                 }
825                         }
826
827                 else switch ( yy_get_next_buffer(  ) )
828                         {
829                         case EOB_ACT_END_OF_FILE:
830                                 {
831                                 (yy_did_buffer_switch_on_eof) = 0;
832
833                                 if ( null_wrap( ) )
834                                         {
835                                         /* Note: because we've taken care in
836                                          * yy_get_next_buffer() to have set up
837                                          * null_text, we can now set up
838                                          * yy_c_buf_p so that if some total
839                                          * hoser (like flex itself) wants to
840                                          * call the scanner after we return the
841                                          * YY_NULL, it'll still work - another
842                                          * YY_NULL will get returned.
843                                          */
844                                         (yy_c_buf_p) = (yytext_ptr) + YY_MORE_ADJ;
845
846                                         yy_act = YY_STATE_EOF(YY_START);
847                                         goto do_action;
848                                         }
849
850                                 else
851                                         {
852                                         if ( ! (yy_did_buffer_switch_on_eof) )
853                                                 YY_NEW_FILE;
854                                         }
855                                 break;
856                                 }
857
858                         case EOB_ACT_CONTINUE_SCAN:
859                                 (yy_c_buf_p) =
860                                         (yytext_ptr) + yy_amount_of_matched_text;
861
862                                 yy_current_state = yy_get_previous_state(  );
863
864                                 yy_cp = (yy_c_buf_p);
865                                 yy_bp = (yytext_ptr) + YY_MORE_ADJ;
866                                 goto yy_match;
867
868                         case EOB_ACT_LAST_MATCH:
869                                 (yy_c_buf_p) =
870                                 &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)];
871
872                                 yy_current_state = yy_get_previous_state(  );
873
874                                 yy_cp = (yy_c_buf_p);
875                                 yy_bp = (yytext_ptr) + YY_MORE_ADJ;
876                                 goto yy_find_action;
877                         }
878                 break;
879                 }
880
881         default:
882                 YY_FATAL_ERROR(
883                         "fatal flex scanner internal error--no action found" );
884         } /* end of action switch */
885                 } /* end of scanning one token */
886 } /* end of null_lex */
887
888 /* yy_get_next_buffer - try to read in a new buffer
889  *
890  * Returns a code representing an action:
891  *      EOB_ACT_LAST_MATCH -
892  *      EOB_ACT_CONTINUE_SCAN - continue scanning from current position
893  *      EOB_ACT_END_OF_FILE - end of file
894  */
895 static int yy_get_next_buffer (void)
896 {
897         register char *dest = YY_CURRENT_BUFFER_LVALUE->yy_ch_buf;
898         register char *source = (yytext_ptr);
899         register int number_to_move, i;
900         int ret_val;
901
902         if ( (yy_c_buf_p) > &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] )
903                 YY_FATAL_ERROR(
904                 "fatal flex scanner internal error--end of buffer missed" );
905
906         if ( YY_CURRENT_BUFFER_LVALUE->yy_fill_buffer == 0 )
907                 { /* Don't try to fill the buffer, so this is an EOF. */
908                 if ( (yy_c_buf_p) - (yytext_ptr) - YY_MORE_ADJ == 1 )
909                         {
910                         /* We matched a single character, the EOB, so
911                          * treat this as a final EOF.
912                          */
913                         return EOB_ACT_END_OF_FILE;
914                         }
915
916                 else
917                         {
918                         /* We matched some text prior to the EOB, first
919                          * process it.
920                          */
921                         return EOB_ACT_LAST_MATCH;
922                         }
923                 }
924
925         /* Try to read more data. */
926
927         /* First move last chars to start of buffer. */
928         number_to_move = (int) ((yy_c_buf_p) - (yytext_ptr)) - 1;
929
930         for ( i = 0; i < number_to_move; ++i )
931                 *(dest++) = *(source++);
932
933         if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_EOF_PENDING )
934                 /* don't do the read, it's not guaranteed to return an EOF,
935                  * just force an EOF
936                  */
937                 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars) = 0;
938
939         else
940                 {
941                         int num_to_read =
942                         YY_CURRENT_BUFFER_LVALUE->yy_buf_size - number_to_move - 1;
943
944                 while ( num_to_read <= 0 )
945                         { /* Not enough room in the buffer - grow it. */
946
947                         /* just a shorter name for the current buffer */
948                         YY_BUFFER_STATE b = YY_CURRENT_BUFFER;
949
950                         int yy_c_buf_p_offset =
951                                 (int) ((yy_c_buf_p) - b->yy_ch_buf);
952
953                         if ( b->yy_is_our_buffer )
954                                 {
955                                 int new_size = b->yy_buf_size * 2;
956
957                                 if ( new_size <= 0 )
958                                         b->yy_buf_size += b->yy_buf_size / 8;
959                                 else
960                                         b->yy_buf_size *= 2;
961
962                                 b->yy_ch_buf = (char *)
963                                         /* Include room in for 2 EOB chars. */
964                                         null_realloc((void *) b->yy_ch_buf,b->yy_buf_size + 2  );
965                                 }
966                         else
967                                 /* Can't grow it, we don't own it. */
968                                 b->yy_ch_buf = 0;
969
970                         if ( ! b->yy_ch_buf )
971                                 YY_FATAL_ERROR(
972                                 "fatal error - scanner input buffer overflow" );
973
974                         (yy_c_buf_p) = &b->yy_ch_buf[yy_c_buf_p_offset];
975
976                         num_to_read = YY_CURRENT_BUFFER_LVALUE->yy_buf_size -
977                                                 number_to_move - 1;
978
979                         }
980
981                 if ( num_to_read > YY_READ_BUF_SIZE )
982                         num_to_read = YY_READ_BUF_SIZE;
983
984                 /* Read in more data. */
985                 YY_INPUT( (&YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[number_to_move]),
986                         (yy_n_chars), (size_t) num_to_read );
987
988                 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
989                 }
990
991         if ( (yy_n_chars) == 0 )
992                 {
993                 if ( number_to_move == YY_MORE_ADJ )
994                         {
995                         ret_val = EOB_ACT_END_OF_FILE;
996                         null_restart(null_in  );
997                         }
998
999                 else
1000                         {
1001                         ret_val = EOB_ACT_LAST_MATCH;
1002                         YY_CURRENT_BUFFER_LVALUE->yy_buffer_status =
1003                                 YY_BUFFER_EOF_PENDING;
1004                         }
1005                 }
1006
1007         else
1008                 ret_val = EOB_ACT_CONTINUE_SCAN;
1009
1010         if ((yy_size_t) ((yy_n_chars) + number_to_move) > YY_CURRENT_BUFFER_LVALUE->yy_buf_size) {
1011                 /* Extend the array by 50%, plus the number we really need. */
1012                 yy_size_t new_size = (yy_n_chars) + number_to_move + ((yy_n_chars) >> 1);
1013                 YY_CURRENT_BUFFER_LVALUE->yy_ch_buf = (char *) null_realloc((void *) YY_CURRENT_BUFFER_LVALUE->yy_ch_buf,new_size  );
1014                 if ( ! YY_CURRENT_BUFFER_LVALUE->yy_ch_buf )
1015                         YY_FATAL_ERROR( "out of dynamic memory in yy_get_next_buffer()" );
1016         }
1017
1018         (yy_n_chars) += number_to_move;
1019         YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] = YY_END_OF_BUFFER_CHAR;
1020         YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] = YY_END_OF_BUFFER_CHAR;
1021
1022         (yytext_ptr) = &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[0];
1023
1024         return ret_val;
1025 }
1026
1027 /* yy_get_previous_state - get the state just before the EOB char was reached */
1028
1029     static yy_state_type yy_get_previous_state (void)
1030 {
1031         register yy_state_type yy_current_state;
1032         register char *yy_cp;
1033     
1034         yy_current_state = (yy_start);
1035
1036         for ( yy_cp = (yytext_ptr) + YY_MORE_ADJ; yy_cp < (yy_c_buf_p); ++yy_cp )
1037                 {
1038                 register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1);
1039                 if ( yy_accept[yy_current_state] )
1040                         {
1041                         (yy_last_accepting_state) = yy_current_state;
1042                         (yy_last_accepting_cpos) = yy_cp;
1043                         }
1044                 while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1045                         {
1046                         yy_current_state = (int) yy_def[yy_current_state];
1047                         if ( yy_current_state >= 6 )
1048                                 yy_c = yy_meta[(unsigned int) yy_c];
1049                         }
1050                 yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1051                 }
1052
1053         return yy_current_state;
1054 }
1055
1056 /* yy_try_NUL_trans - try to make a transition on the NUL character
1057  *
1058  * synopsis
1059  *      next_state = yy_try_NUL_trans( current_state );
1060  */
1061     static yy_state_type yy_try_NUL_trans  (yy_state_type yy_current_state )
1062 {
1063         register int yy_is_jam;
1064         register char *yy_cp = (yy_c_buf_p);
1065
1066         register YY_CHAR yy_c = 1;
1067         if ( yy_accept[yy_current_state] )
1068                 {
1069                 (yy_last_accepting_state) = yy_current_state;
1070                 (yy_last_accepting_cpos) = yy_cp;
1071                 }
1072         while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1073                 {
1074                 yy_current_state = (int) yy_def[yy_current_state];
1075                 if ( yy_current_state >= 6 )
1076                         yy_c = yy_meta[(unsigned int) yy_c];
1077                 }
1078         yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1079         yy_is_jam = (yy_current_state == 5);
1080
1081         return yy_is_jam ? 0 : yy_current_state;
1082 }
1083
1084 #ifndef YY_NO_INPUT
1085 #ifdef __cplusplus
1086     static int yyinput (void)
1087 #else
1088     static int input  (void)
1089 #endif
1090
1091 {
1092         int c;
1093     
1094         *(yy_c_buf_p) = (yy_hold_char);
1095
1096         if ( *(yy_c_buf_p) == YY_END_OF_BUFFER_CHAR )
1097                 {
1098                 /* yy_c_buf_p now points to the character we want to return.
1099                  * If this occurs *before* the EOB characters, then it's a
1100                  * valid NUL; if not, then we've hit the end of the buffer.
1101                  */
1102                 if ( (yy_c_buf_p) < &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
1103                         /* This was really a NUL. */
1104                         *(yy_c_buf_p) = '\0';
1105
1106                 else
1107                         { /* need more input */
1108                         int offset = (yy_c_buf_p) - (yytext_ptr);
1109                         ++(yy_c_buf_p);
1110
1111                         switch ( yy_get_next_buffer(  ) )
1112                                 {
1113                                 case EOB_ACT_LAST_MATCH:
1114                                         /* This happens because yy_g_n_b()
1115                                          * sees that we've accumulated a
1116                                          * token and flags that we need to
1117                                          * try matching the token before
1118                                          * proceeding.  But for input(),
1119                                          * there's no matching to consider.
1120                                          * So convert the EOB_ACT_LAST_MATCH
1121                                          * to EOB_ACT_END_OF_FILE.
1122                                          */
1123
1124                                         /* Reset buffer status. */
1125                                         null_restart(null_in );
1126
1127                                         /*FALLTHROUGH*/
1128
1129                                 case EOB_ACT_END_OF_FILE:
1130                                         {
1131                                         if ( null_wrap( ) )
1132                                                 return EOF;
1133
1134                                         if ( ! (yy_did_buffer_switch_on_eof) )
1135                                                 YY_NEW_FILE;
1136 #ifdef __cplusplus
1137                                         return yyinput();
1138 #else
1139                                         return input();
1140 #endif
1141                                         }
1142
1143                                 case EOB_ACT_CONTINUE_SCAN:
1144                                         (yy_c_buf_p) = (yytext_ptr) + offset;
1145                                         break;
1146                                 }
1147                         }
1148                 }
1149
1150         c = *(unsigned char *) (yy_c_buf_p);    /* cast for 8-bit char's */
1151         *(yy_c_buf_p) = '\0';   /* preserve null_text */
1152         (yy_hold_char) = *++(yy_c_buf_p);
1153
1154         return c;
1155 }
1156 #endif  /* ifndef YY_NO_INPUT */
1157
1158 /** Immediately switch to a different input stream.
1159  * @param input_file A readable stream.
1160  * 
1161  * @note This function does not reset the start condition to @c INITIAL .
1162  */
1163     void null_restart  (FILE * input_file )
1164 {
1165     
1166         if ( ! YY_CURRENT_BUFFER ){
1167         null_ensure_buffer_stack ();
1168                 YY_CURRENT_BUFFER_LVALUE =
1169             null__create_buffer(null_in,YY_BUF_SIZE );
1170         }
1171
1172         null__init_buffer(YY_CURRENT_BUFFER,input_file );
1173         null__load_buffer_state( );
1174 }
1175
1176 /** Switch to a different input buffer.
1177  * @param new_buffer The new input buffer.
1178  * 
1179  */
1180     void null__switch_to_buffer  (YY_BUFFER_STATE  new_buffer )
1181 {
1182     
1183         /* TODO. We should be able to replace this entire function body
1184          * with
1185          *              null_pop_buffer_state();
1186          *              null_push_buffer_state(new_buffer);
1187      */
1188         null_ensure_buffer_stack ();
1189         if ( YY_CURRENT_BUFFER == new_buffer )
1190                 return;
1191
1192         if ( YY_CURRENT_BUFFER )
1193                 {
1194                 /* Flush out information for old buffer. */
1195                 *(yy_c_buf_p) = (yy_hold_char);
1196                 YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
1197                 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
1198                 }
1199
1200         YY_CURRENT_BUFFER_LVALUE = new_buffer;
1201         null__load_buffer_state( );
1202
1203         /* We don't actually know whether we did this switch during
1204          * EOF (null_wrap()) processing, but the only time this flag
1205          * is looked at is after null_wrap() is called, so it's safe
1206          * to go ahead and always set it.
1207          */
1208         (yy_did_buffer_switch_on_eof) = 1;
1209 }
1210
1211 static void null__load_buffer_state  (void)
1212 {
1213         (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
1214         (yytext_ptr) = (yy_c_buf_p) = YY_CURRENT_BUFFER_LVALUE->yy_buf_pos;
1215         null_in = YY_CURRENT_BUFFER_LVALUE->yy_input_file;
1216         (yy_hold_char) = *(yy_c_buf_p);
1217 }
1218
1219 /** Allocate and initialize an input buffer state.
1220  * @param file A readable stream.
1221  * @param size The character buffer size in bytes. When in doubt, use @c YY_BUF_SIZE.
1222  * 
1223  * @return the allocated buffer state.
1224  */
1225     YY_BUFFER_STATE null__create_buffer  (FILE * file, int  size )
1226 {
1227         YY_BUFFER_STATE b;
1228     
1229         b = (YY_BUFFER_STATE) null_alloc(sizeof( struct yy_buffer_state )  );
1230         if ( ! b )
1231                 YY_FATAL_ERROR( "out of dynamic memory in null__create_buffer()" );
1232
1233         b->yy_buf_size = size;
1234
1235         /* yy_ch_buf has to be 2 characters longer than the size given because
1236          * we need to put in 2 end-of-buffer characters.
1237          */
1238         b->yy_ch_buf = (char *) null_alloc(b->yy_buf_size + 2  );
1239         if ( ! b->yy_ch_buf )
1240                 YY_FATAL_ERROR( "out of dynamic memory in null__create_buffer()" );
1241
1242         b->yy_is_our_buffer = 1;
1243
1244         null__init_buffer(b,file );
1245
1246         return b;
1247 }
1248
1249 /** Destroy the buffer.
1250  * @param b a buffer created with null__create_buffer()
1251  * 
1252  */
1253     void null__delete_buffer (YY_BUFFER_STATE  b )
1254 {
1255     
1256         if ( ! b )
1257                 return;
1258
1259         if ( b == YY_CURRENT_BUFFER ) /* Not sure if we should pop here. */
1260                 YY_CURRENT_BUFFER_LVALUE = (YY_BUFFER_STATE) 0;
1261
1262         if ( b->yy_is_our_buffer )
1263                 null_free((void *) b->yy_ch_buf  );
1264
1265         null_free((void *) b  );
1266 }
1267
1268 #ifndef __cplusplus
1269 extern int isatty (int );
1270 #endif /* __cplusplus */
1271     
1272 /* Initializes or reinitializes a buffer.
1273  * This function is sometimes called more than once on the same buffer,
1274  * such as during a null_restart() or at EOF.
1275  */
1276     static void null__init_buffer  (YY_BUFFER_STATE  b, FILE * file )
1277
1278 {
1279         int oerrno = errno;
1280     
1281         null__flush_buffer(b );
1282
1283         b->yy_input_file = file;
1284         b->yy_fill_buffer = 1;
1285
1286     /* If b is the current buffer, then null__init_buffer was _probably_
1287      * called from null_restart() or through yy_get_next_buffer.
1288      * In that case, we don't want to reset the lineno or column.
1289      */
1290     if (b != YY_CURRENT_BUFFER){
1291         b->yy_bs_lineno = 1;
1292         b->yy_bs_column = 0;
1293     }
1294
1295         b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0;
1296     
1297         errno = oerrno;
1298 }
1299
1300 /** Discard all buffered characters. On the next scan, YY_INPUT will be called.
1301  * @param b the buffer state to be flushed, usually @c YY_CURRENT_BUFFER.
1302  * 
1303  */
1304     void null__flush_buffer (YY_BUFFER_STATE  b )
1305 {
1306         if ( ! b )
1307                 return;
1308
1309         b->yy_n_chars = 0;
1310
1311         /* We always need two end-of-buffer characters.  The first causes
1312          * a transition to the end-of-buffer state.  The second causes
1313          * a jam in that state.
1314          */
1315         b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR;
1316         b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR;
1317
1318         b->yy_buf_pos = &b->yy_ch_buf[0];
1319
1320         b->yy_at_bol = 1;
1321         b->yy_buffer_status = YY_BUFFER_NEW;
1322
1323         if ( b == YY_CURRENT_BUFFER )
1324                 null__load_buffer_state( );
1325 }
1326
1327 /** Pushes the new state onto the stack. The new state becomes
1328  *  the current state. This function will allocate the stack
1329  *  if necessary.
1330  *  @param new_buffer The new state.
1331  *  
1332  */
1333 void null_push_buffer_state (YY_BUFFER_STATE new_buffer )
1334 {
1335         if (new_buffer == NULL)
1336                 return;
1337
1338         null_ensure_buffer_stack();
1339
1340         /* This block is copied from null__switch_to_buffer. */
1341         if ( YY_CURRENT_BUFFER )
1342                 {
1343                 /* Flush out information for old buffer. */
1344                 *(yy_c_buf_p) = (yy_hold_char);
1345                 YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
1346                 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
1347                 }
1348
1349         /* Only push if top exists. Otherwise, replace top. */
1350         if (YY_CURRENT_BUFFER)
1351                 (yy_buffer_stack_top)++;
1352         YY_CURRENT_BUFFER_LVALUE = new_buffer;
1353
1354         /* copied from null__switch_to_buffer. */
1355         null__load_buffer_state( );
1356         (yy_did_buffer_switch_on_eof) = 1;
1357 }
1358
1359 /** Removes and deletes the top of the stack, if present.
1360  *  The next element becomes the new top.
1361  *  
1362  */
1363 void null_pop_buffer_state (void)
1364 {
1365         if (!YY_CURRENT_BUFFER)
1366                 return;
1367
1368         null__delete_buffer(YY_CURRENT_BUFFER );
1369         YY_CURRENT_BUFFER_LVALUE = NULL;
1370         if ((yy_buffer_stack_top) > 0)
1371                 --(yy_buffer_stack_top);
1372
1373         if (YY_CURRENT_BUFFER) {
1374                 null__load_buffer_state( );
1375                 (yy_did_buffer_switch_on_eof) = 1;
1376         }
1377 }
1378
1379 /* Allocates the stack if it does not exist.
1380  *  Guarantees space for at least one push.
1381  */
1382 static void null_ensure_buffer_stack (void)
1383 {
1384         int num_to_alloc;
1385     
1386         if (!(yy_buffer_stack)) {
1387
1388                 /* First allocation is just for 2 elements, since we don't know if this
1389                  * scanner will even need a stack. We use 2 instead of 1 to avoid an
1390                  * immediate realloc on the next call.
1391          */
1392                 num_to_alloc = 1;
1393                 (yy_buffer_stack) = (struct yy_buffer_state**)null_alloc
1394                                                                 (num_to_alloc * sizeof(struct yy_buffer_state*)
1395                                                                 );
1396                 if ( ! (yy_buffer_stack) )
1397                         YY_FATAL_ERROR( "out of dynamic memory in null_ensure_buffer_stack()" );
1398                                                                   
1399                 memset((yy_buffer_stack), 0, num_to_alloc * sizeof(struct yy_buffer_state*));
1400                                 
1401                 (yy_buffer_stack_max) = num_to_alloc;
1402                 (yy_buffer_stack_top) = 0;
1403                 return;
1404         }
1405
1406         if ((yy_buffer_stack_top) >= ((yy_buffer_stack_max)) - 1){
1407
1408                 /* Increase the buffer to prepare for a possible push. */
1409                 int grow_size = 8 /* arbitrary grow size */;
1410
1411                 num_to_alloc = (yy_buffer_stack_max) + grow_size;
1412                 (yy_buffer_stack) = (struct yy_buffer_state**)null_realloc
1413                                                                 ((yy_buffer_stack),
1414                                                                 num_to_alloc * sizeof(struct yy_buffer_state*)
1415                                                                 );
1416                 if ( ! (yy_buffer_stack) )
1417                         YY_FATAL_ERROR( "out of dynamic memory in null_ensure_buffer_stack()" );
1418
1419                 /* zero only the new slots.*/
1420                 memset((yy_buffer_stack) + (yy_buffer_stack_max), 0, grow_size * sizeof(struct yy_buffer_state*));
1421                 (yy_buffer_stack_max) = num_to_alloc;
1422         }
1423 }
1424
1425 /** Setup the input buffer state to scan directly from a user-specified character buffer.
1426  * @param base the character buffer
1427  * @param size the size in bytes of the character buffer
1428  * 
1429  * @return the newly allocated buffer state object. 
1430  */
1431 YY_BUFFER_STATE null__scan_buffer  (char * base, yy_size_t  size )
1432 {
1433         YY_BUFFER_STATE b;
1434     
1435         if ( size < 2 ||
1436              base[size-2] != YY_END_OF_BUFFER_CHAR ||
1437              base[size-1] != YY_END_OF_BUFFER_CHAR )
1438                 /* They forgot to leave room for the EOB's. */
1439                 return 0;
1440
1441         b = (YY_BUFFER_STATE) null_alloc(sizeof( struct yy_buffer_state )  );
1442         if ( ! b )
1443                 YY_FATAL_ERROR( "out of dynamic memory in null__scan_buffer()" );
1444
1445         b->yy_buf_size = size - 2;      /* "- 2" to take care of EOB's */
1446         b->yy_buf_pos = b->yy_ch_buf = base;
1447         b->yy_is_our_buffer = 0;
1448         b->yy_input_file = 0;
1449         b->yy_n_chars = b->yy_buf_size;
1450         b->yy_is_interactive = 0;
1451         b->yy_at_bol = 1;
1452         b->yy_fill_buffer = 0;
1453         b->yy_buffer_status = YY_BUFFER_NEW;
1454
1455         null__switch_to_buffer(b  );
1456
1457         return b;
1458 }
1459
1460 /** Setup the input buffer state to scan a string. The next call to null_lex() will
1461  * scan from a @e copy of @a str.
1462  * @param yystr a NUL-terminated string to scan
1463  * 
1464  * @return the newly allocated buffer state object.
1465  * @note If you want to scan bytes that may contain NUL values, then use
1466  *       null__scan_bytes() instead.
1467  */
1468 YY_BUFFER_STATE null__scan_string (yyconst char * yystr )
1469 {
1470     
1471         return null__scan_bytes(yystr,strlen(yystr) );
1472 }
1473
1474 /** Setup the input buffer state to scan the given bytes. The next call to null_lex() will
1475  * scan from a @e copy of @a bytes.
1476  * @param yybytes the byte buffer to scan
1477  * @param _yybytes_len the number of bytes in the buffer pointed to by @a bytes.
1478  * 
1479  * @return the newly allocated buffer state object.
1480  */
1481 YY_BUFFER_STATE null__scan_bytes  (yyconst char * yybytes, int  _yybytes_len )
1482 {
1483         YY_BUFFER_STATE b;
1484         char *buf;
1485         yy_size_t n;
1486         int i;
1487     
1488         /* Get memory for full buffer, including space for trailing EOB's. */
1489         n = _yybytes_len + 2;
1490         buf = (char *) null_alloc(n  );
1491         if ( ! buf )
1492                 YY_FATAL_ERROR( "out of dynamic memory in null__scan_bytes()" );
1493
1494         for ( i = 0; i < _yybytes_len; ++i )
1495                 buf[i] = yybytes[i];
1496
1497         buf[_yybytes_len] = buf[_yybytes_len+1] = YY_END_OF_BUFFER_CHAR;
1498
1499         b = null__scan_buffer(buf,n );
1500         if ( ! b )
1501                 YY_FATAL_ERROR( "bad buffer in null__scan_bytes()" );
1502
1503         /* It's okay to grow etc. this buffer, and we should throw it
1504          * away when we're done.
1505          */
1506         b->yy_is_our_buffer = 1;
1507
1508         return b;
1509 }
1510
1511 #ifndef YY_EXIT_FAILURE
1512 #define YY_EXIT_FAILURE 2
1513 #endif
1514
1515 static void yy_fatal_error (yyconst char* msg )
1516 {
1517         (void) fprintf( stderr, "%s\n", msg );
1518         exit( YY_EXIT_FAILURE );
1519 }
1520
1521 /* Redefine yyless() so it works in section 3 code. */
1522
1523 #undef yyless
1524 #define yyless(n) \
1525         do \
1526                 { \
1527                 /* Undo effects of setting up null_text. */ \
1528         int yyless_macro_arg = (n); \
1529         YY_LESS_LINENO(yyless_macro_arg);\
1530                 null_text[null_leng] = (yy_hold_char); \
1531                 (yy_c_buf_p) = null_text + yyless_macro_arg; \
1532                 (yy_hold_char) = *(yy_c_buf_p); \
1533                 *(yy_c_buf_p) = '\0'; \
1534                 null_leng = yyless_macro_arg; \
1535                 } \
1536         while ( 0 )
1537
1538 /* Accessor  methods (get/set functions) to struct members. */
1539
1540 /** Get the current line number.
1541  * 
1542  */
1543 int null_get_lineno  (void)
1544 {
1545         
1546     return null_lineno;
1547 }
1548
1549 /** Get the input stream.
1550  * 
1551  */
1552 FILE *null_get_in  (void)
1553 {
1554         return null_in;
1555 }
1556
1557 /** Get the output stream.
1558  * 
1559  */
1560 FILE *null_get_out  (void)
1561 {
1562         return null_out;
1563 }
1564
1565 /** Get the length of the current token.
1566  * 
1567  */
1568 int null_get_leng  (void)
1569 {
1570         return null_leng;
1571 }
1572
1573 /** Get the current token.
1574  * 
1575  */
1576
1577 char *null_get_text  (void)
1578 {
1579         return null_text;
1580 }
1581
1582 /** Set the current line number.
1583  * @param line_number
1584  * 
1585  */
1586 void null_set_lineno (int  line_number )
1587 {
1588     
1589     null_lineno = line_number;
1590 }
1591
1592 /** Set the input stream. This does not discard the current
1593  * input buffer.
1594  * @param in_str A readable stream.
1595  * 
1596  * @see null__switch_to_buffer
1597  */
1598 void null_set_in (FILE *  in_str )
1599 {
1600         null_in = in_str ;
1601 }
1602
1603 void null_set_out (FILE *  out_str )
1604 {
1605         null_out = out_str ;
1606 }
1607
1608 int null_get_debug  (void)
1609 {
1610         return null__flex_debug;
1611 }
1612
1613 void null_set_debug (int  bdebug )
1614 {
1615         null__flex_debug = bdebug ;
1616 }
1617
1618 static int yy_init_globals (void)
1619 {
1620         /* Initialization is the same as for the non-reentrant scanner.
1621      * This function is called from null_lex_destroy(), so don't allocate here.
1622      */
1623
1624     (yy_buffer_stack) = 0;
1625     (yy_buffer_stack_top) = 0;
1626     (yy_buffer_stack_max) = 0;
1627     (yy_c_buf_p) = (char *) 0;
1628     (yy_init) = 0;
1629     (yy_start) = 0;
1630
1631 /* Defined in main.c */
1632 #ifdef YY_STDINIT
1633     null_in = stdin;
1634     null_out = stdout;
1635 #else
1636     null_in = (FILE *) 0;
1637     null_out = (FILE *) 0;
1638 #endif
1639
1640     /* For future reference: Set errno on error, since we are called by
1641      * null_lex_init()
1642      */
1643     return 0;
1644 }
1645
1646 /* null_lex_destroy is for both reentrant and non-reentrant scanners. */
1647 int null_lex_destroy  (void)
1648 {
1649     
1650     /* Pop the buffer stack, destroying each element. */
1651         while(YY_CURRENT_BUFFER){
1652                 null__delete_buffer(YY_CURRENT_BUFFER  );
1653                 YY_CURRENT_BUFFER_LVALUE = NULL;
1654                 null_pop_buffer_state();
1655         }
1656
1657         /* Destroy the stack itself. */
1658         null_free((yy_buffer_stack) );
1659         (yy_buffer_stack) = NULL;
1660
1661     /* Reset the globals. This is important in a non-reentrant scanner so the next time
1662      * null_lex() is called, initialization will occur. */
1663     yy_init_globals( );
1664
1665     return 0;
1666 }
1667
1668 /*
1669  * Internal utility routines.
1670  */
1671
1672 #ifndef yytext_ptr
1673 static void yy_flex_strncpy (char* s1, yyconst char * s2, int n )
1674 {
1675         register int i;
1676         for ( i = 0; i < n; ++i )
1677                 s1[i] = s2[i];
1678 }
1679 #endif
1680
1681 #ifdef YY_NEED_STRLEN
1682 static int yy_flex_strlen (yyconst char * s )
1683 {
1684         register int n;
1685         for ( n = 0; s[n]; ++n )
1686                 ;
1687
1688         return n;
1689 }
1690 #endif
1691
1692 void *null_alloc (yy_size_t  size )
1693 {
1694         return (void *) malloc( size );
1695 }
1696
1697 void *null_realloc  (void * ptr, yy_size_t  size )
1698 {
1699         /* The cast to (char *) in the following accommodates both
1700          * implementations that use char* generic pointers, and those
1701          * that use void* generic pointers.  It works with the latter
1702          * because both ANSI C and C++ allow castless assignment from
1703          * any pointer type to void*, and deal with argument conversions
1704          * as though doing an assignment.
1705          */
1706         return (void *) realloc( (char *) ptr, size );
1707 }
1708
1709 void null_free (void * ptr )
1710 {
1711         free( (char *) ptr );   /* see null_realloc() for (char *) cast */
1712 }
1713
1714 #define YYTABLES_NAME "yytables"
1715
1716 #line 10 "../../fsinfo/null_lex.l"