mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 14:55:26 +00:00
Rollup merge of #131260 - notriddle:notriddle/disambiguator-error, r=GuillaumeGomez
rustdoc: cleaner errors on disambiguator/namespace mismatches Resolves https://github.com/rust-lang/rust/pull/131224#pullrequestreview-2348407077 r? `@jyn514`
This commit is contained in:
commit
f66aa600d9
@ -1996,11 +1996,22 @@ fn resolution_failure(
|
||||
&diag_info,
|
||||
);
|
||||
|
||||
format!(
|
||||
"this link resolves to {}, which is not in the {} namespace",
|
||||
item(res),
|
||||
expected_ns.descr()
|
||||
)
|
||||
if let Some(disambiguator) = disambiguator
|
||||
&& !matches!(disambiguator, Disambiguator::Namespace(..))
|
||||
{
|
||||
format!(
|
||||
"this link resolves to {}, which is not {} {}",
|
||||
item(res),
|
||||
disambiguator.article(),
|
||||
disambiguator.descr()
|
||||
)
|
||||
} else {
|
||||
format!(
|
||||
"this link resolves to {}, which is not in the {} namespace",
|
||||
item(res),
|
||||
expected_ns.descr()
|
||||
)
|
||||
}
|
||||
}
|
||||
};
|
||||
if let Some(span) = sp {
|
||||
|
@ -74,7 +74,7 @@ error: unresolved link to `m`
|
||||
--> $DIR/disambiguator-mismatch.rs:52:14
|
||||
|
|
||||
LL | /// Link to [m()]
|
||||
| ^^^ this link resolves to the macro `m`, which is not in the value namespace
|
||||
| ^^^ this link resolves to the macro `m`, which is not a function
|
||||
|
|
||||
help: to link to the macro, add an exclamation mark
|
||||
|
|
||||
@ -142,7 +142,7 @@ error: unresolved link to `std`
|
||||
--> $DIR/disambiguator-mismatch.rs:83:14
|
||||
|
|
||||
LL | /// Link to [fn@std]
|
||||
| ^^^^^^ this link resolves to the crate `std`, which is not in the value namespace
|
||||
| ^^^^^^ this link resolves to the crate `std`, which is not a function
|
||||
|
|
||||
help: to link to the crate, prefix with `mod@`
|
||||
|
|
||||
@ -164,7 +164,7 @@ error: unresolved link to `S::A`
|
||||
--> $DIR/disambiguator-mismatch.rs:93:14
|
||||
|
|
||||
LL | /// Link to [field@S::A]
|
||||
| ^^^^^^^^^^ this link resolves to the variant `A`, which is not in the value namespace
|
||||
| ^^^^^^^^^^ this link resolves to the variant `A`, which is not a field
|
||||
|
|
||||
help: to link to the variant, prefix with `variant@`
|
||||
|
|
||||
|
@ -98,7 +98,7 @@ pub trait T {
|
||||
/// [m()]
|
||||
//~^ ERROR unresolved link
|
||||
//~| HELP to link to the macro
|
||||
//~| NOTE not in the value namespace
|
||||
//~| NOTE not a function
|
||||
#[macro_export]
|
||||
macro_rules! m {
|
||||
() => {};
|
||||
|
@ -104,7 +104,7 @@ error: unresolved link to `S`
|
||||
--> $DIR/errors.rs:68:6
|
||||
|
|
||||
LL | /// [S!]
|
||||
| ^^ this link resolves to the struct `S`, which is not in the macro namespace
|
||||
| ^^ this link resolves to the struct `S`, which is not a macro
|
||||
|
|
||||
help: to link to the struct, prefix with `struct@`
|
||||
|
|
||||
@ -158,7 +158,7 @@ error: unresolved link to `m`
|
||||
--> $DIR/errors.rs:98:6
|
||||
|
|
||||
LL | /// [m()]
|
||||
| ^^^ this link resolves to the macro `m`, which is not in the value namespace
|
||||
| ^^^ this link resolves to the macro `m`, which is not a function
|
||||
|
|
||||
help: to link to the macro, add an exclamation mark
|
||||
|
|
||||
|
@ -2,7 +2,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/issue-110495-suffix-with-space.rs:3:6
|
||||
|
|
||||
LL | //! [Clone ()].
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
note: the lint level is defined here
|
||||
--> $DIR/issue-110495-suffix-with-space.rs:2:9
|
||||
@ -31,7 +31,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/issue-110495-suffix-with-space.rs:5:7
|
||||
|
|
||||
LL | //! [`Clone ()`].
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
|
@ -40,7 +40,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:27:9
|
||||
|
|
||||
LL | /// [ `Clone ()` ]
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -52,7 +52,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:30:7
|
||||
|
|
||||
LL | /// [`Clone ()` ]
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -64,7 +64,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:33:9
|
||||
|
|
||||
LL | /// [ `Clone ()`]
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -76,7 +76,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:36:9
|
||||
|
|
||||
LL | /// [```Clone ()```]
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -88,7 +88,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:42:13
|
||||
|
|
||||
LL | /// [ ``` Clone () ``` ]
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -122,7 +122,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:74:9
|
||||
|
|
||||
LL | /// [x][Clone()]
|
||||
| ^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -134,7 +134,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:77:9
|
||||
|
|
||||
LL | /// [x][Clone ()]
|
||||
| ^^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -176,7 +176,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:97:9
|
||||
|
|
||||
LL | /// [w](Clone\(\))
|
||||
| ^^^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -188,7 +188,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:103:9
|
||||
|
|
||||
LL | /// [w](Clone())
|
||||
| ^^^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
help: to link to the trait, prefix with `trait@`
|
||||
|
|
||||
@ -256,7 +256,7 @@ error: unresolved link to `Clone`
|
||||
--> $DIR/weird-syntax.rs:132:9
|
||||
|
|
||||
LL | /// The [cln][] link here will produce a plain text suggestion
|
||||
| ^^^^^ this link resolves to the trait `Clone`, which is not in the value namespace
|
||||
| ^^^^^ this link resolves to the trait `Clone`, which is not a function
|
||||
|
|
||||
= help: to link to the trait, prefix with `trait@`: trait@Clone
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user