4.1cBSD/usr/src/new/courier/compiler/lex.yy.c

Compare this file to the similar file:
Show the results in this format:

# include "stdio.h"
# define U(x) x
# define NLSTATE yyprevious=YYNEWLINE
# define BEGIN yybgin = yysvec + 1 +
# define INITIAL 0
# define YYLERR yysvec
# define YYSTATE (yyestate-yysvec-1)
# define YYOPTIM 1
# define YYLMAX 200
# define output(c) putc(c,yyout)
# define input() (((yytchar=yysptr>yysbuf?U(*--yysptr):getc(yyin))==10?(yylineno++,yytchar):yytchar)==EOF?0:yytchar)
# define unput(c) {yytchar= (c);if(yytchar=='\n')yylineno--;*yysptr++=yytchar;}
# define yymore() (yymorfg=1)
# define ECHO fprintf(yyout, "%s",yytext)
# define REJECT { nstr = yyreject(); goto yyfussy;}
int yyleng; extern char yytext[];
int yymorfg;
extern char *yysptr, yysbuf[];
int yytchar;
FILE *yyin ={stdin}, *yyout ={stdout};
extern int yylineno;
struct yysvf { 
	struct yywork *yystoff;
	struct yysvf *yyother;
	int *yystops;};
struct yysvf *yyestate;
extern struct yysvf yysvec[], *yybgin;
# define YYNEWLINE 10
yylex(){
int nstr; extern int yyprevious;
while((nstr = yylook()) >= 0)
yyfussy: switch(nstr){
case 0:
if(yywrap()) return(0); break;
case 1:
	;
break;
case 2:
	;
break;
case 3:
	{ return (ARRAY); }
break;
case 4:
	{ return (_BEGIN); }
break;
case 5:
	{ return (BOOLEAN); }
break;
case 6:
{ return (CARDINAL); }
break;
case 7:
	{ return (CHOICE); }
break;
case 8:
	{ return (DEPENDS); }
break;
case 9:
	{ return (END); }
break;
case 10:
	{ return (ERROR); }
break;
case 11:
	{ return (INTEGER); }
break;
case 12:
	{ return (LONG); }
break;
case 13:
	{ return (OF); }
break;
case 14:
{ return (PROCEDURE); }
break;
case 15:
	{ return (PROGRAM); }
break;
case 16:
	{ return (RECORD); }
break;
case 17:
	{ return (REPORTS); }
break;
case 18:
	{ return (RETURNS); }
break;
case 19:
{ return (SEQUENCE); }
break;
case 20:
	{ return (STRING); }
break;
case 21:
	{ return (TYPE); }
break;
case 22:
{ return (UNSPECIFIED); }
break;
case 23:
	{ return (UPON); }
break;
case 24:
	{ return (VERSION); }
break;
case 25:
		{
				/*
				 * Only decimal numbers are supported.
				 */
				yylval.object = make(O_CONSTANT, atoi(yytext));
				return (number);
			}
break;
case 26:
{
				yylval.object = make(O_SYMBOL, yytext);
				return (identifier);
			}
break;
case 27:
		{
				return ((int) yytext[0]);
			}
break;
case -1:
break;
default:
fprintf(yyout,"bad switch yylook %d",nstr);
} return(0); }
/* end of yylex */
int yyvstop[] ={
0,

27,
0,

2,
27,
0,

2,
0,

27,
0,

25,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

26,
27,
0,

25,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

13,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

1,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

9,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

12,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

21,
26,
0,

26,
0,

23,
26,
0,

26,
0,

3,
26,
0,

4,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

10,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

7,
26,
0,

26,
0,

26,
0,

26,
0,

26,
0,

16,
26,
0,

26,
0,

26,
0,

26,
0,

20,
26,
0,

26,
0,

26,
0,

5,
26,
0,

26,
0,

8,
26,
0,

11,
26,
0,

26,
0,

15,
26,
0,

17,
26,
0,

18,
26,
0,

26,
0,

26,
0,

24,
26,
0,

6,
26,
0,

26,
0,

19,
26,
0,

26,
0,

14,
26,
0,

26,
0,

26,
0,

22,
26,
0,
0};
# define YYTYPE int
struct yywork { YYTYPE verify, advance; } yycrank[] ={
0,0,	0,0,	1,3,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	1,4,	1,5,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	1,6,	6,23,	
0,0,	1,7,	6,24,	6,24,	
6,24,	6,24,	6,24,	6,24,	
6,24,	6,24,	6,24,	6,24,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	1,8,	1,9,	
1,10,	1,11,	1,12,	1,13,	
1,13,	1,13,	1,14,	1,13,	
1,13,	1,15,	1,13,	1,13,	
1,16,	1,17,	1,13,	1,18,	
1,19,	1,20,	1,21,	1,22,	
1,13,	1,13,	1,13,	1,13,	
13,25,	12,32,	17,37,	25,25,	
1,13,	12,33,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
1,13,	1,13,	1,13,	1,13,	
2,6,	7,24,	7,24,	7,24,	
7,24,	7,24,	7,24,	7,24,	
7,24,	7,24,	7,24,	14,34,	
20,25,	15,35,	26,46,	14,25,	
15,25,	28,48,	29,49,	20,41,	
28,25,	2,9,	2,10,	2,11,	
2,12,	2,13,	2,13,	2,13,	
2,14,	2,13,	2,13,	2,15,	
2,13,	2,13,	2,16,	2,17,	
2,13,	2,18,	2,19,	2,20,	
2,21,	2,22,	2,13,	2,13,	
2,13,	2,13,	31,51,	21,42,	
31,25,	21,43,	2,13,	21,25,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	2,13,	2,13,	
2,13,	2,13,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
30,50,	33,53,	34,25,	30,25,	
34,54,	36,25,	40,61,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,26,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	37,56,	35,55,	44,65,	
37,25,	8,25,	35,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	8,25,	8,25,	8,25,	
8,25,	9,27,	10,29,	11,31,	
27,47,	16,36,	52,25,	18,38,	
19,39,	10,30,	32,52,	9,28,	
22,44,	72,92,	9,25,	27,25,	
11,25,	16,25,	23,23,	10,25,	
18,25,	19,25,	38,57,	19,40,	
32,25,	22,25,	23,23,	23,45,	
39,60,	39,25,	41,62,	46,66,	
41,25,	42,25,	42,63,	38,58,	
47,67,	38,25,	43,64,	38,59,	
48,68,	43,25,	49,69,	50,70,	
51,71,	47,25,	48,25,	53,72,	
46,25,	54,73,	53,25,	56,75,	
50,25,	55,74,	74,25,	56,76,	
49,25,	51,25,	57,77,	62,82,	
58,78,	57,25,	54,25,	58,25,	
55,25,	23,23,	56,25,	59,25,	
60,25,	61,81,	59,79,	60,80,	
62,25,	63,83,	66,25,	63,25,	
64,84,	68,88,	61,25,	69,89,	
64,25,	66,86,	23,23,	65,25,	
65,85,	67,87,	70,90,	71,91,	
69,25,	67,25,	68,25,	71,25,	
73,93,	75,94,	76,95,	77,96,	
78,97,	79,98,	80,99,	82,25,	
81,100,	70,25,	83,101,	73,25,	
81,25,	84,25,	75,25,	85,102,	
86,25,	87,25,	88,103,	80,25,	
90,105,	89,104,	91,106,	83,25,	
85,25,	89,25,	92,25,	93,107,	
94,108,	95,109,	96,110,	105,25,	
97,25,	90,25,	97,111,	88,25,	
91,25,	98,112,	100,114,	99,113,	
93,25,	98,25,	94,25,	99,25,	
96,25,	101,115,	95,25,	102,116,	
103,117,	100,25,	102,25,	104,118,	
103,25,	106,25,	106,119,	107,120,	
108,25,	109,122,	110,25,	108,121,	
101,25,	113,125,	109,25,	111,25,	
111,123,	112,25,	112,124,	114,25,	
104,25,	115,126,	116,127,	117,25,	
119,25,	118,128,	116,25,	120,25,	
113,25,	121,129,	115,25,	118,25,	
122,25,	123,25,	124,25,	125,130,	
127,25,	126,131,	128,25,	129,132,	
130,25,	131,133,	132,25,	133,134,	
134,135,	135,25,	0,0,	0,0,	
125,25,	126,25,	131,25,	0,0,	
129,25,	0,0,	0,0,	0,0,	
133,25,	0,0,	134,25,	0,0,	
0,0};
struct yysvf yysvec[] ={
0,	0,	0,
yycrank+-1,	0,		0,	
yycrank+-79,	yysvec+1,	0,	
yycrank+0,	0,		yyvstop+1,
yycrank+0,	0,		yyvstop+3,
yycrank+0,	0,		yyvstop+6,
yycrank+2,	0,		yyvstop+8,
yycrank+77,	0,		yyvstop+10,
yycrank+154,	0,		yyvstop+13,
yycrank+208,	yysvec+8,	yyvstop+16,
yycrank+213,	yysvec+8,	yyvstop+19,
yycrank+210,	yysvec+8,	yyvstop+22,
yycrank+15,	yysvec+8,	yyvstop+25,
yycrank+10,	yysvec+8,	yyvstop+28,
yycrank+57,	yysvec+8,	yyvstop+31,
yycrank+58,	yysvec+8,	yyvstop+34,
yycrank+211,	yysvec+8,	yyvstop+37,
yycrank+12,	yysvec+8,	yyvstop+40,
yycrank+214,	yysvec+8,	yyvstop+43,
yycrank+215,	yysvec+8,	yyvstop+46,
yycrank+54,	yysvec+8,	yyvstop+49,
yycrank+93,	yysvec+8,	yyvstop+52,
yycrank+219,	yysvec+8,	yyvstop+55,
yycrank+-293,	0,		0,	
yycrank+0,	yysvec+7,	yyvstop+58,
yycrank+13,	yysvec+8,	yyvstop+60,
yycrank+56,	yysvec+8,	yyvstop+62,
yycrank+209,	yysvec+8,	yyvstop+64,
yycrank+62,	yysvec+8,	yyvstop+66,
yycrank+60,	yysvec+8,	yyvstop+68,
yycrank+133,	yysvec+8,	yyvstop+70,
yycrank+90,	yysvec+8,	yyvstop+72,
yycrank+218,	yysvec+8,	yyvstop+74,
yycrank+131,	yysvec+8,	yyvstop+76,
yycrank+132,	yysvec+8,	yyvstop+78,
yycrank+168,	yysvec+8,	yyvstop+80,
yycrank+135,	yysvec+8,	yyvstop+82,
yycrank+166,	yysvec+8,	yyvstop+85,
yycrank+231,	yysvec+8,	yyvstop+87,
yycrank+223,	yysvec+8,	yyvstop+89,
yycrank+136,	yysvec+8,	yyvstop+91,
yycrank+226,	yysvec+8,	yyvstop+93,
yycrank+227,	yysvec+8,	yyvstop+95,
yycrank+235,	yysvec+8,	yyvstop+97,
yycrank+165,	yysvec+8,	yyvstop+99,
yycrank+0,	0,		yyvstop+101,
yycrank+242,	yysvec+8,	yyvstop+103,
yycrank+239,	yysvec+8,	yyvstop+105,
yycrank+240,	yysvec+8,	yyvstop+107,
yycrank+250,	yysvec+8,	yyvstop+109,
yycrank+246,	yysvec+8,	yyvstop+111,
yycrank+251,	yysvec+8,	yyvstop+113,
yycrank+200,	yysvec+8,	yyvstop+115,
yycrank+244,	yysvec+8,	yyvstop+118,
yycrank+256,	yysvec+8,	yyvstop+120,
yycrank+258,	yysvec+8,	yyvstop+122,
yycrank+260,	yysvec+8,	yyvstop+124,
yycrank+255,	yysvec+8,	yyvstop+126,
yycrank+257,	yysvec+8,	yyvstop+128,
yycrank+261,	yysvec+8,	yyvstop+130,
yycrank+262,	yysvec+8,	yyvstop+132,
yycrank+272,	yysvec+8,	yyvstop+134,
yycrank+266,	yysvec+8,	yyvstop+136,
yycrank+269,	yysvec+8,	yyvstop+138,
yycrank+274,	yysvec+8,	yyvstop+140,
yycrank+277,	yysvec+8,	yyvstop+142,
yycrank+268,	yysvec+8,	yyvstop+144,
yycrank+283,	yysvec+8,	yyvstop+146,
yycrank+284,	yysvec+8,	yyvstop+148,
yycrank+282,	yysvec+8,	yyvstop+150,
yycrank+295,	yysvec+8,	yyvstop+152,
yycrank+285,	yysvec+8,	yyvstop+154,
yycrank+207,	yysvec+8,	yyvstop+156,
yycrank+297,	yysvec+8,	yyvstop+158,
yycrank+248,	yysvec+8,	yyvstop+160,
yycrank+300,	yysvec+8,	yyvstop+163,
yycrank+288,	yysvec+8,	yyvstop+165,
yycrank+289,	yysvec+8,	yyvstop+167,
yycrank+290,	yysvec+8,	yyvstop+169,
yycrank+291,	yysvec+8,	yyvstop+171,
yycrank+305,	yysvec+8,	yyvstop+173,
yycrank+298,	yysvec+8,	yyvstop+175,
yycrank+293,	yysvec+8,	yyvstop+177,
yycrank+309,	yysvec+8,	yyvstop+180,
yycrank+299,	yysvec+8,	yyvstop+182,
yycrank+310,	yysvec+8,	yyvstop+185,
yycrank+302,	yysvec+8,	yyvstop+187,
yycrank+303,	yysvec+8,	yyvstop+190,
yycrank+321,	yysvec+8,	yyvstop+193,
yycrank+311,	yysvec+8,	yyvstop+195,
yycrank+319,	yysvec+8,	yyvstop+197,
yycrank+322,	yysvec+8,	yyvstop+199,
yycrank+312,	yysvec+8,	yyvstop+201,
yycrank+326,	yysvec+8,	yyvstop+204,
yycrank+328,	yysvec+8,	yyvstop+206,
yycrank+332,	yysvec+8,	yyvstop+208,
yycrank+330,	yysvec+8,	yyvstop+210,
yycrank+318,	yysvec+8,	yyvstop+212,
yycrank+327,	yysvec+8,	yyvstop+214,
yycrank+329,	yysvec+8,	yyvstop+216,
yycrank+335,	yysvec+8,	yyvstop+218,
yycrank+346,	yysvec+8,	yyvstop+220,
yycrank+336,	yysvec+8,	yyvstop+222,
yycrank+338,	yysvec+8,	yyvstop+224,
yycrank+354,	yysvec+8,	yyvstop+226,
yycrank+317,	yysvec+8,	yyvstop+228,
yycrank+339,	yysvec+8,	yyvstop+231,
yycrank+341,	yysvec+8,	yyvstop+233,
yycrank+342,	yysvec+8,	yyvstop+235,
yycrank+348,	yysvec+8,	yyvstop+237,
yycrank+344,	yysvec+8,	yyvstop+239,
yycrank+349,	yysvec+8,	yyvstop+242,
yycrank+351,	yysvec+8,	yyvstop+244,
yycrank+362,	yysvec+8,	yyvstop+246,
yycrank+353,	yysvec+8,	yyvstop+248,
yycrank+364,	yysvec+8,	yyvstop+251,
yycrank+360,	yysvec+8,	yyvstop+253,
yycrank+357,	yysvec+8,	yyvstop+255,
yycrank+365,	yysvec+8,	yyvstop+258,
yycrank+358,	yysvec+8,	yyvstop+260,
yycrank+361,	yysvec+8,	yyvstop+263,
yycrank+363,	yysvec+8,	yyvstop+266,
yycrank+366,	yysvec+8,	yyvstop+268,
yycrank+367,	yysvec+8,	yyvstop+271,
yycrank+368,	yysvec+8,	yyvstop+274,
yycrank+382,	yysvec+8,	yyvstop+277,
yycrank+383,	yysvec+8,	yyvstop+279,
yycrank+370,	yysvec+8,	yyvstop+281,
yycrank+372,	yysvec+8,	yyvstop+284,
yycrank+386,	yysvec+8,	yyvstop+287,
yycrank+374,	yysvec+8,	yyvstop+289,
yycrank+384,	yysvec+8,	yyvstop+292,
yycrank+376,	yysvec+8,	yyvstop+294,
yycrank+390,	yysvec+8,	yyvstop+297,
yycrank+392,	yysvec+8,	yyvstop+299,
yycrank+379,	yysvec+8,	yyvstop+301,
0,	0,	0};
struct yywork *yytop = yycrank+474;
struct yysvf *yybgin = yysvec+1;
char yymatch[] ={
00  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,011 ,012 ,01  ,01  ,01  ,01  ,01  ,
01  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
011 ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,
'0' ,'0' ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,01  ,01  ,01  ,01  ,'A' ,
01  ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,01  ,01  ,01  ,01  ,01  ,
0};
char yyextra[] ={
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,
0};
int yylineno =1;
# define YYU(x) x
# define NLSTATE yyprevious=YYNEWLINE
char yytext[YYLMAX];
struct yysvf *yylstate [YYLMAX], **yylsp, **yyolsp;
char yysbuf[YYLMAX];
char *yysptr = yysbuf;
int *yyfnd;
extern struct yysvf *yyestate;
int yyprevious = YYNEWLINE;
yylook(){
	register struct yysvf *yystate, **lsp;
	register struct yywork *yyt;
	struct yysvf *yyz;
	int yych;
	struct yywork *yyr;
# ifdef LEXDEBUG
	int debug;
# endif
	char *yylastch;
	/* start off machines */
# ifdef LEXDEBUG
	debug = 0;
# endif
	if (!yymorfg)
		yylastch = yytext;
	else {
		yymorfg=0;
		yylastch = yytext+yyleng;
		}
	for(;;){
		lsp = yylstate;
		yyestate = yystate = yybgin;
		if (yyprevious==YYNEWLINE) yystate++;
		for (;;){
# ifdef LEXDEBUG
			if(debug)fprintf(yyout,"state %d\n",yystate-yysvec-1);
# endif
			yyt = yystate->yystoff;
			if(yyt == yycrank){		/* may not be any transitions */
				yyz = yystate->yyother;
				if(yyz == 0)break;
				if(yyz->yystoff == yycrank)break;
				}
			*yylastch++ = yych = input();
		tryagain:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"char ");
				allprint(yych);
				putchar('\n');
				}
# endif
			yyr = yyt;
			if ( (int)yyt > (int)yycrank){
				yyt = yyr + yych;
				if (yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				}
# ifdef YYOPTIM
			else if((int)yyt < (int)yycrank) {		/* r < yycrank */
				yyt = yyr = yycrank+(yycrank-yyt);
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"compressed state\n");
# endif
				yyt = yyt + yych;
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				yyt = yyr + YYU(yymatch[yych]);
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"try fall back character ");
					allprint(YYU(yymatch[yych]));
					putchar('\n');
					}
# endif
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transition */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				}
			if ((yystate = yystate->yyother) && (yyt= yystate->yystoff) != yycrank){
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"fall back to state %d\n",yystate-yysvec-1);
# endif
				goto tryagain;
				}
# endif
			else
				{unput(*--yylastch);break;}
		contin:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"state %d char ",yystate-yysvec-1);
				allprint(yych);
				putchar('\n');
				}
# endif
			;
			}
# ifdef LEXDEBUG
		if(debug){
			fprintf(yyout,"stopped at %d with ",*(lsp-1)-yysvec-1);
			allprint(yych);
			putchar('\n');
			}
# endif
		while (lsp-- > yylstate){
			*yylastch-- = 0;
			if (*lsp != 0 && (yyfnd= (*lsp)->yystops) && *yyfnd > 0){
				yyolsp = lsp;
				if(yyextra[*yyfnd]){		/* must backup */
					while(yyback((*lsp)->yystops,-*yyfnd) != 1 && lsp > yylstate){
						lsp--;
						unput(*yylastch--);
						}
					}
				yyprevious = YYU(*yylastch);
				yylsp = lsp;
				yyleng = yylastch-yytext+1;
				yytext[yyleng] = 0;
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"\nmatch ");
					sprint(yytext);
					fprintf(yyout," action %d\n",*yyfnd);
					}
# endif
				return(*yyfnd++);
				}
			unput(*yylastch);
			}
		if (yytext[0] == 0  /* && feof(yyin) */)
			{
			yysptr=yysbuf;
			return(0);
			}
		yyprevious = yytext[0] = input();
		if (yyprevious>0)
			output(yyprevious);
		yylastch=yytext;
# ifdef LEXDEBUG
		if(debug)putchar('\n');
# endif
		}
	}
yyback(p, m)
	int *p;
{
if (p==0) return(0);
while (*p)
	{
	if (*p++ == m)
		return(1);
	}
return(0);
}
	/* the following are only used in the lex library */
yyinput(){
	return(input());
	}
yyoutput(c)
  int c; {
	output(c);
	}
yyunput(c)
   int c; {
	unput(c);
	}