Skip to content

Commit 9b561b1

Browse files
committed
---
yaml --- r: 207253 b: refs/heads/auto c: aca207a h: refs/heads/master i: 207251: 10d2288 v: v3
1 parent 4266a6d commit 9b561b1

File tree

3 files changed

+26
-6
lines changed

3 files changed

+26
-6
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ refs/tags/release-0.3: b5f0d0f648d9a6153664837026ba1be43d3e2503
1010
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
1111
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1212
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
13-
refs/heads/auto: 3bb54a3362a5eae45b345b6cfa690dd863f80fdd
13+
refs/heads/auto: aca207a65c82d7581076772846ef424f1a64449b
1414
refs/heads/servo: af82457af293e2a842ba6b7759b70288da276167
1515
refs/tags/release-0.6: b4ebcfa1812664df5e142f0134a5faea3918544c
1616
refs/tags/0.1: b19db808c2793fe2976759b85a355c3ad8c8b336

branches/auto/src/libsyntax/ext/deriving/show.rs

Lines changed: 11 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -75,6 +75,7 @@ fn show_substructure(cx: &mut ExtCtxt, span: Span,
7575

7676
match *substr.fields {
7777
Struct(ref fields) | EnumMatching(_, _, ref fields) => {
78+
7879
if fields.is_empty() || fields[0].name.is_none() {
7980
// tuple struct/"normal" variant
8081
expr = cx.expr_method_call(span,
@@ -83,11 +84,14 @@ fn show_substructure(cx: &mut ExtCtxt, span: Span,
8384
vec![name]);
8485

8586
for field in fields {
87+
// Use double indirection to make sure this works for unsized types
88+
let field = cx.expr_addr_of(field.span, field.self_.clone());
89+
let field = cx.expr_addr_of(field.span, field);
90+
8691
expr = cx.expr_method_call(span,
8792
expr,
8893
token::str_to_ident("field"),
89-
vec![cx.expr_addr_of(field.span,
90-
field.self_.clone())]);
94+
vec![field]);
9195
}
9296
} else {
9397
// normal struct/struct variant
@@ -100,12 +104,14 @@ fn show_substructure(cx: &mut ExtCtxt, span: Span,
100104
let name = cx.expr_lit(field.span, ast::Lit_::LitStr(
101105
token::get_ident(field.name.clone().unwrap()),
102106
ast::StrStyle::CookedStr));
107+
108+
// Use double indirection to make sure this works for unsized types
109+
let field = cx.expr_addr_of(field.span, field.self_.clone());
110+
let field = cx.expr_addr_of(field.span, field);
103111
expr = cx.expr_method_call(span,
104112
expr,
105113
token::str_to_ident("field"),
106-
vec![name,
107-
cx.expr_addr_of(field.span,
108-
field.self_.clone())]);
114+
vec![name, field]);
109115
}
110116
}
111117
}
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
// Copyright 2015 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+
#[derive(Debug)]
12+
struct Row<T>([T]);
13+
14+
fn main() {}

0 commit comments

Comments
 (0)