about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2015-01-28 21:49:38 +0000
committerbors <bors@rust-lang.org>2015-01-28 21:49:38 +0000
commitc5961ad06d45689b44ff305c15d6ec7ec65755a9 (patch)
treeb8b2b5dc33153ef742d1ccf538be537f1476c756
parentee0be3b3e76773618bf230b7188ac633ac0e76aa (diff)
parent69bc112e723d3117f81552aeee44e9f6beae3584 (diff)
downloadrust-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.rs5
-rw-r--r--src/test/run-pass/issue-21520.rs29
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() { }
+