diff options
| author | bors <bors@rust-lang.org> | 2015-01-28 21:49:38 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2015-01-28 21:49:38 +0000 |
| commit | c5961ad06d45689b44ff305c15d6ec7ec65755a9 (patch) | |
| tree | b8b2b5dc33153ef742d1ccf538be537f1476c756 | |
| parent | ee0be3b3e76773618bf230b7188ac633ac0e76aa (diff) | |
| parent | 69bc112e723d3117f81552aeee44e9f6beae3584 (diff) | |
| download | rust-c5961ad06d45689b44ff305c15d6ec7ec65755a9.tar.gz rust-c5961ad06d45689b44ff305c15d6ec7ec65755a9.zip | |
Auto merge of #21522 - nikomatsakis:assoc-type-ice-hunt-take-3, r=nick29581
Do not propagate the region requirements on the projected type to the input types it is being projected from. Fixes #21520. r? @aturon
| -rw-r--r-- | src/librustc_typeck/check/regionmanip.rs | 5 | ||||
| -rw-r--r-- | src/test/run-pass/issue-21520.rs | 29 |
2 files changed, 29 insertions, 5 deletions
diff --git a/src/librustc_typeck/check/regionmanip.rs b/src/librustc_typeck/check/regionmanip.rs index 58e8a9c6912..cbd51a880ce 100644 --- a/src/librustc_typeck/check/regionmanip.rs +++ b/src/librustc_typeck/check/regionmanip.rs @@ -123,11 +123,6 @@ impl<'a, 'tcx> Wf<'a, 'tcx> { // `<T as TraitRef<..>>::Name` self.push_projection_constraint_from_top(data); - - // this seems like a minimal requirement: - let trait_def = ty::lookup_trait_def(self.tcx, data.trait_ref.def_id); - self.accumulate_from_adt(ty, data.trait_ref.def_id, - &trait_def.generics, data.trait_ref.substs) } ty::ty_tup(ref tuptys) => { diff --git a/src/test/run-pass/issue-21520.rs b/src/test/run-pass/issue-21520.rs new file mode 100644 index 00000000000..3a813641a3f --- /dev/null +++ b/src/test/run-pass/issue-21520.rs @@ -0,0 +1,29 @@ +// 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. + +// Test that the requirement (in `Bar`) that `T::Bar : 'static` does +// not wind up propagating to `T`. + +pub trait Foo { + type Bar; + + fn foo(&self) -> Self; +} + +pub struct Static<T:'static>(T); + +struct Bar<T:Foo> + where T::Bar : 'static +{ + x: Static<Option<T::Bar>> +} + +fn main() { } + |
