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