linux/scripts/genksyms/lex.c_shipped
<<
>>
Prefs
   1#line 2 "scripts/genksyms/lex.c"
   2
   3#line 4 "scripts/genksyms/lex.c"
   4
   5#define  YY_INT_ALIGNED short int
   6
   7/* A lexical scanner generated by flex */
   8
   9/* %not-for-header */
  10
  11/* %if-c-only */
  12/* %if-not-reentrant */
  13
  14/* %endif */
  15/* %endif */
  16/* %ok-for-header */
  17
  18#define FLEX_SCANNER
  19#define YY_FLEX_MAJOR_VERSION 2
  20#define YY_FLEX_MINOR_VERSION 5
  21#define YY_FLEX_SUBMINOR_VERSION 35
  22#if YY_FLEX_SUBMINOR_VERSION > 0
  23#define FLEX_BETA
  24#endif
  25
  26/* %if-c++-only */
  27/* %endif */
  28
  29/* %if-c-only */
  30    
  31/* %endif */
  32
  33/* %if-c-only */
  34
  35/* %endif */
  36
  37/* First, we deal with  platform-specific or compiler-specific issues. */
  38
  39/* begin standard C headers. */
  40/* %if-c-only */
  41#include <stdio.h>
  42#include <string.h>
  43#include <errno.h>
  44#include <stdlib.h>
  45/* %endif */
  46
  47/* %if-tables-serialization */
  48/* %endif */
  49/* end standard C headers. */
  50
  51/* %if-c-or-c++ */
  52/* flex integer type definitions */
  53
  54#ifndef FLEXINT_H
  55#define FLEXINT_H
  56
  57/* C99 systems have <inttypes.h>. Non-C99 systems may or may not. */
  58
  59#if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
  60
  61/* C99 says to define __STDC_LIMIT_MACROS before including stdint.h,
  62 * if you want the limit (max/min) macros for int types. 
  63 */
  64#ifndef __STDC_LIMIT_MACROS
  65#define __STDC_LIMIT_MACROS 1
  66#endif
  67
  68#include <inttypes.h>
  69typedef int8_t flex_int8_t;
  70typedef uint8_t flex_uint8_t;
  71typedef int16_t flex_int16_t;
  72typedef uint16_t flex_uint16_t;
  73typedef int32_t flex_int32_t;
  74typedef uint32_t flex_uint32_t;
  75#else
  76typedef signed char flex_int8_t;
  77typedef short int flex_int16_t;
  78typedef int flex_int32_t;
  79typedef unsigned char flex_uint8_t; 
  80typedef unsigned short int flex_uint16_t;
  81typedef unsigned int flex_uint32_t;
  82
  83/* Limits of integral types. */
  84#ifndef INT8_MIN
  85#define INT8_MIN               (-128)
  86#endif
  87#ifndef INT16_MIN
  88#define INT16_MIN              (-32767-1)
  89#endif
  90#ifndef INT32_MIN
  91#define INT32_MIN              (-2147483647-1)
  92#endif
  93#ifndef INT8_MAX
  94#define INT8_MAX               (127)
  95#endif
  96#ifndef INT16_MAX
  97#define INT16_MAX              (32767)
  98#endif
  99#ifndef INT32_MAX
 100#define INT32_MAX              (2147483647)
 101#endif
 102#ifndef UINT8_MAX
 103#define UINT8_MAX              (255U)
 104#endif
 105#ifndef UINT16_MAX
 106#define UINT16_MAX             (65535U)
 107#endif
 108#ifndef UINT32_MAX
 109#define UINT32_MAX             (4294967295U)
 110#endif
 111
 112#endif /* ! C99 */
 113
 114#endif /* ! FLEXINT_H */
 115
 116/* %endif */
 117
 118/* %if-c++-only */
 119/* %endif */
 120
 121#ifdef __cplusplus
 122
 123/* The "const" storage-class-modifier is valid. */
 124#define YY_USE_CONST
 125
 126#else   /* ! __cplusplus */
 127
 128/* C99 requires __STDC__ to be defined as 1. */
 129#if defined (__STDC__)
 130
 131#define YY_USE_CONST
 132
 133#endif  /* defined (__STDC__) */
 134#endif  /* ! __cplusplus */
 135
 136#ifdef YY_USE_CONST
 137#define yyconst const
 138#else
 139#define yyconst
 140#endif
 141
 142/* %not-for-header */
 143
 144/* Returned upon end-of-file. */
 145#define YY_NULL 0
 146/* %ok-for-header */
 147
 148/* %not-for-header */
 149
 150/* Promotes a possibly negative, possibly signed char to an unsigned
 151 * integer for use as an array index.  If the signed char is negative,
 152 * we want to instead treat it as an 8-bit unsigned char, hence the
 153 * double cast.
 154 */
 155#define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c)
 156/* %ok-for-header */
 157
 158/* %if-reentrant */
 159/* %endif */
 160
 161/* %if-not-reentrant */
 162
 163/* %endif */
 164
 165/* Enter a start condition.  This macro really ought to take a parameter,
 166 * but we do it the disgusting crufty way forced on us by the ()-less
 167 * definition of BEGIN.
 168 */
 169#define BEGIN (yy_start) = 1 + 2 *
 170
 171/* Translate the current start state into a value that can be later handed
 172 * to BEGIN to return to the state.  The YYSTATE alias is for lex
 173 * compatibility.
 174 */
 175#define YY_START (((yy_start) - 1) / 2)
 176#define YYSTATE YY_START
 177
 178/* Action number for EOF rule of a given start state. */
 179#define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1)
 180
 181/* Special action meaning "start processing a new file". */
 182#define YY_NEW_FILE yyrestart(yyin  )
 183
 184#define YY_END_OF_BUFFER_CHAR 0
 185
 186/* Size of default input buffer. */
 187#ifndef YY_BUF_SIZE
 188#define YY_BUF_SIZE 16384
 189#endif
 190
 191/* The state buf must be large enough to hold one state per character in the main buffer.
 192 */
 193#define YY_STATE_BUF_SIZE   ((YY_BUF_SIZE + 2) * sizeof(yy_state_type))
 194
 195#ifndef YY_TYPEDEF_YY_BUFFER_STATE
 196#define YY_TYPEDEF_YY_BUFFER_STATE
 197typedef struct yy_buffer_state *YY_BUFFER_STATE;
 198#endif
 199
 200/* %if-not-reentrant */
 201extern int yyleng;
 202/* %endif */
 203
 204/* %if-c-only */
 205/* %if-not-reentrant */
 206extern FILE *yyin, *yyout;
 207/* %endif */
 208/* %endif */
 209
 210#define EOB_ACT_CONTINUE_SCAN 0
 211#define EOB_ACT_END_OF_FILE 1
 212#define EOB_ACT_LAST_MATCH 2
 213
 214    #define YY_LESS_LINENO(n)
 215    
 216/* Return all but the first "n" matched characters back to the input stream. */
 217#define yyless(n) \
 218        do \
 219                { \
 220                /* Undo effects of setting up yytext. */ \
 221        int yyless_macro_arg = (n); \
 222        YY_LESS_LINENO(yyless_macro_arg);\
 223                *yy_cp = (yy_hold_char); \
 224                YY_RESTORE_YY_MORE_OFFSET \
 225                (yy_c_buf_p) = yy_cp = yy_bp + yyless_macro_arg - YY_MORE_ADJ; \
 226                YY_DO_BEFORE_ACTION; /* set up yytext again */ \
 227                } \
 228        while ( 0 )
 229
 230#define unput(c) yyunput( c, (yytext_ptr)  )
 231
 232#ifndef YY_TYPEDEF_YY_SIZE_T
 233#define YY_TYPEDEF_YY_SIZE_T
 234typedef size_t yy_size_t;
 235#endif
 236
 237#ifndef YY_STRUCT_YY_BUFFER_STATE
 238#define YY_STRUCT_YY_BUFFER_STATE
 239struct yy_buffer_state
 240        {
 241/* %if-c-only */
 242        FILE *yy_input_file;
 243/* %endif */
 244
 245/* %if-c++-only */
 246/* %endif */
 247
 248        char *yy_ch_buf;                /* input buffer */
 249        char *yy_buf_pos;               /* current position in input buffer */
 250
 251        /* Size of input buffer in bytes, not including room for EOB
 252         * characters.
 253         */
 254        yy_size_t yy_buf_size;
 255
 256        /* Number of characters read into yy_ch_buf, not including EOB
 257         * characters.
 258         */
 259        int yy_n_chars;
 260
 261        /* Whether we "own" the buffer - i.e., we know we created it,
 262         * and can realloc() it to grow it, and should free() it to
 263         * delete it.
 264         */
 265        int yy_is_our_buffer;
 266
 267        /* Whether this is an "interactive" input source; if so, and
 268         * if we're using stdio for input, then we want to use getc()
 269         * instead of fread(), to make sure we stop fetching input after
 270         * each newline.
 271         */
 272        int yy_is_interactive;
 273
 274        /* Whether we're considered to be at the beginning of a line.
 275         * If so, '^' rules will be active on the next match, otherwise
 276         * not.
 277         */
 278        int yy_at_bol;
 279
 280    int yy_bs_lineno; /**< The line count. */
 281    int yy_bs_column; /**< The column count. */
 282    
 283        /* Whether to try to fill the input buffer when we reach the
 284         * end of it.
 285         */
 286        int yy_fill_buffer;
 287
 288        int yy_buffer_status;
 289
 290#define YY_BUFFER_NEW 0
 291#define YY_BUFFER_NORMAL 1
 292        /* When an EOF's been seen but there's still some text to process
 293         * then we mark the buffer as YY_EOF_PENDING, to indicate that we
 294         * shouldn't try reading from the input source any more.  We might
 295         * still have a bunch of tokens to match, though, because of
 296         * possible backing-up.
 297         *
 298         * When we actually see the EOF, we change the status to "new"
 299         * (via yyrestart()), so that the user can continue scanning by
 300         * just pointing yyin at a new input file.
 301         */
 302#define YY_BUFFER_EOF_PENDING 2
 303
 304        };
 305#endif /* !YY_STRUCT_YY_BUFFER_STATE */
 306
 307/* %if-c-only Standard (non-C++) definition */
 308/* %not-for-header */
 309
 310/* %if-not-reentrant */
 311
 312/* Stack of input buffers. */
 313static size_t yy_buffer_stack_top = 0; /**< index of top of stack. */
 314static size_t yy_buffer_stack_max = 0; /**< capacity of stack. */
 315static YY_BUFFER_STATE * yy_buffer_stack = 0; /**< Stack as an array. */
 316/* %endif */
 317/* %ok-for-header */
 318
 319/* %endif */
 320
 321/* We provide macros for accessing buffer states in case in the
 322 * future we want to put the buffer states in a more general
 323 * "scanner state".
 324 *
 325 * Returns the top of the stack, or NULL.
 326 */
 327#define YY_CURRENT_BUFFER ( (yy_buffer_stack) \
 328                          ? (yy_buffer_stack)[(yy_buffer_stack_top)] \
 329                          : NULL)
 330
 331/* Same as previous macro, but useful when we know that the buffer stack is not
 332 * NULL or when we need an lvalue. For internal use only.
 333 */
 334#define YY_CURRENT_BUFFER_LVALUE (yy_buffer_stack)[(yy_buffer_stack_top)]
 335
 336/* %if-c-only Standard (non-C++) definition */
 337
 338/* %if-not-reentrant */
 339/* %not-for-header */
 340
 341/* yy_hold_char holds the character lost when yytext is formed. */
 342static char yy_hold_char;
 343static int yy_n_chars;          /* number of characters read into yy_ch_buf */
 344int yyleng;
 345
 346/* Points to current character in buffer. */
 347static char *yy_c_buf_p = (char *) 0;
 348static int yy_init = 0;         /* whether we need to initialize */
 349static int yy_start = 0;        /* start state number */
 350
 351/* Flag which is used to allow yywrap()'s to do buffer switches
 352 * instead of setting up a fresh yyin.  A bit of a hack ...
 353 */
 354static int yy_did_buffer_switch_on_eof;
 355/* %ok-for-header */
 356
 357/* %endif */
 358
 359void yyrestart (FILE *input_file  );
 360void yy_switch_to_buffer (YY_BUFFER_STATE new_buffer  );
 361YY_BUFFER_STATE yy_create_buffer (FILE *file,int size  );
 362void yy_delete_buffer (YY_BUFFER_STATE b  );
 363void yy_flush_buffer (YY_BUFFER_STATE b  );
 364void yypush_buffer_state (YY_BUFFER_STATE new_buffer  );
 365void yypop_buffer_state (void );
 366
 367static void yyensure_buffer_stack (void );
 368static void yy_load_buffer_state (void );
 369static void yy_init_buffer (YY_BUFFER_STATE b,FILE *file  );
 370
 371#define YY_FLUSH_BUFFER yy_flush_buffer(YY_CURRENT_BUFFER )
 372
 373YY_BUFFER_STATE yy_scan_buffer (char *base,yy_size_t size  );
 374YY_BUFFER_STATE yy_scan_string (yyconst char *yy_str  );
 375YY_BUFFER_STATE yy_scan_bytes (yyconst char *bytes,int len  );
 376
 377/* %endif */
 378
 379void *yyalloc (yy_size_t  );
 380void *yyrealloc (void *,yy_size_t  );
 381void yyfree (void *  );
 382
 383#define yy_new_buffer yy_create_buffer
 384
 385#define yy_set_interactive(is_interactive) \
 386        { \
 387        if ( ! YY_CURRENT_BUFFER ){ \
 388        yyensure_buffer_stack (); \
 389                YY_CURRENT_BUFFER_LVALUE =    \
 390            yy_create_buffer(yyin,YY_BUF_SIZE ); \
 391        } \
 392        YY_CURRENT_BUFFER_LVALUE->yy_is_interactive = is_interactive; \
 393        }
 394
 395#define yy_set_bol(at_bol) \
 396        { \
 397        if ( ! YY_CURRENT_BUFFER ){\
 398        yyensure_buffer_stack (); \
 399                YY_CURRENT_BUFFER_LVALUE =    \
 400            yy_create_buffer(yyin,YY_BUF_SIZE ); \
 401        } \
 402        YY_CURRENT_BUFFER_LVALUE->yy_at_bol = at_bol; \
 403        }
 404
 405#define YY_AT_BOL() (YY_CURRENT_BUFFER_LVALUE->yy_at_bol)
 406
 407/* %% [1.0] yytext/yyin/yyout/yy_state_type/yylineno etc. def's & init go here */
 408/* Begin user sect3 */
 409
 410#define yywrap(n) 1
 411#define YY_SKIP_YYWRAP
 412
 413#define FLEX_DEBUG
 414
 415typedef unsigned char YY_CHAR;
 416
 417FILE *yyin = (FILE *) 0, *yyout = (FILE *) 0;
 418
 419typedef int yy_state_type;
 420
 421extern int yylineno;
 422
 423int yylineno = 1;
 424
 425extern char *yytext;
 426#define yytext_ptr yytext
 427
 428/* %if-c-only Standard (non-C++) definition */
 429
 430static yy_state_type yy_get_previous_state (void );
 431static yy_state_type yy_try_NUL_trans (yy_state_type current_state  );
 432static int yy_get_next_buffer (void );
 433static void yy_fatal_error (yyconst char msg[]  );
 434
 435/* %endif */
 436
 437/* Done after the current pattern has been matched and before the
 438 * corresponding action - sets up yytext.
 439 */
 440#define YY_DO_BEFORE_ACTION \
 441        (yytext_ptr) = yy_bp; \
 442/* %% [2.0] code to fiddle yytext and yyleng for yymore() goes here \ */\
 443        yyleng = (size_t) (yy_cp - yy_bp); \
 444        (yy_hold_char) = *yy_cp; \
 445        *yy_cp = '\0'; \
 446/* %% [3.0] code to copy yytext_ptr to yytext[] goes here, if %array \ */\
 447        (yy_c_buf_p) = yy_cp;
 448
 449/* %% [4.0] data tables for the DFA and the user's section 1 definitions go here */
 450#define YY_NUM_RULES 13
 451#define YY_END_OF_BUFFER 14
 452/* This struct is not used in this scanner,
 453   but its presence is necessary. */
 454struct yy_trans_info
 455        {
 456        flex_int32_t yy_verify;
 457        flex_int32_t yy_nxt;
 458        };
 459static yyconst flex_int16_t yy_accept[76] =
 460    {   0,
 461        0,    0,    0,    0,   14,   12,    4,    3,   12,    7,
 462       12,   12,    7,   12,   12,   12,   12,   12,    9,    9,
 463       12,   12,   12,    4,    0,    5,    0,    7,    0,    6,
 464        0,    0,    0,    0,    0,    0,    2,    8,   10,   10,
 465        9,    0,    0,    9,    9,    0,    9,    0,    0,   11,
 466        0,    0,    0,   10,    0,   10,    9,    9,    0,    0,
 467        0,    0,    0,    0,    0,   10,   10,    0,    0,    0,
 468        0,    0,    0,    1,    0
 469    } ;
 470
 471static yyconst flex_int32_t yy_ec[256] =
 472    {   0,
 473        1,    1,    1,    1,    1,    1,    1,    1,    2,    3,
 474        4,    4,    4,    1,    1,    1,    1,    1,    1,    1,
 475        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 476        1,    2,    1,    5,    6,    7,    8,    9,   10,    1,
 477        1,    8,   11,    1,   12,   13,    8,   14,   15,   15,
 478       15,   15,   15,   15,   15,   16,   16,    1,    1,   17,
 479       18,   19,    1,    1,   20,   20,   20,   20,   21,   22,
 480        7,    7,    7,    7,    7,   23,    7,    7,    7,    7,
 481        7,    7,    7,    7,   24,    7,    7,   25,    7,    7,
 482        1,   26,    1,    8,    7,    1,   20,   20,   20,   20,
 483
 484       21,   22,    7,    7,    7,    7,    7,   27,    7,    7,
 485        7,    7,    7,    7,    7,    7,   24,    7,    7,   25,
 486        7,    7,    1,   28,    1,    8,    1,    1,    1,    1,
 487        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 488        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 489        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 490        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 491        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 492        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 493        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 494
 495        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 496        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 497        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 498        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 499        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 500        1,    1,    1,    1,    1
 501    } ;
 502
 503static yyconst flex_int32_t yy_meta[29] =
 504    {   0,
 505        1,    1,    2,    1,    1,    1,    3,    1,    1,    1,
 506        4,    4,    5,    6,    6,    6,    1,    1,    1,    7,
 507        8,    7,    3,    3,    3,    1,    3,    1
 508    } ;
 509
 510static yyconst flex_int16_t yy_base[88] =
 511    {   0,
 512        0,  147,   21,  140,  145,  284,   39,  284,   26,    0,
 513       32,  126,   40,   44,  115,   35,   36,   46,   50,   53,
 514       39,   61,   54,   79,   65,  284,    0,    0,   66,  284,
 515        0,  119,   79,   75,  123,  104,  284,  284,  107,    0,
 516       79,   73,   76,   76,   66,    0,    0,   85,   86,  284,
 517      133,   83,   91,  284,   99,  147,  284,  114,  122,   70,
 518      107,  141,  172,  151,  135,  181,  284,  137,  114,  157,
 519      149,   48,   45,  284,  284,  208,  214,  222,  230,  238,
 520      246,  250,  255,  256,  261,  267,  275
 521    } ;
 522
 523static yyconst flex_int16_t yy_def[88] =
 524    {   0,
 525       75,    1,    1,    3,   75,   75,   75,   75,   76,   77,
 526       78,   75,   77,   79,   75,   75,   75,   75,   75,   19,
 527       75,   75,   75,   75,   76,   75,   80,   77,   78,   75,
 528       81,   75,   76,   78,   79,   79,   75,   75,   75,   39,
 529       19,   82,   83,   75,   75,   84,   20,   76,   78,   75,
 530       79,   51,   85,   75,   75,   75,   75,   84,   79,   51,
 531       79,   79,   79,   51,   75,   75,   75,   86,   79,   63,
 532       86,   87,   87,   75,    0,   75,   75,   75,   75,   75,
 533       75,   75,   75,   75,   75,   75,   75
 534    } ;
 535
 536static yyconst flex_int16_t yy_nxt[313] =
 537    {   0,
 538        6,    7,    8,    7,    9,    6,   10,    6,    6,   11,
 539        6,    6,   12,    6,    6,    6,    6,    6,    6,   10,
 540       10,   10,   13,   10,   10,    6,   10,    6,   15,   16,
 541       26,   15,   17,   18,   19,   20,   20,   21,   15,   22,
 542       24,   30,   24,   38,   33,   36,   37,   74,   23,   34,
 543       74,   27,   38,   38,   38,   38,   38,   31,   32,   39,
 544       39,   39,   40,   41,   41,   42,   47,   47,   47,   26,
 545       43,   38,   44,   45,   46,   30,   44,   75,   38,   38,
 546       24,   38,   24,   26,   30,   40,   55,   55,   57,   26,
 547       27,   31,   57,   43,   35,   30,   64,   64,   64,   57,
 548
 549       31,   65,   65,   75,   27,   36,   37,   35,   59,   37,
 550       27,   31,   56,   56,   56,   59,   37,   51,   52,   52,
 551       39,   39,   39,   59,   37,   37,   68,   53,   54,   54,
 552       69,   50,   38,   54,   59,   37,   44,   45,   32,   37,
 553       44,   35,   59,   37,   75,   14,   60,   60,   66,   66,
 554       66,   37,   14,   72,   75,   61,   62,   63,   59,   61,
 555       56,   56,   56,   69,   64,   64,   64,   69,   67,   67,
 556       75,   75,   75,   67,   37,   35,   75,   75,   75,   61,
 557       62,   75,   75,   61,   75,   70,   70,   70,   75,   75,
 558       75,   70,   70,   70,   66,   66,   66,   75,   75,   75,
 559
 560       75,   75,   54,   54,   75,   75,   75,   54,   25,   25,
 561       25,   25,   25,   25,   25,   25,   28,   75,   75,   28,
 562       28,   28,   29,   29,   29,   29,   29,   29,   29,   29,
 563       35,   35,   35,   35,   35,   35,   35,   35,   48,   75,
 564       48,   48,   48,   48,   48,   48,   49,   75,   49,   49,
 565       49,   49,   49,   49,   42,   42,   75,   42,   56,   75,
 566       56,   58,   58,   58,   66,   75,   66,   71,   71,   71,
 567       71,   71,   71,   71,   71,   73,   73,   73,   73,   73,
 568       73,   73,   73,    5,   75,   75,   75,   75,   75,   75,
 569       75,   75,   75,   75,   75,   75,   75,   75,   75,   75,
 570
 571       75,   75,   75,   75,   75,   75,   75,   75,   75,   75,
 572       75,   75
 573    } ;
 574
 575static yyconst flex_int16_t yy_chk[313] =
 576    {   0,
 577        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 578        1,    1,    1,    1,    1,    1,    1,    1,    1,    1,
 579        1,    1,    1,    1,    1,    1,    1,    1,    3,    3,
 580        9,    3,    3,    3,    3,    3,    3,    3,    3,    3,
 581        7,   11,    7,   16,   13,   14,   14,   73,    3,   13,
 582       72,    9,   16,   17,   17,   21,   21,   11,   18,   18,
 583       18,   18,   19,   19,   19,   19,   20,   20,   20,   25,
 584       19,   23,   19,   19,   19,   29,   19,   20,   22,   22,
 585       24,   23,   24,   33,   34,   42,   43,   43,   45,   48,
 586       25,   29,   45,   42,   60,   49,   52,   52,   52,   44,
 587
 588       34,   53,   53,   41,   33,   36,   36,   52,   61,   61,
 589       48,   49,   55,   55,   55,   69,   69,   36,   36,   36,
 590       39,   39,   39,   59,   59,   35,   59,   39,   39,   39,
 591       61,   32,   15,   39,   51,   51,   58,   58,   12,   68,
 592       58,   68,   62,   62,    5,    4,   51,   51,   65,   65,
 593       65,   71,    2,   71,    0,   51,   51,   51,   70,   51,
 594       56,   56,   56,   62,   64,   64,   64,   62,   56,   56,
 595        0,    0,    0,   56,   63,   64,    0,    0,    0,   70,
 596       70,    0,    0,   70,    0,   63,   63,   63,    0,    0,
 597        0,   63,   63,   63,   66,   66,   66,    0,    0,    0,
 598
 599        0,    0,   66,   66,    0,    0,    0,   66,   76,   76,
 600       76,   76,   76,   76,   76,   76,   77,    0,    0,   77,
 601       77,   77,   78,   78,   78,   78,   78,   78,   78,   78,
 602       79,   79,   79,   79,   79,   79,   79,   79,   80,    0,
 603       80,   80,   80,   80,   80,   80,   81,    0,   81,   81,
 604       81,   81,   81,   81,   82,   82,    0,   82,   83,    0,
 605       83,   84,   84,   84,   85,    0,   85,   86,   86,   86,
 606       86,   86,   86,   86,   86,   87,   87,   87,   87,   87,
 607       87,   87,   87,   75,   75,   75,   75,   75,   75,   75,
 608       75,   75,   75,   75,   75,   75,   75,   75,   75,   75,
 609
 610       75,   75,   75,   75,   75,   75,   75,   75,   75,   75,
 611       75,   75
 612    } ;
 613
 614static yy_state_type yy_last_accepting_state;
 615static char *yy_last_accepting_cpos;
 616
 617extern int yy_flex_debug;
 618int yy_flex_debug = 1;
 619
 620static yyconst flex_int16_t yy_rule_linenum[13] =
 621    {   0,
 622       71,   72,   73,   76,   79,   80,   81,   87,   88,   89,
 623       91,   94
 624    } ;
 625
 626/* The intent behind this definition is that it'll catch
 627 * any uses of REJECT which flex missed.
 628 */
 629#define REJECT reject_used_but_not_detected
 630#define yymore() yymore_used_but_not_detected
 631#define YY_MORE_ADJ 0
 632#define YY_RESTORE_YY_MORE_OFFSET
 633char *yytext;
 634#line 1 "scripts/genksyms/lex.l"
 635/* Lexical analysis for genksyms.
 636   Copyright 1996, 1997 Linux International.
 637
 638   New implementation contributed by Richard Henderson <rth@tamu.edu>
 639   Based on original work by Bjorn Ekwall <bj0rn@blox.se>
 640
 641   Taken from Linux modutils 2.4.22.
 642
 643   This program is free software; you can redistribute it and/or modify it
 644   under the terms of the GNU General Public License as published by the
 645   Free Software Foundation; either version 2 of the License, or (at your
 646   option) any later version.
 647
 648   This program is distributed in the hope that it will be useful, but
 649   WITHOUT ANY WARRANTY; without even the implied warranty of
 650   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 651   General Public License for more details.
 652
 653   You should have received a copy of the GNU General Public License
 654   along with this program; if not, write to the Free Software Foundation,
 655   Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 656#line 25 "scripts/genksyms/lex.l"
 657
 658#include <limits.h>
 659#include <stdlib.h>
 660#include <string.h>
 661#include <ctype.h>
 662
 663#include "genksyms.h"
 664#include "parse.h"
 665
 666/* We've got a two-level lexer here.  We let flex do basic tokenization
 667   and then we categorize those basic tokens in the second stage.  */
 668#define YY_DECL         static int yylex1(void)
 669
 670/* Version 2 checksumming does proper tokenization; version 1 wasn't
 671   quite so pedantic.  */
 672
 673/* We don't do multiple input files.  */
 674#define YY_NO_INPUT 1
 675#line 676 "scripts/genksyms/lex.c"
 676
 677#define INITIAL 0
 678#define V2_TOKENS 1
 679
 680#ifndef YY_NO_UNISTD_H
 681/* Special case for "unistd.h", since it is non-ANSI. We include it way
 682 * down here because we want the user's section 1 to have been scanned first.
 683 * The user has a chance to override it with an option.
 684 */
 685/* %if-c-only */
 686#include <unistd.h>
 687/* %endif */
 688/* %if-c++-only */
 689/* %endif */
 690#endif
 691
 692#ifndef YY_EXTRA_TYPE
 693#define YY_EXTRA_TYPE void *
 694#endif
 695
 696/* %if-c-only Reentrant structure and macros (non-C++). */
 697/* %if-reentrant */
 698/* %if-c-only */
 699
 700static int yy_init_globals (void );
 701
 702/* %endif */
 703/* %if-reentrant */
 704/* %endif */
 705/* %endif End reentrant structures and macros. */
 706
 707/* Accessor methods to globals.
 708   These are made visible to non-reentrant scanners for convenience. */
 709
 710int yylex_destroy (void );
 711
 712int yyget_debug (void );
 713
 714void yyset_debug (int debug_flag  );
 715
 716YY_EXTRA_TYPE yyget_extra (void );
 717
 718void yyset_extra (YY_EXTRA_TYPE user_defined  );
 719
 720FILE *yyget_in (void );
 721
 722void yyset_in  (FILE * in_str  );
 723
 724FILE *yyget_out (void );
 725
 726void yyset_out  (FILE * out_str  );
 727
 728int yyget_leng (void );
 729
 730char *yyget_text (void );
 731
 732int yyget_lineno (void );
 733
 734void yyset_lineno (int line_number  );
 735
 736/* %if-bison-bridge */
 737/* %endif */
 738
 739/* Macros after this point can all be overridden by user definitions in
 740 * section 1.
 741 */
 742
 743#ifndef YY_SKIP_YYWRAP
 744#ifdef __cplusplus
 745extern "C" int yywrap (void );
 746#else
 747extern int yywrap (void );
 748#endif
 749#endif
 750
 751/* %not-for-header */
 752
 753    static void yyunput (int c,char *buf_ptr  );
 754    
 755/* %ok-for-header */
 756
 757/* %endif */
 758
 759#ifndef yytext_ptr
 760static void yy_flex_strncpy (char *,yyconst char *,int );
 761#endif
 762
 763#ifdef YY_NEED_STRLEN
 764static int yy_flex_strlen (yyconst char * );
 765#endif
 766
 767#ifndef YY_NO_INPUT
 768/* %if-c-only Standard (non-C++) definition */
 769/* %not-for-header */
 770
 771#ifdef __cplusplus
 772static int yyinput (void );
 773#else
 774static int input (void );
 775#endif
 776/* %ok-for-header */
 777
 778/* %endif */
 779#endif
 780
 781/* %if-c-only */
 782
 783/* %endif */
 784
 785/* Amount of stuff to slurp up with each read. */
 786#ifndef YY_READ_BUF_SIZE
 787#define YY_READ_BUF_SIZE 8192
 788#endif
 789
 790/* Copy whatever the last rule matched to the standard output. */
 791#ifndef ECHO
 792/* %if-c-only Standard (non-C++) definition */
 793/* This used to be an fputs(), but since the string might contain NUL's,
 794 * we now use fwrite().
 795 */
 796#define ECHO fwrite( yytext, yyleng, 1, yyout )
 797/* %endif */
 798/* %if-c++-only C++ definition */
 799/* %endif */
 800#endif
 801
 802/* Gets input and stuffs it into "buf".  number of characters read, or YY_NULL,
 803 * is returned in "result".
 804 */
 805#ifndef YY_INPUT
 806#define YY_INPUT(buf,result,max_size) \
 807/* %% [5.0] fread()/read() definition of YY_INPUT goes here unless we're doing C++ \ */\
 808        if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \
 809                { \
 810                int c = '*'; \
 811                size_t n; \
 812                for ( n = 0; n < max_size && \
 813                             (c = getc( yyin )) != EOF && c != '\n'; ++n ) \
 814                        buf[n] = (char) c; \
 815                if ( c == '\n' ) \
 816                        buf[n++] = (char) c; \
 817                if ( c == EOF && ferror( yyin ) ) \
 818                        YY_FATAL_ERROR( "input in flex scanner failed" ); \
 819                result = n; \
 820                } \
 821        else \
 822                { \
 823                errno=0; \
 824                while ( (result = fread(buf, 1, max_size, yyin))==0 && ferror(yyin)) \
 825                        { \
 826                        if( errno != EINTR) \
 827                                { \
 828                                YY_FATAL_ERROR( "input in flex scanner failed" ); \
 829                                break; \
 830                                } \
 831                        errno=0; \
 832                        clearerr(yyin); \
 833                        } \
 834                }\
 835\
 836/* %if-c++-only C++ definition \ */\
 837/* %endif */
 838
 839#endif
 840
 841/* No semi-colon after return; correct usage is to write "yyterminate();" -
 842 * we don't want an extra ';' after the "return" because that will cause
 843 * some compilers to complain about unreachable statements.
 844 */
 845#ifndef yyterminate
 846#define yyterminate() return YY_NULL
 847#endif
 848
 849/* Number of entries by which start-condition stack grows. */
 850#ifndef YY_START_STACK_INCR
 851#define YY_START_STACK_INCR 25
 852#endif
 853
 854/* Report a fatal error. */
 855#ifndef YY_FATAL_ERROR
 856/* %if-c-only */
 857#define YY_FATAL_ERROR(msg) yy_fatal_error( msg )
 858/* %endif */
 859/* %if-c++-only */
 860/* %endif */
 861#endif
 862
 863/* %if-tables-serialization structures and prototypes */
 864/* %not-for-header */
 865
 866/* %ok-for-header */
 867
 868/* %not-for-header */
 869
 870/* %tables-yydmap generated elements */
 871/* %endif */
 872/* end tables serialization structures and prototypes */
 873
 874/* %ok-for-header */
 875
 876/* Default declaration of generated scanner - a define so the user can
 877 * easily add parameters.
 878 */
 879#ifndef YY_DECL
 880#define YY_DECL_IS_OURS 1
 881/* %if-c-only Standard (non-C++) definition */
 882
 883extern int yylex (void);
 884
 885#define YY_DECL int yylex (void)
 886/* %endif */
 887/* %if-c++-only C++ definition */
 888/* %endif */
 889#endif /* !YY_DECL */
 890
 891/* Code executed at the beginning of each rule, after yytext and yyleng
 892 * have been set up.
 893 */
 894#ifndef YY_USER_ACTION
 895#define YY_USER_ACTION
 896#endif
 897
 898/* Code executed at the end of each rule. */
 899#ifndef YY_BREAK
 900#define YY_BREAK break;
 901#endif
 902
 903/* %% [6.0] YY_RULE_SETUP definition goes here */
 904#define YY_RULE_SETUP \
 905        if ( yyleng > 0 ) \
 906                YY_CURRENT_BUFFER_LVALUE->yy_at_bol = \
 907                                (yytext[yyleng - 1] == '\n'); \
 908        YY_USER_ACTION
 909
 910/* %not-for-header */
 911
 912/** The main scanner function which does all the work.
 913 */
 914YY_DECL
 915{
 916        register yy_state_type yy_current_state;
 917        register char *yy_cp, *yy_bp;
 918        register int yy_act;
 919    
 920/* %% [7.0] user's declarations go here */
 921#line 67 "scripts/genksyms/lex.l"
 922
 923
 924
 925 /* Keep track of our location in the original source files.  */
 926#line 927 "scripts/genksyms/lex.c"
 927
 928        if ( !(yy_init) )
 929                {
 930                (yy_init) = 1;
 931
 932#ifdef YY_USER_INIT
 933                YY_USER_INIT;
 934#endif
 935
 936                if ( ! (yy_start) )
 937                        (yy_start) = 1; /* first start state */
 938
 939                if ( ! yyin )
 940/* %if-c-only */
 941                        yyin = stdin;
 942/* %endif */
 943/* %if-c++-only */
 944/* %endif */
 945
 946                if ( ! yyout )
 947/* %if-c-only */
 948                        yyout = stdout;
 949/* %endif */
 950/* %if-c++-only */
 951/* %endif */
 952
 953                if ( ! YY_CURRENT_BUFFER ) {
 954                        yyensure_buffer_stack ();
 955                        YY_CURRENT_BUFFER_LVALUE =
 956                                yy_create_buffer(yyin,YY_BUF_SIZE );
 957                }
 958
 959                yy_load_buffer_state( );
 960                }
 961
 962        while ( 1 )             /* loops until end-of-file is reached */
 963                {
 964/* %% [8.0] yymore()-related code goes here */
 965                yy_cp = (yy_c_buf_p);
 966
 967                /* Support of yytext. */
 968                *yy_cp = (yy_hold_char);
 969
 970                /* yy_bp points to the position in yy_ch_buf of the start of
 971                 * the current run.
 972                 */
 973                yy_bp = yy_cp;
 974
 975/* %% [9.0] code to set up and find next match goes here */
 976                yy_current_state = (yy_start);
 977                yy_current_state += YY_AT_BOL();
 978yy_match:
 979                do
 980                        {
 981                        register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)];
 982                        if ( yy_accept[yy_current_state] )
 983                                {
 984                                (yy_last_accepting_state) = yy_current_state;
 985                                (yy_last_accepting_cpos) = yy_cp;
 986                                }
 987                        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
 988                                {
 989                                yy_current_state = (int) yy_def[yy_current_state];
 990                                if ( yy_current_state >= 76 )
 991                                        yy_c = yy_meta[(unsigned int) yy_c];
 992                                }
 993                        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
 994                        ++yy_cp;
 995                        }
 996                while ( yy_base[yy_current_state] != 284 );
 997
 998yy_find_action:
 999/* %% [10.0] code to find the action number goes here */
1000                yy_act = yy_accept[yy_current_state];
1001                if ( yy_act == 0 )
1002                        { /* have to back up */
1003                        yy_cp = (yy_last_accepting_cpos);
1004                        yy_current_state = (yy_last_accepting_state);
1005                        yy_act = yy_accept[yy_current_state];
1006                        }
1007
1008                YY_DO_BEFORE_ACTION;
1009
1010/* %% [11.0] code for yylineno update goes here */
1011
1012do_action:      /* This label is used only to access EOF actions. */
1013
1014/* %% [12.0] debug code goes here */
1015                if ( yy_flex_debug )
1016                        {
1017                        if ( yy_act == 0 )
1018                                fprintf( stderr, "--scanner backing up\n" );
1019                        else if ( yy_act < 13 )
1020                                fprintf( stderr, "--accepting rule at line %ld (\"%s\")\n",
1021                                         (long)yy_rule_linenum[yy_act], yytext );
1022                        else if ( yy_act == 13 )
1023                                fprintf( stderr, "--accepting default rule (\"%s\")\n",
1024                                         yytext );
1025                        else if ( yy_act == 14 )
1026                                fprintf( stderr, "--(end of buffer or a NUL)\n" );
1027                        else
1028                                fprintf( stderr, "--EOF (start condition %d)\n", YY_START );
1029                        }
1030
1031                switch ( yy_act )
1032        { /* beginning of action switch */
1033/* %% [13.0] actions go here */
1034                        case 0: /* must back up */
1035                        /* undo the effects of YY_DO_BEFORE_ACTION */
1036                        *yy_cp = (yy_hold_char);
1037                        yy_cp = (yy_last_accepting_cpos);
1038                        yy_current_state = (yy_last_accepting_state);
1039                        goto yy_find_action;
1040
1041case 1:
1042/* rule 1 can match eol */
1043YY_RULE_SETUP
1044#line 71 "scripts/genksyms/lex.l"
1045return FILENAME;
1046        YY_BREAK
1047case 2:
1048/* rule 2 can match eol */
1049YY_RULE_SETUP
1050#line 72 "scripts/genksyms/lex.l"
1051cur_line++;
1052        YY_BREAK
1053case 3:
1054/* rule 3 can match eol */
1055YY_RULE_SETUP
1056#line 73 "scripts/genksyms/lex.l"
1057cur_line++;
1058        YY_BREAK
1059/* Ignore all other whitespace.  */
1060case 4:
1061YY_RULE_SETUP
1062#line 76 "scripts/genksyms/lex.l"
1063;
1064        YY_BREAK
1065case 5:
1066/* rule 5 can match eol */
1067YY_RULE_SETUP
1068#line 79 "scripts/genksyms/lex.l"
1069return STRING;
1070        YY_BREAK
1071case 6:
1072/* rule 6 can match eol */
1073YY_RULE_SETUP
1074#line 80 "scripts/genksyms/lex.l"
1075return CHAR;
1076        YY_BREAK
1077case 7:
1078YY_RULE_SETUP
1079#line 81 "scripts/genksyms/lex.l"
1080return IDENT;
1081        YY_BREAK
1082/* The Pedant requires that the other C multi-character tokens be
1083    recognized as tokens.  We don't actually use them since we don't
1084    parse expressions, but we do want whitespace to be arranged
1085    around them properly.  */
1086case 8:
1087YY_RULE_SETUP
1088#line 87 "scripts/genksyms/lex.l"
1089return OTHER;
1090        YY_BREAK
1091case 9:
1092YY_RULE_SETUP
1093#line 88 "scripts/genksyms/lex.l"
1094return INT;
1095        YY_BREAK
1096case 10:
1097YY_RULE_SETUP
1098#line 89 "scripts/genksyms/lex.l"
1099return REAL;
1100        YY_BREAK
1101case 11:
1102YY_RULE_SETUP
1103#line 91 "scripts/genksyms/lex.l"
1104return DOTS;
1105        YY_BREAK
1106/* All other tokens are single characters.  */
1107case 12:
1108YY_RULE_SETUP
1109#line 94 "scripts/genksyms/lex.l"
1110return yytext[0];
1111        YY_BREAK
1112case 13:
1113YY_RULE_SETUP
1114#line 97 "scripts/genksyms/lex.l"
1115ECHO;
1116        YY_BREAK
1117#line 1118 "scripts/genksyms/lex.c"
1118case YY_STATE_EOF(INITIAL):
1119case YY_STATE_EOF(V2_TOKENS):
1120        yyterminate();
1121
1122        case YY_END_OF_BUFFER:
1123                {
1124                /* Amount of text matched not including the EOB char. */
1125                int yy_amount_of_matched_text = (int) (yy_cp - (yytext_ptr)) - 1;
1126
1127                /* Undo the effects of YY_DO_BEFORE_ACTION. */
1128                *yy_cp = (yy_hold_char);
1129                YY_RESTORE_YY_MORE_OFFSET
1130
1131                if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_NEW )
1132                        {
1133                        /* We're scanning a new file or input source.  It's
1134                         * possible that this happened because the user
1135                         * just pointed yyin at a new source and called
1136                         * yylex().  If so, then we have to assure
1137                         * consistency between YY_CURRENT_BUFFER and our
1138                         * globals.  Here is the right place to do so, because
1139                         * this is the first action (other than possibly a
1140                         * back-up) that will match for the new input source.
1141                         */
1142                        (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
1143                        YY_CURRENT_BUFFER_LVALUE->yy_input_file = yyin;
1144                        YY_CURRENT_BUFFER_LVALUE->yy_buffer_status = YY_BUFFER_NORMAL;
1145                        }
1146
1147                /* Note that here we test for yy_c_buf_p "<=" to the position
1148                 * of the first EOB in the buffer, since yy_c_buf_p will
1149                 * already have been incremented past the NUL character
1150                 * (since all states make transitions on EOB to the
1151                 * end-of-buffer state).  Contrast this with the test
1152                 * in input().
1153                 */
1154                if ( (yy_c_buf_p) <= &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
1155                        { /* This was really a NUL. */
1156                        yy_state_type yy_next_state;
1157
1158                        (yy_c_buf_p) = (yytext_ptr) + yy_amount_of_matched_text;
1159
1160                        yy_current_state = yy_get_previous_state(  );
1161
1162                        /* Okay, we're now positioned to make the NUL
1163                         * transition.  We couldn't have
1164                         * yy_get_previous_state() go ahead and do it
1165                         * for us because it doesn't know how to deal
1166                         * with the possibility of jamming (and we don't
1167                         * want to build jamming into it because then it
1168                         * will run more slowly).
1169                         */
1170
1171                        yy_next_state = yy_try_NUL_trans( yy_current_state );
1172
1173                        yy_bp = (yytext_ptr) + YY_MORE_ADJ;
1174
1175                        if ( yy_next_state )
1176                                {
1177                                /* Consume the NUL. */
1178                                yy_cp = ++(yy_c_buf_p);
1179                                yy_current_state = yy_next_state;
1180                                goto yy_match;
1181                                }
1182
1183                        else
1184                                {
1185/* %% [14.0] code to do back-up for compressed tables and set up yy_cp goes here */
1186                                yy_cp = (yy_c_buf_p);
1187                                goto yy_find_action;
1188                                }
1189                        }
1190
1191                else switch ( yy_get_next_buffer(  ) )
1192                        {
1193                        case EOB_ACT_END_OF_FILE:
1194                                {
1195                                (yy_did_buffer_switch_on_eof) = 0;
1196
1197                                if ( yywrap( ) )
1198                                        {
1199                                        /* Note: because we've taken care in
1200                                         * yy_get_next_buffer() to have set up
1201                                         * yytext, we can now set up
1202                                         * yy_c_buf_p so that if some total
1203                                         * hoser (like flex itself) wants to
1204                                         * call the scanner after we return the
1205                                         * YY_NULL, it'll still work - another
1206                                         * YY_NULL will get returned.
1207                                         */
1208                                        (yy_c_buf_p) = (yytext_ptr) + YY_MORE_ADJ;
1209
1210                                        yy_act = YY_STATE_EOF(YY_START);
1211                                        goto do_action;
1212                                        }
1213
1214                                else
1215                                        {
1216                                        if ( ! (yy_did_buffer_switch_on_eof) )
1217                                                YY_NEW_FILE;
1218                                        }
1219                                break;
1220                                }
1221
1222                        case EOB_ACT_CONTINUE_SCAN:
1223                                (yy_c_buf_p) =
1224                                        (yytext_ptr) + yy_amount_of_matched_text;
1225
1226                                yy_current_state = yy_get_previous_state(  );
1227
1228                                yy_cp = (yy_c_buf_p);
1229                                yy_bp = (yytext_ptr) + YY_MORE_ADJ;
1230                                goto yy_match;
1231
1232                        case EOB_ACT_LAST_MATCH:
1233                                (yy_c_buf_p) =
1234                                &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)];
1235
1236                                yy_current_state = yy_get_previous_state(  );
1237
1238                                yy_cp = (yy_c_buf_p);
1239                                yy_bp = (yytext_ptr) + YY_MORE_ADJ;
1240                                goto yy_find_action;
1241                        }
1242                break;
1243                }
1244
1245        default:
1246                YY_FATAL_ERROR(
1247                        "fatal flex scanner internal error--no action found" );
1248        } /* end of action switch */
1249                } /* end of scanning one token */
1250} /* end of yylex */
1251/* %ok-for-header */
1252
1253/* %if-c++-only */
1254/* %not-for-header */
1255
1256/* %ok-for-header */
1257
1258/* %endif */
1259
1260/* yy_get_next_buffer - try to read in a new buffer
1261 *
1262 * Returns a code representing an action:
1263 *      EOB_ACT_LAST_MATCH -
1264 *      EOB_ACT_CONTINUE_SCAN - continue scanning from current position
1265 *      EOB_ACT_END_OF_FILE - end of file
1266 */
1267/* %if-c-only */
1268static int yy_get_next_buffer (void)
1269/* %endif */
1270/* %if-c++-only */
1271/* %endif */
1272{
1273        register char *dest = YY_CURRENT_BUFFER_LVALUE->yy_ch_buf;
1274        register char *source = (yytext_ptr);
1275        register int number_to_move, i;
1276        int ret_val;
1277
1278        if ( (yy_c_buf_p) > &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] )
1279                YY_FATAL_ERROR(
1280                "fatal flex scanner internal error--end of buffer missed" );
1281
1282        if ( YY_CURRENT_BUFFER_LVALUE->yy_fill_buffer == 0 )
1283                { /* Don't try to fill the buffer, so this is an EOF. */
1284                if ( (yy_c_buf_p) - (yytext_ptr) - YY_MORE_ADJ == 1 )
1285                        {
1286                        /* We matched a single character, the EOB, so
1287                         * treat this as a final EOF.
1288                         */
1289                        return EOB_ACT_END_OF_FILE;
1290                        }
1291
1292                else
1293                        {
1294                        /* We matched some text prior to the EOB, first
1295                         * process it.
1296                         */
1297                        return EOB_ACT_LAST_MATCH;
1298                        }
1299                }
1300
1301        /* Try to read more data. */
1302
1303        /* First move last chars to start of buffer. */
1304        number_to_move = (int) ((yy_c_buf_p) - (yytext_ptr)) - 1;
1305
1306        for ( i = 0; i < number_to_move; ++i )
1307                *(dest++) = *(source++);
1308
1309        if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_EOF_PENDING )
1310                /* don't do the read, it's not guaranteed to return an EOF,
1311                 * just force an EOF
1312                 */
1313                YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars) = 0;
1314
1315        else
1316                {
1317                        int num_to_read =
1318                        YY_CURRENT_BUFFER_LVALUE->yy_buf_size - number_to_move - 1;
1319
1320                while ( num_to_read <= 0 )
1321                        { /* Not enough room in the buffer - grow it. */
1322
1323                        /* just a shorter name for the current buffer */
1324                        YY_BUFFER_STATE b = YY_CURRENT_BUFFER;
1325
1326                        int yy_c_buf_p_offset =
1327                                (int) ((yy_c_buf_p) - b->yy_ch_buf);
1328
1329                        if ( b->yy_is_our_buffer )
1330                                {
1331                                int new_size = b->yy_buf_size * 2;
1332
1333                                if ( new_size <= 0 )
1334                                        b->yy_buf_size += b->yy_buf_size / 8;
1335                                else
1336                                        b->yy_buf_size *= 2;
1337
1338                                b->yy_ch_buf = (char *)
1339                                        /* Include room in for 2 EOB chars. */
1340                                        yyrealloc((void *) b->yy_ch_buf,b->yy_buf_size + 2  );
1341                                }
1342                        else
1343                                /* Can't grow it, we don't own it. */
1344                                b->yy_ch_buf = 0;
1345
1346                        if ( ! b->yy_ch_buf )
1347                                YY_FATAL_ERROR(
1348                                "fatal error - scanner input buffer overflow" );
1349
1350                        (yy_c_buf_p) = &b->yy_ch_buf[yy_c_buf_p_offset];
1351
1352                        num_to_read = YY_CURRENT_BUFFER_LVALUE->yy_buf_size -
1353                                                number_to_move - 1;
1354
1355                        }
1356
1357                if ( num_to_read > YY_READ_BUF_SIZE )
1358                        num_to_read = YY_READ_BUF_SIZE;
1359
1360                /* Read in more data. */
1361                YY_INPUT( (&YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[number_to_move]),
1362                        (yy_n_chars), (size_t) num_to_read );
1363
1364                YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
1365                }
1366
1367        if ( (yy_n_chars) == 0 )
1368                {
1369                if ( number_to_move == YY_MORE_ADJ )
1370                        {
1371                        ret_val = EOB_ACT_END_OF_FILE;
1372                        yyrestart(yyin  );
1373                        }
1374
1375                else
1376                        {
1377                        ret_val = EOB_ACT_LAST_MATCH;
1378                        YY_CURRENT_BUFFER_LVALUE->yy_buffer_status =
1379                                YY_BUFFER_EOF_PENDING;
1380                        }
1381                }
1382
1383        else
1384                ret_val = EOB_ACT_CONTINUE_SCAN;
1385
1386        if ((yy_size_t) ((yy_n_chars) + number_to_move) > YY_CURRENT_BUFFER_LVALUE->yy_buf_size) {
1387                /* Extend the array by 50%, plus the number we really need. */
1388                yy_size_t new_size = (yy_n_chars) + number_to_move + ((yy_n_chars) >> 1);
1389                YY_CURRENT_BUFFER_LVALUE->yy_ch_buf = (char *) yyrealloc((void *) YY_CURRENT_BUFFER_LVALUE->yy_ch_buf,new_size  );
1390                if ( ! YY_CURRENT_BUFFER_LVALUE->yy_ch_buf )
1391                        YY_FATAL_ERROR( "out of dynamic memory in yy_get_next_buffer()" );
1392        }
1393
1394        (yy_n_chars) += number_to_move;
1395        YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] = YY_END_OF_BUFFER_CHAR;
1396        YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] = YY_END_OF_BUFFER_CHAR;
1397
1398        (yytext_ptr) = &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[0];
1399
1400        return ret_val;
1401}
1402
1403/* yy_get_previous_state - get the state just before the EOB char was reached */
1404
1405/* %if-c-only */
1406/* %not-for-header */
1407
1408    static yy_state_type yy_get_previous_state (void)
1409/* %endif */
1410/* %if-c++-only */
1411/* %endif */
1412{
1413        register yy_state_type yy_current_state;
1414        register char *yy_cp;
1415    
1416/* %% [15.0] code to get the start state into yy_current_state goes here */
1417        yy_current_state = (yy_start);
1418        yy_current_state += YY_AT_BOL();
1419
1420        for ( yy_cp = (yytext_ptr) + YY_MORE_ADJ; yy_cp < (yy_c_buf_p); ++yy_cp )
1421                {
1422/* %% [16.0] code to find the next state goes here */
1423                register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1);
1424                if ( yy_accept[yy_current_state] )
1425                        {
1426                        (yy_last_accepting_state) = yy_current_state;
1427                        (yy_last_accepting_cpos) = yy_cp;
1428                        }
1429                while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1430                        {
1431                        yy_current_state = (int) yy_def[yy_current_state];
1432                        if ( yy_current_state >= 76 )
1433                                yy_c = yy_meta[(unsigned int) yy_c];
1434                        }
1435                yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1436                }
1437
1438        return yy_current_state;
1439}
1440
1441/* yy_try_NUL_trans - try to make a transition on the NUL character
1442 *
1443 * synopsis
1444 *      next_state = yy_try_NUL_trans( current_state );
1445 */
1446/* %if-c-only */
1447    static yy_state_type yy_try_NUL_trans  (yy_state_type yy_current_state )
1448/* %endif */
1449/* %if-c++-only */
1450/* %endif */
1451{
1452        register int yy_is_jam;
1453    /* %% [17.0] code to find the next state, and perhaps do backing up, goes here */
1454        register char *yy_cp = (yy_c_buf_p);
1455
1456        register YY_CHAR yy_c = 1;
1457        if ( yy_accept[yy_current_state] )
1458                {
1459                (yy_last_accepting_state) = yy_current_state;
1460                (yy_last_accepting_cpos) = yy_cp;
1461                }
1462        while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1463                {
1464                yy_current_state = (int) yy_def[yy_current_state];
1465                if ( yy_current_state >= 76 )
1466                        yy_c = yy_meta[(unsigned int) yy_c];
1467                }
1468        yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1469        yy_is_jam = (yy_current_state == 75);
1470
1471        return yy_is_jam ? 0 : yy_current_state;
1472}
1473
1474/* %if-c-only */
1475
1476    static void yyunput (int c, register char * yy_bp )
1477/* %endif */
1478/* %if-c++-only */
1479/* %endif */
1480{
1481        register char *yy_cp;
1482    
1483    yy_cp = (yy_c_buf_p);
1484
1485        /* undo effects of setting up yytext */
1486        *yy_cp = (yy_hold_char);
1487
1488        if ( yy_cp < YY_CURRENT_BUFFER_LVALUE->yy_ch_buf + 2 )
1489                { /* need to shift things up to make room */
1490                /* +2 for EOB chars. */
1491                register int number_to_move = (yy_n_chars) + 2;
1492                register char *dest = &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[
1493                                        YY_CURRENT_BUFFER_LVALUE->yy_buf_size + 2];
1494                register char *source =
1495                                &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[number_to_move];
1496
1497                while ( source > YY_CURRENT_BUFFER_LVALUE->yy_ch_buf )
1498                        *--dest = *--source;
1499
1500                yy_cp += (int) (dest - source);
1501                yy_bp += (int) (dest - source);
1502                YY_CURRENT_BUFFER_LVALUE->yy_n_chars =
1503                        (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_buf_size;
1504
1505                if ( yy_cp < YY_CURRENT_BUFFER_LVALUE->yy_ch_buf + 2 )
1506                        YY_FATAL_ERROR( "flex scanner push-back overflow" );
1507                }
1508
1509        *--yy_cp = (char) c;
1510
1511/* %% [18.0] update yylineno here */
1512
1513        (yytext_ptr) = yy_bp;
1514        (yy_hold_char) = *yy_cp;
1515        (yy_c_buf_p) = yy_cp;
1516}
1517/* %if-c-only */
1518
1519/* %endif */
1520
1521/* %if-c-only */
1522#ifndef YY_NO_INPUT
1523#ifdef __cplusplus
1524    static int yyinput (void)
1525#else
1526    static int input  (void)
1527#endif
1528
1529/* %endif */
1530/* %if-c++-only */
1531/* %endif */
1532{
1533        int c;
1534    
1535        *(yy_c_buf_p) = (yy_hold_char);
1536
1537        if ( *(yy_c_buf_p) == YY_END_OF_BUFFER_CHAR )
1538                {
1539                /* yy_c_buf_p now points to the character we want to return.
1540                 * If this occurs *before* the EOB characters, then it's a
1541                 * valid NUL; if not, then we've hit the end of the buffer.
1542                 */
1543                if ( (yy_c_buf_p) < &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
1544                        /* This was really a NUL. */
1545                        *(yy_c_buf_p) = '\0';
1546
1547                else
1548                        { /* need more input */
1549                        int offset = (yy_c_buf_p) - (yytext_ptr);
1550                        ++(yy_c_buf_p);
1551
1552                        switch ( yy_get_next_buffer(  ) )
1553                                {
1554                                case EOB_ACT_LAST_MATCH:
1555                                        /* This happens because yy_g_n_b()
1556                                         * sees that we've accumulated a
1557                                         * token and flags that we need to
1558                                         * try matching the token before
1559                                         * proceeding.  But for input(),
1560                                         * there's no matching to consider.
1561                                         * So convert the EOB_ACT_LAST_MATCH
1562                                         * to EOB_ACT_END_OF_FILE.
1563                                         */
1564
1565                                        /* Reset buffer status. */
1566                                        yyrestart(yyin );
1567
1568                                        /*FALLTHROUGH*/
1569
1570                                case EOB_ACT_END_OF_FILE:
1571                                        {
1572                                        if ( yywrap( ) )
1573                                                return EOF;
1574
1575                                        if ( ! (yy_did_buffer_switch_on_eof) )
1576                                                YY_NEW_FILE;
1577#ifdef __cplusplus
1578                                        return yyinput();
1579#else
1580                                        return input();
1581#endif
1582                                        }
1583
1584                                case EOB_ACT_CONTINUE_SCAN:
1585                                        (yy_c_buf_p) = (yytext_ptr) + offset;
1586                                        break;
1587                                }
1588                        }
1589                }
1590
1591        c = *(unsigned char *) (yy_c_buf_p);    /* cast for 8-bit char's */
1592        *(yy_c_buf_p) = '\0';   /* preserve yytext */
1593        (yy_hold_char) = *++(yy_c_buf_p);
1594
1595/* %% [19.0] update BOL and yylineno */
1596        YY_CURRENT_BUFFER_LVALUE->yy_at_bol = (c == '\n');
1597
1598        return c;
1599}
1600/* %if-c-only */
1601#endif  /* ifndef YY_NO_INPUT */
1602/* %endif */
1603
1604/** Immediately switch to a different input stream.
1605 * @param input_file A readable stream.
1606 * 
1607 * @note This function does not reset the start condition to @c INITIAL .
1608 */
1609/* %if-c-only */
1610    void yyrestart  (FILE * input_file )
1611/* %endif */
1612/* %if-c++-only */
1613/* %endif */
1614{
1615    
1616        if ( ! YY_CURRENT_BUFFER ){
1617        yyensure_buffer_stack ();
1618                YY_CURRENT_BUFFER_LVALUE =
1619            yy_create_buffer(yyin,YY_BUF_SIZE );
1620        }
1621
1622        yy_init_buffer(YY_CURRENT_BUFFER,input_file );
1623        yy_load_buffer_state( );
1624}
1625
1626/** Switch to a different input buffer.
1627 * @param new_buffer The new input buffer.
1628 * 
1629 */
1630/* %if-c-only */
1631    void yy_switch_to_buffer  (YY_BUFFER_STATE  new_buffer )
1632/* %endif */
1633/* %if-c++-only */
1634/* %endif */
1635{
1636    
1637        /* TODO. We should be able to replace this entire function body
1638         * with
1639         *              yypop_buffer_state();
1640         *              yypush_buffer_state(new_buffer);
1641     */
1642        yyensure_buffer_stack ();
1643        if ( YY_CURRENT_BUFFER == new_buffer )
1644                return;
1645
1646        if ( YY_CURRENT_BUFFER )
1647                {
1648                /* Flush out information for old buffer. */
1649                *(yy_c_buf_p) = (yy_hold_char);
1650                YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
1651                YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
1652                }
1653
1654        YY_CURRENT_BUFFER_LVALUE = new_buffer;
1655        yy_load_buffer_state( );
1656
1657        /* We don't actually know whether we did this switch during
1658         * EOF (yywrap()) processing, but the only time this flag
1659         * is looked at is after yywrap() is called, so it's safe
1660         * to go ahead and always set it.
1661         */
1662        (yy_did_buffer_switch_on_eof) = 1;
1663}
1664
1665/* %if-c-only */
1666static void yy_load_buffer_state  (void)
1667/* %endif */
1668/* %if-c++-only */
1669/* %endif */
1670{
1671        (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
1672        (yytext_ptr) = (yy_c_buf_p) = YY_CURRENT_BUFFER_LVALUE->yy_buf_pos;
1673        yyin = YY_CURRENT_BUFFER_LVALUE->yy_input_file;
1674        (yy_hold_char) = *(yy_c_buf_p);
1675}
1676
1677/** Allocate and initialize an input buffer state.
1678 * @param file A readable stream.
1679 * @param size The character buffer size in bytes. When in doubt, use @c YY_BUF_SIZE.
1680 * 
1681 * @return the allocated buffer state.
1682 */
1683/* %if-c-only */
1684    YY_BUFFER_STATE yy_create_buffer  (FILE * file, int  size )
1685/* %endif */
1686/* %if-c++-only */
1687/* %endif */
1688{
1689        YY_BUFFER_STATE b;
1690    
1691        b = (YY_BUFFER_STATE) yyalloc(sizeof( struct yy_buffer_state )  );
1692        if ( ! b )
1693                YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" );
1694
1695        b->yy_buf_size = size;
1696
1697        /* yy_ch_buf has to be 2 characters longer than the size given because
1698         * we need to put in 2 end-of-buffer characters.
1699         */
1700        b->yy_ch_buf = (char *) yyalloc(b->yy_buf_size + 2  );
1701        if ( ! b->yy_ch_buf )
1702                YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" );
1703
1704        b->yy_is_our_buffer = 1;
1705
1706        yy_init_buffer(b,file );
1707
1708        return b;
1709}
1710
1711/** Destroy the buffer.
1712 * @param b a buffer created with yy_create_buffer()
1713 * 
1714 */
1715/* %if-c-only */
1716    void yy_delete_buffer (YY_BUFFER_STATE  b )
1717/* %endif */
1718/* %if-c++-only */
1719/* %endif */
1720{
1721    
1722        if ( ! b )
1723                return;
1724
1725        if ( b == YY_CURRENT_BUFFER ) /* Not sure if we should pop here. */
1726                YY_CURRENT_BUFFER_LVALUE = (YY_BUFFER_STATE) 0;
1727
1728        if ( b->yy_is_our_buffer )
1729                yyfree((void *) b->yy_ch_buf  );
1730
1731        yyfree((void *) b  );
1732}
1733
1734/* %if-c-only */
1735
1736#ifndef __cplusplus
1737extern int isatty (int );
1738#endif /* __cplusplus */
1739    
1740/* %endif */
1741
1742/* %if-c++-only */
1743/* %endif */
1744
1745/* Initializes or reinitializes a buffer.
1746 * This function is sometimes called more than once on the same buffer,
1747 * such as during a yyrestart() or at EOF.
1748 */
1749/* %if-c-only */
1750    static void yy_init_buffer  (YY_BUFFER_STATE  b, FILE * file )
1751/* %endif */
1752/* %if-c++-only */
1753/* %endif */
1754
1755{
1756        int oerrno = errno;
1757    
1758        yy_flush_buffer(b );
1759
1760        b->yy_input_file = file;
1761        b->yy_fill_buffer = 1;
1762
1763    /* If b is the current buffer, then yy_init_buffer was _probably_
1764     * called from yyrestart() or through yy_get_next_buffer.
1765     * In that case, we don't want to reset the lineno or column.
1766     */
1767    if (b != YY_CURRENT_BUFFER){
1768        b->yy_bs_lineno = 1;
1769        b->yy_bs_column = 0;
1770    }
1771
1772/* %if-c-only */
1773
1774        b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0;
1775    
1776/* %endif */
1777/* %if-c++-only */
1778/* %endif */
1779        errno = oerrno;
1780}
1781
1782/** Discard all buffered characters. On the next scan, YY_INPUT will be called.
1783 * @param b the buffer state to be flushed, usually @c YY_CURRENT_BUFFER.
1784 * 
1785 */
1786/* %if-c-only */
1787    void yy_flush_buffer (YY_BUFFER_STATE  b )
1788/* %endif */
1789/* %if-c++-only */
1790/* %endif */
1791{
1792        if ( ! b )
1793                return;
1794
1795        b->yy_n_chars = 0;
1796
1797        /* We always need two end-of-buffer characters.  The first causes
1798         * a transition to the end-of-buffer state.  The second causes
1799         * a jam in that state.
1800         */
1801        b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR;
1802        b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR;
1803
1804        b->yy_buf_pos = &b->yy_ch_buf[0];
1805
1806        b->yy_at_bol = 1;
1807        b->yy_buffer_status = YY_BUFFER_NEW;
1808
1809        if ( b == YY_CURRENT_BUFFER )
1810                yy_load_buffer_state( );
1811}
1812
1813/* %if-c-or-c++ */
1814/** Pushes the new state onto the stack. The new state becomes
1815 *  the current state. This function will allocate the stack
1816 *  if necessary.
1817 *  @param new_buffer The new state.
1818 *  
1819 */
1820/* %if-c-only */
1821void yypush_buffer_state (YY_BUFFER_STATE new_buffer )
1822/* %endif */
1823/* %if-c++-only */
1824/* %endif */
1825{
1826        if (new_buffer == NULL)
1827                return;
1828
1829        yyensure_buffer_stack();
1830
1831        /* This block is copied from yy_switch_to_buffer. */
1832        if ( YY_CURRENT_BUFFER )
1833                {
1834                /* Flush out information for old buffer. */
1835                *(yy_c_buf_p) = (yy_hold_char);
1836                YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
1837                YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
1838                }
1839
1840        /* Only push if top exists. Otherwise, replace top. */
1841        if (YY_CURRENT_BUFFER)
1842                (yy_buffer_stack_top)++;
1843        YY_CURRENT_BUFFER_LVALUE = new_buffer;
1844
1845        /* copied from yy_switch_to_buffer. */
1846        yy_load_buffer_state( );
1847        (yy_did_buffer_switch_on_eof) = 1;
1848}
1849/* %endif */
1850
1851/* %if-c-or-c++ */
1852/** Removes and deletes the top of the stack, if present.
1853 *  The next element becomes the new top.
1854 *  
1855 */
1856/* %if-c-only */
1857void yypop_buffer_state (void)
1858/* %endif */
1859/* %if-c++-only */
1860/* %endif */
1861{
1862        if (!YY_CURRENT_BUFFER)
1863                return;
1864
1865        yy_delete_buffer(YY_CURRENT_BUFFER );
1866        YY_CURRENT_BUFFER_LVALUE = NULL;
1867        if ((yy_buffer_stack_top) > 0)
1868                --(yy_buffer_stack_top);
1869
1870        if (YY_CURRENT_BUFFER) {
1871                yy_load_buffer_state( );
1872                (yy_did_buffer_switch_on_eof) = 1;
1873        }
1874}
1875/* %endif */
1876
1877/* %if-c-or-c++ */
1878/* Allocates the stack if it does not exist.
1879 *  Guarantees space for at least one push.
1880 */
1881/* %if-c-only */
1882static void yyensure_buffer_stack (void)
1883/* %endif */
1884/* %if-c++-only */
1885/* %endif */
1886{
1887        int num_to_alloc;
1888    
1889        if (!(yy_buffer_stack)) {
1890
1891                /* First allocation is just for 2 elements, since we don't know if this
1892                 * scanner will even need a stack. We use 2 instead of 1 to avoid an
1893                 * immediate realloc on the next call.
1894         */
1895                num_to_alloc = 1;
1896                (yy_buffer_stack) = (struct yy_buffer_state**)yyalloc
1897                                                                (num_to_alloc * sizeof(struct yy_buffer_state*)
1898                                                                );
1899                if ( ! (yy_buffer_stack) )
1900                        YY_FATAL_ERROR( "out of dynamic memory in yyensure_buffer_stack()" );
1901                                                                  
1902                memset((yy_buffer_stack), 0, num_to_alloc * sizeof(struct yy_buffer_state*));
1903                                
1904                (yy_buffer_stack_max) = num_to_alloc;
1905                (yy_buffer_stack_top) = 0;
1906                return;
1907        }
1908
1909        if ((yy_buffer_stack_top) >= ((yy_buffer_stack_max)) - 1){
1910
1911                /* Increase the buffer to prepare for a possible push. */
1912                int grow_size = 8 /* arbitrary grow size */;
1913
1914                num_to_alloc = (yy_buffer_stack_max) + grow_size;
1915                (yy_buffer_stack) = (struct yy_buffer_state**)yyrealloc
1916                                                                ((yy_buffer_stack),
1917                                                                num_to_alloc * sizeof(struct yy_buffer_state*)
1918                                                                );
1919                if ( ! (yy_buffer_stack) )
1920                        YY_FATAL_ERROR( "out of dynamic memory in yyensure_buffer_stack()" );
1921
1922                /* zero only the new slots.*/
1923                memset((yy_buffer_stack) + (yy_buffer_stack_max), 0, grow_size * sizeof(struct yy_buffer_state*));
1924                (yy_buffer_stack_max) = num_to_alloc;
1925        }
1926}
1927/* %endif */
1928
1929/* %if-c-only */
1930/** Setup the input buffer state to scan directly from a user-specified character buffer.
1931 * @param base the character buffer
1932 * @param size the size in bytes of the character buffer
1933 * 
1934 * @return the newly allocated buffer state object. 
1935 */
1936YY_BUFFER_STATE yy_scan_buffer  (char * base, yy_size_t  size )
1937{
1938        YY_BUFFER_STATE b;
1939    
1940        if ( size < 2 ||
1941             base[size-2] != YY_END_OF_BUFFER_CHAR ||
1942             base[size-1] != YY_END_OF_BUFFER_CHAR )
1943                /* They forgot to leave room for the EOB's. */
1944                return 0;
1945
1946        b = (YY_BUFFER_STATE) yyalloc(sizeof( struct yy_buffer_state )  );
1947        if ( ! b )
1948                YY_FATAL_ERROR( "out of dynamic memory in yy_scan_buffer()" );
1949
1950        b->yy_buf_size = size - 2;      /* "- 2" to take care of EOB's */
1951        b->yy_buf_pos = b->yy_ch_buf = base;
1952        b->yy_is_our_buffer = 0;
1953        b->yy_input_file = 0;
1954        b->yy_n_chars = b->yy_buf_size;
1955        b->yy_is_interactive = 0;
1956        b->yy_at_bol = 1;
1957        b->yy_fill_buffer = 0;
1958        b->yy_buffer_status = YY_BUFFER_NEW;
1959
1960        yy_switch_to_buffer(b  );
1961
1962        return b;
1963}
1964/* %endif */
1965
1966/* %if-c-only */
1967/** Setup the input buffer state to scan a string. The next call to yylex() will
1968 * scan from a @e copy of @a str.
1969 * @param yystr a NUL-terminated string to scan
1970 * 
1971 * @return the newly allocated buffer state object.
1972 * @note If you want to scan bytes that may contain NUL values, then use
1973 *       yy_scan_bytes() instead.
1974 */
1975YY_BUFFER_STATE yy_scan_string (yyconst char * yystr )
1976{
1977    
1978        return yy_scan_bytes(yystr,strlen(yystr) );
1979}
1980/* %endif */
1981
1982/* %if-c-only */
1983/** Setup the input buffer state to scan the given bytes. The next call to yylex() will
1984 * scan from a @e copy of @a bytes.
1985 * @param bytes the byte buffer to scan
1986 * @param len the number of bytes in the buffer pointed to by @a bytes.
1987 * 
1988 * @return the newly allocated buffer state object.
1989 */
1990YY_BUFFER_STATE yy_scan_bytes  (yyconst char * yybytes, int  _yybytes_len )
1991{
1992        YY_BUFFER_STATE b;
1993        char *buf;
1994        yy_size_t n;
1995        int i;
1996    
1997        /* Get memory for full buffer, including space for trailing EOB's. */
1998        n = _yybytes_len + 2;
1999        buf = (char *) yyalloc(n  );
2000        if ( ! buf )
2001                YY_FATAL_ERROR( "out of dynamic memory in yy_scan_bytes()" );
2002
2003        for ( i = 0; i < _yybytes_len; ++i )
2004                buf[i] = yybytes[i];
2005
2006        buf[_yybytes_len] = buf[_yybytes_len+1] = YY_END_OF_BUFFER_CHAR;
2007
2008        b = yy_scan_buffer(buf,n );
2009        if ( ! b )
2010                YY_FATAL_ERROR( "bad buffer in yy_scan_bytes()" );
2011
2012        /* It's okay to grow etc. this buffer, and we should throw it
2013         * away when we're done.
2014         */
2015        b->yy_is_our_buffer = 1;
2016
2017        return b;
2018}
2019/* %endif */
2020
2021#ifndef YY_EXIT_FAILURE
2022#define YY_EXIT_FAILURE 2
2023#endif
2024
2025/* %if-c-only */
2026static void yy_fatal_error (yyconst char* msg )
2027{
2028        (void) fprintf( stderr, "%s\n", msg );
2029        exit( YY_EXIT_FAILURE );
2030}
2031/* %endif */
2032/* %if-c++-only */
2033/* %endif */
2034
2035/* Redefine yyless() so it works in section 3 code. */
2036
2037#undef yyless
2038#define yyless(n) \
2039        do \
2040                { \
2041                /* Undo effects of setting up yytext. */ \
2042        int yyless_macro_arg = (n); \
2043        YY_LESS_LINENO(yyless_macro_arg);\
2044                yytext[yyleng] = (yy_hold_char); \
2045                (yy_c_buf_p) = yytext + yyless_macro_arg; \
2046                (yy_hold_char) = *(yy_c_buf_p); \
2047                *(yy_c_buf_p) = '\0'; \
2048                yyleng = yyless_macro_arg; \
2049                } \
2050        while ( 0 )
2051
2052/* Accessor  methods (get/set functions) to struct members. */
2053
2054/* %if-c-only */
2055/* %if-reentrant */
2056/* %endif */
2057
2058/** Get the current line number.
2059 * 
2060 */
2061int yyget_lineno  (void)
2062{
2063        
2064    return yylineno;
2065}
2066
2067/** Get the input stream.
2068 * 
2069 */
2070FILE *yyget_in  (void)
2071{
2072        return yyin;
2073}
2074
2075/** Get the output stream.
2076 * 
2077 */
2078FILE *yyget_out  (void)
2079{
2080        return yyout;
2081}
2082
2083/** Get the length of the current token.
2084 * 
2085 */
2086int yyget_leng  (void)
2087{
2088        return yyleng;
2089}
2090
2091/** Get the current token.
2092 * 
2093 */
2094
2095char *yyget_text  (void)
2096{
2097        return yytext;
2098}
2099
2100/* %if-reentrant */
2101/* %endif */
2102
2103/** Set the current line number.
2104 * @param line_number
2105 * 
2106 */
2107void yyset_lineno (int  line_number )
2108{
2109    
2110    yylineno = line_number;
2111}
2112
2113/** Set the input stream. This does not discard the current
2114 * input buffer.
2115 * @param in_str A readable stream.
2116 * 
2117 * @see yy_switch_to_buffer
2118 */
2119void yyset_in (FILE *  in_str )
2120{
2121        yyin = in_str ;
2122}
2123
2124void yyset_out (FILE *  out_str )
2125{
2126        yyout = out_str ;
2127}
2128
2129int yyget_debug  (void)
2130{
2131        return yy_flex_debug;
2132}
2133
2134void yyset_debug (int  bdebug )
2135{
2136        yy_flex_debug = bdebug ;
2137}
2138
2139/* %endif */
2140
2141/* %if-reentrant */
2142/* %if-bison-bridge */
2143/* %endif */
2144/* %endif if-c-only */
2145
2146/* %if-c-only */
2147static int yy_init_globals (void)
2148{
2149        /* Initialization is the same as for the non-reentrant scanner.
2150     * This function is called from yylex_destroy(), so don't allocate here.
2151     */
2152
2153    (yy_buffer_stack) = 0;
2154    (yy_buffer_stack_top) = 0;
2155    (yy_buffer_stack_max) = 0;
2156    (yy_c_buf_p) = (char *) 0;
2157    (yy_init) = 0;
2158    (yy_start) = 0;
2159
2160/* Defined in main.c */
2161#ifdef YY_STDINIT
2162    yyin = stdin;
2163    yyout = stdout;
2164#else
2165    yyin = (FILE *) 0;
2166    yyout = (FILE *) 0;
2167#endif
2168
2169    /* For future reference: Set errno on error, since we are called by
2170     * yylex_init()
2171     */
2172    return 0;
2173}
2174/* %endif */
2175
2176/* %if-c-only SNIP! this currently causes conflicts with the c++ scanner */
2177/* yylex_destroy is for both reentrant and non-reentrant scanners. */
2178int yylex_destroy  (void)
2179{
2180    
2181    /* Pop the buffer stack, destroying each element. */
2182        while(YY_CURRENT_BUFFER){
2183                yy_delete_buffer(YY_CURRENT_BUFFER  );
2184                YY_CURRENT_BUFFER_LVALUE = NULL;
2185                yypop_buffer_state();
2186        }
2187
2188        /* Destroy the stack itself. */
2189        yyfree((yy_buffer_stack) );
2190        (yy_buffer_stack) = NULL;
2191
2192    /* Reset the globals. This is important in a non-reentrant scanner so the next time
2193     * yylex() is called, initialization will occur. */
2194    yy_init_globals( );
2195
2196/* %if-reentrant */
2197/* %endif */
2198    return 0;
2199}
2200/* %endif */
2201
2202/*
2203 * Internal utility routines.
2204 */
2205
2206#ifndef yytext_ptr
2207static void yy_flex_strncpy (char* s1, yyconst char * s2, int n )
2208{
2209        register int i;
2210        for ( i = 0; i < n; ++i )
2211                s1[i] = s2[i];
2212}
2213#endif
2214
2215#ifdef YY_NEED_STRLEN
2216static int yy_flex_strlen (yyconst char * s )
2217{
2218        register int n;
2219        for ( n = 0; s[n]; ++n )
2220                ;
2221
2222        return n;
2223}
2224#endif
2225
2226void *yyalloc (yy_size_t  size )
2227{
2228        return (void *) malloc( size );
2229}
2230
2231void *yyrealloc  (void * ptr, yy_size_t  size )
2232{
2233        /* The cast to (char *) in the following accommodates both
2234         * implementations that use char* generic pointers, and those
2235         * that use void* generic pointers.  It works with the latter
2236         * because both ANSI C and C++ allow castless assignment from
2237         * any pointer type to void*, and deal with argument conversions
2238         * as though doing an assignment.
2239         */
2240        return (void *) realloc( (char *) ptr, size );
2241}
2242
2243void yyfree (void * ptr )
2244{
2245        free( (char *) ptr );   /* see yyrealloc() for (char *) cast */
2246}
2247
2248/* %if-tables-serialization definitions */
2249/* %define-yytables   The name for this specific scanner's tables. */
2250#define YYTABLES_NAME "yytables"
2251/* %endif */
2252
2253/* %ok-for-header */
2254
2255#line 97 "scripts/genksyms/lex.l"
2256
2257
2258
2259/* Bring in the keyword recognizer.  */
2260
2261#include "keywords.c"
2262
2263
2264/* Macros to append to our phrase collection list.  */
2265
2266#define _APP(T,L)       do {                                               \
2267                          cur_node = next_node;                            \
2268                          next_node = xmalloc(sizeof(*next_node));         \
2269                          next_node->next = cur_node;                      \
2270                          cur_node->string = memcpy(xmalloc(L+1), T, L+1); \
2271                          cur_node->tag = SYM_NORMAL;                      \
2272                        } while (0)
2273
2274#define APP             _APP(yytext, yyleng)
2275
2276
2277/* The second stage lexer.  Here we incorporate knowledge of the state
2278   of the parser to tailor the tokens that are returned.  */
2279
2280int
2281yylex(void)
2282{
2283  static enum {
2284    ST_NOTSTARTED, ST_NORMAL, ST_ATTRIBUTE, ST_ASM, ST_BRACKET, ST_BRACE,
2285    ST_EXPRESSION, ST_TABLE_1, ST_TABLE_2, ST_TABLE_3, ST_TABLE_4,
2286    ST_TABLE_5, ST_TABLE_6
2287  } lexstate = ST_NOTSTARTED;
2288
2289  static int suppress_type_lookup, dont_want_brace_phrase;
2290  static struct string_list *next_node;
2291
2292  int token, count = 0;
2293  struct string_list *cur_node;
2294
2295  if (lexstate == ST_NOTSTARTED)
2296    {
2297      BEGIN(V2_TOKENS);
2298      next_node = xmalloc(sizeof(*next_node));
2299      next_node->next = NULL;
2300      lexstate = ST_NORMAL;
2301    }
2302
2303repeat:
2304  token = yylex1();
2305
2306  if (token == 0)
2307    return 0;
2308  else if (token == FILENAME)
2309    {
2310      char *file, *e;
2311
2312      /* Save the filename and line number for later error messages.  */
2313
2314      if (cur_filename)
2315        free(cur_filename);
2316
2317      file = strchr(yytext, '\"')+1;
2318      e = strchr(file, '\"');
2319      *e = '\0';
2320      cur_filename = memcpy(xmalloc(e-file+1), file, e-file+1);
2321      cur_line = atoi(yytext+2);
2322
2323      goto repeat;
2324    }
2325
2326  switch (lexstate)
2327    {
2328    case ST_NORMAL:
2329      switch (token)
2330        {
2331        case IDENT:
2332          APP;
2333          {
2334            const struct resword *r = is_reserved_word(yytext, yyleng);
2335            if (r)
2336              {
2337                switch (token = r->token)
2338                  {
2339                  case ATTRIBUTE_KEYW:
2340                    lexstate = ST_ATTRIBUTE;
2341                    count = 0;
2342                    goto repeat;
2343                  case ASM_KEYW:
2344                    lexstate = ST_ASM;
2345                    count = 0;
2346                    goto repeat;
2347
2348                  case STRUCT_KEYW:
2349                  case UNION_KEYW:
2350                    dont_want_brace_phrase = 3;
2351                  case ENUM_KEYW:
2352                    suppress_type_lookup = 2;
2353                    goto fini;
2354
2355                  case EXPORT_SYMBOL_KEYW:
2356                      goto fini;
2357                  }
2358              }
2359            if (!suppress_type_lookup)
2360              {
2361                struct symbol *sym = find_symbol(yytext, SYM_TYPEDEF);
2362                if (sym && sym->type == SYM_TYPEDEF)
2363                  token = TYPE;
2364              }
2365          }
2366          break;
2367
2368        case '[':
2369          APP;
2370          lexstate = ST_BRACKET;
2371          count = 1;
2372          goto repeat;
2373
2374        case '{':
2375          APP;
2376          if (dont_want_brace_phrase)
2377            break;
2378          lexstate = ST_BRACE;
2379          count = 1;
2380          goto repeat;
2381
2382        case '=': case ':':
2383          APP;
2384          lexstate = ST_EXPRESSION;
2385          break;
2386
2387        case DOTS:
2388        default:
2389          APP;
2390          break;
2391        }
2392      break;
2393
2394    case ST_ATTRIBUTE:
2395      APP;
2396      switch (token)
2397        {
2398        case '(':
2399          ++count;
2400          goto repeat;
2401        case ')':
2402          if (--count == 0)
2403            {
2404              lexstate = ST_NORMAL;
2405              token = ATTRIBUTE_PHRASE;
2406              break;
2407            }
2408          goto repeat;
2409        default:
2410          goto repeat;
2411        }
2412      break;
2413
2414    case ST_ASM:
2415      APP;
2416      switch (token)
2417        {
2418        case '(':
2419          ++count;
2420          goto repeat;
2421        case ')':
2422          if (--count == 0)
2423            {
2424              lexstate = ST_NORMAL;
2425              token = ASM_PHRASE;
2426              break;
2427            }
2428          goto repeat;
2429        default:
2430          goto repeat;
2431        }
2432      break;
2433
2434    case ST_BRACKET:
2435      APP;
2436      switch (token)
2437        {
2438        case '[':
2439          ++count;
2440          goto repeat;
2441        case ']':
2442          if (--count == 0)
2443            {
2444              lexstate = ST_NORMAL;
2445              token = BRACKET_PHRASE;
2446              break;
2447            }
2448          goto repeat;
2449        default:
2450          goto repeat;
2451        }
2452      break;
2453
2454    case ST_BRACE:
2455      APP;
2456      switch (token)
2457        {
2458        case '{':
2459          ++count;
2460          goto repeat;
2461        case '}':
2462          if (--count == 0)
2463            {
2464              lexstate = ST_NORMAL;
2465              token = BRACE_PHRASE;
2466              break;
2467            }
2468          goto repeat;
2469        default:
2470          goto repeat;
2471        }
2472      break;
2473
2474    case ST_EXPRESSION:
2475      switch (token)
2476        {
2477        case '(': case '[': case '{':
2478          ++count;
2479          APP;
2480          goto repeat;
2481        case ')': case ']': case '}':
2482          --count;
2483          APP;
2484          goto repeat;
2485        case ',': case ';':
2486          if (count == 0)
2487            {
2488              /* Put back the token we just read so's we can find it again
2489                 after registering the expression.  */
2490              unput(token);
2491
2492              lexstate = ST_NORMAL;
2493              token = EXPRESSION_PHRASE;
2494              break;
2495            }
2496          APP;
2497          goto repeat;
2498        default:
2499          APP;
2500          goto repeat;
2501        }
2502      break;
2503
2504    case ST_TABLE_1:
2505      goto repeat;
2506
2507    case ST_TABLE_2:
2508      if (token == IDENT && yyleng == 1 && yytext[0] == 'X')
2509        {
2510          token = EXPORT_SYMBOL_KEYW;
2511          lexstate = ST_TABLE_5;
2512          APP;
2513          break;
2514        }
2515      lexstate = ST_TABLE_6;
2516      /* FALLTHRU */
2517
2518    case ST_TABLE_6:
2519      switch (token)
2520        {
2521        case '{': case '[': case '(':
2522          ++count;
2523          break;
2524        case '}': case ']': case ')':
2525          --count;
2526          break;
2527        case ',':
2528          if (count == 0)
2529            lexstate = ST_TABLE_2;
2530          break;
2531        };
2532      goto repeat;
2533
2534    case ST_TABLE_3:
2535      goto repeat;
2536
2537    case ST_TABLE_4:
2538      if (token == ';')
2539        lexstate = ST_NORMAL;
2540      goto repeat;
2541
2542    case ST_TABLE_5:
2543      switch (token)
2544        {
2545        case ',':
2546          token = ';';
2547          lexstate = ST_TABLE_2;
2548          APP;
2549          break;
2550        default:
2551          APP;
2552          break;
2553        }
2554      break;
2555
2556    default:
2557      exit(1);
2558    }
2559fini:
2560
2561  if (suppress_type_lookup > 0)
2562    --suppress_type_lookup;
2563  if (dont_want_brace_phrase > 0)
2564    --dont_want_brace_phrase;
2565
2566  yylval = &next_node->next;
2567
2568  return token;
2569}
2570/* A Bison parser, made by GNU Bison 2.3.  */
2571
2572/* Skeleton interface for Bison's Yacc-like parsers in C
2573
2574   Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
2575   Free Software Foundation, Inc.
2576
2577   This program is free software; you can redistribute it and/or modify
2578   it under the terms of the GNU General Public License as published by
2579   the Free Software Foundation; either version 2, or (at your option)
2580   any later version.
2581
2582   This program is distributed in the hope that it will be useful,
2583   but WITHOUT ANY WARRANTY; without even the implied warranty of
2584   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
2585   GNU General Public License for more details.
2586
2587   You should have received a copy of the GNU General Public License
2588   along with this program; if not, write to the Free Software
2589   Foundation, Inc., 51 Franklin Street, Fifth Floor,
2590   Boston, MA 02110-1301, USA.  */
2591
2592/* As a special exception, you may create a larger work that contains
2593   part or all of the Bison parser skeleton and distribute that work
2594   under terms of your choice, so long as that work isn't itself a
2595   parser generator using the skeleton or a modified version thereof
2596   as a parser skeleton.  Alternatively, if you modify or redistribute
2597   the parser skeleton itself, you may (at your option) remove this
2598   special exception, which will cause the skeleton and the resulting
2599   Bison output files to be licensed under the GNU General Public
2600   License without this special exception.
2601
2602   This special exception was added by the Free Software Foundation in
2603   version 2.2 of Bison.  */
2604
2605/* Tokens.  */
2606#ifndef YYTOKENTYPE
2607# define YYTOKENTYPE
2608   /* Put the tokens into the symbol table, so that GDB and other debuggers
2609      know about them.  */
2610   enum yytokentype {
2611     ASM_KEYW = 258,
2612     ATTRIBUTE_KEYW = 259,
2613     AUTO_KEYW = 260,
2614     BOOL_KEYW = 261,
2615     CHAR_KEYW = 262,
2616     CONST_KEYW = 263,
2617     DOUBLE_KEYW = 264,
2618     ENUM_KEYW = 265,
2619     EXTERN_KEYW = 266,
2620     EXTENSION_KEYW = 267,
2621     FLOAT_KEYW = 268,
2622     INLINE_KEYW = 269,
2623     INT_KEYW = 270,
2624     LONG_KEYW = 271,
2625     REGISTER_KEYW = 272,
2626     RESTRICT_KEYW = 273,
2627     SHORT_KEYW = 274,
2628     SIGNED_KEYW = 275,
2629     STATIC_KEYW = 276,
2630     STRUCT_KEYW = 277,
2631     TYPEDEF_KEYW = 278,
2632     UNION_KEYW = 279,
2633     UNSIGNED_KEYW = 280,
2634     VOID_KEYW = 281,
2635     VOLATILE_KEYW = 282,
2636     TYPEOF_KEYW = 283,
2637     EXPORT_SYMBOL_KEYW = 284,
2638     ASM_PHRASE = 285,
2639     ATTRIBUTE_PHRASE = 286,
2640     BRACE_PHRASE = 287,
2641     BRACKET_PHRASE = 288,
2642     EXPRESSION_PHRASE = 289,
2643     CHAR = 290,
2644     DOTS = 291,
2645     IDENT = 292,
2646     INT = 293,
2647     REAL = 294,
2648     STRING = 295,
2649     TYPE = 296,
2650     OTHER = 297,
2651     FILENAME = 298
2652   };
2653#endif
2654/* Tokens.  */
2655#define ASM_KEYW 258
2656#define ATTRIBUTE_KEYW 259
2657#define AUTO_KEYW 260
2658#define BOOL_KEYW 261
2659#define CHAR_KEYW 262
2660#define CONST_KEYW 263
2661#define DOUBLE_KEYW 264
2662#define ENUM_KEYW 265
2663#define EXTERN_KEYW 266
2664#define EXTENSION_KEYW 267
2665#define FLOAT_KEYW 268
2666#define INLINE_KEYW 269
2667#define INT_KEYW 270
2668#define LONG_KEYW 271
2669#define REGISTER_KEYW 272
2670#define RESTRICT_KEYW 273
2671#define SHORT_KEYW 274
2672#define SIGNED_KEYW 275
2673#define STATIC_KEYW 276
2674#define STRUCT_KEYW 277
2675#define TYPEDEF_KEYW 278
2676#define UNION_KEYW 279
2677#define UNSIGNED_KEYW 280
2678#define VOID_KEYW 281
2679#define VOLATILE_KEYW 282
2680#define TYPEOF_KEYW 283
2681#define EXPORT_SYMBOL_KEYW 284
2682#define ASM_PHRASE 285
2683#define ATTRIBUTE_PHRASE 286
2684#define BRACE_PHRASE 287
2685#define BRACKET_PHRASE 288
2686#define EXPRESSION_PHRASE 289
2687#define CHAR 290
2688#define DOTS 291
2689#define IDENT 292
2690#define INT 293
2691#define REAL 294
2692#define STRING 295
2693#define TYPE 296
2694#define OTHER 297
2695#define FILENAME 298
2696
2697
2698
2699
2700#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
2701typedef int YYSTYPE;
2702# define yystype YYSTYPE /* obsolescent; will be withdrawn */
2703# define YYSTYPE_IS_DECLARED 1
2704# define YYSTYPE_IS_TRIVIAL 1
2705#endif
2706
2707extern YYSTYPE yylval;
2708
2709
2710