lexer.cpp
来自「编译原理实验将简单中缀算术表达式变换成后缀形式」· C++ 代码 · 共 54 行
CPP
54 行
//lexer.c
#include "stdafx.h"
#include "global.h"
char lexbuf[BSIZE];
int lineno=1;
int tokenval=NONE;
int lexan()
{
int t;
while(1)
{
t=fgetc(fp1);
if(t==' '||t=='\t')
;
//else if(t=='\n')
//lineno=lineno+1;
else if(isdigit(t))
{
ungetc(t,fp1);
fscanf(fp1,"%d",&tokenval);
return NUM;
}
else if(isalpha(t))
{
int p,b=0;
while(isalnum(t))
{
lexbuf[b]=t;
t=fgetc(fp1);
b=b+1;
if(b>=BSIZE)
error2("compiler error");
}
lexbuf[b]=EOS;
if(t!=EOF)
ungetc(t,fp1);
p=lookup(lexbuf);
if(p==0)
p=insert(lexbuf,ID);
tokenval=p;
return symtable[p].token;
}
else if(t==EOF)
return DONE;
else
{
tokenval=NONE;
return t;
}
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?