annotate dmd/CaseRangeStatement.d @ 64:4290d870944a

More fixes
author korDen
date Mon, 23 Aug 2010 20:29:15 +0400
parents b7d29f613539
children 2e2a5c3f943a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
1 module dmd.CaseRangeStatement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
2
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
3 import dmd.Statement;
64
4290d870944a More fixes
korDen
parents: 51
diff changeset
4 import dmd.ArrayTypes;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
5 import dmd.Expression;
64
4290d870944a More fixes
korDen
parents: 51
diff changeset
6 import dmd.ExpStatement;
4290d870944a More fixes
korDen
parents: 51
diff changeset
7 import dmd.IntegerExp;
4290d870944a More fixes
korDen
parents: 51
diff changeset
8 import dmd.CaseStatement;
4290d870944a More fixes
korDen
parents: 51
diff changeset
9 import dmd.CompoundStatement;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
10 import dmd.Statement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
11 import dmd.Loc;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
12 import dmd.OutBuffer;
64
4290d870944a More fixes
korDen
parents: 51
diff changeset
13 import dmd.WANT;
4290d870944a More fixes
korDen
parents: 51
diff changeset
14 import dmd.SwitchStatement;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
15 import dmd.HdrGenState;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
16 import dmd.Scope;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
17
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
18 class CaseRangeStatement : Statement
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
19 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
20 Expression first;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
21 Expression last;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
22 Statement statement;
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
23
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
24 this(Loc loc, Expression first, Expression last, Statement s)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
25 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
26 super(loc);
51
b7d29f613539 StaticAssertStatement.syntaxCopy
korDen
parents: 0
diff changeset
27 this.first = first;
b7d29f613539 StaticAssertStatement.syntaxCopy
korDen
parents: 0
diff changeset
28 this.last = last;
b7d29f613539 StaticAssertStatement.syntaxCopy
korDen
parents: 0
diff changeset
29 this.statement = s;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
30 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
31
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
32 Statement syntaxCopy()
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
33 {
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
34 assert(false);
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
35 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
36
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
37 Statement semantic(Scope sc)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
38 {
64
4290d870944a More fixes
korDen
parents: 51
diff changeset
39 SwitchStatement sw = sc.sw;
4290d870944a More fixes
korDen
parents: 51
diff changeset
40
4290d870944a More fixes
korDen
parents: 51
diff changeset
41 //printf("CaseRangeStatement.semantic() %s\n", toChars());
4290d870944a More fixes
korDen
parents: 51
diff changeset
42 if (sw.isFinal)
4290d870944a More fixes
korDen
parents: 51
diff changeset
43 error("case ranges not allowed in final switch");
4290d870944a More fixes
korDen
parents: 51
diff changeset
44
4290d870944a More fixes
korDen
parents: 51
diff changeset
45 first = first.semantic(sc);
4290d870944a More fixes
korDen
parents: 51
diff changeset
46 first = first.implicitCastTo(sc, sw.condition.type);
4290d870944a More fixes
korDen
parents: 51
diff changeset
47 first = first.optimize(WANTvalue | WANTinterpret);
4290d870944a More fixes
korDen
parents: 51
diff changeset
48 long fval = first.toInteger();
4290d870944a More fixes
korDen
parents: 51
diff changeset
49
4290d870944a More fixes
korDen
parents: 51
diff changeset
50 last = last.semantic(sc);
4290d870944a More fixes
korDen
parents: 51
diff changeset
51 last = last.implicitCastTo(sc, sw.condition.type);
4290d870944a More fixes
korDen
parents: 51
diff changeset
52 last = last.optimize(WANTvalue | WANTinterpret);
4290d870944a More fixes
korDen
parents: 51
diff changeset
53 long lval = last.toInteger();
4290d870944a More fixes
korDen
parents: 51
diff changeset
54
4290d870944a More fixes
korDen
parents: 51
diff changeset
55 if (lval - fval > 256)
4290d870944a More fixes
korDen
parents: 51
diff changeset
56 {
4290d870944a More fixes
korDen
parents: 51
diff changeset
57 error("more than 256 cases in case range");
4290d870944a More fixes
korDen
parents: 51
diff changeset
58 lval = fval + 256;
4290d870944a More fixes
korDen
parents: 51
diff changeset
59 }
4290d870944a More fixes
korDen
parents: 51
diff changeset
60
4290d870944a More fixes
korDen
parents: 51
diff changeset
61 /* This works by replacing the CaseRange with an array of Case's.
4290d870944a More fixes
korDen
parents: 51
diff changeset
62 *
4290d870944a More fixes
korDen
parents: 51
diff changeset
63 * case a: .. case b: s;
4290d870944a More fixes
korDen
parents: 51
diff changeset
64 * =>
4290d870944a More fixes
korDen
parents: 51
diff changeset
65 * case a:
4290d870944a More fixes
korDen
parents: 51
diff changeset
66 * [...]
4290d870944a More fixes
korDen
parents: 51
diff changeset
67 * case b:
4290d870944a More fixes
korDen
parents: 51
diff changeset
68 * s;
4290d870944a More fixes
korDen
parents: 51
diff changeset
69 */
4290d870944a More fixes
korDen
parents: 51
diff changeset
70
4290d870944a More fixes
korDen
parents: 51
diff changeset
71 Statements statements = new Statements();
4290d870944a More fixes
korDen
parents: 51
diff changeset
72 for (long i = fval; i <= lval; i++)
4290d870944a More fixes
korDen
parents: 51
diff changeset
73 {
4290d870944a More fixes
korDen
parents: 51
diff changeset
74 Statement s = statement;
4290d870944a More fixes
korDen
parents: 51
diff changeset
75 if (i != lval)
4290d870944a More fixes
korDen
parents: 51
diff changeset
76 s = new ExpStatement(loc, null);
4290d870944a More fixes
korDen
parents: 51
diff changeset
77 Expression e = new IntegerExp(loc, i, first.type);
4290d870944a More fixes
korDen
parents: 51
diff changeset
78 Statement cs = new CaseStatement(loc, e, s);
4290d870944a More fixes
korDen
parents: 51
diff changeset
79 statements.push(cast(void*)cs);
4290d870944a More fixes
korDen
parents: 51
diff changeset
80 }
4290d870944a More fixes
korDen
parents: 51
diff changeset
81 Statement s = new CompoundStatement(loc, statements);
4290d870944a More fixes
korDen
parents: 51
diff changeset
82 s = s.semantic(sc);
4290d870944a More fixes
korDen
parents: 51
diff changeset
83 return s;
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
84 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
85
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
86 void toCBuffer(OutBuffer buf, HdrGenState* hgs)
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
87 {
64
4290d870944a More fixes
korDen
parents: 51
diff changeset
88 buf.writestring("case ");
4290d870944a More fixes
korDen
parents: 51
diff changeset
89 first.toCBuffer(buf, hgs);
4290d870944a More fixes
korDen
parents: 51
diff changeset
90 buf.writestring(": .. case ");
4290d870944a More fixes
korDen
parents: 51
diff changeset
91 last.toCBuffer(buf, hgs);
4290d870944a More fixes
korDen
parents: 51
diff changeset
92 buf.writenl();
4290d870944a More fixes
korDen
parents: 51
diff changeset
93 statement.toCBuffer(buf, hgs);
0
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
94 }
10317f0c89a5 Initial commit
korDen
parents:
diff changeset
95 }