diff options
| author | Ariel Ben-Yehuda <arielb1@mail.tau.ac.il> | 2015-07-06 21:38:08 +0300 |
|---|---|---|
| committer | Ariel Ben-Yehuda <ariel.byd@gmail.com> | 2015-07-20 00:16:37 +0300 |
| commit | 8edcff59d9131dfd78cf1897e861f0ee4140db10 (patch) | |
| tree | dcb0056f2480594dd8d8d411455339c43b5b4ae8 /src | |
| parent | 34309cdf12e752104474c8083b17615f642dac29 (diff) | |
| download | rust-8edcff59d9131dfd78cf1897e861f0ee4140db10.tar.gz rust-8edcff59d9131dfd78cf1897e861f0ee4140db10.zip | |
return erased regions from fulfill_obligation
Fixes #26802.
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_trans/trans/common.rs | 10 | ||||
| -rw-r--r-- | src/test/run-pass/issue-26802.rs | 23 |
2 files changed, 29 insertions, 4 deletions
diff --git a/src/librustc_trans/trans/common.rs b/src/librustc_trans/trans/common.rs index d7d3be699cb..7280c13bc5d 100644 --- a/src/librustc_trans/trans/common.rs +++ b/src/librustc_trans/trans/common.rs @@ -905,11 +905,13 @@ pub fn fulfill_obligation<'a, 'tcx>(ccx: &CrateContext<'a, 'tcx>, let vtable = selection.map(|predicate| { fulfill_cx.register_predicate_obligation(&infcx, predicate); }); - let vtable = drain_fulfillment_cx_or_panic(span, &infcx, &mut fulfill_cx, &vtable); + let vtable = erase_regions(tcx, + &drain_fulfillment_cx_or_panic(span, &infcx, &mut fulfill_cx, &vtable) + ); - info!("Cache miss: {:?}", trait_ref); - ccx.trait_cache().borrow_mut().insert(trait_ref, - vtable.clone()); + info!("Cache miss: {:?} => {:?}", trait_ref, vtable); + + ccx.trait_cache().borrow_mut().insert(trait_ref, vtable.clone()); vtable } diff --git a/src/test/run-pass/issue-26802.rs b/src/test/run-pass/issue-26802.rs new file mode 100644 index 00000000000..854340b0eae --- /dev/null +++ b/src/test/run-pass/issue-26802.rs @@ -0,0 +1,23 @@ +// Copyright 2015 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. + +trait Foo<'a> { + fn bar<'b>(&self, x: &'b u8) -> u8 where 'a: 'b { *x+7 } +} + +pub struct FooBar; +impl Foo<'static> for FooBar {} +fn test(foobar: FooBar) -> Box<Foo<'static>> { + Box::new(foobar) +} + +fn main() { + assert_eq!(test(FooBar).bar(&4), 11); +} |
