Support Reference & ReferenceUnknown link lint

This commit is contained in:
Kyle Lin 2023-06-30 22:48:20 +08:00
parent c7369891ba
commit 46df95817d
5 changed files with 1135 additions and 67 deletions

View file

@ -1040,7 +1040,7 @@ impl LinkCollector<'_, '_> {
matches!(ori_link.kind, LinkType::Reference | LinkType::Shortcut),
)?;
self.check_redundant_explicit_link(
self.resolve_display_text(
path_str,
ResolutionInfo {
item_id,
@ -1384,8 +1384,12 @@ impl LinkCollector<'_, '_> {
}
}
/// Check if resolution of inline link's display text and explicit link are same.
fn check_redundant_explicit_link(
/// Resolve display text if the provided link has separated parts of links.
///
/// For example:
/// Inline link `[display_text](dest_link)` and reference link `[display_text][reference_link]` has
/// separated parts of links.
fn resolve_display_text(
&mut self,
explicit_link: &Box<str>,
display_res_info: ResolutionInfo,
@ -1393,33 +1397,80 @@ impl LinkCollector<'_, '_> {
diag_info: &DiagnosticInfo<'_>,
) {
// Check if explicit resolution's path is same as resolution of original link's display text path, e.g.
//
// LinkType::Inline:
//
// [target](target)
// [`target`](target)
// [target](path::to::target)
// [`target`](path::to::target)
// [path::to::target](target)
// [`path::to::target`](target)
// [path::to::target](path::to::target)
// [`path::to::target`](path::to::target)
//
// LinkType::ReferenceUnknown
//
// [target][target]
// [`target`][target]
// [target][path::to::target]
// [`target`][path::to::target]
// [path::to::target][target]
// [`path::to::target`][target]
// [path::to::target][path::to::target]
// [`path::to::target`][path::to::target]
//
// LinkType::Reference
//
// [target][target]
// [`target`][target]
// [target][path::to::target]
// [`target`][path::to::target]
// [path::to::target][target]
// [`path::to::target`][target]
// [path::to::target][path::to::target]
// [`path::to::target`][path::to::target]
//
// [target]: target // or [target]: path::to::target
// [path::to::target]: path::to::target // or [path::to::target]: target
//
// To avoid disambiguator from panicking, we check if display text path is possible to be disambiguated
// into explicit path.
if ori_link.kind != LinkType::Inline {
if !matches!(
ori_link.kind,
LinkType::Inline | LinkType::Reference | LinkType::ReferenceUnknown
) {
return;
}
// Algorithm to check if display text could possibly be the explicit link:
//
// Consider 2 links which are display text and explicit link, pick the shorter
// one as symbol and longer one as full qualified path, and tries to match symbol
// to the full qualified path's last symbol.
//
// Otherwise, check if 2 links are same, if so, skip the resolve process.
//
// Notice that this algorithm is passive, might possibly miss actual redudant cases.
let explicit_link = &explicit_link.to_string();
let display_text = &ori_link.display_text;
let display_len = display_text.len();
let explicit_len = explicit_link.len();
if explicit_len >= display_len
&& &explicit_link[(explicit_len - display_len)..] == display_text
if display_len == explicit_len {
// Whether they are same or not, skip the resolve process.
return;
}
if (explicit_len >= display_len
&& &explicit_link[(explicit_len - display_len)..] == display_text)
|| (display_len >= explicit_len
&& &display_text[(display_len - explicit_len)..] == explicit_link)
{
self.resolve_with_disambiguator_cached(
display_res_info,
diag_info.clone(), // this struct should really be Copy, but Range is not :(
// For reference-style links we want to report only one error so unsuccessful
// resolutions are cached, for other links we want to report an error every
// time so they are not cached.
matches!(ori_link.kind, LinkType::Reference),
false,
);
}
}

View file

@ -1,19 +1,20 @@
use std::ops::Range;
use pulldown_cmark::{Parser, BrokenLink, Event, Tag, LinkType, OffsetIter};
use pulldown_cmark::{BrokenLink, CowStr, Event, LinkType, OffsetIter, Parser, Tag};
use rustc_ast::NodeId;
use rustc_errors::SuggestionStyle;
use rustc_hir::def::{DefKind, DocLinkResMap, Namespace, Res};
use rustc_hir::HirId;
use rustc_hir::def::{Namespace, DefKind, DocLinkResMap, Res};
use rustc_lint_defs::Applicability;
use rustc_span::Symbol;
use crate::clean::Item;
use crate::clean::utils::find_nearest_parent_module;
use crate::clean::Item;
use crate::core::DocContext;
use crate::html::markdown::main_body_opts;
use crate::passes::source_span_for_markdown_range;
#[derive(Debug)]
struct LinkData {
resolvable_link: Option<String>,
resolvable_link_range: Option<Range<usize>>,
@ -34,56 +35,91 @@ pub(crate) fn visit_item(cx: &DocContext<'_>, item: &Item) {
check_redundant_explicit_link(cx, item, hir_id, &doc);
}
fn check_redundant_explicit_link<'md>(cx: &DocContext<'_>, item: &Item, hir_id: HirId, doc: &'md str) {
fn check_redundant_explicit_link<'md>(
cx: &DocContext<'_>,
item: &Item,
hir_id: HirId,
doc: &'md str,
) -> Option<()> {
let mut broken_line_callback = |link: BrokenLink<'md>| Some((link.reference, "".into()));
let mut offset_iter = Parser::new_with_broken_link_callback(&doc, main_body_opts(), Some(&mut broken_line_callback)).into_offset_iter();
while let Some((event, link_range)) = offset_iter.next() {
match event {
Event::Start(Tag::Link(link_type, dest, _)) => {
let link_data = collect_link_data(&mut offset_iter);
let dest = dest.to_string();
if link_type == LinkType::Inline {
check_inline_link_redundancy(cx, item, hir_id, doc, link_range, dest, link_data);
}
}
_ => {}
}
}
}
fn check_inline_link_redundancy(cx: &DocContext<'_>, item: &Item, hir_id: HirId, doc: &str, link_range: Range<usize>, dest: String, link_data: LinkData) -> Option<()> {
let mut offset_iter = Parser::new_with_broken_link_callback(
&doc,
main_body_opts(),
Some(&mut broken_line_callback),
)
.into_offset_iter();
let item_id = item.def_id()?;
let module_id = match cx.tcx.def_kind(item_id) {
DefKind::Mod if item.inner_docs(cx.tcx) => item_id,
_ => find_nearest_parent_module(cx.tcx, item_id).unwrap(),
};
let resolutions = cx.tcx.doc_link_resolutions(module_id);
let (resolvable_link, resolvable_link_range) = (&link_data.resolvable_link?, &link_data.resolvable_link_range?);
let (dest_res, display_res) = (find_resolution(resolutions, &dest)?, find_resolution(resolutions, resolvable_link)?);
while let Some((event, link_range)) = offset_iter.next() {
match event {
Event::Start(Tag::Link(link_type, dest, _)) => match link_type {
LinkType::Inline | LinkType::ReferenceUnknown => {
check_inline_or_reference_unknown_redundancy(
cx,
item,
hir_id,
doc,
resolutions,
link_range,
dest.to_string(),
collect_link_data(&mut offset_iter),
if link_type == LinkType::Inline { (b'(', b')') } else { (b'[', b']') },
);
}
LinkType::Reference => {
check_reference_redundancy(
cx,
item,
hir_id,
doc,
resolutions,
link_range,
&dest,
collect_link_data(&mut offset_iter),
);
}
_ => {}
},
_ => {}
}
}
None
}
/// FIXME(ChAoSUnItY): Too many arguments.
fn check_inline_or_reference_unknown_redundancy(
cx: &DocContext<'_>,
item: &Item,
hir_id: HirId,
doc: &str,
resolutions: &DocLinkResMap,
link_range: Range<usize>,
dest: String,
link_data: LinkData,
(open, close): (u8, u8),
) -> Option<()> {
let (resolvable_link, resolvable_link_range) =
(&link_data.resolvable_link?, &link_data.resolvable_link_range?);
let (dest_res, display_res) =
(find_resolution(resolutions, &dest)?, find_resolution(resolutions, resolvable_link)?);
if dest_res == display_res {
let link_span = source_span_for_markdown_range(
cx.tcx,
&doc,
&link_range,
&item.attrs,
).unwrap_or(item.attr_span(cx.tcx));
let link_span = source_span_for_markdown_range(cx.tcx, &doc, &link_range, &item.attrs)
.unwrap_or(item.attr_span(cx.tcx));
let explicit_span = source_span_for_markdown_range(
cx.tcx,
&doc,
&offset_explicit_range(doc, &link_range, b'(', b')'),
&item.attrs
&offset_explicit_range(doc, link_range, open, close),
&item.attrs,
)?;
let display_span = source_span_for_markdown_range(
cx.tcx,
&doc,
&resolvable_link_range,
&item.attrs
)?;
let display_span =
source_span_for_markdown_range(cx.tcx, &doc, &resolvable_link_range, &item.attrs)?;
cx.tcx.struct_span_lint_hir(crate::lint::REDUNDANT_EXPLICIT_LINKS, hir_id, explicit_span, "redundant explicit link target", |lint| {
lint.span_label(explicit_span, "explicit target is redundant")
@ -98,25 +134,66 @@ fn check_inline_link_redundancy(cx: &DocContext<'_>, item: &Item, hir_id: HirId,
None
}
fn find_resolution<'tcx>(resolutions: &'tcx DocLinkResMap, path: &str) -> Option<&'tcx Res<NodeId>> {
for ns in [Namespace::TypeNS, Namespace::ValueNS, Namespace::MacroNS] {
let Some(Some(res)) = resolutions.get(&(Symbol::intern(path), ns))
else {
continue;
};
/// FIXME(ChAoSUnItY): Too many arguments.
fn check_reference_redundancy(
cx: &DocContext<'_>,
item: &Item,
hir_id: HirId,
doc: &str,
resolutions: &DocLinkResMap,
link_range: Range<usize>,
dest: &CowStr<'_>,
link_data: LinkData,
) -> Option<()> {
let (resolvable_link, resolvable_link_range) =
(&link_data.resolvable_link?, &link_data.resolvable_link_range?);
let (dest_res, display_res) =
(find_resolution(resolutions, &dest)?, find_resolution(resolutions, resolvable_link)?);
return Some(res);
if dest_res == display_res {
let link_span = source_span_for_markdown_range(cx.tcx, &doc, &link_range, &item.attrs)
.unwrap_or(item.attr_span(cx.tcx));
let explicit_span = source_span_for_markdown_range(
cx.tcx,
&doc,
&offset_explicit_range(doc, link_range.clone(), b'[', b']'),
&item.attrs,
)?;
let display_span =
source_span_for_markdown_range(cx.tcx, &doc, &resolvable_link_range, &item.attrs)?;
let def_span = source_span_for_markdown_range(
cx.tcx,
&doc,
&offset_reference_def_range(doc, dest, link_range),
&item.attrs,
)?;
cx.tcx.struct_span_lint_hir(crate::lint::REDUNDANT_EXPLICIT_LINKS, hir_id, explicit_span, "redundant explicit link target", |lint| {
lint.span_label(explicit_span, "explicit target is redundant")
.span_label(display_span, "because label contains path that resolves to same destination")
.span_note(def_span, "referenced explicit link target defined here")
.note("when a link's destination is not specified,\nthe label is used to resolve intra-doc links")
.span_suggestion_with_style(link_span, "remove explicit link target", format!("[{}]", link_data.display_link), Applicability::MaybeIncorrect, SuggestionStyle::ShowAlways);
lint
});
}
None
}
fn find_resolution(resolutions: &DocLinkResMap, path: &str) -> Option<Res<NodeId>> {
[Namespace::TypeNS, Namespace::ValueNS, Namespace::MacroNS]
.into_iter()
.find_map(|ns| resolutions.get(&(Symbol::intern(path), ns)).copied().flatten())
}
/// Collects all neccessary data of link.
fn collect_link_data(offset_iter: &mut OffsetIter<'_, '_>) -> LinkData {
let mut resolvable_link = None;
let mut resolvable_link_range = None;
let mut display_link = String::new();
while let Some((event, range)) = offset_iter.next() {
match event {
Event::Text(code) => {
@ -140,14 +217,10 @@ fn collect_link_data(offset_iter: &mut OffsetIter<'_, '_>) -> LinkData {
}
}
LinkData {
resolvable_link,
resolvable_link_range,
display_link,
}
LinkData { resolvable_link, resolvable_link_range, display_link }
}
fn offset_explicit_range(md: &str, link_range: &Range<usize>, open: u8, close: u8) -> Range<usize> {
fn offset_explicit_range(md: &str, link_range: Range<usize>, open: u8, close: u8) -> Range<usize> {
let mut open_brace = !0;
let mut close_brace = !0;
for (i, b) in md.as_bytes()[link_range.clone()].iter().copied().enumerate().rev() {
@ -159,7 +232,7 @@ fn offset_explicit_range(md: &str, link_range: &Range<usize>, open: u8, close: u
}
if close_brace < link_range.start || close_brace >= link_range.end {
return link_range.clone();
return link_range;
}
let mut nesting = 1;
@ -181,8 +254,44 @@ fn offset_explicit_range(md: &str, link_range: &Range<usize>, open: u8, close: u
assert!(open_brace != close_brace);
if open_brace < link_range.start || open_brace >= link_range.end {
return link_range.clone();
return link_range;
}
// do not actually include braces in the span
(open_brace + 1)..close_brace
}
fn offset_reference_def_range(
md: &str,
dest: &CowStr<'_>,
link_range: Range<usize>,
) -> Range<usize> {
// For diagnostics, we want to underline the link's definition but `span` will point at
// where the link is used. This is a problem for reference-style links, where the definition
// is separate from the usage.
match dest {
// `Borrowed` variant means the string (the link's destination) may come directly from
// the markdown text and we can locate the original link destination.
// NOTE: LinkReplacer also provides `Borrowed` but possibly from other sources,
// so `locate()` can fall back to use `span`.
CowStr::Borrowed(s) => {
// FIXME: remove this function once pulldown_cmark can provide spans for link definitions.
unsafe {
let s_start = dest.as_ptr();
let s_end = s_start.add(s.len());
let md_start = md.as_ptr();
let md_end = md_start.add(md.len());
if md_start <= s_start && s_end <= md_end {
let start = s_start.offset_from(md_start) as usize;
let end = s_end.offset_from(md_start) as usize;
start..end
} else {
link_range
}
}
}
// For anything else, we can only use the provided range.
CowStr::Boxed(_) | CowStr::Inlined(_) => link_range,
}
}

View file

@ -52,3 +52,107 @@ pub fn should_warn_inline() {}
/// [`Vec<T>`](Vec)
/// [`Vec<T>`](std::vec::Vec)
pub fn should_not_warn_inline() {}
/// [dummy_target]
//~^ ERROR redundant explicit link target
/// [`dummy_target`]
//~^ ERROR redundant explicit link target
///
/// [Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`]
//~^ ERROR redundant explicit link target
/// [Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`]
//~^ ERROR redundant explicit link target
///
/// [usize]
//~^ ERROR redundant explicit link target
/// [`usize`]
//~^ ERROR redundant explicit link target
/// [usize]
//~^ ERROR redundant explicit link target
/// [`usize`]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`]
//~^ ERROR redundant explicit link target
///
/// [dummy_target] TEXT
//~^ ERROR redundant explicit link target
/// [`dummy_target`] TEXT
//~^ ERROR redundant explicit link target
pub fn should_warn_reference_unknown() {}
/// [`Vec<T>`][Vec]
/// [`Vec<T>`][std::vec::Vec]
pub fn should_not_warn_reference_unknown() {}
/// [dummy_target]
//~^ ERROR redundant explicit link target
/// [`dummy_target`]
//~^ ERROR redundant explicit link target
///
/// [Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`]
//~^ ERROR redundant explicit link target
/// [Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`]
//~^ ERROR redundant explicit link target
///
/// [usize]
//~^ ERROR redundant explicit link target
/// [`usize`]
//~^ ERROR redundant explicit link target
/// [usize]
//~^ ERROR redundant explicit link target
/// [`usize`]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`]
//~^ ERROR redundant explicit link target
///
/// [dummy_target] TEXT
//~^ ERROR redundant explicit link target
/// [`dummy_target`] TEXT
//~^ ERROR redundant explicit link target
///
/// [dummy_target]: dummy_target
/// [Vec]: Vec
/// [std::vec::Vec]: Vec
/// [usize]: usize
/// [std::primitive::usize]: usize
pub fn should_warn_reference() {}
/// [`Vec<T>`]: Vec
/// [`Vec<T>`]: std::vec::Vec
pub fn should_not_warn_reference() {}

View file

@ -52,3 +52,107 @@ pub fn should_warn_inline() {}
/// [`Vec<T>`](Vec)
/// [`Vec<T>`](std::vec::Vec)
pub fn should_not_warn_inline() {}
/// [dummy_target][dummy_target]
//~^ ERROR redundant explicit link target
/// [`dummy_target`][dummy_target]
//~^ ERROR redundant explicit link target
///
/// [Vec][Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`][Vec]
//~^ ERROR redundant explicit link target
/// [Vec][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec][Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`][Vec]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`][std::vec::Vec]
//~^ ERROR redundant explicit link target
///
/// [usize][usize]
//~^ ERROR redundant explicit link target
/// [`usize`][usize]
//~^ ERROR redundant explicit link target
/// [usize][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`usize`][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize][usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`][usize]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`][std::primitive::usize]
//~^ ERROR redundant explicit link target
///
/// [dummy_target][dummy_target] TEXT
//~^ ERROR redundant explicit link target
/// [`dummy_target`][dummy_target] TEXT
//~^ ERROR redundant explicit link target
pub fn should_warn_reference_unknown() {}
/// [`Vec<T>`][Vec]
/// [`Vec<T>`][std::vec::Vec]
pub fn should_not_warn_reference_unknown() {}
/// [dummy_target][dummy_target]
//~^ ERROR redundant explicit link target
/// [`dummy_target`][dummy_target]
//~^ ERROR redundant explicit link target
///
/// [Vec][Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`][Vec]
//~^ ERROR redundant explicit link target
/// [Vec][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`Vec`][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec][Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`][Vec]
//~^ ERROR redundant explicit link target
/// [std::vec::Vec][std::vec::Vec]
//~^ ERROR redundant explicit link target
/// [`std::vec::Vec`][std::vec::Vec]
//~^ ERROR redundant explicit link target
///
/// [usize][usize]
//~^ ERROR redundant explicit link target
/// [`usize`][usize]
//~^ ERROR redundant explicit link target
/// [usize][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`usize`][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize][usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`][usize]
//~^ ERROR redundant explicit link target
/// [std::primitive::usize][std::primitive::usize]
//~^ ERROR redundant explicit link target
/// [`std::primitive::usize`][std::primitive::usize]
//~^ ERROR redundant explicit link target
///
/// [dummy_target][dummy_target] TEXT
//~^ ERROR redundant explicit link target
/// [`dummy_target`][dummy_target] TEXT
//~^ ERROR redundant explicit link target
///
/// [dummy_target]: dummy_target
/// [Vec]: Vec
/// [std::vec::Vec]: Vec
/// [usize]: usize
/// [std::primitive::usize]: usize
pub fn should_warn_reference() {}
/// [`Vec<T>`]: Vec
/// [`Vec<T>`]: std::vec::Vec
pub fn should_not_warn_reference() {}

View file

@ -303,5 +303,705 @@ help: remove explicit link target
LL | /// [`dummy_target`] TEXT
| ~~~~~~~~~~~~~~~~
error: aborting due to 20 previous errors
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:56:20
|
LL | /// [dummy_target][dummy_target]
| ------------ ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [dummy_target]
| ~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:58:22
|
LL | /// [`dummy_target`][dummy_target]
| -------------- ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`dummy_target`]
| ~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:61:11
|
LL | /// [Vec][Vec]
| --- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [Vec]
| ~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:63:13
|
LL | /// [`Vec`][Vec]
| ----- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`Vec`]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:65:11
|
LL | /// [Vec][std::vec::Vec]
| --- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [Vec]
| ~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:67:13
|
LL | /// [`Vec`][std::vec::Vec]
| ----- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`Vec`]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:69:21
|
LL | /// [std::vec::Vec][Vec]
| ------------- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::vec::Vec]
| ~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:71:23
|
LL | /// [`std::vec::Vec`][Vec]
| --------------- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::vec::Vec`]
| ~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:73:21
|
LL | /// [std::vec::Vec][std::vec::Vec]
| ------------- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::vec::Vec]
| ~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:75:23
|
LL | /// [`std::vec::Vec`][std::vec::Vec]
| --------------- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::vec::Vec`]
| ~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:78:13
|
LL | /// [usize][usize]
| ----- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [usize]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:80:15
|
LL | /// [`usize`][usize]
| ------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`usize`]
| ~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:82:13
|
LL | /// [usize][std::primitive::usize]
| ----- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [usize]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:84:15
|
LL | /// [`usize`][std::primitive::usize]
| ------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`usize`]
| ~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:86:29
|
LL | /// [std::primitive::usize][usize]
| --------------------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::primitive::usize]
| ~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:88:31
|
LL | /// [`std::primitive::usize`][usize]
| ----------------------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::primitive::usize`]
| ~~~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:90:29
|
LL | /// [std::primitive::usize][std::primitive::usize]
| --------------------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::primitive::usize]
| ~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:92:31
|
LL | /// [`std::primitive::usize`][std::primitive::usize]
| ----------------------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::primitive::usize`]
| ~~~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:95:20
|
LL | /// [dummy_target][dummy_target] TEXT
| ------------ ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [dummy_target] TEXT
| ~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:97:22
|
LL | /// [`dummy_target`][dummy_target] TEXT
| -------------- ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`dummy_target`] TEXT
| ~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:105:20
|
LL | /// [dummy_target][dummy_target]
| ------------ ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:149:21
|
LL | /// [dummy_target]: dummy_target
| ^^^^^^^^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [dummy_target]
| ~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:107:22
|
LL | /// [`dummy_target`][dummy_target]
| -------------- ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:149:21
|
LL | /// [dummy_target]: dummy_target
| ^^^^^^^^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`dummy_target`]
| ~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:110:11
|
LL | /// [Vec][Vec]
| --- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:150:12
|
LL | /// [Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [Vec]
| ~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:112:13
|
LL | /// [`Vec`][Vec]
| ----- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:150:12
|
LL | /// [Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`Vec`]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:114:11
|
LL | /// [Vec][std::vec::Vec]
| --- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:151:22
|
LL | /// [std::vec::Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [Vec]
| ~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:116:13
|
LL | /// [`Vec`][std::vec::Vec]
| ----- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:151:22
|
LL | /// [std::vec::Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`Vec`]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:118:21
|
LL | /// [std::vec::Vec][Vec]
| ------------- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:150:12
|
LL | /// [Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::vec::Vec]
| ~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:120:23
|
LL | /// [`std::vec::Vec`][Vec]
| --------------- ^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:150:12
|
LL | /// [Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::vec::Vec`]
| ~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:122:21
|
LL | /// [std::vec::Vec][std::vec::Vec]
| ------------- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:151:22
|
LL | /// [std::vec::Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::vec::Vec]
| ~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:124:23
|
LL | /// [`std::vec::Vec`][std::vec::Vec]
| --------------- ^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:151:22
|
LL | /// [std::vec::Vec]: Vec
| ^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::vec::Vec`]
| ~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:127:13
|
LL | /// [usize][usize]
| ----- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:152:14
|
LL | /// [usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [usize]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:129:15
|
LL | /// [`usize`][usize]
| ------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:152:14
|
LL | /// [usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`usize`]
| ~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:131:13
|
LL | /// [usize][std::primitive::usize]
| ----- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:153:30
|
LL | /// [std::primitive::usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [usize]
| ~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:133:15
|
LL | /// [`usize`][std::primitive::usize]
| ------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:153:30
|
LL | /// [std::primitive::usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`usize`]
| ~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:135:29
|
LL | /// [std::primitive::usize][usize]
| --------------------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:152:14
|
LL | /// [usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::primitive::usize]
| ~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:137:31
|
LL | /// [`std::primitive::usize`][usize]
| ----------------------- ^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:152:14
|
LL | /// [usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::primitive::usize`]
| ~~~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:139:29
|
LL | /// [std::primitive::usize][std::primitive::usize]
| --------------------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:153:30
|
LL | /// [std::primitive::usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [std::primitive::usize]
| ~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:141:31
|
LL | /// [`std::primitive::usize`][std::primitive::usize]
| ----------------------- ^^^^^^^^^^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:153:30
|
LL | /// [std::primitive::usize]: usize
| ^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`std::primitive::usize`]
| ~~~~~~~~~~~~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:144:20
|
LL | /// [dummy_target][dummy_target] TEXT
| ------------ ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:149:21
|
LL | /// [dummy_target]: dummy_target
| ^^^^^^^^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [dummy_target] TEXT
| ~~~~~~~~~~~~~~
error: redundant explicit link target
--> $DIR/redundant_explicit_links.rs:146:22
|
LL | /// [`dummy_target`][dummy_target] TEXT
| -------------- ^^^^^^^^^^^^ explicit target is redundant
| |
| because label contains path that resolves to same destination
|
note: referenced explicit link target defined here
--> $DIR/redundant_explicit_links.rs:149:21
|
LL | /// [dummy_target]: dummy_target
| ^^^^^^^^^^^^
= note: when a link's destination is not specified,
the label is used to resolve intra-doc links
help: remove explicit link target
|
LL | /// [`dummy_target`] TEXT
| ~~~~~~~~~~~~~~~~
error: aborting due to 60 previous errors