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
27 lines
663 B
Rust
27 lines
663 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.
|
|
|
|
#[deny(dead_code)];
|
|
|
|
mod inner {
|
|
pub trait Trait {
|
|
fn f(&self) { f(); }
|
|
}
|
|
|
|
impl Trait for int {}
|
|
|
|
fn f() {}
|
|
}
|
|
|
|
pub fn foo() {
|
|
let a = &1 as &inner::Trait;
|
|
a.f();
|
|
}
|