diff options
| author | bors <bors@rust-lang.org> | 2016-06-26 22:24:03 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-06-26 22:24:03 -0700 |
| commit | b42884fc64e9c97d8ab2926cb8e4896c32abf93b (patch) | |
| tree | 40e614b80e3e6410e425e8f983f405fb44816097 /src | |
| parent | af2fe634bfa770e7da675210aa661a96cde51275 (diff) | |
| parent | 096ae80b33396f98304f739adb6c56eab98147b0 (diff) | |
| download | rust-b42884fc64e9c97d8ab2926cb8e4896c32abf93b.tar.gz rust-b42884fc64e9c97d8ab2926cb8e4896c32abf93b.zip | |
Auto merge of #34419 - eddyb:virtually-inexistent, r=Aatch
Don't translate vtable methods with Self: Sized bounds. Fixes #34416.
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc/traits/object_safety.rs | 7 | ||||
| -rw-r--r-- | src/test/run-pass/trait-object-exclusion.rs | 28 |
2 files changed, 34 insertions, 1 deletions
diff --git a/src/librustc/traits/object_safety.rs b/src/librustc/traits/object_safety.rs index 8cafa779739..ffa1530a14e 100644 --- a/src/librustc/traits/object_safety.rs +++ b/src/librustc/traits/object_safety.rs @@ -228,9 +228,14 @@ impl<'a, 'gcx, 'tcx> TyCtxt<'a, 'gcx, 'tcx> { /// otherwise ensure that they cannot be used when `Self=Trait`. pub fn is_vtable_safe_method(self, trait_def_id: DefId, - method: &ty::Method<'tcx>) + method: &ty::Method<'gcx>) -> bool { + // Any method that has a `Self : Sized` requisite can't be called. + if self.generics_require_sized_self(&method.generics, &method.predicates) { + return false; + } + self.virtual_call_violation_for_method(trait_def_id, method).is_none() } diff --git a/src/test/run-pass/trait-object-exclusion.rs b/src/test/run-pass/trait-object-exclusion.rs new file mode 100644 index 00000000000..13b725b7c9e --- /dev/null +++ b/src/test/run-pass/trait-object-exclusion.rs @@ -0,0 +1,28 @@ +// Copyright 2016 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 Future: 'static { + // The requirement for Self: Sized must prevent instantiation of + // Future::forget in vtables, otherwise there's an infinite type + // recursion through <Map<...> as Future>::forget. + fn forget(self) where Self: Sized { + Box::new(Map(self)) as Box<Future>; + } +} + +struct Map<A>(A); +impl<A: Future> Future for Map<A> {} + +pub struct Promise; +impl Future for Promise {} + +fn main() { + Promise.forget(); +} |
