diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2014-11-02 18:45:27 -0800 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2014-11-03 08:31:46 -0800 |
| commit | bb7805f58fb1aa02fee037390dab86bd1622bdf2 (patch) | |
| tree | c0fbcc2ce3eb5d8059ec6496514de358ff615a42 /src | |
| parent | 6f00bee168e854c210f13df6d1a41c389b55c51f (diff) | |
| parent | 107af281037e77fbb322b63895fa68dadac61e53 (diff) | |
| download | rust-bb7805f58fb1aa02fee037390dab86bd1622bdf2.tar.gz rust-bb7805f58fb1aa02fee037390dab86bd1622bdf2.zip | |
rollup merge of #18527 : bkoropoff/issue-18490
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc/middle/typeck/check/vtable.rs | 6 | ||||
| -rw-r--r-- | src/test/run-pass/trait-object-safety.rs | 27 |
2 files changed, 32 insertions, 1 deletions
diff --git a/src/librustc/middle/typeck/check/vtable.rs b/src/librustc/middle/typeck/check/vtable.rs index a17194f0085..87b0aed4ac4 100644 --- a/src/librustc/middle/typeck/check/vtable.rs +++ b/src/librustc/middle/typeck/check/vtable.rs @@ -187,7 +187,11 @@ pub fn check_object_safety(tcx: &ty::ctxt, object_trait: &ty::TyTrait, span: Spa receiver through a trait object", method_name)) } - ty::StaticExplicitSelfCategory | + ty::StaticExplicitSelfCategory => { + // Static methods are always object-safe since they + // can't be called through a trait object + return msgs + } ty::ByReferenceExplicitSelfCategory(..) | ty::ByBoxExplicitSelfCategory => {} } diff --git a/src/test/run-pass/trait-object-safety.rs b/src/test/run-pass/trait-object-safety.rs new file mode 100644 index 00000000000..929cb9e7f17 --- /dev/null +++ b/src/test/run-pass/trait-object-safety.rs @@ -0,0 +1,27 @@ +// Copyright 2014 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. + +// Check that object-safe methods are identified as such. Also +// acts as a regression test for #18490 + +trait Tr { + // Static methods are always safe regardless of other rules + fn new() -> Self; +} + +struct St; + +impl Tr for St { + fn new() -> St { St } +} + +fn main() { + &St as &Tr; +} |
