Fix future_prelude_collision false positive

This commit is contained in:
jam1garner 2021-06-27 00:28:07 -04:00
parent a1411de9de
commit bf0da4418f
2 changed files with 23 additions and 0 deletions

View file

@ -57,6 +57,13 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
{
return;
}
// if it's an inherent `self` method (not `&self` or `&mut self`), it will take
// precedence over the `TryInto` impl, and thus won't break in 2021 edition
if pick.autoderefs == 0 && pick.autoref_or_ptr_adjustment.is_none() {
return;
}
// Inherent impls only require not relying on autoref and autoderef in order to
// ensure that the trait implementation won't be used
self.tcx.struct_span_lint_hir(

View file

@ -0,0 +1,16 @@
// edition:2018
// check-pass
#![allow(unused)]
#![deny(future_prelude_collision)]
struct S;
impl S {
fn try_into(self) -> S { S }
}
// See https://github.com/rust-lang/rust/issues/86633
fn main() {
let s = S;
let s2 = s.try_into();
}