Skip to content

Commit 13f6d7e

Browse files
authored
Rollup merge of #88504 - m-ou-se:turbofish-please-stay, r=oli-obk
Keep turbofish in prelude collision lint. Fixes #88442
2 parents 91c4fee + 532be28 commit 13f6d7e

File tree

4 files changed

+97
-2
lines changed

4 files changed

+97
-2
lines changed

compiler/rustc_typeck/src/check/method/prelude2021.rs

+16-2
Original file line numberDiff line numberDiff line change
@@ -174,8 +174,22 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
174174
sp,
175175
"disambiguate the associated function",
176176
format!(
177-
"{}::{}({}{})",
178-
trait_name, segment.ident.name, self_adjusted, args
177+
"{}::{}{}({}{})",
178+
trait_name,
179+
segment.ident.name,
180+
if let Some(args) = segment.args.as_ref().and_then(|args| self
181+
.sess()
182+
.source_map()
183+
.span_to_snippet(args.span_ext)
184+
.ok())
185+
{
186+
// Keep turbofish.
187+
format!("::{}", args)
188+
} else {
189+
String::new()
190+
},
191+
self_adjusted,
192+
args,
179193
),
180194
Applicability::MachineApplicable,
181195
);
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
// See https://github.com/rust-lang/rust/issues/88442
2+
// run-rustfix
3+
// edition:2018
4+
// check-pass
5+
#![allow(unused)]
6+
#![warn(rust_2021_prelude_collisions)]
7+
8+
trait AnnotatableTryInto {
9+
fn try_into<T>(self) -> Result<T, Self::Error>
10+
where Self: std::convert::TryInto<T> {
11+
std::convert::TryInto::try_into(self)
12+
}
13+
}
14+
15+
impl<T> AnnotatableTryInto for T where T: From<u8> {}
16+
17+
fn main() -> Result<(), &'static str> {
18+
let x: u64 = 1;
19+
AnnotatableTryInto::try_into::<usize>(x).or(Err("foo"))?.checked_sub(1);
20+
//~^ WARNING trait method `try_into` will become ambiguous in Rust 2021
21+
//~| WARNING this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
22+
23+
AnnotatableTryInto::try_into::<usize>(x).or(Err("foo"))?;
24+
//~^ WARNING trait method `try_into` will become ambiguous in Rust 2021
25+
//~| WARNING this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
26+
27+
Ok(())
28+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
// See https://github.com/rust-lang/rust/issues/88442
2+
// run-rustfix
3+
// edition:2018
4+
// check-pass
5+
#![allow(unused)]
6+
#![warn(rust_2021_prelude_collisions)]
7+
8+
trait AnnotatableTryInto {
9+
fn try_into<T>(self) -> Result<T, Self::Error>
10+
where Self: std::convert::TryInto<T> {
11+
std::convert::TryInto::try_into(self)
12+
}
13+
}
14+
15+
impl<T> AnnotatableTryInto for T where T: From<u8> {}
16+
17+
fn main() -> Result<(), &'static str> {
18+
let x: u64 = 1;
19+
x.try_into::<usize>().or(Err("foo"))?.checked_sub(1);
20+
//~^ WARNING trait method `try_into` will become ambiguous in Rust 2021
21+
//~| WARNING this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
22+
23+
x.try_into::<usize>().or(Err("foo"))?;
24+
//~^ WARNING trait method `try_into` will become ambiguous in Rust 2021
25+
//~| WARNING this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
26+
27+
Ok(())
28+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
warning: trait method `try_into` will become ambiguous in Rust 2021
2+
--> $DIR/future-prelude-collision-turbofish.rs:19:5
3+
|
4+
LL | x.try_into::<usize>().or(Err("foo"))?.checked_sub(1);
5+
| ^^^^^^^^^^^^^^^^^^^^^ help: disambiguate the associated function: `AnnotatableTryInto::try_into::<usize>(x)`
6+
|
7+
note: the lint level is defined here
8+
--> $DIR/future-prelude-collision-turbofish.rs:6:9
9+
|
10+
LL | #![warn(rust_2021_prelude_collisions)]
11+
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
12+
= warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
13+
= note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/prelude.html>
14+
15+
warning: trait method `try_into` will become ambiguous in Rust 2021
16+
--> $DIR/future-prelude-collision-turbofish.rs:23:5
17+
|
18+
LL | x.try_into::<usize>().or(Err("foo"))?;
19+
| ^^^^^^^^^^^^^^^^^^^^^ help: disambiguate the associated function: `AnnotatableTryInto::try_into::<usize>(x)`
20+
|
21+
= warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
22+
= note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/prelude.html>
23+
24+
warning: 2 warnings emitted
25+

0 commit comments

Comments
 (0)