diff options
| author | Johann Hemmann <johann.hemmann@code.berlin> | 2024-01-18 13:36:11 +0100 |
|---|---|---|
| committer | Johann Hemmann <johann.hemmann@code.berlin> | 2024-01-18 13:36:11 +0100 |
| commit | c81728634bb9cf68f7dc74cd1a30973c19a3d00c (patch) | |
| tree | 9ef4acf43977371734446195d1ce02229f9eeaa8 | |
| parent | bfc2e568dd862827b987ef979f4b2f04638beb7a (diff) | |
| download | rust-c81728634bb9cf68f7dc74cd1a30973c19a3d00c.tar.gz rust-c81728634bb9cf68f7dc74cd1a30973c19a3d00c.zip | |
Handle intra-doc links with anchor
| -rw-r--r-- | crates/ide/src/doc_links.rs | 9 |
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())) } |
