Skip to content

Commit

Permalink
In unsize_unique_expr, do not convert scratch value to lvalue.
Browse files Browse the repository at this point in the history
Fix the issue-20055-box-trait.rs test to actually test `Box<Trait>`.

Fix #21695.
  • Loading branch information
pnkfelix committed Jan 28, 2015
1 parent 5b66c6d commit d855202
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 13 deletions.
5 changes: 0 additions & 5 deletions src/librustc_trans/trans/expr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -475,11 +475,6 @@ fn apply_adjustments<'blk, 'tcx>(bcx: Block<'blk, 'tcx>,
let info = unsized_info(bcx, k, expr.id, unboxed_ty, |t| ty::mk_uniq(tcx, t));
Store(bcx, info, get_len(bcx, scratch.val));

let scratch = unpack_datum!(bcx,
scratch.to_expr_datum().to_lvalue_datum(bcx,
"fresh_uniq_fat_ptr",
expr.id));

DatumBlock::new(bcx, scratch.to_expr_datum())
}
}
Expand Down
24 changes: 16 additions & 8 deletions src/test/run-pass/issue-20055-box-trait.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,14 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.

// See Issues #20055 and #21695.

// We are checking here that the temporaries `Box<[i8, k]>`, for `k`
// in 1, 2, 3, 4, that are induced by the match expression are
// properly handled, in that only *one* will be initialized by
// whichever arm is run, and subsequently dropped at the end of the
// statement surrounding the `match`.

trait Boo { }

impl Boo for [i8; 1] { }
Expand All @@ -16,12 +24,12 @@ impl Boo for [i8; 3] { }
impl Boo for [i8; 4] { }

pub fn foo(box_1: fn () -> Box<[i8; 1]>,
box_2: fn () -> Box<[i8; 20]>,
box_3: fn () -> Box<[i8; 300]>,
box_4: fn () -> Box<[i8; 4000]>,
box_2: fn () -> Box<[i8; 2]>,
box_3: fn () -> Box<[i8; 3]>,
box_4: fn () -> Box<[i8; 4]>,
) {
println!("Hello World 1");
let _: Box<[i8]> = match 3 {
let _: Box<Boo> = match 3 {
1 => box_1(),
2 => box_2(),
3 => box_3(),
Expand All @@ -31,10 +39,10 @@ pub fn foo(box_1: fn () -> Box<[i8; 1]>,
}

pub fn main() {
fn box_1() -> Box<[i8; 1]> { Box::new( [1i8] ) }
fn box_2() -> Box<[i8; 20]> { Box::new( [1i8; 20] ) }
fn box_3() -> Box<[i8; 300]> { Box::new( [1i8; 300] ) }
fn box_4() -> Box<[i8; 4000]> { Box::new( [1i8; 4000] ) }
fn box_1() -> Box<[i8; 1]> { Box::new( [1i8; 1] ) }
fn box_2() -> Box<[i8; 2]> { Box::new( [1i8; 2] ) }
fn box_3() -> Box<[i8; 3]> { Box::new( [1i8; 3] ) }
fn box_4() -> Box<[i8; 4]> { Box::new( [1i8; 4] ) }

foo(box_1, box_2, box_3, box_4);
}
5 changes: 5 additions & 0 deletions src/test/run-pass/issue-20055-box-unsized-array.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,11 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.

// Issue #2005: Check that boxed fixed-size arrays are properly
// accounted for (namely, only deallocated if they were actually
// created) when they appear as temporaries in unused arms of a match
// expression.

pub fn foo(box_1: fn () -> Box<[i8; 1]>,
box_2: fn () -> Box<[i8; 20]>,
box_3: fn () -> Box<[i8; 300]>,
Expand Down

0 comments on commit d855202

Please sign in to comment.