2 #line 3 "src/simdag/dax_dtd.c"
4 #define YY_INT_ALIGNED short int
6 /* A lexical scanner generated by flex */
8 #define yy_create_buffer dax__create_buffer
9 #define yy_delete_buffer dax__delete_buffer
10 #define yy_flex_debug dax__flex_debug
11 #define yy_init_buffer dax__init_buffer
12 #define yy_flush_buffer dax__flush_buffer
13 #define yy_load_buffer_state dax__load_buffer_state
14 #define yy_switch_to_buffer dax__switch_to_buffer
16 #define yyleng dax_leng
18 #define yylineno dax_lineno
20 #define yyrestart dax_restart
21 #define yytext dax_text
22 #define yywrap dax_wrap
23 #define yyalloc dax_alloc
24 #define yyrealloc dax_realloc
25 #define yyfree dax_free
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
35 /* First, we deal with platform-specific or compiler-specific issues. */
37 /* begin standard C headers. */
43 /* end standard C headers. */
45 /* flex integer type definitions */
50 /* C99 systems have <inttypes.h>. Non-C99 systems may or may not. */
52 #if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
54 /* C99 says to define __STDC_LIMIT_MACROS before including stdint.h,
55 * if you want the limit (max/min) macros for int types.
57 #ifndef __STDC_LIMIT_MACROS
58 #define __STDC_LIMIT_MACROS 1
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;
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;
76 /* Limits of integral types. */
78 #define INT8_MIN (-128)
81 #define INT16_MIN (-32767-1)
84 #define INT32_MIN (-2147483647-1)
87 #define INT8_MAX (127)
90 #define INT16_MAX (32767)
93 #define INT32_MAX (2147483647)
96 #define UINT8_MAX (255U)
99 #define UINT16_MAX (65535U)
102 #define UINT32_MAX (4294967295U)
107 #endif /* ! FLEXINT_H */
111 /* The "const" storage-class-modifier is valid. */
114 #else /* ! __cplusplus */
116 /* C99 requires __STDC__ to be defined as 1. */
117 #if defined (__STDC__)
121 #endif /* defined (__STDC__) */
122 #endif /* ! __cplusplus */
125 #define yyconst const
130 /* Returned upon end-of-file. */
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
138 #define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c)
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.
144 #define BEGIN (yy_start) = 1 + 2 *
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
150 #define YY_START (((yy_start) - 1) / 2)
151 #define YYSTATE YY_START
153 /* Action number for EOF rule of a given start state. */
154 #define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1)
156 /* Special action meaning "start processing a new file". */
157 #define YY_NEW_FILE dax_restart(dax_in )
159 #define YY_END_OF_BUFFER_CHAR 0
161 /* Size of default input buffer. */
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.
168 #define YY_BUF_SIZE 32768
170 #define YY_BUF_SIZE 16384
171 #endif /* __ia64__ */
174 /* The state buf must be large enough to hold one state per character in the main buffer.
176 #define YY_STATE_BUF_SIZE ((YY_BUF_SIZE + 2) * sizeof(yy_state_type))
178 #ifndef YY_TYPEDEF_YY_BUFFER_STATE
179 #define YY_TYPEDEF_YY_BUFFER_STATE
180 typedef struct yy_buffer_state *YY_BUFFER_STATE;
185 extern FILE *dax_in, *dax_out;
187 #define EOB_ACT_CONTINUE_SCAN 0
188 #define EOB_ACT_END_OF_FILE 1
189 #define EOB_ACT_LAST_MATCH 2
191 /* Note: We specifically omit the test for yy_rule_can_match_eol because it requires
192 * access to the local variable yy_act. Since yyless() is a macro, it would break
193 * existing scanners that call yyless() from OUTSIDE dax_lex.
194 * One obvious solution it to make yy_act a global. I tried that, and saw
195 * a 5% performance hit in a non-dax_lineno scanner, because yy_act is
196 * normally declared as a register variable-- so it is not worth it.
198 #define YY_LESS_LINENO(n) \
201 for ( yyl = n; yyl < dax_leng; ++yyl )\
202 if ( dax_text[yyl] == '\n' )\
206 /* Return all but the first "n" matched characters back to the input stream. */
210 /* Undo effects of setting up dax_text. */ \
211 int yyless_macro_arg = (n); \
212 YY_LESS_LINENO(yyless_macro_arg);\
213 *yy_cp = (yy_hold_char); \
214 YY_RESTORE_YY_MORE_OFFSET \
215 (yy_c_buf_p) = yy_cp = yy_bp + yyless_macro_arg - YY_MORE_ADJ; \
216 YY_DO_BEFORE_ACTION; /* set up dax_text again */ \
220 #define unput(c) yyunput( c, (yytext_ptr) )
222 #ifndef YY_TYPEDEF_YY_SIZE_T
223 #define YY_TYPEDEF_YY_SIZE_T
224 typedef size_t yy_size_t;
227 #ifndef YY_STRUCT_YY_BUFFER_STATE
228 #define YY_STRUCT_YY_BUFFER_STATE
229 struct yy_buffer_state
233 char *yy_ch_buf; /* input buffer */
234 char *yy_buf_pos; /* current position in input buffer */
236 /* Size of input buffer in bytes, not including room for EOB
239 yy_size_t yy_buf_size;
241 /* Number of characters read into yy_ch_buf, not including EOB
246 /* Whether we "own" the buffer - i.e., we know we created it,
247 * and can realloc() it to grow it, and should free() it to
250 int yy_is_our_buffer;
252 /* Whether this is an "interactive" input source; if so, and
253 * if we're using stdio for input, then we want to use getc()
254 * instead of fread(), to make sure we stop fetching input after
257 int yy_is_interactive;
259 /* Whether we're considered to be at the beginning of a line.
260 * If so, '^' rules will be active on the next match, otherwise
265 int yy_bs_lineno; /**< The line count. */
266 int yy_bs_column; /**< The column count. */
268 /* Whether to try to fill the input buffer when we reach the
273 int yy_buffer_status;
275 #define YY_BUFFER_NEW 0
276 #define YY_BUFFER_NORMAL 1
277 /* When an EOF's been seen but there's still some text to process
278 * then we mark the buffer as YY_EOF_PENDING, to indicate that we
279 * shouldn't try reading from the input source any more. We might
280 * still have a bunch of tokens to match, though, because of
281 * possible backing-up.
283 * When we actually see the EOF, we change the status to "new"
284 * (via dax_restart()), so that the user can continue scanning by
285 * just pointing dax_in at a new input file.
287 #define YY_BUFFER_EOF_PENDING 2
290 #endif /* !YY_STRUCT_YY_BUFFER_STATE */
292 /* Stack of input buffers. */
293 static size_t yy_buffer_stack_top = 0; /**< index of top of stack. */
294 static size_t yy_buffer_stack_max = 0; /**< capacity of stack. */
295 static YY_BUFFER_STATE * yy_buffer_stack = 0; /**< Stack as an array. */
297 /* We provide macros for accessing buffer states in case in the
298 * future we want to put the buffer states in a more general
301 * Returns the top of the stack, or NULL.
303 #define YY_CURRENT_BUFFER ( (yy_buffer_stack) \
304 ? (yy_buffer_stack)[(yy_buffer_stack_top)] \
307 /* Same as previous macro, but useful when we know that the buffer stack is not
308 * NULL or when we need an lvalue. For internal use only.
310 #define YY_CURRENT_BUFFER_LVALUE (yy_buffer_stack)[(yy_buffer_stack_top)]
312 /* yy_hold_char holds the character lost when dax_text is formed. */
313 static char yy_hold_char;
314 static int yy_n_chars; /* number of characters read into yy_ch_buf */
317 /* Points to current character in buffer. */
318 static char *yy_c_buf_p = (char *) 0;
319 static int yy_init = 0; /* whether we need to initialize */
320 static int yy_start = 0; /* start state number */
322 /* Flag which is used to allow dax_wrap()'s to do buffer switches
323 * instead of setting up a fresh dax_in. A bit of a hack ...
325 static int yy_did_buffer_switch_on_eof;
327 void dax_restart (FILE *input_file );
328 void dax__switch_to_buffer (YY_BUFFER_STATE new_buffer );
329 YY_BUFFER_STATE dax__create_buffer (FILE *file,int size );
330 void dax__delete_buffer (YY_BUFFER_STATE b );
331 void dax__flush_buffer (YY_BUFFER_STATE b );
332 void dax_push_buffer_state (YY_BUFFER_STATE new_buffer );
333 void dax_pop_buffer_state (void );
335 static void dax_ensure_buffer_stack (void );
336 static void dax__load_buffer_state (void );
337 static void dax__init_buffer (YY_BUFFER_STATE b,FILE *file );
339 #define YY_FLUSH_BUFFER dax__flush_buffer(YY_CURRENT_BUFFER )
341 YY_BUFFER_STATE dax__scan_buffer (char *base,yy_size_t size );
342 YY_BUFFER_STATE dax__scan_string (yyconst char *yy_str );
343 YY_BUFFER_STATE dax__scan_bytes (yyconst char *bytes,int len );
345 void *dax_alloc (yy_size_t );
346 void *dax_realloc (void *,yy_size_t );
347 void dax_free (void * );
349 #define yy_new_buffer dax__create_buffer
351 #define yy_set_interactive(is_interactive) \
353 if ( ! YY_CURRENT_BUFFER ){ \
354 dax_ensure_buffer_stack (); \
355 YY_CURRENT_BUFFER_LVALUE = \
356 dax__create_buffer(dax_in,YY_BUF_SIZE ); \
358 YY_CURRENT_BUFFER_LVALUE->yy_is_interactive = is_interactive; \
361 #define yy_set_bol(at_bol) \
363 if ( ! YY_CURRENT_BUFFER ){\
364 dax_ensure_buffer_stack (); \
365 YY_CURRENT_BUFFER_LVALUE = \
366 dax__create_buffer(dax_in,YY_BUF_SIZE ); \
368 YY_CURRENT_BUFFER_LVALUE->yy_at_bol = at_bol; \
371 #define YY_AT_BOL() (YY_CURRENT_BUFFER_LVALUE->yy_at_bol)
373 /* Begin user sect3 */
375 #define dax_wrap(n) 1
376 #define YY_SKIP_YYWRAP
378 typedef unsigned char YY_CHAR;
380 FILE *dax_in = (FILE *) 0, *dax_out = (FILE *) 0;
382 typedef int yy_state_type;
384 extern int dax_lineno;
388 extern char *dax_text;
389 #define yytext_ptr dax_text
391 static yy_state_type yy_get_previous_state (void );
392 static yy_state_type yy_try_NUL_trans (yy_state_type current_state );
393 static int yy_get_next_buffer (void );
394 static void yy_fatal_error (yyconst char msg[] );
396 /* Done after the current pattern has been matched and before the
397 * corresponding action - sets up dax_text.
399 #define YY_DO_BEFORE_ACTION \
400 (yytext_ptr) = yy_bp; \
401 dax_leng = (size_t) (yy_cp - yy_bp); \
402 (yy_hold_char) = *yy_cp; \
404 (yy_c_buf_p) = yy_cp;
406 #define YY_NUM_RULES 140
407 #define YY_END_OF_BUFFER 141
408 /* This struct is not used in this scanner,
409 but its presence is necessary. */
412 flex_int32_t yy_verify;
415 static yyconst flex_int16_t yy_accept[775] =
417 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
418 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
419 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
420 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
421 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
422 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
423 0, 0, 0, 0, 0, 0, 141, 139, 15, 10,
424 10, 15, 15, 119, 10, 119, 5, 6, 5, 8,
425 9, 8, 135, 127, 128, 136, 133, 136, 134, 138,
426 127, 128, 138, 139, 40, 10, 40, 40, 40, 38,
428 40, 40, 40, 40, 40, 40, 40, 44, 10, 44,
429 44, 139, 139, 44, 61, 10, 61, 61, 61, 59,
430 61, 61, 61, 61, 61, 65, 10, 65, 139, 65,
431 92, 10, 92, 92, 92, 90, 92, 92, 92, 92,
432 92, 92, 96, 10, 96, 103, 10, 103, 103, 103,
433 101, 103, 107, 10, 107, 139, 107, 114, 10, 114,
434 114, 114, 112, 114, 118, 10, 118, 136, 135, 10,
435 0, 2, 2, 0, 4, 7, 130, 129, 0, 0,
436 0, 0, 0, 0, 0, 39, 41, 41, 41, 41,
437 41, 41, 41, 41, 41, 41, 0, 0, 0, 0,
439 0, 0, 0, 0, 60, 62, 62, 62, 62, 62,
440 62, 0, 0, 91, 93, 93, 93, 93, 93, 93,
441 93, 93, 0, 102, 104, 104, 0, 0, 113, 115,
442 115, 0, 0, 0, 0, 0, 0, 0, 3, 0,
443 0, 0, 0, 0, 0, 0, 137, 0, 41, 41,
444 41, 41, 41, 41, 41, 41, 41, 0, 0, 0,
445 0, 0, 0, 0, 0, 0, 0, 0, 62, 62,
446 62, 62, 0, 0, 0, 93, 93, 93, 93, 93,
447 93, 93, 0, 0, 104, 0, 0, 0, 115, 0,
448 0, 0, 132, 0, 14, 1, 0, 0, 125, 0,
450 0, 0, 122, 121, 0, 0, 41, 41, 41, 41,
451 41, 41, 41, 41, 41, 0, 0, 43, 0, 0,
452 0, 46, 0, 0, 45, 0, 0, 48, 47, 62,
453 62, 62, 62, 0, 0, 64, 0, 0, 93, 93,
454 93, 93, 93, 93, 93, 0, 0, 95, 0, 0,
455 0, 0, 0, 106, 0, 0, 0, 0, 0, 0,
456 117, 0, 0, 0, 0, 126, 120, 0, 0, 17,
457 41, 41, 41, 41, 41, 0, 0, 41, 41, 41,
458 0, 16, 0, 46, 0, 66, 45, 0, 62, 0,
459 0, 62, 62, 62, 0, 67, 0, 0, 0, 0,
461 93, 93, 0, 0, 93, 0, 0, 0, 0, 100,
462 99, 0, 0, 0, 111, 110, 0, 0, 0, 0,
463 0, 12, 0, 123, 124, 17, 41, 0, 0, 41,
464 0, 0, 41, 0, 31, 30, 41, 0, 41, 0,
465 41, 0, 16, 98, 0, 66, 97, 0, 0, 0,
466 52, 51, 62, 62, 62, 0, 63, 67, 0, 69,
467 68, 0, 0, 0, 93, 93, 0, 89, 88, 93,
468 0, 87, 86, 0, 0, 0, 0, 0, 0, 0,
469 0, 11, 41, 0, 27, 26, 41, 0, 29, 28,
470 41, 41, 41, 0, 19, 18, 41, 0, 42, 98,
472 108, 97, 0, 58, 57, 62, 62, 62, 0, 0,
473 0, 0, 93, 93, 93, 0, 94, 0, 109, 0,
474 0, 0, 0, 0, 41, 41, 41, 0, 0, 41,
475 41, 108, 62, 0, 0, 0, 0, 0, 0, 0,
476 0, 93, 93, 93, 0, 105, 109, 0, 0, 0,
477 0, 0, 41, 41, 0, 0, 0, 25, 24, 41,
478 41, 62, 0, 56, 55, 0, 54, 53, 0, 0,
479 0, 0, 0, 0, 0, 0, 0, 0, 0, 116,
480 131, 0, 0, 0, 41, 0, 0, 0, 33, 32,
481 0, 0, 41, 0, 0, 0, 0, 0, 0, 0,
483 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
484 0, 0, 0, 0, 35, 34, 0, 21, 20, 41,
485 0, 50, 49, 0, 0, 0, 0, 0, 0, 0,
486 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
487 0, 0, 0, 37, 36, 41, 71, 0, 70, 0,
488 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
489 0, 0, 0, 0, 0, 41, 73, 72, 0, 0,
490 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
491 0, 0, 0, 0, 41, 0, 0, 0, 0, 0,
492 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
494 0, 0, 0, 41, 0, 85, 0, 84, 0, 77,
495 0, 76, 0, 81, 0, 80, 0, 0, 0, 0,
496 0, 0, 41, 83, 82, 75, 74, 79, 78, 0,
497 0, 0, 12, 0, 12, 0, 41, 0, 0, 0,
498 0, 0, 41, 0, 0, 0, 0, 0, 11, 0,
499 23, 22, 0, 0, 0, 0, 0, 0, 0, 0,
500 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
504 static yyconst flex_int32_t yy_ec[256] =
506 1, 1, 1, 1, 1, 1, 1, 1, 2, 3,
507 1, 2, 4, 1, 1, 1, 1, 1, 1, 1,
508 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
509 1, 2, 5, 6, 7, 1, 1, 8, 9, 1,
510 1, 1, 1, 1, 10, 11, 12, 13, 13, 13,
511 13, 13, 13, 13, 13, 13, 13, 14, 15, 16,
512 17, 18, 19, 1, 20, 21, 22, 23, 24, 21,
513 25, 25, 25, 25, 25, 26, 27, 25, 28, 29,
514 25, 25, 30, 31, 25, 25, 25, 25, 32, 25,
515 33, 1, 34, 1, 25, 1, 35, 36, 37, 38,
517 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
518 49, 50, 51, 52, 53, 54, 55, 56, 25, 57,
519 58, 59, 1, 1, 1, 1, 1, 1, 1, 1,
520 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
521 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
522 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
523 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
524 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
525 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
526 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
528 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
529 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
530 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
531 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
532 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
536 static yyconst flex_int32_t yy_meta[60] =
538 1, 2, 2, 2, 1, 1, 1, 1, 1, 3,
539 3, 1, 4, 5, 1, 1, 1, 6, 1, 7,
540 7, 7, 7, 7, 5, 5, 5, 5, 5, 5,
541 5, 5, 1, 1, 7, 7, 7, 7, 7, 7,
542 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
543 5, 5, 5, 5, 5, 5, 5, 5, 5
546 static yyconst flex_int16_t yy_base[814] =
548 0, 0, 0, 3, 6, 9, 24, 27, 11, 14,
549 15, 17, 29, 38, 45, 52, 59, 61, 67, 70,
550 95, 0, 73, 76, 153, 156, 159, 162, 177, 180,
551 183, 186, 201, 204, 207, 210, 226, 0, 284, 287,
552 290, 293, 308, 311, 314, 317, 333, 0, 391, 394,
553 410, 462, 429, 432, 435, 438, 481, 484, 487, 490,
554 514, 566, 533, 536, 585, 587, 1886, 2164, 2164, 397,
555 400, 47, 62, 2164, 453, 172, 2164, 2164, 1875, 2164,
556 2164, 1865, 2164, 1866, 1863, 551, 2164, 2164, 2164, 2164,
557 1861, 1861, 1829, 441, 2164, 505, 1844, 0, 196, 2164,
559 8, 1818, 1812, 1810, 1823, 1813, 35, 2164, 508, 593,
560 601, 589, 622, 630, 2164, 539, 1833, 0, 303, 2164,
561 1811, 1809, 1793, 1772, 1786, 2164, 542, 649, 657, 676,
562 2164, 551, 1798, 0, 442, 2164, 1772, 1770, 1750, 1760,
563 1751, 32, 2164, 557, 545, 2164, 607, 1775, 0, 494,
564 2164, 1752, 2164, 612, 684, 703, 711, 2164, 667, 1764,
565 0, 546, 2164, 1722, 2164, 733, 641, 1752, 1721, 739,
566 594, 1690, 2164, 1735, 1723, 2164, 2164, 2164, 2, 44,
567 1685, 1684, 1675, 1711, 1689, 2164, 0, 1678, 1663, 1670,
568 1677, 1676, 1664, 1658, 1650, 1652, 1658, 1650, 1645, 1636,
570 1645, 1626, 1628, 1630, 2164, 0, 747, 1615, 1618, 1615,
571 1610, 1616, 1599, 2164, 0, 1605, 1601, 1590, 1602, 1582,
572 1601, 1585, 1578, 2164, 0, 1588, 1590, 1590, 2164, 0,
573 1584, 1572, 1584, 1594, 1593, 1599, 431, 1554, 2164, 72,
574 0, 1549, 1549, 1581, 1576, 1541, 2164, 1553, 1540, 1535,
575 1533, 1528, 1544, 1525, 1503, 1507, 1539, 765, 768, 1517,
576 1507, 1509, 1488, 1500, 1501, 1486, 771, 775, 1489, 1487,
577 1467, 1467, 787, 790, 1479, 1477, 1470, 1470, 1459, 1462,
578 1445, 1429, 793, 796, 799, 815, 818, 1415, 821, 824,
579 827, 1443, 2164, 1446, 2164, 2164, 17, 1400, 2164, 1428,
581 1426, 1384, 2164, 2164, 1381, 1389, 1391, 1373, 1394, 1358,
582 1364, 844, 1368, 1357, 1344, 848, 851, 2164, 854, 1355,
583 1344, 861, 1350, 1318, 871, 1324, 874, 2164, 2164, 1322,
584 882, 1317, 1316, 888, 891, 2164, 894, 1301, 898, 901,
585 1304, 1295, 917, 1290, 920, 923, 929, 2164, 936, 940,
586 946, 956, 959, 2164, 962, 1301, 965, 981, 968, 989,
587 2164, 992, 1309, 616, 995, 2164, 2164, 1316, 1314, 998,
588 1302, 1013, 1274, 1016, 1266, 1019, 1022, 1269, 1035, 1279,
589 1038, 1043, 1274, 1051, 1253, 1055, 1058, 1262, 1061, 1064,
590 1067, 1248, 1246, 1243, 1080, 1083, 1086, 1090, 1098, 1102,
592 1242, 1231, 1110, 1114, 1244, 1122, 1126, 1134, 1138, 2164,
593 2164, 1146, 1234, 1151, 2164, 2164, 1159, 1257, 632, 1258,
594 1163, 2164, 1256, 2164, 2164, 1166, 1224, 1169, 1176, 1216,
595 1172, 1191, 1212, 1201, 2164, 2164, 1211, 1209, 1196, 1212,
596 1209, 1220, 1225, 1228, 1196, 1231, 1237, 1240, 1243, 1252,
597 2164, 2164, 1213, 1198, 1188, 1260, 2164, 1263, 1266, 2164,
598 2164, 1277, 124, 125, 1190, 1181, 1285, 2164, 2164, 1178,
599 1293, 2164, 2164, 1301, 1304, 1155, 1307, 1177, 578, 152,
600 5, 2164, 1151, 1311, 2164, 2164, 1153, 1324, 2164, 2164,
601 1145, 1332, 1143, 1335, 2164, 2164, 1152, 1343, 2164, 1348,
603 1354, 1360, 1363, 2164, 2164, 1153, 1371, 1374, 1140, 1129,
604 1135, 1104, 1112, 1104, 1099, 1377, 2164, 1380, 1383, 1390,
605 1126, 174, 158, 280, 1097, 1089, 1397, 1400, 1403, 1091,
606 1086, 1416, 1092, 1419, 1422, 1430, 1436, 1072, 1067, 1069,
607 1056, 1446, 1449, 1452, 1455, 2164, 1458, 1468, 1076, 1472,
608 176, 510, 1053, 1475, 1478, 1485, 1494, 2164, 2164, 1502,
609 1062, 1505, 1508, 2164, 2164, 1521, 2164, 2164, 1040, 1041,
610 1025, 1027, 1529, 1532, 1540, 1545, 1556, 1559, 1481, 2164,
611 2164, 1567, 287, 179, 1572, 1575, 1578, 1591, 2164, 2164,
612 1601, 1604, 1049, 1612, 1617, 1020, 1017, 997, 995, 1628,
614 633, 643, 1636, 651, 660, 1644, 670, 675, 412, 283,
615 538, 1652, 1655, 1664, 2164, 2164, 1672, 2164, 2164, 999,
616 1680, 2164, 2164, 1037, 981, 1025, 978, 994, 975, 977,
617 959, 974, 956, 971, 952, 968, 937, 953, 929, 605,
618 281, 434, 1688, 2164, 2164, 942, 2164, 972, 2164, 967,
619 927, 901, 907, 896, 900, 890, 890, 874, 882, 859,
620 867, 856, 611, 614, 1696, 875, 2164, 2164, 855, 820,
621 760, 773, 757, 770, 732, 713, 674, 686, 664, 670,
622 1699, 1702, 1705, 1722, 652, 659, 673, 619, 616, 541,
623 556, 495, 496, 463, 495, 419, 444, 1730, 1733, 1740,
625 1750, 1768, 1802, 381, 403, 2164, 399, 2164, 400, 2164,
626 396, 2164, 325, 2164, 319, 2164, 700, 1820, 657, 613,
627 1838, 1872, 274, 2164, 2164, 2164, 2164, 2164, 2164, 660,
628 727, 200, 301, 745, 295, 1760, 254, 726, 218, 202,
629 207, 1794, 1865, 480, 153, 1890, 1786, 738, 2164, 1828,
630 2164, 2164, 1763, 1893, 664, 742, 741, 769, 814, 822,
631 823, 826, 744, 797, 789, 863, 849, 850, 864, 898,
632 1906, 1910, 2164, 2164, 1928, 1935, 1942, 1949, 1956, 1963,
633 1970, 1977, 1984, 1991, 1998, 2005, 2012, 2019, 2024, 2029,
634 2034, 2039, 2044, 2051, 2054, 2057, 2060, 2063, 2066, 2073,
636 2077, 2083, 2089, 2095, 2101, 2107, 2114, 2121, 2128, 2135,
640 static yyconst flex_int16_t yy_def[814] =
642 775, 775, 776, 776, 776, 776, 777, 777, 778, 778,
643 779, 779, 780, 780, 780, 780, 781, 781, 775, 775,
644 774, 21, 782, 782, 782, 782, 775, 775, 782, 782,
645 775, 775, 782, 782, 782, 782, 774, 37, 783, 783,
646 775, 775, 783, 783, 783, 783, 774, 47, 784, 784,
647 785, 785, 786, 786, 775, 775, 786, 786, 786, 786,
648 787, 787, 788, 788, 780, 780, 774, 774, 774, 774,
649 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
650 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
651 774, 774, 774, 774, 774, 774, 774, 789, 774, 774,
653 789, 789, 789, 789, 789, 789, 789, 774, 774, 774,
654 774, 774, 774, 774, 774, 774, 774, 790, 774, 774,
655 790, 790, 790, 790, 790, 774, 774, 774, 774, 774,
656 774, 774, 774, 791, 774, 774, 791, 791, 791, 791,
657 791, 791, 774, 774, 774, 774, 774, 774, 792, 774,
658 774, 792, 774, 774, 774, 774, 774, 774, 774, 774,
659 793, 774, 774, 793, 774, 774, 774, 774, 774, 774,
660 794, 774, 774, 774, 774, 774, 774, 774, 774, 774,
661 774, 774, 774, 774, 774, 774, 789, 789, 789, 789,
662 789, 789, 789, 789, 789, 789, 795, 774, 774, 774,
664 774, 774, 774, 774, 774, 790, 790, 790, 790, 790,
665 790, 796, 774, 774, 791, 791, 791, 791, 791, 791,
666 791, 791, 797, 774, 792, 792, 798, 774, 774, 793,
667 793, 799, 774, 774, 800, 774, 800, 774, 774, 774,
668 801, 774, 774, 774, 774, 774, 774, 774, 789, 789,
669 789, 789, 789, 789, 789, 789, 789, 802, 802, 774,
670 774, 774, 774, 774, 774, 774, 774, 774, 790, 790,
671 790, 790, 803, 803, 774, 791, 791, 791, 791, 791,
672 791, 791, 804, 804, 792, 805, 805, 774, 793, 806,
673 806, 774, 774, 800, 774, 774, 800, 774, 774, 801,
675 774, 774, 774, 774, 774, 774, 789, 789, 789, 789,
676 789, 789, 789, 789, 789, 774, 802, 774, 802, 774,
677 774, 774, 774, 774, 774, 774, 774, 774, 774, 790,
678 790, 790, 790, 774, 803, 774, 803, 774, 791, 791,
679 791, 791, 791, 791, 791, 774, 804, 774, 804, 774,
680 774, 774, 805, 774, 805, 774, 774, 774, 774, 806,
681 774, 806, 774, 800, 807, 774, 774, 774, 774, 774,
682 789, 789, 789, 789, 789, 774, 774, 789, 789, 789,
683 802, 774, 774, 774, 774, 774, 774, 774, 790, 774,
684 774, 790, 790, 790, 803, 774, 774, 774, 774, 774,
686 791, 791, 774, 774, 791, 774, 774, 804, 774, 774,
687 774, 805, 774, 774, 774, 774, 806, 774, 800, 807,
688 807, 774, 807, 774, 774, 774, 789, 774, 774, 789,
689 774, 774, 789, 774, 774, 774, 789, 774, 789, 774,
690 789, 802, 774, 774, 774, 774, 774, 774, 774, 774,
691 774, 774, 790, 790, 790, 774, 774, 774, 774, 774,
692 774, 774, 774, 774, 791, 791, 774, 774, 774, 791,
693 774, 774, 774, 804, 805, 774, 806, 774, 800, 807,
694 807, 774, 789, 774, 774, 774, 789, 774, 774, 774,
695 789, 789, 789, 774, 774, 774, 789, 774, 774, 774,
697 774, 774, 774, 774, 774, 790, 790, 790, 774, 774,
698 774, 774, 791, 791, 791, 774, 774, 805, 774, 806,
699 774, 800, 807, 807, 789, 789, 789, 774, 774, 789,
700 789, 774, 790, 774, 774, 774, 774, 774, 774, 774,
701 774, 791, 791, 791, 774, 774, 774, 806, 774, 800,
702 807, 807, 789, 789, 774, 774, 774, 774, 774, 789,
703 789, 790, 774, 774, 774, 774, 774, 774, 774, 774,
704 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
705 774, 800, 807, 807, 789, 774, 774, 774, 774, 774,
706 774, 774, 789, 774, 774, 774, 774, 774, 774, 774,
708 774, 774, 774, 774, 774, 774, 774, 774, 800, 807,
709 807, 774, 774, 774, 774, 774, 774, 774, 774, 789,
710 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
711 774, 774, 774, 774, 774, 774, 774, 774, 774, 800,
712 807, 807, 774, 774, 774, 789, 774, 774, 774, 774,
713 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
714 774, 774, 800, 807, 807, 789, 774, 774, 774, 774,
715 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
716 800, 807, 807, 807, 789, 774, 774, 774, 774, 774,
717 774, 774, 774, 774, 774, 774, 774, 800, 807, 807,
719 807, 808, 809, 789, 774, 774, 774, 774, 774, 774,
720 774, 774, 774, 774, 774, 774, 800, 807, 810, 811,
721 808, 809, 789, 774, 774, 774, 774, 774, 774, 800,
722 810, 807, 812, 811, 813, 807, 789, 800, 812, 774,
723 813, 807, 789, 800, 774, 774, 774, 800, 774, 774,
724 774, 774, 800, 800, 800, 800, 800, 800, 800, 800,
725 800, 800, 800, 800, 800, 800, 800, 800, 800, 800,
726 800, 800, 774, 0, 774, 774, 774, 774, 774, 774,
727 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
728 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
730 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
734 static yyconst flex_int16_t yy_nxt[2224] =
736 774, 70, 71, 70, 70, 71, 70, 70, 71, 70,
737 70, 71, 70, 78, 240, 72, 78, 81, 72, 81,
738 79, 73, 422, 79, 73, 75, 71, 75, 75, 71,
739 75, 84, 85, 82, 295, 82, 86, 87, 364, 76,
740 84, 85, 76, 524, 88, 86, 87, 84, 85, 188,
741 89, 171, 86, 88, 84, 85, 189, 89, 241, 86,
742 88, 91, 92, 91, 92, 172, 171, 88, 71, 71,
743 71, 71, 71, 71, 109, 71, 109, 109, 71, 109,
744 173, 195, 94, 221, 240, 94, 299, 196, 110, 222,
745 242, 110, 93, 243, 93, 95, 96, 71, 96, 95,
747 95, 95, 95, 95, 95, 95, 97, 95, 98, 95,
748 99, 95, 100, 95, 98, 98, 98, 98, 98, 98,
749 98, 98, 98, 98, 98, 98, 98, 95, 95, 98,
750 98, 101, 98, 98, 102, 98, 98, 103, 104, 98,
751 98, 98, 105, 98, 98, 98, 98, 98, 98, 98,
752 106, 107, 98, 98, 109, 71, 109, 109, 71, 109,
753 71, 71, 71, 71, 71, 71, 509, 511, 111, 422,
754 749, 111, 510, 512, 112, 422, 174, 112, 109, 71,
755 109, 109, 71, 109, 71, 71, 71, 71, 71, 71,
756 173, 295, 110, 422, 551, 110, 422, 550, 113, 523,
758 174, 113, 109, 71, 109, 109, 71, 109, 109, 71,
759 109, 109, 71, 109, 173, 740, 111, 422, 423, 111,
760 745, 611, 114, 740, 583, 114, 115, 116, 71, 116,
761 115, 115, 115, 115, 115, 115, 115, 117, 115, 118,
762 115, 119, 115, 120, 115, 118, 118, 118, 118, 118,
763 118, 118, 118, 118, 118, 118, 118, 118, 115, 115,
764 118, 118, 118, 118, 118, 118, 118, 118, 121, 118,
765 118, 122, 118, 123, 118, 118, 118, 124, 118, 118,
766 118, 125, 118, 118, 118, 127, 71, 127, 127, 71,
767 127, 71, 71, 71, 71, 71, 71, 422, 422, 128,
769 422, 743, 128, 740, 422, 129, 740, 174, 129, 127,
770 71, 127, 127, 71, 127, 127, 71, 127, 127, 71,
771 127, 173, 737, 128, 610, 641, 128, 729, 664, 130,
772 728, 552, 130, 131, 132, 71, 132, 131, 131, 131,
773 131, 131, 131, 131, 133, 131, 134, 131, 135, 131,
774 136, 131, 134, 134, 134, 134, 134, 134, 134, 134,
775 134, 134, 134, 134, 134, 131, 131, 134, 134, 134,
776 134, 134, 137, 134, 134, 134, 134, 134, 138, 134,
777 134, 139, 134, 134, 140, 141, 142, 134, 134, 134,
778 134, 134, 144, 71, 144, 144, 71, 144, 170, 170,
780 170, 170, 170, 170, 727, 726, 145, 725, 724, 145,
781 146, 147, 71, 147, 146, 146, 146, 146, 146, 146,
782 146, 148, 146, 723, 146, 150, 146, 151, 146, 295,
783 154, 71, 154, 154, 71, 154, 71, 71, 71, 71,
784 71, 71, 146, 146, 155, 174, 174, 155, 295, 640,
785 156, 422, 716, 156, 170, 170, 170, 715, 297, 173,
786 173, 152, 146, 147, 71, 147, 146, 146, 146, 146,
787 146, 146, 146, 148, 146, 185, 146, 150, 146, 151,
788 146, 665, 154, 71, 154, 154, 71, 154, 154, 71,
789 154, 154, 71, 154, 146, 146, 155, 295, 174, 155,
791 714, 713, 157, 748, 712, 157, 170, 170, 170, 170,
792 170, 170, 173, 152, 158, 159, 71, 159, 158, 158,
793 158, 158, 158, 158, 158, 160, 158, 422, 158, 162,
794 158, 163, 158, 711, 166, 71, 166, 166, 71, 166,
795 170, 170, 170, 170, 170, 170, 158, 158, 167, 174,
796 174, 167, 170, 170, 170, 422, 223, 179, 170, 170,
797 170, 710, 584, 173, 173, 164, 158, 159, 71, 159,
798 158, 158, 158, 158, 158, 158, 158, 160, 158, 709,
799 158, 162, 158, 163, 158, 180, 642, 84, 85, 84,
800 85, 181, 86, 174, 86, 295, 182, 174, 158, 158,
802 168, 183, 168, 236, 197, 174, 522, 173, 170, 170,
803 170, 173, 197, 170, 170, 170, 237, 164, 169, 173,
804 169, 732, 295, 198, 708, 204, 174, 198, 295, 199,
805 735, 422, 200, 295, 174, 198, 200, 199, 201, 663,
806 173, 197, 201, 202, 203, 174, 419, 202, 173, 295,
807 201, 681, 232, 174, 682, 202, 198, 707, 199, 173,
808 212, 174, 732, 479, 198, 203, 204, 173, 170, 170,
809 170, 201, 628, 203, 733, 173, 202, 295, 706, 201,
810 174, 295, 630, 198, 202, 204, 629, 212, 174, 738,
811 632, 198, 203, 204, 173, 227, 631, 705, 201, 634,
813 203, 757, 173, 213, 633, 704, 201, 174, 697, 636,
814 198, 213, 204, 635, 638, 174, 696, 295, 198, 203,
815 204, 173, 227, 637, 695, 201, 694, 203, 639, 173,
816 202, 730, 732, 228, 170, 170, 170, 198, 202, 204,
817 170, 170, 170, 295, 733, 198, 203, 204, 267, 267,
818 267, 693, 228, 732, 203, 295, 744, 202, 295, 295,
819 201, 295, 735, 268, 753, 202, 316, 316, 316, 316,
820 316, 316, 267, 267, 267, 759, 327, 327, 327, 758,
821 328, 765, 318, 329, 692, 318, 295, 268, 334, 334,
822 334, 334, 334, 334, 346, 346, 346, 346, 346, 346,
824 350, 350, 350, 760, 336, 319, 295, 336, 691, 690,
825 348, 689, 688, 348, 295, 351, 352, 352, 352, 352,
826 352, 352, 357, 357, 357, 359, 359, 359, 359, 359,
827 359, 295, 354, 763, 766, 354, 764, 358, 337, 295,
828 295, 361, 767, 295, 361, 376, 376, 376, 349, 316,
829 316, 316, 316, 316, 316, 316, 316, 316, 687, 355,
830 377, 362, 384, 384, 384, 318, 295, 295, 318, 771,
831 761, 318, 387, 387, 387, 327, 327, 327, 762, 328,
832 295, 295, 329, 390, 390, 390, 769, 770, 381, 334,
833 334, 334, 334, 334, 334, 334, 334, 334, 391, 397,
835 397, 397, 399, 399, 399, 336, 771, 686, 336, 685,
836 680, 336, 679, 678, 398, 295, 768, 400, 403, 403,
837 403, 406, 406, 406, 346, 346, 346, 677, 676, 395,
838 346, 346, 346, 404, 392, 675, 407, 346, 346, 346,
839 348, 350, 350, 350, 674, 673, 348, 409, 409, 409,
840 672, 410, 671, 348, 411, 670, 351, 352, 352, 352,
841 352, 352, 352, 352, 352, 352, 357, 357, 357, 359,
842 359, 359, 669, 354, 408, 668, 354, 667, 666, 354,
843 662, 358, 414, 414, 414, 361, 415, 661, 660, 416,
844 359, 359, 359, 359, 359, 359, 421, 421, 421, 426,
846 426, 426, 659, 658, 412, 657, 361, 656, 655, 361,
847 654, 653, 422, 423, 428, 428, 428, 431, 431, 431,
848 376, 376, 376, 434, 434, 434, 652, 435, 651, 429,
849 436, 650, 432, 649, 648, 377, 438, 438, 438, 316,
850 316, 316, 647, 417, 443, 443, 443, 646, 439, 627,
851 626, 440, 384, 384, 384, 318, 446, 446, 446, 387,
852 387, 387, 448, 448, 448, 390, 390, 390, 450, 450,
853 450, 625, 451, 624, 620, 452, 599, 449, 442, 598,
854 391, 456, 456, 456, 458, 458, 458, 397, 397, 397,
855 597, 459, 459, 459, 596, 460, 593, 457, 461, 399,
857 399, 399, 398, 462, 462, 462, 585, 463, 581, 572,
858 464, 403, 403, 403, 400, 467, 467, 467, 571, 468,
859 570, 569, 469, 406, 406, 406, 404, 471, 471, 471,
860 562, 472, 561, 560, 473, 346, 346, 346, 407, 409,
861 409, 409, 554, 410, 553, 549, 411, 352, 352, 352,
862 544, 348, 414, 414, 414, 543, 415, 542, 541, 416,
863 359, 359, 359, 354, 421, 421, 421, 426, 426, 426,
864 428, 428, 428, 431, 431, 431, 361, 484, 484, 484,
865 422, 485, 540, 539, 486, 429, 474, 538, 432, 533,
866 531, 475, 488, 488, 488, 530, 489, 477, 527, 490,
868 526, 480, 434, 434, 434, 525, 435, 521, 519, 436,
869 438, 438, 438, 494, 494, 494, 515, 495, 481, 514,
870 496, 498, 498, 498, 513, 440, 443, 443, 443, 500,
871 500, 500, 446, 446, 446, 508, 507, 499, 502, 502,
872 502, 448, 448, 448, 503, 503, 503, 506, 504, 501,
873 497, 505, 493, 450, 450, 450, 449, 451, 492, 491,
874 452, 456, 456, 456, 458, 458, 458, 459, 459, 459,
875 487, 460, 483, 482, 461, 422, 478, 457, 462, 462,
876 462, 476, 463, 470, 466, 464, 467, 467, 467, 465,
877 468, 455, 454, 469, 471, 471, 471, 453, 472, 447,
879 445, 473, 516, 516, 516, 352, 352, 352, 359, 359,
880 359, 444, 484, 484, 484, 441, 485, 437, 517, 486,
881 433, 354, 430, 427, 361, 488, 488, 488, 425, 489,
882 424, 418, 490, 528, 528, 528, 494, 494, 494, 413,
883 495, 518, 405, 496, 498, 498, 498, 402, 529, 500,
884 500, 500, 401, 396, 520, 532, 532, 532, 394, 393,
885 499, 502, 502, 502, 503, 503, 503, 389, 504, 388,
886 386, 505, 534, 534, 534, 536, 536, 536, 516, 516,
887 516, 545, 545, 545, 547, 547, 547, 535, 385, 383,
888 537, 359, 359, 359, 517, 382, 380, 546, 555, 555,
890 555, 528, 528, 528, 557, 557, 557, 361, 558, 379,
891 378, 559, 375, 556, 374, 373, 529, 532, 532, 532,
892 534, 534, 534, 563, 563, 563, 372, 564, 371, 370,
893 565, 536, 536, 536, 369, 535, 368, 566, 566, 566,
894 367, 567, 366, 548, 568, 365, 537, 573, 573, 573,
895 575, 575, 575, 577, 577, 577, 545, 545, 545, 547,
896 547, 547, 574, 295, 363, 576, 356, 345, 578, 579,
897 579, 579, 546, 582, 582, 582, 586, 586, 586, 555,
898 555, 555, 579, 579, 579, 580, 588, 588, 588, 295,
899 589, 587, 344, 590, 556, 557, 557, 557, 580, 558,
901 343, 342, 559, 591, 591, 591, 594, 594, 594, 563,
902 563, 563, 341, 564, 340, 339, 565, 338, 592, 333,
903 332, 595, 566, 566, 566, 331, 567, 330, 326, 568,
904 573, 573, 573, 600, 600, 600, 325, 601, 324, 323,
905 602, 575, 575, 575, 322, 574, 603, 603, 603, 321,
906 604, 320, 315, 605, 314, 313, 576, 577, 577, 577,
907 606, 606, 606, 312, 607, 311, 310, 608, 582, 582,
908 582, 309, 578, 612, 612, 612, 586, 586, 586, 614,
909 614, 614, 308, 615, 295, 307, 616, 306, 613, 305,
910 304, 587, 588, 588, 588, 303, 589, 302, 301, 590,
912 298, 609, 591, 591, 591, 617, 617, 617, 296, 618,
913 295, 293, 619, 594, 594, 594, 292, 592, 621, 621,
914 621, 291, 622, 289, 288, 623, 287, 285, 595, 600,
915 600, 600, 284, 601, 282, 281, 602, 603, 603, 603,
916 280, 604, 279, 278, 605, 606, 606, 606, 277, 607,
917 276, 275, 608, 612, 612, 612, 643, 643, 643, 274,
918 644, 272, 271, 645, 270, 614, 614, 614, 613, 615,
919 269, 266, 616, 617, 617, 617, 265, 618, 264, 263,
920 619, 621, 621, 621, 262, 622, 261, 260, 623, 643,
921 643, 643, 259, 644, 257, 256, 645, 683, 683, 683,
923 698, 698, 698, 699, 699, 699, 683, 683, 683, 255,
924 254, 253, 684, 422, 252, 251, 295, 250, 700, 422,
925 249, 684, 422, 701, 701, 701, 248, 702, 247, 246,
926 703, 698, 698, 698, 699, 699, 699, 245, 244, 422,
927 239, 718, 718, 718, 236, 719, 238, 295, 720, 700,
928 422, 701, 701, 701, 234, 702, 233, 422, 703, 717,
929 231, 742, 742, 742, 754, 754, 754, 422, 420, 420,
930 420, 420, 420, 420, 420, 420, 420, 422, 423, 420,
931 295, 229, 420, 420, 420, 422, 420, 750, 750, 750,
932 226, 751, 224, 220, 752, 742, 742, 742, 219, 218,
934 420, 420, 420, 420, 420, 420, 420, 420, 420, 420,
935 420, 422, 217, 420, 216, 214, 420, 420, 420, 422,
936 420, 718, 718, 718, 211, 719, 210, 209, 720, 750,
937 750, 750, 480, 751, 420, 420, 752, 422, 420, 420,
938 420, 420, 420, 736, 420, 420, 420, 208, 207, 420,
939 205, 194, 420, 420, 420, 422, 420, 193, 192, 191,
940 190, 186, 184, 178, 177, 178, 746, 746, 746, 177,
941 420, 420, 420, 420, 420, 420, 420, 420, 420, 420,
942 736, 747, 176, 420, 175, 774, 420, 420, 420, 422,
943 420, 746, 746, 746, 754, 754, 754, 774, 755, 774,
945 774, 756, 774, 774, 420, 420, 747, 772, 772, 772,
946 295, 772, 772, 772, 774, 774, 774, 774, 774, 774,
947 774, 774, 774, 773, 774, 774, 774, 773, 68, 68,
948 68, 68, 68, 68, 68, 69, 69, 69, 69, 69,
949 69, 69, 74, 74, 74, 74, 74, 74, 74, 77,
950 77, 77, 77, 77, 77, 77, 80, 80, 80, 80,
951 80, 80, 80, 83, 83, 83, 83, 83, 83, 83,
952 90, 90, 90, 90, 90, 90, 90, 108, 108, 108,
953 108, 108, 108, 108, 126, 126, 126, 126, 126, 126,
954 126, 143, 143, 143, 143, 143, 143, 143, 149, 149,
956 149, 149, 149, 149, 149, 153, 153, 153, 153, 153,
957 153, 153, 161, 161, 161, 161, 161, 161, 161, 165,
958 165, 165, 165, 165, 165, 165, 187, 187, 187, 774,
959 187, 206, 206, 206, 774, 206, 215, 215, 215, 774,
960 215, 225, 225, 225, 774, 225, 230, 230, 230, 774,
961 230, 235, 235, 235, 235, 235, 774, 235, 258, 774,
962 258, 273, 774, 273, 283, 774, 283, 286, 774, 286,
963 290, 774, 290, 294, 294, 294, 294, 294, 294, 294,
964 300, 774, 774, 300, 317, 317, 317, 317, 317, 317,
965 335, 335, 335, 335, 335, 335, 347, 347, 347, 347,
967 347, 347, 353, 353, 353, 353, 353, 353, 360, 360,
968 360, 360, 360, 360, 420, 420, 420, 420, 420, 420,
969 420, 721, 721, 721, 721, 721, 721, 721, 722, 722,
970 722, 722, 722, 722, 722, 731, 731, 731, 731, 731,
971 731, 731, 734, 734, 734, 734, 734, 734, 734, 739,
972 739, 739, 739, 739, 739, 739, 741, 741, 741, 741,
973 741, 741, 741, 67, 774, 774, 774, 774, 774, 774,
974 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
975 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
976 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
978 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
979 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
983 static yyconst flex_int16_t yy_chk[2224] =
985 0, 3, 3, 3, 4, 4, 4, 5, 5, 5,
986 6, 6, 6, 9, 179, 3, 10, 11, 4, 12,
987 9, 5, 481, 10, 6, 7, 7, 7, 8, 8,
988 8, 13, 13, 11, 297, 12, 13, 13, 297, 7,
989 14, 14, 8, 481, 13, 14, 14, 15, 15, 101,
990 15, 72, 15, 14, 16, 16, 101, 16, 179, 16,
991 15, 17, 17, 18, 18, 72, 73, 16, 19, 19,
992 19, 20, 20, 20, 23, 23, 23, 24, 24, 24,
993 73, 107, 19, 142, 240, 20, 240, 107, 23, 142,
994 180, 24, 17, 180, 18, 21, 21, 21, 21, 21,
996 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
997 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
998 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
999 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1000 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
1001 21, 21, 21, 21, 25, 25, 25, 26, 26, 26,
1002 27, 27, 27, 28, 28, 28, 463, 464, 25, 480,
1003 745, 26, 463, 464, 27, 523, 76, 28, 29, 29,
1004 29, 30, 30, 30, 31, 31, 31, 32, 32, 32,
1005 76, 522, 29, 551, 523, 30, 584, 522, 31, 480,
1007 99, 32, 33, 33, 33, 34, 34, 34, 35, 35,
1008 35, 36, 36, 36, 99, 741, 33, 732, 732, 34,
1009 740, 584, 35, 739, 551, 36, 37, 37, 37, 37,
1010 37, 37, 37, 37, 37, 37, 37, 37, 37, 37,
1011 37, 37, 37, 37, 37, 37, 37, 37, 37, 37,
1012 37, 37, 37, 37, 37, 37, 37, 37, 37, 37,
1013 37, 37, 37, 37, 37, 37, 37, 37, 37, 37,
1014 37, 37, 37, 37, 37, 37, 37, 37, 37, 37,
1015 37, 37, 37, 37, 37, 39, 39, 39, 40, 40,
1016 40, 41, 41, 41, 42, 42, 42, 524, 641, 39,
1018 610, 737, 40, 735, 583, 41, 733, 119, 42, 43,
1019 43, 43, 44, 44, 44, 45, 45, 45, 46, 46,
1020 46, 119, 723, 43, 583, 610, 44, 715, 641, 45,
1021 713, 524, 46, 47, 47, 47, 47, 47, 47, 47,
1022 47, 47, 47, 47, 47, 47, 47, 47, 47, 47,
1023 47, 47, 47, 47, 47, 47, 47, 47, 47, 47,
1024 47, 47, 47, 47, 47, 47, 47, 47, 47, 47,
1025 47, 47, 47, 47, 47, 47, 47, 47, 47, 47,
1026 47, 47, 47, 47, 47, 47, 47, 47, 47, 47,
1027 47, 47, 49, 49, 49, 50, 50, 50, 70, 70,
1029 70, 71, 71, 71, 711, 709, 49, 707, 705, 50,
1030 51, 51, 51, 51, 51, 51, 51, 51, 51, 51,
1031 51, 51, 51, 704, 51, 51, 51, 51, 51, 609,
1032 53, 53, 53, 54, 54, 54, 55, 55, 55, 56,
1033 56, 56, 51, 51, 53, 94, 135, 54, 237, 609,
1034 55, 642, 697, 56, 75, 75, 75, 696, 237, 94,
1035 135, 51, 52, 52, 52, 52, 52, 52, 52, 52,
1036 52, 52, 52, 52, 52, 94, 52, 52, 52, 52,
1037 52, 642, 57, 57, 57, 58, 58, 58, 59, 59,
1038 59, 60, 60, 60, 52, 52, 57, 744, 150, 58,
1040 695, 694, 59, 744, 693, 60, 96, 96, 96, 109,
1041 109, 109, 150, 52, 61, 61, 61, 61, 61, 61,
1042 61, 61, 61, 61, 61, 61, 61, 552, 61, 61,
1043 61, 61, 61, 692, 63, 63, 63, 64, 64, 64,
1044 116, 116, 116, 127, 127, 127, 61, 61, 63, 145,
1045 162, 64, 132, 132, 132, 611, 145, 86, 144, 144,
1046 144, 691, 552, 145, 162, 61, 62, 62, 62, 62,
1047 62, 62, 62, 62, 62, 62, 62, 62, 62, 690,
1048 62, 62, 62, 62, 62, 86, 611, 65, 65, 66,
1049 66, 86, 65, 112, 66, 479, 86, 110, 62, 62,
1051 65, 86, 66, 171, 110, 111, 479, 112, 147, 147,
1052 147, 110, 111, 154, 154, 154, 171, 62, 65, 111,
1053 66, 720, 640, 112, 689, 112, 113, 110, 663, 110,
1054 720, 664, 112, 364, 114, 111, 110, 111, 112, 640,
1055 113, 114, 110, 112, 111, 167, 364, 110, 114, 419,
1056 111, 663, 167, 128, 664, 111, 113, 688, 113, 167,
1057 128, 129, 719, 419, 114, 113, 114, 128, 159, 159,
1058 159, 113, 601, 114, 719, 129, 113, 730, 687, 114,
1059 130, 755, 602, 128, 114, 128, 601, 130, 155, 730,
1060 604, 129, 128, 129, 130, 155, 602, 686, 128, 605,
1062 129, 755, 155, 128, 604, 685, 129, 156, 680, 607,
1063 130, 129, 130, 605, 608, 157, 679, 717, 155, 130,
1064 155, 156, 157, 607, 678, 130, 677, 155, 608, 157,
1065 130, 717, 731, 155, 166, 166, 166, 156, 155, 156,
1066 170, 170, 170, 738, 731, 157, 156, 157, 207, 207,
1067 207, 676, 156, 734, 157, 748, 738, 156, 757, 756,
1068 157, 763, 734, 207, 748, 157, 258, 258, 258, 259,
1069 259, 259, 267, 267, 267, 757, 268, 268, 268, 756,
1070 268, 763, 258, 268, 675, 259, 758, 267, 273, 273,
1071 273, 274, 274, 274, 283, 283, 283, 284, 284, 284,
1073 285, 285, 285, 758, 273, 259, 765, 274, 674, 673,
1074 283, 672, 671, 284, 764, 285, 286, 286, 286, 287,
1075 287, 287, 289, 289, 289, 290, 290, 290, 291, 291,
1076 291, 759, 286, 761, 764, 287, 762, 289, 274, 760,
1077 761, 290, 765, 762, 291, 312, 312, 312, 284, 316,
1078 316, 316, 317, 317, 317, 319, 319, 319, 670, 287,
1079 312, 291, 322, 322, 322, 316, 767, 768, 317, 769,
1080 759, 319, 325, 325, 325, 327, 327, 327, 760, 327,
1081 766, 769, 327, 331, 331, 331, 767, 768, 319, 334,
1082 334, 334, 335, 335, 335, 337, 337, 337, 331, 339,
1084 339, 339, 340, 340, 340, 334, 770, 669, 335, 666,
1085 662, 337, 661, 660, 339, 770, 766, 340, 343, 343,
1086 343, 345, 345, 345, 346, 346, 346, 659, 658, 337,
1087 347, 347, 347, 343, 331, 657, 345, 349, 349, 349,
1088 346, 350, 350, 350, 656, 655, 347, 351, 351, 351,
1089 654, 351, 653, 349, 351, 652, 350, 352, 352, 352,
1090 353, 353, 353, 355, 355, 355, 357, 357, 357, 359,
1091 359, 359, 651, 352, 349, 650, 353, 648, 646, 355,
1092 639, 357, 358, 358, 358, 359, 358, 638, 637, 358,
1093 360, 360, 360, 362, 362, 362, 365, 365, 365, 370,
1095 370, 370, 636, 635, 355, 634, 360, 633, 632, 362,
1096 631, 630, 365, 365, 372, 372, 372, 374, 374, 374,
1097 376, 376, 376, 377, 377, 377, 629, 377, 628, 372,
1098 377, 627, 374, 626, 625, 376, 379, 379, 379, 381,
1099 381, 381, 624, 362, 382, 382, 382, 620, 379, 599,
1100 598, 379, 384, 384, 384, 381, 386, 386, 386, 387,
1101 387, 387, 389, 389, 389, 390, 390, 390, 391, 391,
1102 391, 597, 391, 596, 593, 391, 572, 389, 381, 571,
1103 390, 395, 395, 395, 396, 396, 396, 397, 397, 397,
1104 570, 398, 398, 398, 569, 398, 561, 395, 398, 399,
1106 399, 399, 397, 400, 400, 400, 553, 400, 549, 541,
1107 400, 403, 403, 403, 399, 404, 404, 404, 540, 404,
1108 539, 538, 404, 406, 406, 406, 403, 407, 407, 407,
1109 533, 407, 531, 530, 407, 408, 408, 408, 406, 409,
1110 409, 409, 526, 409, 525, 521, 409, 412, 412, 412,
1111 515, 408, 414, 414, 414, 514, 414, 513, 512, 414,
1112 417, 417, 417, 412, 421, 421, 421, 426, 426, 426,
1113 428, 428, 428, 431, 431, 431, 417, 429, 429, 429,
1114 421, 429, 511, 510, 429, 428, 408, 509, 431, 506,
1115 497, 412, 432, 432, 432, 493, 432, 417, 491, 432,
1117 487, 421, 434, 434, 434, 483, 434, 478, 476, 434,
1118 438, 438, 438, 440, 440, 440, 470, 440, 421, 466,
1119 440, 442, 442, 442, 465, 438, 443, 443, 443, 444,
1120 444, 444, 446, 446, 446, 455, 454, 442, 447, 447,
1121 447, 448, 448, 448, 449, 449, 449, 453, 449, 445,
1122 441, 449, 439, 450, 450, 450, 448, 450, 437, 433,
1123 450, 456, 456, 456, 458, 458, 458, 459, 459, 459,
1124 430, 459, 427, 423, 459, 420, 418, 456, 462, 462,
1125 462, 413, 462, 405, 402, 462, 467, 467, 467, 401,
1126 467, 394, 393, 467, 471, 471, 471, 392, 471, 388,
1128 385, 471, 474, 474, 474, 475, 475, 475, 477, 477,
1129 477, 383, 484, 484, 484, 380, 484, 378, 474, 484,
1130 375, 475, 373, 371, 477, 488, 488, 488, 369, 488,
1131 368, 363, 488, 492, 492, 492, 494, 494, 494, 356,
1132 494, 475, 344, 494, 498, 498, 498, 342, 492, 500,
1133 500, 500, 341, 338, 477, 501, 501, 501, 333, 332,
1134 498, 502, 502, 502, 503, 503, 503, 330, 503, 326,
1135 324, 503, 507, 507, 507, 508, 508, 508, 516, 516,
1136 516, 518, 518, 518, 519, 519, 519, 507, 323, 321,
1137 508, 520, 520, 520, 516, 320, 315, 518, 527, 527,
1139 527, 528, 528, 528, 529, 529, 529, 520, 529, 314,
1140 313, 529, 311, 527, 310, 309, 528, 532, 532, 532,
1141 534, 534, 534, 535, 535, 535, 308, 535, 307, 306,
1142 535, 536, 536, 536, 305, 534, 302, 537, 537, 537,
1143 301, 537, 300, 520, 537, 298, 536, 542, 542, 542,
1144 543, 543, 543, 544, 544, 544, 545, 545, 545, 547,
1145 547, 547, 542, 294, 292, 543, 288, 282, 544, 548,
1146 548, 548, 545, 550, 550, 550, 554, 554, 554, 555,
1147 555, 555, 579, 579, 579, 548, 556, 556, 556, 550,
1148 556, 554, 281, 556, 555, 557, 557, 557, 579, 557,
1150 280, 279, 557, 560, 560, 560, 562, 562, 562, 563,
1151 563, 563, 278, 563, 277, 276, 563, 275, 560, 272,
1152 271, 562, 566, 566, 566, 270, 566, 269, 266, 566,
1153 573, 573, 573, 574, 574, 574, 265, 574, 264, 263,
1154 574, 575, 575, 575, 262, 573, 576, 576, 576, 261,
1155 576, 260, 257, 576, 256, 255, 575, 577, 577, 577,
1156 578, 578, 578, 254, 578, 253, 252, 578, 582, 582,
1157 582, 251, 577, 585, 585, 585, 586, 586, 586, 587,
1158 587, 587, 250, 587, 582, 249, 587, 248, 585, 246,
1159 245, 586, 588, 588, 588, 244, 588, 243, 242, 588,
1161 238, 582, 591, 591, 591, 592, 592, 592, 236, 592,
1162 235, 234, 592, 594, 594, 594, 233, 591, 595, 595,
1163 595, 232, 595, 231, 228, 595, 227, 226, 594, 600,
1164 600, 600, 223, 600, 222, 221, 600, 603, 603, 603,
1165 220, 603, 219, 218, 603, 606, 606, 606, 217, 606,
1166 216, 213, 606, 612, 612, 612, 613, 613, 613, 212,
1167 613, 211, 210, 613, 209, 614, 614, 614, 612, 614,
1168 208, 204, 614, 617, 617, 617, 203, 617, 202, 201,
1169 617, 621, 621, 621, 200, 621, 199, 198, 621, 643,
1170 643, 643, 197, 643, 196, 195, 643, 665, 665, 665,
1172 681, 681, 681, 682, 682, 682, 683, 683, 683, 194,
1173 193, 192, 665, 665, 191, 190, 681, 189, 682, 682,
1174 188, 683, 683, 684, 684, 684, 185, 684, 184, 183,
1175 684, 698, 698, 698, 699, 699, 699, 182, 181, 684,
1176 175, 700, 700, 700, 174, 700, 172, 698, 700, 699,
1177 699, 701, 701, 701, 169, 701, 168, 700, 701, 698,
1178 164, 736, 736, 736, 753, 753, 753, 701, 702, 702,
1179 702, 702, 702, 702, 702, 702, 702, 736, 736, 702,
1180 753, 160, 702, 702, 702, 702, 702, 747, 747, 747,
1181 152, 747, 148, 141, 747, 742, 742, 742, 140, 139,
1183 702, 702, 703, 703, 703, 703, 703, 703, 703, 703,
1184 703, 742, 138, 703, 137, 133, 703, 703, 703, 703,
1185 703, 718, 718, 718, 125, 718, 124, 123, 718, 750,
1186 750, 750, 742, 750, 703, 703, 750, 718, 721, 721,
1187 721, 721, 721, 721, 721, 721, 721, 122, 121, 721,
1188 117, 106, 721, 721, 721, 721, 721, 105, 104, 103,
1189 102, 97, 93, 92, 91, 85, 743, 743, 743, 84,
1190 721, 721, 722, 722, 722, 722, 722, 722, 722, 722,
1191 722, 743, 82, 722, 79, 67, 722, 722, 722, 722,
1192 722, 746, 746, 746, 754, 754, 754, 0, 754, 0,
1194 0, 754, 0, 0, 722, 722, 746, 771, 771, 771,
1195 754, 772, 772, 772, 0, 0, 0, 0, 0, 0,
1196 0, 0, 0, 771, 0, 0, 0, 772, 775, 775,
1197 775, 775, 775, 775, 775, 776, 776, 776, 776, 776,
1198 776, 776, 777, 777, 777, 777, 777, 777, 777, 778,
1199 778, 778, 778, 778, 778, 778, 779, 779, 779, 779,
1200 779, 779, 779, 780, 780, 780, 780, 780, 780, 780,
1201 781, 781, 781, 781, 781, 781, 781, 782, 782, 782,
1202 782, 782, 782, 782, 783, 783, 783, 783, 783, 783,
1203 783, 784, 784, 784, 784, 784, 784, 784, 785, 785,
1205 785, 785, 785, 785, 785, 786, 786, 786, 786, 786,
1206 786, 786, 787, 787, 787, 787, 787, 787, 787, 788,
1207 788, 788, 788, 788, 788, 788, 789, 789, 789, 0,
1208 789, 790, 790, 790, 0, 790, 791, 791, 791, 0,
1209 791, 792, 792, 792, 0, 792, 793, 793, 793, 0,
1210 793, 794, 794, 794, 794, 794, 0, 794, 795, 0,
1211 795, 796, 0, 796, 797, 0, 797, 798, 0, 798,
1212 799, 0, 799, 800, 800, 800, 800, 800, 800, 800,
1213 801, 0, 0, 801, 802, 802, 802, 802, 802, 802,
1214 803, 803, 803, 803, 803, 803, 804, 804, 804, 804,
1216 804, 804, 805, 805, 805, 805, 805, 805, 806, 806,
1217 806, 806, 806, 806, 807, 807, 807, 807, 807, 807,
1218 807, 808, 808, 808, 808, 808, 808, 808, 809, 809,
1219 809, 809, 809, 809, 809, 810, 810, 810, 810, 810,
1220 810, 810, 811, 811, 811, 811, 811, 811, 811, 812,
1221 812, 812, 812, 812, 812, 812, 813, 813, 813, 813,
1222 813, 813, 813, 774, 774, 774, 774, 774, 774, 774,
1223 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
1224 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
1225 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
1227 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
1228 774, 774, 774, 774, 774, 774, 774, 774, 774, 774,
1232 /* Table of booleans, true if rule could match eol. */
1233 static yyconst flex_int32_t yy_rule_can_match_eol[141] =
1235 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1,
1236 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0,
1237 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,
1238 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1239 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1,
1240 1, 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0,
1241 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1,
1244 static yy_state_type yy_last_accepting_state;
1245 static char *yy_last_accepting_cpos;
1247 extern int dax__flex_debug;
1248 int dax__flex_debug = 0;
1250 /* The intent behind this definition is that it'll catch
1251 * any uses of REJECT which flex missed.
1253 #define REJECT reject_used_but_not_detected
1254 #define yymore() yymore_used_but_not_detected
1255 #define YY_MORE_ADJ 0
1256 #define YY_RESTORE_YY_MORE_OFFSET
1258 /* Validating XML processor for src/simdag/dax.dtd.
1260 * This program was generated with the FleXML XML processor generator.
1261 * FleXML is Copyright (C) 1999-2005 Kristoffer Rose. All rights reserved.
1262 * FleXML is Copyright (C) 2003-2006 Martin Quinson. All rights reserved.
1263 * (Id: flexml.pl,v 1.64 2007/11/09 13:38:20 mquinson Exp).
1265 * There are two, intertwined parts to this program, part A and part B.
1270 * Some parts, here collectively called "Part A", are found in the
1271 * FleXML package. They are Copyright (C) 1999-2005 Kristoffer Rose
1272 * and Copyright (C) 2003-2006 Martin Quinson. All rights reserved.
1274 * You can redistribute, use, perform, display and/or modify "Part A"
1275 * provided the following two conditions hold:
1277 * 1. The program is distributed WITHOUT ANY WARRANTY from the author of
1278 * FleXML; without even the implied warranty of MERCHANTABILITY or
1279 * FITNESS FOR A PARTICULAR PURPOSE.
1281 * 2. The program distribution conditions do not in any way affect the
1282 * distribution conditions of the FleXML system used to generate this
1283 * file or any version of FleXML derived from that system.
1285 * Notice that these are explicit rights granted to you for files
1286 * generated by the FleXML system. For your rights in connection with
1287 * the FleXML system itself please consult the GNU General Public License.
1292 * The other parts, here collectively called "Part B", and which came
1293 * from the DTD used by FleXML to generate this program, can be
1294 * distributed (or not, as the case may be) under the terms of whoever
1295 * wrote them, provided these terms respect and obey the two conditions
1296 * above under the heading "Part A".
1298 * The author of and contributors to FleXML specifically disclaim
1299 * any copyright interest in "Part B", unless "Part B" was written
1300 * by the author of or contributors to FleXML.
1304 /* Version strings. */
1305 const char rcs_dax__flexml_skeleton[] =
1306 "$" "Id: skel,v 1.40 2007/10/11 09:57:24 mquinson Exp $";
1307 const char rcs_dax__flexml[] =
1308 "$" "Id: flexml.pl,v 1.64 2007/11/09 13:38:20 mquinson Exp $";
1311 #include <stdlib.h> /* for realloc() -- needed here when using flex 2.5.4 */
1318 #if defined(_XBT_WIN32) || defined(__WIN32__) || defined(WIN32) || defined(__TOS_WIN__)
1319 # ifndef __STRICT_ANSI__
1321 # include <process.h>
1324 # include <unistd.h>
1327 #ifndef FLEXML_INDEXSTACKSIZE
1328 #define FLEXML_INDEXSTACKSIZE 1000
1331 /* Generated definitions. */
1332 #define FLEXML_yylineno
1333 #ifndef FLEXML_BUFFERSTACKSIZE
1334 #define FLEXML_BUFFERSTACKSIZE 1000000
1336 #define FLEXML_NEED_BUFFERLIT
1338 /* XML processor api. */
1339 /* FleXML-provided data. */
1341 extern char *dax__bufferstack;
1342 #define dax__pcdata (dax__bufferstack + dax__pcdata_ix)
1343 AT_dax__adag_version AX_dax__adag_version;
1344 #define A_dax__adag_version (dax__bufferstack + AX_dax__adag_version)
1345 AT_dax__uses_type AX_dax__uses_type;
1346 #define A_dax__uses_type (dax__bufferstack + AX_dax__uses_type)
1347 AT_dax__uses_optional AX_dax__uses_optional;
1348 #define A_dax__uses_optional AX_dax__uses_optional
1349 AT_dax__adag_name AX_dax__adag_name;
1350 #define A_dax__adag_name (dax__bufferstack + AX_dax__adag_name)
1351 AT_dax__child_ref AX_dax__child_ref;
1352 #define A_dax__child_ref (dax__bufferstack + AX_dax__child_ref)
1353 AT_dax__adag_xmlns AX_dax__adag_xmlns;
1354 #define A_dax__adag_xmlns (dax__bufferstack + AX_dax__adag_xmlns)
1355 AT_dax__uses_transfer AX_dax__uses_transfer;
1356 #define A_dax__uses_transfer AX_dax__uses_transfer
1357 AT_dax__job_id AX_dax__job_id;
1358 #define A_dax__job_id (dax__bufferstack + AX_dax__job_id)
1359 AT_dax__uses_file AX_dax__uses_file;
1360 #define A_dax__uses_file (dax__bufferstack + AX_dax__uses_file)
1361 AT_dax__parent_ref AX_dax__parent_ref;
1362 #define A_dax__parent_ref (dax__bufferstack + AX_dax__parent_ref)
1363 AT_dax__adag_count AX_dax__adag_count;
1364 #define A_dax__adag_count (dax__bufferstack + AX_dax__adag_count)
1365 AT_dax__adag_xmlns_c_xsi AX_dax__adag_xmlns_c_xsi;
1366 #define A_dax__adag_xmlns_c_xsi (dax__bufferstack + AX_dax__adag_xmlns_c_xsi)
1367 AT_dax__adag_index AX_dax__adag_index;
1368 #define A_dax__adag_index (dax__bufferstack + AX_dax__adag_index)
1369 AT_dax__uses_size AX_dax__uses_size;
1370 #define A_dax__uses_size (dax__bufferstack + AX_dax__uses_size)
1371 AT_dax__adag_childCount AX_dax__adag_childCount;
1372 #define A_dax__adag_childCount (dax__bufferstack + AX_dax__adag_childCount)
1373 AT_dax__uses_link AX_dax__uses_link;
1374 #define A_dax__uses_link AX_dax__uses_link
1375 AT_dax__job_runtime AX_dax__job_runtime;
1376 #define A_dax__job_runtime (dax__bufferstack + AX_dax__job_runtime)
1377 AT_dax__job_level AX_dax__job_level;
1378 #define A_dax__job_level (dax__bufferstack + AX_dax__job_level)
1379 AT_dax__job_namespace AX_dax__job_namespace;
1380 #define A_dax__job_namespace (dax__bufferstack + AX_dax__job_namespace)
1381 AT_dax__job_name AX_dax__job_name;
1382 #define A_dax__job_name (dax__bufferstack + AX_dax__job_name)
1383 AT_dax__adag_jobCount AX_dax__adag_jobCount;
1384 #define A_dax__adag_jobCount (dax__bufferstack + AX_dax__adag_jobCount)
1385 AT_dax__job_version AX_dax__job_version;
1386 #define A_dax__job_version (dax__bufferstack + AX_dax__job_version)
1387 AT_dax__adag_xsi_c_schemaLocation AX_dax__adag_xsi_c_schemaLocation;
1388 #define A_dax__adag_xsi_c_schemaLocation (dax__bufferstack + AX_dax__adag_xsi_c_schemaLocation)
1389 AT_dax__uses_register AX_dax__uses_register;
1390 #define A_dax__uses_register AX_dax__uses_register
1391 AT_dax__adag_fileCount AX_dax__adag_fileCount;
1392 #define A_dax__adag_fileCount (dax__bufferstack + AX_dax__adag_fileCount)
1396 # define ENTER(state) debug_enter(state,#state)
1397 # define LEAVE debug_leave()
1398 # define SET(state) debug_set(state,#state)
1399 static void debug_enter(int, const char*);
1400 static void debug_leave(void);
1401 static void debug_set(int, const char*);
1403 # define ENTER(state) (yy_push_state(state))
1404 # define LEAVE (yy_pop_state())
1405 # define SET(state) BEGIN(state)
1408 /* Generic actions. */
1409 #define SKIP /*skip*/
1410 #define SUCCEED CLEANUP; return 0
1412 #define FAIL return fail
1413 static int fail(const char*, ...);
1415 enum {flexml_max_err_msg_size = 512};
1416 static char flexml_err_msg[flexml_max_err_msg_size];
1417 const char * dax__parse_err_msg()
1419 return flexml_err_msg;
1421 static void reset_dax__parse_err_msg()
1423 flexml_err_msg[0] = '\0';
1427 static void cleanup(void);
1428 #define CLEANUP cleanup()
1430 /* Text buffer stack handling. */
1431 char *dax__bufferstack = NULL;
1432 static int blimit = FLEXML_BUFFERSTACKSIZE;
1433 static int bnext = 1;
1435 static int *indexstack = NULL;
1436 static int ilimit = FLEXML_INDEXSTACKSIZE;
1437 static int inext = 1;
1439 #define BUFFERSET(P) (P = bnext)
1440 #define BUFFERPUTC(C) (ck_blimit(), dax__bufferstack[bnext++] = (C))
1441 #define BUFFERDONE (BUFFERPUTC('\0'))
1443 #define BUFFERLITERAL(C, P) dax__bufferliteral(C, &(P), dax_text)
1445 /* after this is called, there are at least 2 slots left in the stack */
1446 static int ck_blimit()
1448 if (bnext >= blimit) {
1449 blimit += FLEXML_BUFFERSTACKSIZE + 2;
1451 char *temp = (char *) realloc(dax__bufferstack, blimit);
1453 dax__bufferstack = temp;
1459 /* after this is called, there are at least 2 slots left in the stack */
1460 static int ck_ilimit()
1462 if (inext >= ilimit) {
1463 ilimit += FLEXML_INDEXSTACKSIZE + 2;
1465 int *temp = (int *) realloc(indexstack, ilimit);
1473 #ifdef FLEXML_NEED_BUFFERLIT
1474 static void dax__bufferliteral(char c, int* pp, const char* text)
1476 const char *s = (c ? strchr(text,c) : text-1), *e = strrchr(text,c);
1477 assert(s <= e); BUFFERSET(*pp);
1479 if (isspace(*s) && c) { BUFFERPUTC(' '); while (isspace(*s)) ++s; }
1480 else BUFFERPUTC(*s);
1486 static void pushbuffer(int p)
1489 indexstack[inext++] = p;
1490 indexstack[inext++] = bnext;
1493 static int popbuffer(void)
1496 bnext = indexstack[--inext];
1497 return indexstack[--inext];
1500 /* General internal entities are `unput' back onto the input stream... */
1501 #define ENTITYTEXT(T) \
1502 { char *s = (T), *e = s+strlen(s);\
1503 while (--e >= s) { unput(*e); }}
1505 /* Flex standard options. */
1506 #define YY_NO_INPUT 1
1507 /* Flex user-requested options. */
1508 /* XML character classes (currently restricted to ASCII). */
1509 /* "Common syntactic structures." */
1510 /* "Names and Tokens." */
1511 /* Miscellaneous. */
1512 /* Parser states (flex `exclusive start conditions'):
1514 * PROLOG the XML prolog of the document before <?xml...>
1515 * DOCTYPE the XML prolog of the document after <?xml...>
1516 * EPILOG after the root element
1517 * INCOMMENT inside an XML comment <!--....-->
1518 * INPI inside an XML PI <?...?>
1519 * VALUE1 inside a '...'-delimited literal
1520 * VALUE2 inside a "..."-delimited literal
1521 * CDATA inside a <![CDATA[...] ]> section.
1522 * ROOT_<tag> expect root element <tag>
1523 * AL_<tag> inside the attribute list for <tag>
1524 * IN_<tag> inside a <tag> with element contents (ready for end tag)
1525 * IMPOSSIBLE dummy to permit disabling rules; must be last
1529 const char* *dax__statenames=NULL;
1540 #define ROOT_dax__adag 9
1541 #define AL_dax__adag 10
1542 #define S_dax__adag 11
1543 #define S_dax__adag_1 12
1544 #define S_dax__adag_2 13
1545 #define S_dax__adag_3 14
1546 #define S_dax__adag_4 15
1547 #define S_dax__adag_5 16
1548 #define E_dax__adag 17
1549 #define AL_dax__job 18
1550 #define S_dax__job 19
1551 #define S_dax__job_1 20
1552 #define S_dax__job_2 21
1553 #define E_dax__job 22
1554 #define AL_dax__uses 23
1555 #define E_dax__uses 24
1556 #define AL_dax__child 25
1557 #define S_dax__child 26
1558 #define S_dax__child_1 27
1559 #define S_dax__child_2 28
1560 #define E_dax__child 29
1561 #define AL_dax__parent 30
1562 #define E_dax__parent 31
1563 #define IMPOSSIBLE 32
1565 #ifndef YY_NO_UNISTD_H
1566 /* Special case for "unistd.h", since it is non-ANSI. We include it way
1567 * down here because we want the user's section 1 to have been scanned first.
1568 * The user has a chance to override it with an option.
1570 #if defined(_XBT_WIN32) || defined(__WIN32__) || defined(WIN32) || defined(__TOS_WIN__)
1571 # ifndef __STRICT_ANSI__
1573 # include <process.h>
1576 # include <unistd.h>
1580 #ifndef YY_EXTRA_TYPE
1581 #define YY_EXTRA_TYPE void *
1584 static int yy_init_globals (void );
1586 /* Accessor methods to globals.
1587 These are made visible to non-reentrant scanners for convenience. */
1589 int dax_lex_destroy (void );
1591 int dax_get_debug (void );
1593 void dax_set_debug (int debug_flag );
1595 YY_EXTRA_TYPE dax_get_extra (void );
1597 void dax_set_extra (YY_EXTRA_TYPE user_defined );
1599 FILE *dax_get_in (void );
1601 void dax_set_in (FILE * in_str );
1603 FILE *dax_get_out (void );
1605 void dax_set_out (FILE * out_str );
1607 int dax_get_leng (void );
1609 char *dax_get_text (void );
1611 int dax_get_lineno (void );
1613 void dax_set_lineno (int line_number );
1615 /* Macros after this point can all be overridden by user definitions in
1619 #ifndef YY_SKIP_YYWRAP
1621 extern "C" int dax_wrap (void );
1623 extern int dax_wrap (void );
1628 static void yy_flex_strncpy (char *,yyconst char *,int );
1631 #ifdef YY_NEED_STRLEN
1632 static int yy_flex_strlen (yyconst char * );
1638 static int yyinput (void );
1640 static int input (void );
1645 static int yy_start_stack_ptr = 0;
1646 static int yy_start_stack_depth = 0;
1647 static int *yy_start_stack = NULL;
1649 static void yy_push_state (int new_state );
1651 static void yy_pop_state (void );
1653 /* Amount of stuff to slurp up with each read. */
1654 #ifndef YY_READ_BUF_SIZE
1656 /* On IA-64, the buffer size is 16k, not 8k */
1657 #define YY_READ_BUF_SIZE 16384
1659 #define YY_READ_BUF_SIZE 8192
1660 #endif /* __ia64__ */
1663 /* Copy whatever the last rule matched to the standard output. */
1665 /* This used to be an fputs(), but since the string might contain NUL's,
1666 * we now use fwrite().
1668 #define ECHO do { if (fwrite( dax_text, dax_leng, 1, dax_out )) {} } while (0)
1671 /* Gets input and stuffs it into "buf". number of characters read, or YY_NULL,
1672 * is returned in "result".
1675 #define YY_INPUT(buf,result,max_size) \
1676 if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \
1680 for ( n = 0; n < max_size && \
1681 (c = getc( dax_in )) != EOF && c != '\n'; ++n ) \
1682 buf[n] = (char) c; \
1684 buf[n++] = (char) c; \
1685 if ( c == EOF && ferror( dax_in ) ) \
1686 YY_FATAL_ERROR( "input in flex scanner failed" ); \
1692 while ( (result = fread(buf, 1, max_size, dax_in))==0 && ferror(dax_in)) \
1694 if( errno != EINTR) \
1696 YY_FATAL_ERROR( "input in flex scanner failed" ); \
1707 /* No semi-colon after return; correct usage is to write "yyterminate();" -
1708 * we don't want an extra ';' after the "return" because that will cause
1709 * some compilers to complain about unreachable statements.
1712 #define yyterminate() return YY_NULL
1715 /* Number of entries by which start-condition stack grows. */
1716 #ifndef YY_START_STACK_INCR
1717 #define YY_START_STACK_INCR 25
1720 /* Report a fatal error. */
1721 #ifndef YY_FATAL_ERROR
1722 #define YY_FATAL_ERROR(msg) yy_fatal_error( msg )
1725 /* end tables serialization structures and prototypes */
1727 /* Default declaration of generated scanner - a define so the user can
1728 * easily add parameters.
1731 #define YY_DECL_IS_OURS 1
1733 extern int dax_lex (void);
1735 #define YY_DECL int dax_lex (void)
1736 #endif /* !YY_DECL */
1738 /* Code executed at the beginning of each rule, after dax_text and dax_leng
1741 #ifndef YY_USER_ACTION
1742 #define YY_USER_ACTION
1745 /* Code executed at the end of each rule. */
1747 #define YY_BREAK break;
1750 #define YY_RULE_SETUP \
1753 /** The main scanner function which does all the work.
1757 register yy_state_type yy_current_state;
1758 register char *yy_cp, *yy_bp;
1759 register int yy_act;
1761 /* Bypass Flex's default INITIAL state and begin by parsing the XML prolog. */
1763 reset_dax__parse_err_msg();
1764 dax__bufferstack = (char *) malloc(FLEXML_BUFFERSTACKSIZE);
1765 assert(dax__bufferstack);
1769 for (i = 0; i < blimit; i++) {
1770 dax__bufferstack[i] = '\377';
1774 dax__bufferstack[0] = '\0';
1775 indexstack = (int *) malloc(FLEXML_INDEXSTACKSIZE * sizeof(int));
1781 dax__bufferliteral('\0', &bnext, "http://pegasus.isi.edu/schema/DAX");
1782 dax__bufferliteral('\0', &bnext, "http://www.w3.org/2001/XMLSchema-instance");
1783 dax__bufferliteral('\0', &bnext, "http://pegasus.isi.edu/schema/DAX http://pegasus.isi.edu/schema/dax-2.1.xsd");
1784 dax__bufferliteral('\0', &bnext, "1.0");
1785 dax__bufferliteral('\0', &bnext, "0.0");
1786 dax__bufferliteral('\0', &bnext, "data");
1787 if(!dax__statenames) {dax__statenames= (const char **)calloc(IMPOSSIBLE,sizeof(char*));
1788 dax__statenames[PROLOG] = NULL;
1789 dax__statenames[DOCTYPE] = NULL;
1790 dax__statenames[EPILOG] = NULL;
1791 dax__statenames[INCOMMENT] = NULL;
1792 dax__statenames[INPI] = NULL;
1793 dax__statenames[VALUE1] = NULL;
1794 dax__statenames[VALUE2] = NULL;
1795 dax__statenames[CDATA] = NULL;
1796 dax__statenames[ROOT_dax__adag] = NULL;
1797 dax__statenames[AL_dax__adag] = NULL;
1798 dax__statenames[S_dax__adag] = "adag";
1799 dax__statenames[S_dax__adag_1] = "adag";
1800 dax__statenames[S_dax__adag_2] = "adag";
1801 dax__statenames[S_dax__adag_3] = "adag";
1802 dax__statenames[S_dax__adag_4] = "adag";
1803 dax__statenames[S_dax__adag_5] = "adag";
1804 dax__statenames[E_dax__adag] = "adag";
1805 dax__statenames[AL_dax__job] = NULL;
1806 dax__statenames[S_dax__job] = "job";
1807 dax__statenames[S_dax__job_1] = "job";
1808 dax__statenames[S_dax__job_2] = "job";
1809 dax__statenames[E_dax__job] = "job";
1810 dax__statenames[AL_dax__uses] = NULL;
1811 dax__statenames[E_dax__uses] = "uses";
1812 dax__statenames[AL_dax__child] = NULL;
1813 dax__statenames[S_dax__child] = "child";
1814 dax__statenames[S_dax__child_1] = "child";
1815 dax__statenames[S_dax__child_2] = "child";
1816 dax__statenames[E_dax__child] = "child";
1817 dax__statenames[AL_dax__parent] = NULL;
1818 dax__statenames[E_dax__parent] = "parent";
1821 /* COMMENTS and PIs: handled uniformly for efficiency. */
1832 (yy_start) = 1; /* first start state */
1840 if ( ! YY_CURRENT_BUFFER ) {
1841 dax_ensure_buffer_stack ();
1842 YY_CURRENT_BUFFER_LVALUE =
1843 dax__create_buffer(dax_in,YY_BUF_SIZE );
1846 dax__load_buffer_state( );
1849 while ( 1 ) /* loops until end-of-file is reached */
1851 yy_cp = (yy_c_buf_p);
1853 /* Support of dax_text. */
1854 *yy_cp = (yy_hold_char);
1856 /* yy_bp points to the position in yy_ch_buf of the start of
1861 yy_current_state = (yy_start);
1865 register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)];
1866 if ( yy_accept[yy_current_state] )
1868 (yy_last_accepting_state) = yy_current_state;
1869 (yy_last_accepting_cpos) = yy_cp;
1871 while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
1873 yy_current_state = (int) yy_def[yy_current_state];
1874 if ( yy_current_state >= 775 )
1875 yy_c = yy_meta[(unsigned int) yy_c];
1877 yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
1880 while ( yy_base[yy_current_state] != 2164 );
1883 yy_act = yy_accept[yy_current_state];
1885 { /* have to back up */
1886 yy_cp = (yy_last_accepting_cpos);
1887 yy_current_state = (yy_last_accepting_state);
1888 yy_act = yy_accept[yy_current_state];
1891 YY_DO_BEFORE_ACTION;
1893 if ( yy_act != YY_END_OF_BUFFER && yy_rule_can_match_eol[yy_act] )
1896 for ( yyl = 0; yyl < dax_leng; ++yyl )
1897 if ( dax_text[yyl] == '\n' )
1903 do_action: /* This label is used only to access EOF actions. */
1906 { /* beginning of action switch */
1907 case 0: /* must back up */
1908 /* undo the effects of YY_DO_BEFORE_ACTION */
1909 *yy_cp = (yy_hold_char);
1910 yy_cp = (yy_last_accepting_cpos);
1911 yy_current_state = (yy_last_accepting_state);
1912 goto yy_find_action;
1930 /* rule 6 can match eol */
1934 case YY_STATE_EOF(INCOMMENT):
1935 FAIL("EOF in comment.");
1944 /* rule 9 can match eol */
1948 case YY_STATE_EOF(INPI):
1949 FAIL("EOF in PI (processing instruction).");
1952 /* SPACES: skipped uniformly */
1954 /* rule 10 can match eol */
1958 /* PROLOG: determine root element and process it. */
1961 /* rule 11 can match eol */
1963 SET(ROOT_dax__adag);
1966 /* rule 12 can match eol */
1968 FAIL("Bad declaration %s.",dax_text);
1972 /* rule 13 can match eol */
1974 SET(ROOT_dax__adag);
1977 /* rule 14 can match eol */
1979 FAIL("Bad declaration %s.",dax_text);
1983 FAIL("Unexpected character `%c' in prolog.", dax_text[0]);
1985 case YY_STATE_EOF(PROLOG):
1986 case YY_STATE_EOF(DOCTYPE):
1987 FAIL("EOF in prolog.");
1990 /* RULES DERIVED FROM DTD. */
1991 /* <!-- Small DTD for DAX files. --> */
1993 /* rule 16 can match eol */
1995 FAIL("Starting tag <adag> is not allowed here.");
1998 /* rule 17 can match eol */
2001 AX_dax__adag_xmlns = 1;
2002 dax__adag_xmlns_isset = 0;
2003 AX_dax__adag_xmlns_c_xsi = 35;
2004 dax__adag_xmlns_c_xsi_isset = 0;
2005 AX_dax__adag_xsi_c_schemaLocation = 77;
2006 dax__adag_xsi_c_schemaLocation_isset = 0;
2007 AX_dax__adag_version = 153;
2008 dax__adag_version_isset = 0;
2009 AX_dax__adag_count = 0;
2010 dax__adag_count_isset = 0;
2011 AX_dax__adag_index = 0;
2012 dax__adag_index_isset = 0;
2013 AX_dax__adag_name = 0;
2014 dax__adag_name_isset = 0;
2015 AX_dax__adag_jobCount = 0;
2016 dax__adag_jobCount_isset = 0;
2017 AX_dax__adag_fileCount = 0;
2018 dax__adag_fileCount_isset = 0;
2019 AX_dax__adag_childCount = 0;
2020 dax__adag_childCount_isset = 0;
2021 ENTER(AL_dax__adag); pushbuffer(0);
2026 /* rule 18 can match eol */
2028 if (dax__adag_xmlns_isset != 0) {FAIL("Multiple definition of attribute xmlns in <dax__adag>");} dax__adag_xmlns_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_xmlns);
2031 /* rule 19 can match eol */
2033 if (dax__adag_xmlns_isset != 0) {FAIL("Multiple definition of attribute xmlns in <dax__adag>");} dax__adag_xmlns_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_xmlns);
2036 /* rule 20 can match eol */
2038 if (dax__adag_xmlns_c_xsi_isset != 0) {FAIL("Multiple definition of attribute xmlns:xsi in <dax__adag>");} dax__adag_xmlns_c_xsi_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_xmlns_c_xsi);
2041 /* rule 21 can match eol */
2043 if (dax__adag_xmlns_c_xsi_isset != 0) {FAIL("Multiple definition of attribute xmlns:xsi in <dax__adag>");} dax__adag_xmlns_c_xsi_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_xmlns_c_xsi);
2046 /* rule 22 can match eol */
2048 if (dax__adag_xsi_c_schemaLocation_isset != 0) {FAIL("Multiple definition of attribute xsi:schemaLocation in <dax__adag>");} dax__adag_xsi_c_schemaLocation_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_xsi_c_schemaLocation);
2051 /* rule 23 can match eol */
2053 if (dax__adag_xsi_c_schemaLocation_isset != 0) {FAIL("Multiple definition of attribute xsi:schemaLocation in <dax__adag>");} dax__adag_xsi_c_schemaLocation_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_xsi_c_schemaLocation);
2056 /* rule 24 can match eol */
2058 if (dax__adag_version_isset != 0) {FAIL("Multiple definition of attribute version in <dax__adag>");} dax__adag_version_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_version);
2061 /* rule 25 can match eol */
2063 if (dax__adag_version_isset != 0) {FAIL("Multiple definition of attribute version in <dax__adag>");} dax__adag_version_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_version);
2066 /* rule 26 can match eol */
2068 if (dax__adag_count_isset != 0) {FAIL("Multiple definition of attribute count in <dax__adag>");} dax__adag_count_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_count);
2071 /* rule 27 can match eol */
2073 if (dax__adag_count_isset != 0) {FAIL("Multiple definition of attribute count in <dax__adag>");} dax__adag_count_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_count);
2076 /* rule 28 can match eol */
2078 if (dax__adag_index_isset != 0) {FAIL("Multiple definition of attribute index in <dax__adag>");} dax__adag_index_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_index);
2081 /* rule 29 can match eol */
2083 if (dax__adag_index_isset != 0) {FAIL("Multiple definition of attribute index in <dax__adag>");} dax__adag_index_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_index);
2086 /* rule 30 can match eol */
2088 if (dax__adag_name_isset != 0) {FAIL("Multiple definition of attribute name in <dax__adag>");} dax__adag_name_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_name);
2091 /* rule 31 can match eol */
2093 if (dax__adag_name_isset != 0) {FAIL("Multiple definition of attribute name in <dax__adag>");} dax__adag_name_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_name);
2096 /* rule 32 can match eol */
2098 if (dax__adag_jobCount_isset != 0) {FAIL("Multiple definition of attribute jobCount in <dax__adag>");} dax__adag_jobCount_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_jobCount);
2101 /* rule 33 can match eol */
2103 if (dax__adag_jobCount_isset != 0) {FAIL("Multiple definition of attribute jobCount in <dax__adag>");} dax__adag_jobCount_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_jobCount);
2106 /* rule 34 can match eol */
2108 if (dax__adag_fileCount_isset != 0) {FAIL("Multiple definition of attribute fileCount in <dax__adag>");} dax__adag_fileCount_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_fileCount);
2111 /* rule 35 can match eol */
2113 if (dax__adag_fileCount_isset != 0) {FAIL("Multiple definition of attribute fileCount in <dax__adag>");} dax__adag_fileCount_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_fileCount);
2116 /* rule 36 can match eol */
2118 if (dax__adag_childCount_isset != 0) {FAIL("Multiple definition of attribute childCount in <dax__adag>");} dax__adag_childCount_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__adag_childCount);
2121 /* rule 37 can match eol */
2123 if (dax__adag_childCount_isset != 0) {FAIL("Multiple definition of attribute childCount in <dax__adag>");} dax__adag_childCount_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__adag_childCount);
2128 LEAVE; STag_dax__adag();dax__pcdata_ix = 0; ENTER(S_dax__adag);
2134 LEAVE; STag_dax__adag(); dax__pcdata_ix = 0; ETag_dax__adag(); popbuffer(); /* attribute */
2136 case ROOT_dax__adag: SET(EPILOG); break;
2142 FAIL("Unexpected character `%c' in attribute list of adag element.", dax_text[0]);
2146 FAIL("Bad attribute `%s' in `adag' element start tag.",dax_text);
2148 case YY_STATE_EOF(AL_dax__adag):
2149 FAIL("EOF in attribute list of `adag' element.");
2153 /* rule 42 can match eol */
2158 popbuffer(); /* attribute */
2160 case ROOT_dax__adag: SET(EPILOG); break;
2165 /* rule 43 can match eol */
2167 FAIL("Unexpected end-tag `%s': `</adag>' expected.",dax_text);
2171 FAIL("Unexpected character `%c': `</adag>' expected.",dax_text[0]);
2173 case YY_STATE_EOF(S_dax__adag_1):
2174 case YY_STATE_EOF(S_dax__adag_5):
2175 case YY_STATE_EOF(E_dax__adag):
2176 case YY_STATE_EOF(S_dax__adag_3):
2177 case YY_STATE_EOF(S_dax__adag):
2178 FAIL("Premature EOF: `</adag>' expected.");
2182 /* rule 45 can match eol */
2184 FAIL("Starting tag <job> is not allowed here.");
2187 /* rule 46 can match eol */
2191 dax__job_id_isset = 0;
2192 AX_dax__job_namespace = 0;
2193 dax__job_namespace_isset = 0;
2194 AX_dax__job_name = 0;
2195 dax__job_name_isset = 0;
2196 AX_dax__job_version = 157;
2197 dax__job_version_isset = 0;
2198 AX_dax__job_runtime = 0;
2199 dax__job_runtime_isset = 0;
2200 AX_dax__job_level = 0;
2201 dax__job_level_isset = 0;
2202 ENTER(AL_dax__job); pushbuffer(0);
2207 /* rule 47 can match eol */
2209 if (dax__job_id_isset != 0) {FAIL("Multiple definition of attribute id in <dax__job>");} dax__job_id_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_id);
2212 /* rule 48 can match eol */
2214 if (dax__job_id_isset != 0) {FAIL("Multiple definition of attribute id in <dax__job>");} dax__job_id_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_id);
2217 /* rule 49 can match eol */
2219 if (dax__job_namespace_isset != 0) {FAIL("Multiple definition of attribute namespace in <dax__job>");} dax__job_namespace_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_namespace);
2222 /* rule 50 can match eol */
2224 if (dax__job_namespace_isset != 0) {FAIL("Multiple definition of attribute namespace in <dax__job>");} dax__job_namespace_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_namespace);
2227 /* rule 51 can match eol */
2229 if (dax__job_name_isset != 0) {FAIL("Multiple definition of attribute name in <dax__job>");} dax__job_name_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_name);
2232 /* rule 52 can match eol */
2234 if (dax__job_name_isset != 0) {FAIL("Multiple definition of attribute name in <dax__job>");} dax__job_name_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_name);
2237 /* rule 53 can match eol */
2239 if (dax__job_version_isset != 0) {FAIL("Multiple definition of attribute version in <dax__job>");} dax__job_version_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_version);
2242 /* rule 54 can match eol */
2244 if (dax__job_version_isset != 0) {FAIL("Multiple definition of attribute version in <dax__job>");} dax__job_version_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_version);
2247 /* rule 55 can match eol */
2249 if (dax__job_runtime_isset != 0) {FAIL("Multiple definition of attribute runtime in <dax__job>");} dax__job_runtime_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_runtime);
2252 /* rule 56 can match eol */
2254 if (dax__job_runtime_isset != 0) {FAIL("Multiple definition of attribute runtime in <dax__job>");} dax__job_runtime_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_runtime);
2257 /* rule 57 can match eol */
2259 if (dax__job_level_isset != 0) {FAIL("Multiple definition of attribute level in <dax__job>");} dax__job_level_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__job_level);
2262 /* rule 58 can match eol */
2264 if (dax__job_level_isset != 0) {FAIL("Multiple definition of attribute level in <dax__job>");} dax__job_level_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__job_level);
2269 if (!AX_dax__job_id) FAIL("Required attribute `id' not set for `job' element.");
2270 if (!AX_dax__job_name) FAIL("Required attribute `name' not set for `job' element.");
2271 if (!AX_dax__job_runtime) FAIL("Required attribute `runtime' not set for `job' element.");
2272 LEAVE; STag_dax__job();dax__pcdata_ix = 0; ENTER(S_dax__job);
2278 if (!AX_dax__job_id) FAIL("Required attribute `id' not set for `job' element.");
2279 if (!AX_dax__job_name) FAIL("Required attribute `name' not set for `job' element.");
2280 if (!AX_dax__job_runtime) FAIL("Required attribute `runtime' not set for `job' element.");
2281 LEAVE; STag_dax__job(); dax__pcdata_ix = 0; ETag_dax__job(); popbuffer(); /* attribute */
2283 case S_dax__adag_2: case S_dax__adag_3: case S_dax__adag: SET(S_dax__adag_3); break;
2289 FAIL("Unexpected character `%c' in attribute list of job element.", dax_text[0]);
2293 FAIL("Bad attribute `%s' in `job' element start tag.",dax_text);
2295 case YY_STATE_EOF(AL_dax__job):
2296 FAIL("EOF in attribute list of `job' element.");
2300 /* rule 63 can match eol */
2305 popbuffer(); /* attribute */
2307 case S_dax__adag_2: case S_dax__adag_3: case S_dax__adag: SET(S_dax__adag_3); break;
2312 /* rule 64 can match eol */
2314 FAIL("Unexpected end-tag `%s': `</job>' expected.",dax_text);
2318 FAIL("Unexpected character `%c': `</job>' expected.",dax_text[0]);
2320 case YY_STATE_EOF(S_dax__job):
2321 case YY_STATE_EOF(E_dax__job):
2322 case YY_STATE_EOF(S_dax__job_2):
2323 FAIL("Premature EOF: `</job>' expected.");
2327 * <!-- ignored --> */
2329 /* rule 66 can match eol */
2331 FAIL("Starting tag <uses> is not allowed here.");
2334 /* rule 67 can match eol */
2337 AX_dax__uses_file = 0;
2338 dax__uses_file_isset = 0;
2339 AX_dax__uses_link = AU_dax__uses_link;
2340 dax__uses_link_isset = 0;
2341 AX_dax__uses_register = A_dax__uses_register_true;
2342 dax__uses_register_isset = 0;
2343 AX_dax__uses_transfer = A_dax__uses_transfer_true;
2344 dax__uses_transfer_isset = 0;
2345 AX_dax__uses_optional = A_dax__uses_optional_false;
2346 dax__uses_optional_isset = 0;
2347 AX_dax__uses_type = 161;
2348 dax__uses_type_isset = 0;
2349 AX_dax__uses_size = 0;
2350 dax__uses_size_isset = 0;
2351 ENTER(AL_dax__uses); pushbuffer(0);
2356 /* rule 68 can match eol */
2358 if (dax__uses_file_isset != 0) {FAIL("Multiple definition of attribute file in <dax__uses>");} dax__uses_file_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__uses_file);
2361 /* rule 69 can match eol */
2363 if (dax__uses_file_isset != 0) {FAIL("Multiple definition of attribute file in <dax__uses>");} dax__uses_file_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__uses_file);
2366 /* rule 70 can match eol */
2368 /* rule 71 can match eol */
2370 A_dax__uses_link = A_dax__uses_link_input;
2373 /* rule 72 can match eol */
2375 /* rule 73 can match eol */
2377 A_dax__uses_link = A_dax__uses_link_output;
2380 /* rule 74 can match eol */
2382 /* rule 75 can match eol */
2384 A_dax__uses_register = A_dax__uses_register_false;
2387 /* rule 76 can match eol */
2389 /* rule 77 can match eol */
2391 A_dax__uses_register = A_dax__uses_register_true;
2394 /* rule 78 can match eol */
2396 /* rule 79 can match eol */
2398 A_dax__uses_transfer = A_dax__uses_transfer_false;
2401 /* rule 80 can match eol */
2403 /* rule 81 can match eol */
2405 A_dax__uses_transfer = A_dax__uses_transfer_true;
2408 /* rule 82 can match eol */
2410 /* rule 83 can match eol */
2412 A_dax__uses_optional = A_dax__uses_optional_false;
2415 /* rule 84 can match eol */
2417 /* rule 85 can match eol */
2419 A_dax__uses_optional = A_dax__uses_optional_true;
2422 /* rule 86 can match eol */
2424 if (dax__uses_type_isset != 0) {FAIL("Multiple definition of attribute type in <dax__uses>");} dax__uses_type_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__uses_type);
2427 /* rule 87 can match eol */
2429 if (dax__uses_type_isset != 0) {FAIL("Multiple definition of attribute type in <dax__uses>");} dax__uses_type_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__uses_type);
2432 /* rule 88 can match eol */
2434 if (dax__uses_size_isset != 0) {FAIL("Multiple definition of attribute size in <dax__uses>");} dax__uses_size_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__uses_size);
2437 /* rule 89 can match eol */
2439 if (dax__uses_size_isset != 0) {FAIL("Multiple definition of attribute size in <dax__uses>");} dax__uses_size_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__uses_size);
2444 if (!AX_dax__uses_file) FAIL("Required attribute `file' not set for `uses' element.");
2445 if (!AX_dax__uses_size) FAIL("Required attribute `size' not set for `uses' element.");
2446 LEAVE; STag_dax__uses();dax__pcdata_ix = 0; ENTER(E_dax__uses);
2452 if (!AX_dax__uses_file) FAIL("Required attribute `file' not set for `uses' element.");
2453 if (!AX_dax__uses_size) FAIL("Required attribute `size' not set for `uses' element.");
2454 LEAVE; STag_dax__uses(); dax__pcdata_ix = 0; ETag_dax__uses(); popbuffer(); /* attribute */
2456 case S_dax__job: case S_dax__job_2: case S_dax__job_1: SET(S_dax__job_2); break;
2462 FAIL("Unexpected character `%c' in attribute list of uses element.", dax_text[0]);
2466 FAIL("Bad attribute `%s' in `uses' element start tag.",dax_text);
2468 case YY_STATE_EOF(AL_dax__uses):
2469 FAIL("EOF in attribute list of `uses' element.");
2473 /* rule 94 can match eol */
2478 popbuffer(); /* attribute */
2480 case S_dax__job: case S_dax__job_2: case S_dax__job_1: SET(S_dax__job_2); break;
2485 /* rule 95 can match eol */
2487 FAIL("Unexpected end-tag `%s': `</uses>' expected.",dax_text);
2491 FAIL("Unexpected character `%c': `</uses>' expected.",dax_text[0]);
2493 case YY_STATE_EOF(E_dax__uses):
2494 FAIL("Premature EOF: `</uses>' expected.");
2498 /* rule 97 can match eol */
2500 FAIL("Starting tag <child> is not allowed here.");
2503 /* rule 98 can match eol */
2506 AX_dax__child_ref = 0;
2507 dax__child_ref_isset = 0;
2508 ENTER(AL_dax__child); pushbuffer(0);
2513 /* rule 99 can match eol */
2515 if (dax__child_ref_isset != 0) {FAIL("Multiple definition of attribute ref in <dax__child>");} dax__child_ref_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__child_ref);
2518 /* rule 100 can match eol */
2520 if (dax__child_ref_isset != 0) {FAIL("Multiple definition of attribute ref in <dax__child>");} dax__child_ref_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__child_ref);
2525 if (!AX_dax__child_ref) FAIL("Required attribute `ref' not set for `child' element.");
2526 LEAVE; STag_dax__child();dax__pcdata_ix = 0; ENTER(S_dax__child);
2532 if (!AX_dax__child_ref) FAIL("Required attribute `ref' not set for `child' element.");
2533 LEAVE; STag_dax__child(); dax__pcdata_ix = 0; ETag_dax__child(); popbuffer(); /* attribute */
2535 case S_dax__adag_1: case S_dax__adag_4: case S_dax__adag_5: case S_dax__adag_3: case S_dax__adag: SET(S_dax__adag_5); break;
2541 FAIL("Unexpected character `%c' in attribute list of child element.", dax_text[0]);
2545 FAIL("Bad attribute `%s' in `child' element start tag.",dax_text);
2547 case YY_STATE_EOF(AL_dax__child):
2548 FAIL("EOF in attribute list of `child' element.");
2552 /* rule 105 can match eol */
2557 popbuffer(); /* attribute */
2559 case S_dax__adag_1: case S_dax__adag_4: case S_dax__adag_5: case S_dax__adag_3: case S_dax__adag: SET(S_dax__adag_5); break;
2564 /* rule 106 can match eol */
2566 FAIL("Unexpected end-tag `%s': `</child>' expected.",dax_text);
2570 FAIL("Unexpected character `%c': `</child>' expected.",dax_text[0]);
2572 case YY_STATE_EOF(S_dax__child_2):
2573 case YY_STATE_EOF(E_dax__child):
2574 case YY_STATE_EOF(S_dax__child):
2575 FAIL("Premature EOF: `</child>' expected.");
2579 /* rule 108 can match eol */
2581 FAIL("Starting tag <parent> is not allowed here.");
2584 /* rule 109 can match eol */
2587 AX_dax__parent_ref = 0;
2588 dax__parent_ref_isset = 0;
2589 ENTER(AL_dax__parent); pushbuffer(0);
2594 /* rule 110 can match eol */
2596 if (dax__parent_ref_isset != 0) {FAIL("Multiple definition of attribute ref in <dax__parent>");} dax__parent_ref_isset = 1; ENTER(VALUE1); BUFFERSET(AX_dax__parent_ref);
2599 /* rule 111 can match eol */
2601 if (dax__parent_ref_isset != 0) {FAIL("Multiple definition of attribute ref in <dax__parent>");} dax__parent_ref_isset = 1; ENTER(VALUE2); BUFFERSET(AX_dax__parent_ref);
2606 if (!AX_dax__parent_ref) FAIL("Required attribute `ref' not set for `parent' element.");
2607 LEAVE; STag_dax__parent();dax__pcdata_ix = 0; ENTER(E_dax__parent);
2613 if (!AX_dax__parent_ref) FAIL("Required attribute `ref' not set for `parent' element.");
2614 LEAVE; STag_dax__parent(); dax__pcdata_ix = 0; ETag_dax__parent(); popbuffer(); /* attribute */
2616 case S_dax__child_2: case S_dax__child: case S_dax__child_1: SET(S_dax__child_2); break;
2622 FAIL("Unexpected character `%c' in attribute list of parent element.", dax_text[0]);
2626 FAIL("Bad attribute `%s' in `parent' element start tag.",dax_text);
2628 case YY_STATE_EOF(AL_dax__parent):
2629 FAIL("EOF in attribute list of `parent' element.");
2633 /* rule 116 can match eol */
2638 popbuffer(); /* attribute */
2640 case S_dax__child_2: case S_dax__child: case S_dax__child_1: SET(S_dax__child_2); break;
2645 /* rule 117 can match eol */
2647 FAIL("Unexpected end-tag `%s': `</parent>' expected.",dax_text);
2651 FAIL("Unexpected character `%c': `</parent>' expected.",dax_text[0]);
2653 case YY_STATE_EOF(E_dax__parent):
2654 FAIL("Premature EOF: `</parent>' expected.");
2657 /* EPILOG: after the root element. */
2661 {SET(PROLOG); yyless(0); CLEANUP; return -1;}
2663 case YY_STATE_EOF(EPILOG):
2667 /* CHARACTER DATA. */
2669 /* Non-defined standard entities... */
2690 /* Character entities. */
2693 BUFFERPUTC((unsigned char)atoi(dax_text+2));
2697 BUFFERPUTC((unsigned char)strtol(dax_text+3,NULL,16));
2701 /* rule 127 can match eol */
2703 /* rule 128 can match eol */
2705 /* rule 129 can match eol */
2707 /* rule 130 can match eol */
2718 FAIL("Unexpected `]""]>' in character data.");
2725 case YY_STATE_EOF(VALUE1):
2726 FAIL("EOF in literal (\"'\" expected).");
2733 case YY_STATE_EOF(VALUE2):
2734 FAIL("EOF in literal (`\"' expected).");
2738 /* rule 135 can match eol */
2740 BUFFERPUTC(dax_text[0]);
2744 FAIL("Spurious `%c' in character data.",dax_text[0]);
2751 /* "]""]" BUFFERPUTC(dax_text[0]); BUFFERPUTC(dax_text[1]); */
2754 BUFFERPUTC(dax_text[0]);
2756 case YY_STATE_EOF(CDATA):
2757 FAIL("EOF in CDATA section.");
2760 /* Impossible rules to avoid warnings from flex(1). */
2761 /* Ideally, this should be replaced by code in flexml.pl that
2762 generates just the states not covered by other rules. */
2765 /* rule 139 can match eol */
2767 FAIL("Syntax error on character `%c'.", dax_text[0]);
2774 case YY_STATE_EOF(INITIAL):
2775 case YY_STATE_EOF(ROOT_dax__adag):
2776 case YY_STATE_EOF(S_dax__adag_2):
2777 case YY_STATE_EOF(S_dax__adag_4):
2778 case YY_STATE_EOF(S_dax__job_1):
2779 case YY_STATE_EOF(S_dax__child_1):
2780 case YY_STATE_EOF(IMPOSSIBLE):
2783 case YY_END_OF_BUFFER:
2785 /* Amount of text matched not including the EOB char. */
2786 int yy_amount_of_matched_text = (int) (yy_cp - (yytext_ptr)) - 1;
2788 /* Undo the effects of YY_DO_BEFORE_ACTION. */
2789 *yy_cp = (yy_hold_char);
2790 YY_RESTORE_YY_MORE_OFFSET
2792 if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_NEW )
2794 /* We're scanning a new file or input source. It's
2795 * possible that this happened because the user
2796 * just pointed dax_in at a new source and called
2797 * dax_lex(). If so, then we have to assure
2798 * consistency between YY_CURRENT_BUFFER and our
2799 * globals. Here is the right place to do so, because
2800 * this is the first action (other than possibly a
2801 * back-up) that will match for the new input source.
2803 (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
2804 YY_CURRENT_BUFFER_LVALUE->yy_input_file = dax_in;
2805 YY_CURRENT_BUFFER_LVALUE->yy_buffer_status = YY_BUFFER_NORMAL;
2808 /* Note that here we test for yy_c_buf_p "<=" to the position
2809 * of the first EOB in the buffer, since yy_c_buf_p will
2810 * already have been incremented past the NUL character
2811 * (since all states make transitions on EOB to the
2812 * end-of-buffer state). Contrast this with the test
2815 if ( (yy_c_buf_p) <= &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
2816 { /* This was really a NUL. */
2817 yy_state_type yy_next_state;
2819 (yy_c_buf_p) = (yytext_ptr) + yy_amount_of_matched_text;
2821 yy_current_state = yy_get_previous_state( );
2823 /* Okay, we're now positioned to make the NUL
2824 * transition. We couldn't have
2825 * yy_get_previous_state() go ahead and do it
2826 * for us because it doesn't know how to deal
2827 * with the possibility of jamming (and we don't
2828 * want to build jamming into it because then it
2829 * will run more slowly).
2832 yy_next_state = yy_try_NUL_trans( yy_current_state );
2834 yy_bp = (yytext_ptr) + YY_MORE_ADJ;
2836 if ( yy_next_state )
2838 /* Consume the NUL. */
2839 yy_cp = ++(yy_c_buf_p);
2840 yy_current_state = yy_next_state;
2846 yy_cp = (yy_c_buf_p);
2847 goto yy_find_action;
2851 else switch ( yy_get_next_buffer( ) )
2853 case EOB_ACT_END_OF_FILE:
2855 (yy_did_buffer_switch_on_eof) = 0;
2859 /* Note: because we've taken care in
2860 * yy_get_next_buffer() to have set up
2861 * dax_text, we can now set up
2862 * yy_c_buf_p so that if some total
2863 * hoser (like flex itself) wants to
2864 * call the scanner after we return the
2865 * YY_NULL, it'll still work - another
2866 * YY_NULL will get returned.
2868 (yy_c_buf_p) = (yytext_ptr) + YY_MORE_ADJ;
2870 yy_act = YY_STATE_EOF(YY_START);
2876 if ( ! (yy_did_buffer_switch_on_eof) )
2882 case EOB_ACT_CONTINUE_SCAN:
2884 (yytext_ptr) + yy_amount_of_matched_text;
2886 yy_current_state = yy_get_previous_state( );
2888 yy_cp = (yy_c_buf_p);
2889 yy_bp = (yytext_ptr) + YY_MORE_ADJ;
2892 case EOB_ACT_LAST_MATCH:
2894 &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)];
2896 yy_current_state = yy_get_previous_state( );
2898 yy_cp = (yy_c_buf_p);
2899 yy_bp = (yytext_ptr) + YY_MORE_ADJ;
2900 goto yy_find_action;
2907 "fatal flex scanner internal error--no action found" );
2908 } /* end of action switch */
2909 } /* end of scanning one token */
2910 } /* end of dax_lex */
2912 /* yy_get_next_buffer - try to read in a new buffer
2914 * Returns a code representing an action:
2915 * EOB_ACT_LAST_MATCH -
2916 * EOB_ACT_CONTINUE_SCAN - continue scanning from current position
2917 * EOB_ACT_END_OF_FILE - end of file
2919 static int yy_get_next_buffer (void)
2921 register char *dest = YY_CURRENT_BUFFER_LVALUE->yy_ch_buf;
2922 register char *source = (yytext_ptr);
2923 register int number_to_move, i;
2926 if ( (yy_c_buf_p) > &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] )
2928 "fatal flex scanner internal error--end of buffer missed" );
2930 if ( YY_CURRENT_BUFFER_LVALUE->yy_fill_buffer == 0 )
2931 { /* Don't try to fill the buffer, so this is an EOF. */
2932 if ( (yy_c_buf_p) - (yytext_ptr) - YY_MORE_ADJ == 1 )
2934 /* We matched a single character, the EOB, so
2935 * treat this as a final EOF.
2937 return EOB_ACT_END_OF_FILE;
2942 /* We matched some text prior to the EOB, first
2945 return EOB_ACT_LAST_MATCH;
2949 /* Try to read more data. */
2951 /* First move last chars to start of buffer. */
2952 number_to_move = (int) ((yy_c_buf_p) - (yytext_ptr)) - 1;
2954 for ( i = 0; i < number_to_move; ++i )
2955 *(dest++) = *(source++);
2957 if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_EOF_PENDING )
2958 /* don't do the read, it's not guaranteed to return an EOF,
2961 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars) = 0;
2966 YY_CURRENT_BUFFER_LVALUE->yy_buf_size - number_to_move - 1;
2968 while ( num_to_read <= 0 )
2969 { /* Not enough room in the buffer - grow it. */
2971 /* just a shorter name for the current buffer */
2972 YY_BUFFER_STATE b = YY_CURRENT_BUFFER;
2974 int yy_c_buf_p_offset =
2975 (int) ((yy_c_buf_p) - b->yy_ch_buf);
2977 if ( b->yy_is_our_buffer )
2979 int new_size = b->yy_buf_size * 2;
2981 if ( new_size <= 0 )
2982 b->yy_buf_size += b->yy_buf_size / 8;
2984 b->yy_buf_size *= 2;
2986 b->yy_ch_buf = (char *)
2987 /* Include room in for 2 EOB chars. */
2988 dax_realloc((void *) b->yy_ch_buf,b->yy_buf_size + 2 );
2991 /* Can't grow it, we don't own it. */
2994 if ( ! b->yy_ch_buf )
2996 "fatal error - scanner input buffer overflow" );
2998 (yy_c_buf_p) = &b->yy_ch_buf[yy_c_buf_p_offset];
3000 num_to_read = YY_CURRENT_BUFFER_LVALUE->yy_buf_size -
3005 if ( num_to_read > YY_READ_BUF_SIZE )
3006 num_to_read = YY_READ_BUF_SIZE;
3008 /* Read in more data. */
3009 YY_INPUT( (&YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[number_to_move]),
3010 (yy_n_chars), (size_t) num_to_read );
3012 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
3015 if ( (yy_n_chars) == 0 )
3017 if ( number_to_move == YY_MORE_ADJ )
3019 ret_val = EOB_ACT_END_OF_FILE;
3020 dax_restart(dax_in );
3025 ret_val = EOB_ACT_LAST_MATCH;
3026 YY_CURRENT_BUFFER_LVALUE->yy_buffer_status =
3027 YY_BUFFER_EOF_PENDING;
3032 ret_val = EOB_ACT_CONTINUE_SCAN;
3034 if ((yy_size_t) ((yy_n_chars) + number_to_move) > YY_CURRENT_BUFFER_LVALUE->yy_buf_size) {
3035 /* Extend the array by 50%, plus the number we really need. */
3036 yy_size_t new_size = (yy_n_chars) + number_to_move + ((yy_n_chars) >> 1);
3037 YY_CURRENT_BUFFER_LVALUE->yy_ch_buf = (char *) dax_realloc((void *) YY_CURRENT_BUFFER_LVALUE->yy_ch_buf,new_size );
3038 if ( ! YY_CURRENT_BUFFER_LVALUE->yy_ch_buf )
3039 YY_FATAL_ERROR( "out of dynamic memory in yy_get_next_buffer()" );
3042 (yy_n_chars) += number_to_move;
3043 YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] = YY_END_OF_BUFFER_CHAR;
3044 YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] = YY_END_OF_BUFFER_CHAR;
3046 (yytext_ptr) = &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[0];
3051 /* yy_get_previous_state - get the state just before the EOB char was reached */
3053 static yy_state_type yy_get_previous_state (void)
3055 register yy_state_type yy_current_state;
3056 register char *yy_cp;
3058 yy_current_state = (yy_start);
3060 for ( yy_cp = (yytext_ptr) + YY_MORE_ADJ; yy_cp < (yy_c_buf_p); ++yy_cp )
3062 register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1);
3063 if ( yy_accept[yy_current_state] )
3065 (yy_last_accepting_state) = yy_current_state;
3066 (yy_last_accepting_cpos) = yy_cp;
3068 while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
3070 yy_current_state = (int) yy_def[yy_current_state];
3071 if ( yy_current_state >= 775 )
3072 yy_c = yy_meta[(unsigned int) yy_c];
3074 yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
3077 return yy_current_state;
3080 /* yy_try_NUL_trans - try to make a transition on the NUL character
3083 * next_state = yy_try_NUL_trans( current_state );
3085 static yy_state_type yy_try_NUL_trans (yy_state_type yy_current_state )
3087 register int yy_is_jam;
3088 register char *yy_cp = (yy_c_buf_p);
3090 register YY_CHAR yy_c = 1;
3091 if ( yy_accept[yy_current_state] )
3093 (yy_last_accepting_state) = yy_current_state;
3094 (yy_last_accepting_cpos) = yy_cp;
3096 while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
3098 yy_current_state = (int) yy_def[yy_current_state];
3099 if ( yy_current_state >= 775 )
3100 yy_c = yy_meta[(unsigned int) yy_c];
3102 yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
3103 yy_is_jam = (yy_current_state == 774);
3105 return yy_is_jam ? 0 : yy_current_state;
3110 static int yyinput (void)
3112 static int input (void)
3118 *(yy_c_buf_p) = (yy_hold_char);
3120 if ( *(yy_c_buf_p) == YY_END_OF_BUFFER_CHAR )
3122 /* yy_c_buf_p now points to the character we want to return.
3123 * If this occurs *before* the EOB characters, then it's a
3124 * valid NUL; if not, then we've hit the end of the buffer.
3126 if ( (yy_c_buf_p) < &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] )
3127 /* This was really a NUL. */
3128 *(yy_c_buf_p) = '\0';
3131 { /* need more input */
3132 int offset = (yy_c_buf_p) - (yytext_ptr);
3135 switch ( yy_get_next_buffer( ) )
3137 case EOB_ACT_LAST_MATCH:
3138 /* This happens because yy_g_n_b()
3139 * sees that we've accumulated a
3140 * token and flags that we need to
3141 * try matching the token before
3142 * proceeding. But for input(),
3143 * there's no matching to consider.
3144 * So convert the EOB_ACT_LAST_MATCH
3145 * to EOB_ACT_END_OF_FILE.
3148 /* Reset buffer status. */
3149 dax_restart(dax_in );
3153 case EOB_ACT_END_OF_FILE:
3158 if ( ! (yy_did_buffer_switch_on_eof) )
3167 case EOB_ACT_CONTINUE_SCAN:
3168 (yy_c_buf_p) = (yytext_ptr) + offset;
3174 c = *(unsigned char *) (yy_c_buf_p); /* cast for 8-bit char's */
3175 *(yy_c_buf_p) = '\0'; /* preserve dax_text */
3176 (yy_hold_char) = *++(yy_c_buf_p);
3185 #endif /* ifndef YY_NO_INPUT */
3187 /** Immediately switch to a different input stream.
3188 * @param input_file A readable stream.
3190 * @note This function does not reset the start condition to @c INITIAL .
3192 void dax_restart (FILE * input_file )
3195 if ( ! YY_CURRENT_BUFFER ){
3196 dax_ensure_buffer_stack ();
3197 YY_CURRENT_BUFFER_LVALUE =
3198 dax__create_buffer(dax_in,YY_BUF_SIZE );
3201 dax__init_buffer(YY_CURRENT_BUFFER,input_file );
3202 dax__load_buffer_state( );
3205 /** Switch to a different input buffer.
3206 * @param new_buffer The new input buffer.
3209 void dax__switch_to_buffer (YY_BUFFER_STATE new_buffer )
3212 /* TODO. We should be able to replace this entire function body
3214 * dax_pop_buffer_state();
3215 * dax_push_buffer_state(new_buffer);
3217 dax_ensure_buffer_stack ();
3218 if ( YY_CURRENT_BUFFER == new_buffer )
3221 if ( YY_CURRENT_BUFFER )
3223 /* Flush out information for old buffer. */
3224 *(yy_c_buf_p) = (yy_hold_char);
3225 YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
3226 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
3229 YY_CURRENT_BUFFER_LVALUE = new_buffer;
3230 dax__load_buffer_state( );
3232 /* We don't actually know whether we did this switch during
3233 * EOF (dax_wrap()) processing, but the only time this flag
3234 * is looked at is after dax_wrap() is called, so it's safe
3235 * to go ahead and always set it.
3237 (yy_did_buffer_switch_on_eof) = 1;
3240 static void dax__load_buffer_state (void)
3242 (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars;
3243 (yytext_ptr) = (yy_c_buf_p) = YY_CURRENT_BUFFER_LVALUE->yy_buf_pos;
3244 dax_in = YY_CURRENT_BUFFER_LVALUE->yy_input_file;
3245 (yy_hold_char) = *(yy_c_buf_p);
3248 /** Allocate and initialize an input buffer state.
3249 * @param file A readable stream.
3250 * @param size The character buffer size in bytes. When in doubt, use @c YY_BUF_SIZE.
3252 * @return the allocated buffer state.
3254 YY_BUFFER_STATE dax__create_buffer (FILE * file, int size )
3258 b = (YY_BUFFER_STATE) dax_alloc(sizeof( struct yy_buffer_state ) );
3260 YY_FATAL_ERROR( "out of dynamic memory in dax__create_buffer()" );
3262 b->yy_buf_size = size;
3264 /* yy_ch_buf has to be 2 characters longer than the size given because
3265 * we need to put in 2 end-of-buffer characters.
3267 b->yy_ch_buf = (char *) dax_alloc(b->yy_buf_size + 2 );
3268 if ( ! b->yy_ch_buf )
3269 YY_FATAL_ERROR( "out of dynamic memory in dax__create_buffer()" );
3271 b->yy_is_our_buffer = 1;
3273 dax__init_buffer(b,file );
3278 /** Destroy the buffer.
3279 * @param b a buffer created with dax__create_buffer()
3282 void dax__delete_buffer (YY_BUFFER_STATE b )
3288 if ( b == YY_CURRENT_BUFFER ) /* Not sure if we should pop here. */
3289 YY_CURRENT_BUFFER_LVALUE = (YY_BUFFER_STATE) 0;
3291 if ( b->yy_is_our_buffer )
3292 dax_free((void *) b->yy_ch_buf );
3294 dax_free((void *) b );
3298 extern int isatty (int );
3299 #endif /* __cplusplus */
3301 /* Initializes or reinitializes a buffer.
3302 * This function is sometimes called more than once on the same buffer,
3303 * such as during a dax_restart() or at EOF.
3305 static void dax__init_buffer (YY_BUFFER_STATE b, FILE * file )
3310 dax__flush_buffer(b );
3312 b->yy_input_file = file;
3313 b->yy_fill_buffer = 1;
3315 /* If b is the current buffer, then dax__init_buffer was _probably_
3316 * called from dax_restart() or through yy_get_next_buffer.
3317 * In that case, we don't want to reset the lineno or column.
3319 if (b != YY_CURRENT_BUFFER){
3320 b->yy_bs_lineno = 1;
3321 b->yy_bs_column = 0;
3324 b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0;
3329 /** Discard all buffered characters. On the next scan, YY_INPUT will be called.
3330 * @param b the buffer state to be flushed, usually @c YY_CURRENT_BUFFER.
3333 void dax__flush_buffer (YY_BUFFER_STATE b )
3340 /* We always need two end-of-buffer characters. The first causes
3341 * a transition to the end-of-buffer state. The second causes
3342 * a jam in that state.
3344 b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR;
3345 b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR;
3347 b->yy_buf_pos = &b->yy_ch_buf[0];
3350 b->yy_buffer_status = YY_BUFFER_NEW;
3352 if ( b == YY_CURRENT_BUFFER )
3353 dax__load_buffer_state( );
3356 /** Pushes the new state onto the stack. The new state becomes
3357 * the current state. This function will allocate the stack
3359 * @param new_buffer The new state.
3362 void dax_push_buffer_state (YY_BUFFER_STATE new_buffer )
3364 if (new_buffer == NULL)
3367 dax_ensure_buffer_stack();
3369 /* This block is copied from dax__switch_to_buffer. */
3370 if ( YY_CURRENT_BUFFER )
3372 /* Flush out information for old buffer. */
3373 *(yy_c_buf_p) = (yy_hold_char);
3374 YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p);
3375 YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars);
3378 /* Only push if top exists. Otherwise, replace top. */
3379 if (YY_CURRENT_BUFFER)
3380 (yy_buffer_stack_top)++;
3381 YY_CURRENT_BUFFER_LVALUE = new_buffer;
3383 /* copied from dax__switch_to_buffer. */
3384 dax__load_buffer_state( );
3385 (yy_did_buffer_switch_on_eof) = 1;
3388 /** Removes and deletes the top of the stack, if present.
3389 * The next element becomes the new top.
3392 void dax_pop_buffer_state (void)
3394 if (!YY_CURRENT_BUFFER)
3397 dax__delete_buffer(YY_CURRENT_BUFFER );
3398 YY_CURRENT_BUFFER_LVALUE = NULL;
3399 if ((yy_buffer_stack_top) > 0)
3400 --(yy_buffer_stack_top);
3402 if (YY_CURRENT_BUFFER) {
3403 dax__load_buffer_state( );
3404 (yy_did_buffer_switch_on_eof) = 1;
3408 /* Allocates the stack if it does not exist.
3409 * Guarantees space for at least one push.
3411 static void dax_ensure_buffer_stack (void)
3415 if (!(yy_buffer_stack)) {
3417 /* First allocation is just for 2 elements, since we don't know if this
3418 * scanner will even need a stack. We use 2 instead of 1 to avoid an
3419 * immediate realloc on the next call.
3422 (yy_buffer_stack) = (struct yy_buffer_state**)dax_alloc
3423 (num_to_alloc * sizeof(struct yy_buffer_state*)
3425 if ( ! (yy_buffer_stack) )
3426 YY_FATAL_ERROR( "out of dynamic memory in dax_ensure_buffer_stack()" );
3428 memset((yy_buffer_stack), 0, num_to_alloc * sizeof(struct yy_buffer_state*));
3430 (yy_buffer_stack_max) = num_to_alloc;
3431 (yy_buffer_stack_top) = 0;
3435 if ((yy_buffer_stack_top) >= ((yy_buffer_stack_max)) - 1){
3437 /* Increase the buffer to prepare for a possible push. */
3438 int grow_size = 8 /* arbitrary grow size */;
3440 num_to_alloc = (yy_buffer_stack_max) + grow_size;
3441 (yy_buffer_stack) = (struct yy_buffer_state**)dax_realloc
3443 num_to_alloc * sizeof(struct yy_buffer_state*)
3445 if ( ! (yy_buffer_stack) )
3446 YY_FATAL_ERROR( "out of dynamic memory in dax_ensure_buffer_stack()" );
3448 /* zero only the new slots.*/
3449 memset((yy_buffer_stack) + (yy_buffer_stack_max), 0, grow_size * sizeof(struct yy_buffer_state*));
3450 (yy_buffer_stack_max) = num_to_alloc;
3454 /** Setup the input buffer state to scan directly from a user-specified character buffer.
3455 * @param base the character buffer
3456 * @param size the size in bytes of the character buffer
3458 * @return the newly allocated buffer state object.
3460 YY_BUFFER_STATE dax__scan_buffer (char * base, yy_size_t size )
3465 base[size-2] != YY_END_OF_BUFFER_CHAR ||
3466 base[size-1] != YY_END_OF_BUFFER_CHAR )
3467 /* They forgot to leave room for the EOB's. */
3470 b = (YY_BUFFER_STATE) dax_alloc(sizeof( struct yy_buffer_state ) );
3472 YY_FATAL_ERROR( "out of dynamic memory in dax__scan_buffer()" );
3474 b->yy_buf_size = size - 2; /* "- 2" to take care of EOB's */
3475 b->yy_buf_pos = b->yy_ch_buf = base;
3476 b->yy_is_our_buffer = 0;
3477 b->yy_input_file = 0;
3478 b->yy_n_chars = b->yy_buf_size;
3479 b->yy_is_interactive = 0;
3481 b->yy_fill_buffer = 0;
3482 b->yy_buffer_status = YY_BUFFER_NEW;
3484 dax__switch_to_buffer(b );
3489 /** Setup the input buffer state to scan a string. The next call to dax_lex() will
3490 * scan from a @e copy of @a str.
3491 * @param yystr a NUL-terminated string to scan
3493 * @return the newly allocated buffer state object.
3494 * @note If you want to scan bytes that may contain NUL values, then use
3495 * dax__scan_bytes() instead.
3497 YY_BUFFER_STATE dax__scan_string (yyconst char * yystr )
3500 return dax__scan_bytes(yystr,strlen(yystr) );
3503 /** Setup the input buffer state to scan the given bytes. The next call to dax_lex() will
3504 * scan from a @e copy of @a bytes.
3505 * @param yybytes the byte buffer to scan
3506 * @param _yybytes_len the number of bytes in the buffer pointed to by @a bytes.
3508 * @return the newly allocated buffer state object.
3510 YY_BUFFER_STATE dax__scan_bytes (yyconst char * yybytes, int _yybytes_len )
3517 /* Get memory for full buffer, including space for trailing EOB's. */
3518 n = _yybytes_len + 2;
3519 buf = (char *) dax_alloc(n );
3521 YY_FATAL_ERROR( "out of dynamic memory in dax__scan_bytes()" );
3523 for ( i = 0; i < _yybytes_len; ++i )
3524 buf[i] = yybytes[i];
3526 buf[_yybytes_len] = buf[_yybytes_len+1] = YY_END_OF_BUFFER_CHAR;
3528 b = dax__scan_buffer(buf,n );
3530 YY_FATAL_ERROR( "bad buffer in dax__scan_bytes()" );
3532 /* It's okay to grow etc. this buffer, and we should throw it
3533 * away when we're done.
3535 b->yy_is_our_buffer = 1;
3540 static void yy_push_state (int new_state )
3542 if ( (yy_start_stack_ptr) >= (yy_start_stack_depth) )
3546 (yy_start_stack_depth) += YY_START_STACK_INCR;
3547 new_size = (yy_start_stack_depth) * sizeof( int );
3549 if ( ! (yy_start_stack) )
3550 (yy_start_stack) = (int *) dax_alloc(new_size );
3553 (yy_start_stack) = (int *) dax_realloc((void *) (yy_start_stack),new_size );
3555 if ( ! (yy_start_stack) )
3556 YY_FATAL_ERROR( "out of memory expanding start-condition stack" );
3559 (yy_start_stack)[(yy_start_stack_ptr)++] = YY_START;
3564 static void yy_pop_state (void)
3566 if ( --(yy_start_stack_ptr) < 0 )
3567 YY_FATAL_ERROR( "start-condition stack underflow" );
3569 BEGIN((yy_start_stack)[(yy_start_stack_ptr)]);
3572 #ifndef YY_EXIT_FAILURE
3573 #define YY_EXIT_FAILURE 2
3576 static void yy_fatal_error (yyconst char* msg )
3578 (void) fprintf( stderr, "%s\n", msg );
3579 exit( YY_EXIT_FAILURE );
3582 /* Redefine yyless() so it works in section 3 code. */
3588 /* Undo effects of setting up dax_text. */ \
3589 int yyless_macro_arg = (n); \
3590 YY_LESS_LINENO(yyless_macro_arg);\
3591 dax_text[dax_leng] = (yy_hold_char); \
3592 (yy_c_buf_p) = dax_text + yyless_macro_arg; \
3593 (yy_hold_char) = *(yy_c_buf_p); \
3594 *(yy_c_buf_p) = '\0'; \
3595 dax_leng = yyless_macro_arg; \
3599 /* Accessor methods (get/set functions) to struct members. */
3601 /** Get the current line number.
3604 int dax_get_lineno (void)
3610 /** Get the input stream.
3613 FILE *dax_get_in (void)
3618 /** Get the output stream.
3621 FILE *dax_get_out (void)
3626 /** Get the length of the current token.
3629 int dax_get_leng (void)
3634 /** Get the current token.
3638 char *dax_get_text (void)
3643 /** Set the current line number.
3644 * @param line_number
3647 void dax_set_lineno (int line_number )
3650 dax_lineno = line_number;
3653 /** Set the input stream. This does not discard the current
3655 * @param in_str A readable stream.
3657 * @see dax__switch_to_buffer
3659 void dax_set_in (FILE * in_str )
3664 void dax_set_out (FILE * out_str )
3669 int dax_get_debug (void)
3671 return dax__flex_debug;
3674 void dax_set_debug (int bdebug )
3676 dax__flex_debug = bdebug ;
3679 static int yy_init_globals (void)
3681 /* Initialization is the same as for the non-reentrant scanner.
3682 * This function is called from dax_lex_destroy(), so don't allocate here.
3685 /* We do not touch dax_lineno unless the option is enabled. */
3688 (yy_buffer_stack) = 0;
3689 (yy_buffer_stack_top) = 0;
3690 (yy_buffer_stack_max) = 0;
3691 (yy_c_buf_p) = (char *) 0;
3695 (yy_start_stack_ptr) = 0;
3696 (yy_start_stack_depth) = 0;
3697 (yy_start_stack) = NULL;
3699 /* Defined in main.c */
3704 dax_in = (FILE *) 0;
3705 dax_out = (FILE *) 0;
3708 /* For future reference: Set errno on error, since we are called by
3714 /* dax_lex_destroy is for both reentrant and non-reentrant scanners. */
3715 int dax_lex_destroy (void)
3718 /* Pop the buffer stack, destroying each element. */
3719 while(YY_CURRENT_BUFFER){
3720 dax__delete_buffer(YY_CURRENT_BUFFER );
3721 YY_CURRENT_BUFFER_LVALUE = NULL;
3722 dax_pop_buffer_state();
3725 /* Destroy the stack itself. */
3726 dax_free((yy_buffer_stack) );
3727 (yy_buffer_stack) = NULL;
3729 /* Destroy the start condition stack. */
3730 dax_free((yy_start_stack) );
3731 (yy_start_stack) = NULL;
3733 /* Reset the globals. This is important in a non-reentrant scanner so the next time
3734 * dax_lex() is called, initialization will occur. */
3741 * Internal utility routines.
3745 static void yy_flex_strncpy (char* s1, yyconst char * s2, int n )
3748 for ( i = 0; i < n; ++i )
3753 #ifdef YY_NEED_STRLEN
3754 static int yy_flex_strlen (yyconst char * s )
3757 for ( n = 0; s[n]; ++n )
3764 void *dax_alloc (yy_size_t size )
3766 return (void *) malloc( size );
3769 void *dax_realloc (void * ptr, yy_size_t size )
3771 /* The cast to (char *) in the following accommodates both
3772 * implementations that use char* generic pointers, and those
3773 * that use void* generic pointers. It works with the latter
3774 * because both ANSI C and C++ allow castless assignment from
3775 * any pointer type to void*, and deal with argument conversions
3776 * as though doing an assignment.
3778 return (void *) realloc( (char *) ptr, size );
3781 void dax_free (void * ptr )
3783 free( (char *) ptr ); /* see dax_realloc() for (char *) cast */
3786 #define YYTABLES_NAME "yytables"
3788 /* Element context stack lookup. */
3789 int dax__element_context(int i)
3791 return (0<i && i<yy_start_stack_depth
3792 ? yy_start_stack[yy_start_stack_ptr - i]
3797 void print_yy_stack(char* fmt, ...)
3799 int i = 0; va_list ap; va_start(ap, fmt);
3800 vfprintf(stderr, fmt, ap);
3801 if (dax__statenames) {
3802 for (i=1; i<yy_start_stack_ptr; i++) {
3803 fprintf(stderr, "%s/", dax__statenames[yy_start_stack[i] ]);
3805 fprintf(stderr,"%s\n", dax__statenames[YY_START]);
3810 void print_dax__bufferstack()
3813 fputs("Buffer: ", stderr);
3814 for (i = 0; i < blimit; i++) {
3815 if ( dax__bufferstack[i] == '\377' ) break;
3816 putc(dax__bufferstack[i], stderr);
3821 static void debug_enter(int state, const char* statename) {
3822 yy_push_state(state);
3823 if (dax__flex_debug) {
3824 print_yy_stack("--ENTER(%s) : ",statename);
3825 print_dax__bufferstack();
3829 static void debug_leave(void) {
3830 if (dax__flex_debug) {
3831 print_yy_stack("--LEAVE : ");
3832 print_dax__bufferstack();
3837 static void debug_set(int state, const char* statename) {
3839 if (dax__flex_debug) print_yy_stack("--SET(%s) : ",statename);
3843 static void cleanup(void)
3845 if (dax__statenames) {
3846 free(dax__statenames);
3847 dax__statenames = NULL;
3849 free(dax__bufferstack);
3850 dax__bufferstack = NULL;
3856 static int fail(const char* fmt, ...)
3858 int chars_left, used;
3859 va_list ap; va_start(ap, fmt);
3860 #ifdef FLEXML_yylineno
3861 used = sprintf(flexml_err_msg,
3862 "Invalid XML (XML input line %d, state %d): ",
3863 dax_lineno, YY_START);
3865 used = sprintf(flexml_err_msg,
3866 "Invalid XML (state %d): ",
3869 chars_left = flexml_max_err_msg_size - used - 1;
3870 vsnprintf(flexml_err_msg + used, chars_left, fmt, ap);
3873 #ifndef FLEXML_quiet_parser
3874 /* print directly to sdterr */
3875 fprintf(stderr, "%s\n", flexml_err_msg);
3876 flexml_err_msg[0] = '\0';