From d6bb243ff51a592bf2440c9ad2a52a6c69147a8c Mon Sep 17 00:00:00 2001 From: Frits van Bommel Date: Sun, 15 Mar 2009 16:57:44 +0100 Subject: [PATCH] Apply [1120] to D2 as well (untested). --- dmd2/expression.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/dmd2/expression.c b/dmd2/expression.c index e37534de..95b7496f 100644 --- a/dmd2/expression.c +++ b/dmd2/expression.c @@ -1319,11 +1319,17 @@ integer_t IntegerExp::toInteger() case Twchar: case Tuns16: value = (d_uns16) value; break; case Tint32: value = (d_int32) value; break; - case Tpointer: case Tdchar: case Tuns32: value = (d_uns32) value; break; case Tint64: value = (d_int64) value; break; case Tuns64: value = (d_uns64) value; break; + case Tpointer: + // FIXME: Other pointer widths than 32 and 64? + if (PTRSIZE == 4) + value = (d_uns32) value; + else + value = (d_uns64) value; + break; case Tenum: { @@ -1483,6 +1489,7 @@ void IntegerExp::toCBuffer(OutBuffer *buf, HdrGenState *hgs) break; case Tuns64: + L4: buf->printf("%lluLU", v); break; @@ -1495,7 +1502,11 @@ void IntegerExp::toCBuffer(OutBuffer *buf, HdrGenState *hgs) buf->writestring("cast("); buf->writestring(t->toChars()); buf->writeByte(')'); - goto L3; + // FIXME: Other pointer widths than 32 and 64? + if (PTRSIZE == 4) + goto L3; + else + goto L4; default: /* This can happen if errors, such as