Mercurial > projects > ddmd
view dmd/CaseRangeStatement.d @ 64:4290d870944a
More fixes
author | korDen |
---|---|
date | Mon, 23 Aug 2010 20:29:15 +0400 |
parents | b7d29f613539 |
children | 2e2a5c3f943a |
line wrap: on
line source
module dmd.CaseRangeStatement; import dmd.Statement; import dmd.ArrayTypes; import dmd.Expression; import dmd.ExpStatement; import dmd.IntegerExp; import dmd.CaseStatement; import dmd.CompoundStatement; import dmd.Statement; import dmd.Loc; import dmd.OutBuffer; import dmd.WANT; import dmd.SwitchStatement; import dmd.HdrGenState; import dmd.Scope; class CaseRangeStatement : Statement { Expression first; Expression last; Statement statement; this(Loc loc, Expression first, Expression last, Statement s) { super(loc); this.first = first; this.last = last; this.statement = s; } Statement syntaxCopy() { assert(false); } Statement semantic(Scope sc) { SwitchStatement sw = sc.sw; //printf("CaseRangeStatement.semantic() %s\n", toChars()); if (sw.isFinal) error("case ranges not allowed in final switch"); first = first.semantic(sc); first = first.implicitCastTo(sc, sw.condition.type); first = first.optimize(WANTvalue | WANTinterpret); long fval = first.toInteger(); last = last.semantic(sc); last = last.implicitCastTo(sc, sw.condition.type); last = last.optimize(WANTvalue | WANTinterpret); long lval = last.toInteger(); if (lval - fval > 256) { error("more than 256 cases in case range"); lval = fval + 256; } /* This works by replacing the CaseRange with an array of Case's. * * case a: .. case b: s; * => * case a: * [...] * case b: * s; */ Statements statements = new Statements(); for (long i = fval; i <= lval; i++) { Statement s = statement; if (i != lval) s = new ExpStatement(loc, null); Expression e = new IntegerExp(loc, i, first.type); Statement cs = new CaseStatement(loc, e, s); statements.push(cast(void*)cs); } Statement s = new CompoundStatement(loc, statements); s = s.semantic(sc); return s; } void toCBuffer(OutBuffer buf, HdrGenState* hgs) { buf.writestring("case "); first.toCBuffer(buf, hgs); buf.writestring(": .. case "); last.toCBuffer(buf, hgs); buf.writenl(); statement.toCBuffer(buf, hgs); } }