ref: 849dee9be47627e40d26594257d03c081d501152
parent: f76f863288e8d289c9377dadb31a40bf83baa279
author: Michael Forney <[email protected]>
date: Wed Jun 28 21:38:56 EDT 2017
Use switch statement in postcheckpass We don't need to check for Nexpr since exprop asserts e->type == Nexpr.
--- a/parse/infer.c
+++ b/parse/infer.c
@@ -2199,16 +2199,13 @@
for (i = 0; i < st->npostcheck; i++) {
n = st->postcheck[i];
pushstab(st->postcheckscope[i]);
- if (n->type == Nexpr && exprop(n) == Omemb)
- infercompn(st, n, rem, nrem, remscope, nremscope);
- else if (n->type == Nexpr && exprop(n) == Ocast)
- checkcast(st, n, rem, nrem, remscope, nremscope);
- else if (n->type == Nexpr && exprop(n) == Ostruct)
- checkstruct(st, n, rem, nrem, remscope, nremscope);
- else if (n->type == Nexpr && exprop(n) == Ovar)
- checkvar(st, n, rem, nrem, remscope, nremscope);
- else
- die("Thing we shouldn't be checking in postcheck\n");
+ switch (exprop(n)) {
+ case Omemb: infercompn(st, n, rem, nrem, remscope, nremscope); break;
+ case Ocast: checkcast(st, n, rem, nrem, remscope, nremscope); break;
+ case Ostruct: checkstruct(st, n, rem, nrem, remscope, nremscope); break;
+ case Ovar: checkvar(st, n, rem, nrem, remscope, nremscope); break;
+ default: die("should not see %s in postcheck\n", opstr[exprop(n)]);
+ }
popstab();
}
}