ref: 99083f8dd0647e0f1a455918c7ccd0152f753895
parent: 609bb6b7743e8a37538a2701df3aaa3b652ebfb7
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Mon Sep 7 13:07:49 EDT 2015
Fix integer constant parsing Sign cannot be part of the constant, it is an unary operator.
--- a/cc1/lex.c
+++ b/cc1/lex.c
@@ -206,15 +206,10 @@
{
Type *tp = sym->type;
struct limits *lim = getlimits(tp);
- TUINT u, val, max, factor = 1;
+ TUINT u, val, max;
int c;
max = (tp->sign) ? lim->max.u : lim->max.i;
- switch (*s++) {
- case '-': factor = -1; break;
- default: --s;
- case '+': factor = 1; break;
- }
for (u = 0; isxdigit(c = *s++); u = u * base + val) {
val = (c <= '9') ? c - '0' : 10 + c - 'A';
@@ -221,20 +216,20 @@
if (u <= max/base + val)
continue;
if (tp->sign) {
- if (tp == inttype)
+ if (tp == inttype) {
tp = longtype;
- else if (tp == longtype)
+ } else if (tp == longtype) {
tp == llongtype;
- else {
+ } else {
errorp("overflow in integer constant");
break;
}
} else {
- if (tp == uinttype)
+ if (tp == uinttype) {
tp = ulongtype;
- else if (tp == ulongtype)
+ } else if (tp == ulongtype) {
tp == ullongtype;
- else {
+ } else {
errorp("overflow in integer constant");
break;
}
@@ -243,7 +238,7 @@
}
if (tp->sign)
- sym->u.i = u * factor;
+ sym->u.i = u;
else
sym->u.u = u;