diff options
| author | Patrick Walton <pcwalton@mimiga.net> | 2014-07-25 15:56:42 -0700 |
|---|---|---|
| committer | Patrick Walton <pcwalton@mimiga.net> | 2014-07-25 15:58:01 -0700 |
| commit | 5de8ed541a93310f8fae5384ccbf422a8f2fcdcb (patch) | |
| tree | e3a72894416924c6abdeb21f6b09a5083f950bec | |
| parent | 66a0b528a6601d060095655f31c7d38e2a841511 (diff) | |
| download | rust-5de8ed541a93310f8fae5384ccbf422a8f2fcdcb.tar.gz rust-5de8ed541a93310f8fae5384ccbf422a8f2fcdcb.zip | |
librustc: Resolve regions and report errors in trait/impl method
matching.
This breaks code like:
struct Foo<'a,'b> {
x: &'a int,
y: &'b int,
}
trait Tr {
fn foo(x: Self) {}
}
impl<'a,'b> Tr for Foo<'a,'b> {
fn foo(x: Foo<'b,'a>) {} // <-- bad
}
Change this code to not contain a lifetime mismatch error. For example:
struct Foo<'a,'b> {
x: &'a int,
y: &'b int,
}
trait Tr {
fn foo(x: Self) {}
}
impl<'a,'b> Tr for Foo<'a,'b> {
fn foo(x: Foo<'a,'b>) {} // OK
}
Closes #15517.
[breaking-change]
| -rw-r--r-- | src/librustc/middle/typeck/check/mod.rs | 4 | ||||
| -rw-r--r-- | src/test/compile-fail/trait-matching-lifetimes.rs | 30 |
2 files changed, 34 insertions, 0 deletions
diff --git a/src/librustc/middle/typeck/check/mod.rs b/src/librustc/middle/typeck/check/mod.rs index fd6b3a20a19..08a26eefa22 100644 --- a/src/librustc/middle/typeck/check/mod.rs +++ b/src/librustc/middle/typeck/check/mod.rs @@ -1076,6 +1076,10 @@ fn compare_impl_method(tcx: &ty::ctxt, ty::note_and_explain_type_err(tcx, terr); } } + + // Finally, resolve all regions. This catches wily misuses of lifetime + // parameters. + infcx.resolve_regions_and_report_errors(); } fn check_cast(fcx: &FnCtxt, diff --git a/src/test/compile-fail/trait-matching-lifetimes.rs b/src/test/compile-fail/trait-matching-lifetimes.rs new file mode 100644 index 00000000000..f1b30166b5e --- /dev/null +++ b/src/test/compile-fail/trait-matching-lifetimes.rs @@ -0,0 +1,30 @@ +// Copyright 2012 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. + +// Tests that the trait matching code takes lifetime parameters into account. +// (Issue #15517.) + +struct Foo<'a,'b> { + x: &'a int, + y: &'b int, +} + +trait Tr { + fn foo(x: Self) {} +} + +impl<'a,'b> Tr for Foo<'a,'b> { + fn foo(x: Foo<'b,'a>) { + //~^ ERROR method not compatible with trait + //~^^ ERROR method not compatible with trait + } +} + +fn main(){} |
