diff options
| author | Scott A Carr <s.carr1024@gmail.com> | 2016-08-02 11:24:55 -0700 |
|---|---|---|
| committer | Scott A Carr <s.carr1024@gmail.com> | 2016-08-02 11:24:55 -0700 |
| commit | e8bfba7dc8a484a3241055eeeaf7ecb733b54fa6 (patch) | |
| tree | 07c013c5d3e86467462a20a146bbf493f0bb6de5 /src | |
| parent | bda46c21fe30377b9587b584c64ffe99da6c14ce (diff) | |
| download | rust-e8bfba7dc8a484a3241055eeeaf7ecb733b54fa6.tar.gz rust-e8bfba7dc8a484a3241055eeeaf7ecb733b54fa6.zip | |
fix field type, add test
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_mir/transform/deaggregator.rs | 2 | ||||
| -rw-r--r-- | src/test/mir-opt/deaggregator_test.rs | 41 |
2 files changed, 42 insertions, 1 deletions
diff --git a/src/librustc_mir/transform/deaggregator.rs b/src/librustc_mir/transform/deaggregator.rs index 3d8e013c5a7..05bdefab40b 100644 --- a/src/librustc_mir/transform/deaggregator.rs +++ b/src/librustc_mir/transform/deaggregator.rs @@ -59,7 +59,7 @@ impl<'tcx> MirPass<'tcx> for Deaggregator { bb.statements.reserve(n + operands.len() + suffix_stmts.len()); for (i, op) in operands.iter().enumerate() { let ref variant_def = adt_def.variants[variant]; - let ty = variant_def.fields[variant].ty(tcx, substs); + let ty = variant_def.fields[i].ty(tcx, substs); let rhs = Rvalue::Use(op.clone()); // since we don't handle enums, we don't need a cast diff --git a/src/test/mir-opt/deaggregator_test.rs b/src/test/mir-opt/deaggregator_test.rs new file mode 100644 index 00000000000..e57a9674cf6 --- /dev/null +++ b/src/test/mir-opt/deaggregator_test.rs @@ -0,0 +1,41 @@ +// 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. + +struct Baz { + x: usize, + y: f32, + z: bool, +} + +fn bar(a: usize) -> Baz { + Baz { x: a, y: 0.0, z: false } +} + +fn main() {} + +// END RUST SOURCE +// START rustc.node13.Deaggregator.before.mir +// bb0: { +// var0 = arg0; // scope 0 at main.rs:8:8: 8:9 +// tmp0 = var0; // scope 1 at main.rs:9:14: 9:15 +// return = Baz { x: tmp0, y: const F32(0), z: const false }; // scope ... +// goto -> bb1; // scope 1 at main.rs:8:1: 10:2 +// } +// END rustc.node13.Deaggregator.before.mir +// START rustc.node13.Deaggregator.after.mir +// bb0: { +// var0 = arg0; // scope 0 at main.rs:8:8: 8:9 +// tmp0 = var0; // scope 1 at main.rs:9:14: 9:15 +// (return.0: usize) = tmp0; // scope 1 at main.rs:9:5: 9:34 +// (return.1: f32) = const F32(0); // scope 1 at main.rs:9:5: 9:34 +// (return.2: bool) = const false; // scope 1 at main.rs:9:5: 9:34 +// goto -> bb1; // scope 1 at main.rs:8:1: 10:2 +// } +// END rustc.node13.Deaggregator.after.mir \ No newline at end of file |
