shithub: scc

Download patch

ref: 8022f78f34e2b0532f880d2d64d363bb1e20531d
parent: e6183c2b047fec411a87bcb04ccc3833ec846b20
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Sat Jul 18 06:31:19 EDT 2015

Rewrite clever expressions in cpp.c

These expressions were too much clever and obscure. Using
an intermediate variable helps to understand them.

--- a/cc1/cpp.c
+++ b/cc1/cpp.c
@@ -447,9 +447,11 @@
 {
 	Symbol *sym;
 	unsigned n;
+	int status;
 
 	if (cppctx == NR_COND-1)
 		error("too much nesting levels of conditional inclusion");
+
 	n = cppctx++;
 	if (yytoken != IDEN) {
 		error("no macro name given in #%s directive",
@@ -458,7 +460,10 @@
 
 	sym = lookup(NS_CPP);
 	next();
-	if (!(ifstatus[n] = (sym->flags & ISDEFINED) != 0 == isdef))
+
+	status = (sym->flags & ISDEFINED) != 0 == isdef;
+
+	if (!(ifstatus[n] = status))
 		++cppoff;
 }
 
@@ -486,10 +491,13 @@
 static void
 elseclause(void)
 {
+	int status;
+
 	if (cppctx == 0)
 		error("#else without #ifdef/ifndef");
 
-	cppoff += (ifstatus[cppctx-1] ^= 1) ? -1 : 1;
+	status = (ifstatus[cppctx-1] ^= 1);
+	cppoff += (status) ? -1 : 1;
 }
 
 static void