Make lex more pedant friendly.

This commit is contained in:
wkj 2004-05-16 07:59:27 +00:00
parent a87f4771c7
commit eb43e9ba97
3 changed files with 5 additions and 2 deletions

View file

@ -85,7 +85,7 @@ void
phead2(void)
{
Bprint(&fout,"while((nstr = yylook()) >= 0)\n");
Bprint(&fout,"yyfussy: switch(nstr){\n");
Bprint(&fout,"goto yyfussy;\nyyfussy: switch(nstr){\n");
Bprint(&fout,"case 0:\n");
Bprint(&fout,"if(yywrap()) return(0); break;\n");
}

View file

@ -11,6 +11,7 @@ int yyprevious = YYNEWLINE;
# ifdef LEXDEBUG
extern void allprint(char);
# endif
int
yylook(void){
struct yysvf *yystate, **lsp;
struct yywork *yyt;
@ -158,6 +159,7 @@ yylook(void){
}
return(0); /* shut up the compiler; i have no idea what should be returned */
}
int
yyback(int *p, int m)
{
if (p==0) return(0);
@ -169,6 +171,7 @@ while (*p)
return(0);
}
/* the following are only used in the lex library */
int
yyinput(void){
if(yyin == ((void*)0))
yyin = stdin;

View file

@ -240,7 +240,7 @@ yylex(void)
case '%':
lgate();
Bprint(&fout,"#define YYNEWLINE %d\n",'\n');
Bprint(&fout,"yylex(void){\nint nstr; extern int yyprevious;\n");
Bprint(&fout,"int\nyylex(void){\nint nstr; extern int yyprevious;\nif(yyprevious){}\n");
sectbegin = TRUE;
i = treesize*(sizeof(*name)+sizeof(*left)+
sizeof(*right)+sizeof(*nullstr)+sizeof(*parent))+ALITTLEEXTRA;