📄 parser.c
字号:
int lookahead;
void match(int t);
void term();
void expr();
void factor();
void parse();
void match(int t)
{
if(lookahead == t)
{
if(t==';')
if((s.top-s.base)==1)
{
pop();
printf("the result is %d\n",topvalue);
}
lookahead = lexan(); }
else error(" match syntax error");
}
void term()
{
int t;
factor();
while(1)
switch (lookahead){
case '*':case '/':case DIV:case MOD:
t=lookahead;
match(lookahead);factor();emit(t,NONE);
continue;
default:
return;
}
}
void expr()
{
int t;
term();
while(1)
switch (lookahead){
case '+':case '-':
t=lookahead;
match(lookahead);term();emit(t,NONE);
continue;
default:
return;
}
}
void factor()
{
switch(lookahead) {
case '(':
match('(');expr();match(')');break;
case NUM:
emit(NUM,tokenval);match(NUM);break;
case ID:
emit(ID,tokenval);match(ID);break;
default:
error("factor syntax error");
}
}
void parse()
{
lookahead = lexan();
while (lookahead != DONE)
{
expr();
match(';');
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -