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 + -
显示快捷键?