Skip to content

Commit 6cc502c

Browse files
committed
Auto merge of #32253 - durka:derive-31886, r=alexcrichton
derive: assume enum repr defaults to isize derive: assume enum repr defaults to isize Fixes #31886. Spawned from #32139. r? @alexcrichton
2 parents 4621dd2 + 9d0748f commit 6cc502c

File tree

2 files changed

+21
-1
lines changed

2 files changed

+21
-1
lines changed

src/libsyntax_ext/deriving/generic/mod.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -758,7 +758,7 @@ impl<'a> TraitDef<'a> {
758758

759759
fn find_repr_type_name(diagnostic: &Handler,
760760
type_attrs: &[ast::Attribute]) -> &'static str {
761-
let mut repr_type_name = "i32";
761+
let mut repr_type_name = "isize";
762762
for a in type_attrs {
763763
for r in &attr::find_repr_attrs(diagnostic, a) {
764764
repr_type_name = match *r {
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
// With no repr attribute the discriminant will default to isize.
12+
// On 32-bit architectures this is equivalent to i32 so the variants
13+
// collide. On other architectures we need compilation to fail anyway,
14+
// so force the repr.
15+
#[cfg_attr(not(target_pointer_width = "32"), repr(i32))]
16+
enum Eu64 {
17+
Au64 = 0,
18+
Bu64 = 0x8000_0000_0000_0000 //~ERROR already exists
19+
}
20+

0 commit comments

Comments
 (0)