mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-29 10:13:54 +00:00
Rollup merge of #127310 - chenyukang:yukang-fix-suggest-import-ice, r=estebank
Fix import suggestion ice Fixes #127302 #127302 only crash in edition 2015 #120074 can only reproduced in edition 2021 so I added revisions in test file.
This commit is contained in:
commit
afb2fbf692
@ -1992,12 +1992,12 @@ impl<'a, 'tcx> Resolver<'a, 'tcx> {
|
|||||||
if let Some(candidate) = candidates.get(0) {
|
if let Some(candidate) = candidates.get(0) {
|
||||||
let path = {
|
let path = {
|
||||||
// remove the possible common prefix of the path
|
// remove the possible common prefix of the path
|
||||||
let start_index = (0..failed_segment_idx)
|
let len = candidate.path.segments.len();
|
||||||
.find(|&i| path[i].ident != candidate.path.segments[i].ident)
|
let start_index = (0..=failed_segment_idx.min(len - 1))
|
||||||
|
.find(|&i| path[i].ident.name != candidate.path.segments[i].ident.name)
|
||||||
.unwrap_or_default();
|
.unwrap_or_default();
|
||||||
let segments = (start_index..=failed_segment_idx)
|
let segments =
|
||||||
.map(|s| candidate.path.segments[s].clone())
|
(start_index..len).map(|s| candidate.path.segments[s].clone()).collect();
|
||||||
.collect();
|
|
||||||
Path { segments, span: Span::default(), tokens: None }
|
Path { segments, span: Span::default(), tokens: None }
|
||||||
};
|
};
|
||||||
(
|
(
|
||||||
|
@ -0,0 +1,41 @@
|
|||||||
|
error[E0583]: file not found for module `config`
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:3:1
|
||||||
|
|
|
||||||
|
LL | mod config;
|
||||||
|
| ^^^^^^^^^^^
|
||||||
|
|
|
||||||
|
= help: to create the module `config`, create file "$DIR/config.rs" or "$DIR/config/mod.rs"
|
||||||
|
= note: if there is a `mod config` elsewhere in the crate already, import it with `use crate::...` instead
|
||||||
|
|
||||||
|
error: format argument must be a string literal
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:10:14
|
||||||
|
|
|
||||||
|
LL | println!(args.ctx.compiler.display());
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
|
||||||
|
help: you might be missing a string literal to format with
|
||||||
|
|
|
||||||
|
LL | println!("{}", args.ctx.compiler.display());
|
||||||
|
| +++++
|
||||||
|
|
||||||
|
error[E0425]: cannot find value `args` in this scope
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:6:12
|
||||||
|
|
|
||||||
|
LL | match &args.cmd {
|
||||||
|
| ^^^^ not found in this scope
|
||||||
|
|
|
||||||
|
help: consider importing this function
|
||||||
|
|
|
||||||
|
LL + use std::env::args;
|
||||||
|
|
|
||||||
|
|
||||||
|
error[E0532]: expected unit struct, unit variant or constant, found module `crate::config`
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:7:9
|
||||||
|
|
|
||||||
|
LL | crate::config => {}
|
||||||
|
| ^^^^^^^^^^^^^ not a unit struct, unit variant or constant
|
||||||
|
|
||||||
|
error: aborting due to 4 previous errors
|
||||||
|
|
||||||
|
Some errors have detailed explanations: E0425, E0532, E0583.
|
||||||
|
For more information about an error, try `rustc --explain E0425`.
|
@ -0,0 +1,41 @@
|
|||||||
|
error[E0583]: file not found for module `config`
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:3:1
|
||||||
|
|
|
||||||
|
LL | mod config;
|
||||||
|
| ^^^^^^^^^^^
|
||||||
|
|
|
||||||
|
= help: to create the module `config`, create file "$DIR/config.rs" or "$DIR/config/mod.rs"
|
||||||
|
= note: if there is a `mod config` elsewhere in the crate already, import it with `use crate::...` instead
|
||||||
|
|
||||||
|
error: format argument must be a string literal
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:10:14
|
||||||
|
|
|
||||||
|
LL | println!(args.ctx.compiler.display());
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
|
||||||
|
help: you might be missing a string literal to format with
|
||||||
|
|
|
||||||
|
LL | println!("{}", args.ctx.compiler.display());
|
||||||
|
| +++++
|
||||||
|
|
||||||
|
error[E0425]: cannot find value `args` in this scope
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:6:12
|
||||||
|
|
|
||||||
|
LL | match &args.cmd {
|
||||||
|
| ^^^^ not found in this scope
|
||||||
|
|
|
||||||
|
help: consider importing this function
|
||||||
|
|
|
||||||
|
LL + use std::env::args;
|
||||||
|
|
|
||||||
|
|
||||||
|
error[E0532]: expected unit struct, unit variant or constant, found module `crate::config`
|
||||||
|
--> $DIR/suggest-import-ice-issue-127302.rs:7:9
|
||||||
|
|
|
||||||
|
LL | crate::config => {}
|
||||||
|
| ^^^^^^^^^^^^^ not a unit struct, unit variant or constant
|
||||||
|
|
||||||
|
error: aborting due to 4 previous errors
|
||||||
|
|
||||||
|
Some errors have detailed explanations: E0425, E0532, E0583.
|
||||||
|
For more information about an error, try `rustc --explain E0425`.
|
12
tests/ui/imports/suggest-import-ice-issue-127302.rs
Normal file
12
tests/ui/imports/suggest-import-ice-issue-127302.rs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
//@ revisions: edition2015 edition2021
|
||||||
|
|
||||||
|
mod config; //~ ERROR file not found for module
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
match &args.cmd { //~ ERROR cannot find value `args` in this scope
|
||||||
|
crate::config => {} //~ ERROR expected unit struct, unit variant or constant, found module `crate::config`
|
||||||
|
}
|
||||||
|
|
||||||
|
println!(args.ctx.compiler.display());
|
||||||
|
//~^ ERROR format argument must be a string literal
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
error[E0433]: failed to resolve: unresolved import
|
error[E0433]: failed to resolve: unresolved import
|
||||||
--> $DIR/suggest-import-issue-120074.rs:10:35
|
--> $DIR/suggest-import-issue-120074.rs:12:35
|
||||||
|
|
|
|
||||||
LL | println!("Hello, {}!", crate::bar::do_the_thing);
|
LL | println!("Hello, {}!", crate::bar::do_the_thing);
|
||||||
| ^^^ unresolved import
|
| ^^^ unresolved import
|
@ -0,0 +1,23 @@
|
|||||||
|
error[E0433]: failed to resolve: unresolved import
|
||||||
|
--> $DIR/suggest-import-issue-120074.rs:12:35
|
||||||
|
|
|
||||||
|
LL | println!("Hello, {}!", crate::bar::do_the_thing);
|
||||||
|
| ^^^ unresolved import
|
||||||
|
|
|
||||||
|
help: a similar path exists
|
||||||
|
|
|
||||||
|
LL | println!("Hello, {}!", crate::foo::bar::do_the_thing);
|
||||||
|
| ~~~~~~~~
|
||||||
|
help: consider importing this module
|
||||||
|
|
|
||||||
|
LL + use foo::bar;
|
||||||
|
|
|
||||||
|
help: if you import `bar`, refer to it directly
|
||||||
|
|
|
||||||
|
LL - println!("Hello, {}!", crate::bar::do_the_thing);
|
||||||
|
LL + println!("Hello, {}!", bar::do_the_thing);
|
||||||
|
|
|
||||||
|
|
||||||
|
error: aborting due to 1 previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0433`.
|
@ -1,3 +1,5 @@
|
|||||||
|
//@ revisions: edition2015 edition2021
|
||||||
|
|
||||||
pub mod foo {
|
pub mod foo {
|
||||||
pub mod bar {
|
pub mod bar {
|
||||||
pub fn do_the_thing() -> usize {
|
pub fn do_the_thing() -> usize {
|
||||||
|
Loading…
Reference in New Issue
Block a user