Skip to content

Commit 0309187

Browse files
---
yaml --- r: 64466 b: refs/heads/snap-stage3 c: eed2d0e h: refs/heads/master v: v3
1 parent c47a480 commit 0309187

File tree

3 files changed

+73
-2
lines changed

3 files changed

+73
-2
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
---
22
refs/heads/master: 2d28d645422c1617be58c8ca7ad9a457264ca850
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4-
refs/heads/snap-stage3: 7af2e6ee451ffa9baacfc3eb04d45f7b3cee295d
4+
refs/heads/snap-stage3: eed2d0e1f2f4c6743b33efa06d5028fcc33db3b1
55
refs/heads/try: 7b78b52e602bb3ea8174f9b2006bff3315f03ef9
66
refs/tags/release-0.1: 1f5c5126e96c79d22cb7862f75304136e204f105
77
refs/heads/ndm: f3868061cd7988080c30d6d5bf352a5a5fe2460b

branches/snap-stage3/src/librustc/middle/trans/debuginfo.rs

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -673,7 +673,9 @@ fn create_enum_metadata(cx: &mut CrateContext,
673673
0) // RuntimeLang
674674
}};
675675
}
676-
_ => { return ptr::null(); }
676+
adt::NullablePointer { nonnull: ref struct_def, nndiscr, _ } => {
677+
return create_adt_struct_metadata(cx, struct_def, variants[nndiscr], None, span);
678+
}
677679
}
678680

679681
fn create_adt_struct_metadata(cx: &mut CrateContext,
Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
// Copyright 2013 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+
// compile-flags:-Z extra-debug-info
12+
// debugger:break zzz
13+
// debugger:run
14+
// debugger:finish
15+
16+
// debugger:print some
17+
// check:$1 = {0x12345678}
18+
19+
// debugger:print none
20+
// check:$2 = {0x0}
21+
22+
// debugger:print full
23+
// check:$3 = {454545, 0x87654321, 9988}
24+
25+
// debugger:print empty
26+
// check:$4 = {0, 0x0, 0}
27+
28+
// debugger:print droid
29+
// check:$5 = {id = 675675, range = 10000001, internals = 0x43218765}
30+
31+
// debugger:print void_droid
32+
// check:$6 = {id = 0, range = 0, internals = 0x0}
33+
34+
35+
// If a struct has exactly two variants, one of them is empty, and the other one
36+
// contains a non-nullable pointer, then this value is used as the discriminator.
37+
// The test cases in this file make sure that something readable is generated for
38+
// this kind of types.
39+
40+
enum MoreFields<'self> {
41+
Full(u32, &'self int, i16),
42+
Empty
43+
}
44+
45+
enum NamedFields<'self> {
46+
Droid { id: i32, range: i64, internals: &'self int },
47+
Void
48+
}
49+
50+
fn main() {
51+
52+
let some : Option<&u32> = Some(unsafe { std::cast::transmute(0x12345678) });
53+
let none : Option<&u32> = None;
54+
55+
let full = Full(454545, unsafe { std::cast::transmute(0x87654321) }, 9988);
56+
57+
let int_val = 0;
58+
let mut empty = Full(0, &int_val, 0);
59+
empty = Empty;
60+
61+
let droid = Droid { id: 675675, range: 10000001, internals: unsafe { std::cast::transmute(0x43218765) } };
62+
63+
let mut void_droid = Droid { id: 0, range: 0, internals: &int_val };
64+
void_droid = Void;
65+
66+
zzz();
67+
}
68+
69+
fn zzz() {()}

0 commit comments

Comments
 (0)