shithub: scc

Download patch

ref: 19e83e69aa412cea8f41a28506cc9bfcc84525c4
parent: 71d0843d509fd2d0a14717bfc6dd30617a1aaba7
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Wed Sep 2 10:56:56 EDT 2015

Concentrate all the division by 0 in only one place

--- a/cc1/fold.c
+++ b/cc1/fold.c
@@ -93,11 +93,7 @@
 {
 	struct limits *lim = getlimits(tp);
 
-	if (r == 0) {
-		warn("division by 0");
-		return 0;
-	}
-	if (l == lim->min.i && r == -1) {
+	if (r == 0 || l == lim->min.i && r == -1) {
 		warn("overflow in constant expression");
 		return 0;
 	}
@@ -112,11 +108,7 @@
 	if (l < 0) l = -l;
 	if (r < 0) r = -r;
 
-	if (r == 0.0) {
-		warn("division by 0");
-		return 0;
-	}
-	if (r < 1.0 && l > lim->max.f * r) {
+	if (r == 0.0 || r < 1.0 && l > lim->max.f * r) {
 		warn("overflow in constant expression");
 		return 0;
 	}
@@ -308,8 +300,13 @@
 	Node *np;
 	int type;
 
+	if ((op == ODIV || op == OMOD) && cmpnode(rp, 0)) {
+		warn("division by 0");
+		return NULL;
+	}
 	if (!lp->constant || rp && !rp->constant)
 		return NULL;
+
 	ls = lp->sym;
 	rs = (rp) ? rp->sym : NULL;
 
@@ -416,9 +413,9 @@
 {
 	Node *np;
 
+	commutative(&op, &lp, &rp);
 	if ((np = fold(op, tp, lp, rp)) != NULL)
 		return np;
-	commutative(&op, &lp, &rp);
 	if ((np = identity(op, lp, rp)) != NULL)
 		return np;
 	return node(op, tp, lp, rp);