about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJohann Hemmann <johann.hemmann@code.berlin>2024-01-18 13:36:11 +0100
committerJohann Hemmann <johann.hemmann@code.berlin>2024-01-18 13:36:11 +0100
commitc81728634bb9cf68f7dc74cd1a30973c19a3d00c (patch)
tree9ef4acf43977371734446195d1ce02229f9eeaa8
parentbfc2e568dd862827b987ef979f4b2f04638beb7a (diff)
downloadrust-c81728634bb9cf68f7dc74cd1a30973c19a3d00c.tar.gz
rust-c81728634bb9cf68f7dc74cd1a30973c19a3d00c.zip
Handle intra-doc links with anchor
-rw-r--r--crates/ide/src/doc_links.rs9
1 files changed, 7 insertions, 2 deletions
diff --git a/crates/ide/src/doc_links.rs b/crates/ide/src/doc_links.rs
index f590b14c034..1357f426368 100644
--- a/crates/ide/src/doc_links.rs
+++ b/crates/ide/src/doc_links.rs
@@ -368,16 +368,21 @@ fn rewrite_intra_doc_link(
 ) -> Option<(String, String)> {
     let (link, ns) = parse_intra_doc_link(target);
 
+    let (link, anchor) = match link.split_once('#') {
+        Some((new_link, anchor)) => (new_link, Some(anchor)),
+        None => (link, None),
+    };
+
     let resolved = resolve_doc_path_for_def(db, def, link, ns)?;
     let mut url = get_doc_base_urls(db, resolved, None, None).0?;
 
-    let (_, file, frag) = filename_and_frag_for_def(db, resolved)?;
+    let (_, file, _) = filename_and_frag_for_def(db, resolved)?;
     if let Some(path) = mod_path_of_def(db, resolved) {
         url = url.join(&path).ok()?;
     }
 
     url = url.join(&file).ok()?;
-    url.set_fragment(frag.as_deref());
+    url.set_fragment(anchor);
 
     Some((url.into(), strip_prefixes_suffixes(title).to_string()))
 }