Skip to content

Commit bb7805f

Browse files
committed
rollup merge of rust-lang#18527 : bkoropoff/issue-18490
2 parents 6f00bee + 107af28 commit bb7805f

File tree

2 files changed

+32
-1
lines changed

2 files changed

+32
-1
lines changed

src/librustc/middle/typeck/check/vtable.rs

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -187,7 +187,11 @@ pub fn check_object_safety(tcx: &ty::ctxt, object_trait: &ty::TyTrait, span: Spa
187187
receiver through a trait object", method_name))
188188
}
189189

190-
ty::StaticExplicitSelfCategory |
190+
ty::StaticExplicitSelfCategory => {
191+
// Static methods are always object-safe since they
192+
// can't be called through a trait object
193+
return msgs
194+
}
191195
ty::ByReferenceExplicitSelfCategory(..) |
192196
ty::ByBoxExplicitSelfCategory => {}
193197
}
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
// Copyright 2014 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+
// Check that object-safe methods are identified as such. Also
12+
// acts as a regression test for #18490
13+
14+
trait Tr {
15+
// Static methods are always safe regardless of other rules
16+
fn new() -> Self;
17+
}
18+
19+
struct St;
20+
21+
impl Tr for St {
22+
fn new() -> St { St }
23+
}
24+
25+
fn main() {
26+
&St as &Tr;
27+
}

0 commit comments

Comments
 (0)