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