Skip to content

Commit 5404ad5

Browse files
committed
---
yaml --- r: 46798 b: refs/heads/auto c: b673b26 h: refs/heads/master v: v3
1 parent f2540aa commit 5404ad5

File tree

2 files changed

+17
-9
lines changed

2 files changed

+17
-9
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,4 +14,4 @@ refs/heads/try3: 9387340aab40a73e8424c48fd42f0c521a4875c0
1414
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
1515
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1616
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
17-
refs/heads/auto: a5030e7615f7d37acaee69b13f97b9ffa23159a5
17+
refs/heads/auto: b673b26f03043f974682efceffbf40df9cf4bc84

branches/auto/src/librustc/middle/trans/adt.rs

Lines changed: 16 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -159,19 +159,27 @@ fn load_discr(bcx: block, scrutinee: ValueRef, min: int, max: int)
159159
}
160160
}
161161

162-
pub fn trans_switch(bcx: block, r: &Repr, scrutinee: ValueRef) ->
163-
(_match::branch_kind, Option<ValueRef>) {
162+
pub fn trans_switch(bcx: block, r: &Repr, scrutinee: ValueRef)
163+
-> (_match::branch_kind, Option<ValueRef>) {
164164
match *r {
165-
CEnum(min, max) => {
166-
(_match::switch, Some(load_discr(bcx, scrutinee, min, max)))
165+
CEnum(*) | General(*) => {
166+
(_match::switch, Some(trans_cast_to_int(bcx, r, scrutinee)))
167167
}
168168
Unit(*) | Univariant(*) => {
169169
(_match::single, None)
170170
}
171-
General(ref cases) => {
172-
(_match::switch, Some(load_discr(bcx, scrutinee, 0,
173-
(cases.len() - 1) as int)))
174-
}
171+
}
172+
}
173+
174+
pub fn trans_cast_to_int(bcx: block, r: &Repr, scrutinee: ValueRef)
175+
-> ValueRef {
176+
match *r {
177+
Unit(the_disc) => C_int(bcx.ccx(), the_disc),
178+
CEnum(min, max) => load_discr(bcx, scrutinee, min, max),
179+
Univariant(*) => bcx.ccx().sess.bug(~"type has no explicit \
180+
discriminant"),
181+
General(ref cases) => load_discr(bcx, scrutinee, 0,
182+
(cases.len() - 1) as int)
175183
}
176184
}
177185

0 commit comments

Comments
 (0)