LCC编译器的源程序分析(36)case语句

case语句是使用在switch语句之中,它实现了选择一个分支执行。当表达式的值与case后面的常量表达式的值相等时,就执行此case语句后面的语句。LCC处理这个语句的代码如下:
#001 case CASE:
#002 {
#003 int lab = genlabel(1);
#004 if (swp == NULL)
#005 error("illegal case label\n");
#006
#007 definelab(lab);

第3行生成标号1起始值。
第4行是判断是否在switch语句中,如果不在就在第5行里提示出错。
第7行是生成标号1。

下面开始循环处理所有case语句。
#008 while (t == CASE)
#009 {
#010 static char stop[] = { IF, ID, 0 };
#011 Tree p;
#012 t = gettok();
#013 p = constexpr(0);
#014 if (generic(p->op) == CNST && isint(p->type))
#015 {
#016 if (swp)
#017 {
#018 needconst++;
#019 p = cast(p, swp->sym->type);
#020 if (p->type->op == UNSIGNED)
#021 p->u.v.i = extend(p->u.v.u, p->type);
#022 needconst—;
#023 caselabel(swp, p->u.v.i, lab);
#024 }
#025 }
#026 else
#027 error("case label must be a constant integer expression\n");
#028
#029 test(':', stop);
#030 }
第12行是获取下一个记号。
第13行是处理case语句后面的常量表达式,它是通过函数constexpr来处理的。
第14行到第27行都是处理常量表达式的类型,如果不是就会出错提示。

#031 statement(loop, swp, lev);
#032 }
#033 break;
第31行是处理case后面的语句,它是递归调用函数statement来处理。

通过上面这段代码,就处理完成一个case语句。它是先定义一个标号,计算常量表达式,并判断常量表达式的类型,最后处理语句。

Unless otherwise stated, the content of this page is licensed under Creative Commons Attribution-ShareAlike 3.0 License