0daaeab244
The comments have more information as to why this is done, but the basic idea is that finding an exported trait is actually a fairly difficult problem. The true answer lies in whether a trait is ever referenced from another exported method, and right now this kind of analysis doesn't exist, so the conservative answer of "yes" is always returned to answer whether a trait is exported. Closes #11224 Closes #11225
33 lines
769 B
Rust
33 lines
769 B
Rust
// Copyright 2013 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.
|
|
|
|
use inner::Trait;
|
|
|
|
mod inner {
|
|
pub struct Foo;
|
|
pub trait Trait {
|
|
fn f(&self);
|
|
}
|
|
|
|
impl Trait for Foo {
|
|
fn f(&self) { }
|
|
}
|
|
}
|
|
|
|
pub trait Outer {
|
|
fn foo<T: Trait>(&self, t: T) { t.f(); }
|
|
}
|
|
|
|
impl Outer for int {}
|
|
|
|
pub fn foo<T: Outer>(t: T) {
|
|
t.foo(inner::Foo);
|
|
}
|