lexer.c

来自「将简单中缀算术表达式变换成: (1)后缀形式 (2)生成书上描述的抽象堆栈机」· C语言 代码 · 共 55 行

C
55
字号
#include "global.h"

char lexbuf[BSIZE];
int lineno = 1;
int tokenval = NONE;
int wflag=0; //初始令wflag=0
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)
					error("compiler error");
				wflag=1;  //表达式含标识符,wflag=1
			}
			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 + -
显示快捷键?