Skip to content

Commit 4f542f9

Browse files
Ariel Ben-Yehudaarielb1
Ariel Ben-Yehuda
authored andcommitted
traits with self-containing supertraits are not object safe
This should be the last time I fix this function. Fixes rust-lang#38404.
1 parent 7ef1a69 commit 4f542f9

File tree

2 files changed

+20
-2
lines changed

2 files changed

+20
-2
lines changed

src/librustc/traits/object_safety.rs

+4-2
Original file line numberDiff line numberDiff line change
@@ -81,8 +81,10 @@ impl<'a, 'gcx, 'tcx> TyCtxt<'a, 'gcx, 'tcx> {
8181
{
8282
let mut violations = vec![];
8383

84-
if self.supertraits_reference_self(trait_def_id) {
85-
violations.push(ObjectSafetyViolation::SupertraitSelf);
84+
for def_id in traits::supertrait_def_ids(self, trait_def_id) {
85+
if self.supertraits_reference_self(def_id) {
86+
violations.push(ObjectSafetyViolation::SupertraitSelf);
87+
}
8688
}
8789

8890
debug!("astconv_object_safety_violations(trait_def_id={:?}) = {:?}",

src/test/compile-fail/issue-38404.rs

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
trait A<T>: std::ops::Add<Self> + Sized {}
12+
trait B<T>: A<T> {}
13+
trait C<T>: A<B<T, Output=usize>> {}
14+
//~^ ERROR the trait `B` cannot be made into an object
15+
16+
fn main() {}

0 commit comments

Comments
 (0)