about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2016-05-13 12:16:53 -0700
committerbors <bors@rust-lang.org>2016-05-13 12:16:53 -0700
commit33a5c9dfd106e2f900aba7074f10b5e8e617be7b (patch)
tree69a4148b67314c52e4402b961c1e267f87fba04c
parentbc5789902bae5e3437bcfea9a06bc0fcb11726f0 (diff)
parentf3e1d57bc2d52f1a7ca5dbd9a31b5ad813483e2c (diff)
downloadrust-33a5c9dfd106e2f900aba7074f10b5e8e617be7b.tar.gz
rust-33a5c9dfd106e2f900aba7074f10b5e8e617be7b.zip
Auto merge of #33355 - luqmana:33202-repr-ice, r=nrc
adt: Allow repr attribute on single variant enum.

Fixes #33202.
-rw-r--r--src/librustc_trans/adt.rs4
-rw-r--r--src/test/run-pass/issue-33202.rs18
2 files changed, 19 insertions, 3 deletions
diff --git a/src/librustc_trans/adt.rs b/src/librustc_trans/adt.rs
index 49775388038..a4792ea328f 100644
--- a/src/librustc_trans/adt.rs
+++ b/src/librustc_trans/adt.rs
@@ -306,10 +306,8 @@ fn represent_type_uncached<'a, 'tcx>(cx: &CrateContext<'a, 'tcx>,
                      cx.tcx().item_path_str(def.did));
             }
 
-            if cases.len() == 1 {
+            if cases.len() == 1 && hint == attr::ReprAny {
                 // Equivalent to a struct/tuple/newtype.
-                // (Typechecking will reject discriminant-sizing attrs.)
-                assert_eq!(hint, attr::ReprAny);
                 let mut ftys = cases[0].tys.clone();
                 if dtor { ftys.push(cx.tcx().dtor_type()); }
                 return Univariant(mk_struct(cx, &ftys[..], false, t),
diff --git a/src/test/run-pass/issue-33202.rs b/src/test/run-pass/issue-33202.rs
new file mode 100644
index 00000000000..eb4192942f5
--- /dev/null
+++ b/src/test/run-pass/issue-33202.rs
@@ -0,0 +1,18 @@
+// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+#[repr(C)]
+pub enum CPOption<T> {
+    PSome(T),
+}
+
+fn main() {
+  println!("sizeof CPOption<i32> {}", std::mem::size_of::<CPOption<i32>>());
+}