Skip to content

Commit

Permalink
Fix @link with declaration reference using !~
Browse files Browse the repository at this point in the history
Resolves #2810
  • Loading branch information
Gerrit0 committed Dec 25, 2024
1 parent 9e667d0 commit d626468
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ title: Changelog
- TypeDoc will now avoid making references to references, #2811.
- Fixed output specific option specification, #2818.
- Improved type reference conversion to avoid including defaulted type arguments, #2820.
- Fixed parsing of declaration references which include a module and a local reference, #2810.
- Improved link resolution logic to prioritize type alias properties with the
same symbol over type literal properties within function parameters.

Expand Down
5 changes: 5 additions & 0 deletions site/declaration-references.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,11 @@ The deliminator is used to determine how to navigate the project tree.
| `#` | Indicates that the next component is a "member", including class instance properties, interface members, and enum members. |
| `~` | Indicates that the next component is an export of a namespace/module. |

> [!warning] The TSDoc specification says that `~` traverses via locals. This is
> different than TypeDoc's behavior. TypeDoc will treat `~` as a stricter `.`
> which only supports navigating to a namespace/module export. It should
> generally be avoided in favor of `.` for improved compatibility with VSCode.
```ts
// module.ts
/**
Expand Down
13 changes: 12 additions & 1 deletion src/lib/converter/comments/declarationReference.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,8 @@ export interface ComponentPath {
* How to resolve the `path`
* - `.` - Navigate via `exports` of symbol
* - `#` - Navigate via `members` of symbol
* - `~` - Navigate via `locals` of symbol
* - `~` - Navigate via `locals` of symbol (note: TypeDoc does not support
* locals, see the declaration reference docs)
*/
navigation: "." | "#" | "~";
path: string;
Expand Down Expand Up @@ -432,6 +433,7 @@ export function parseDeclarationReference(
let moduleSource: string | undefined;
let symbolReference: SymbolReference | undefined;
let resolutionStart: "global" | "local" = "local";
let topLevelLocalReference = false;

const moduleSourceOrSymbolRef = parseModuleSource(source, pos, end);
if (moduleSourceOrSymbolRef) {
Expand All @@ -443,6 +445,12 @@ export function parseDeclarationReference(
pos = moduleSourceOrSymbolRef[1] + 1;
resolutionStart = "global";
moduleSource = moduleSourceOrSymbolRef[0];

// We might be referencing a local of a module
if (source[pos] === "~") {
topLevelLocalReference = true;
pos++;
}
}
} else if (source[pos] === "!") {
pos++;
Expand All @@ -452,6 +460,9 @@ export function parseDeclarationReference(
const ref = parseSymbolReference(source, pos, end);
if (ref) {
symbolReference = ref[0];
if (topLevelLocalReference && symbolReference.path?.length) {
symbolReference.path[0].navigation = "~";
}
pos = ref[1];
}

Expand Down
11 changes: 11 additions & 0 deletions src/test/declarationReference.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -215,5 +215,16 @@ describe("Declaration References", () => {
equal(parse(""), undefined);
equal(parse("@test/foo"), undefined);
});

it("Handles module reference with top level ~ reference", () => {
equal(parse("mod!~foo"), {
moduleSource: "mod",
resolutionStart: "global",
symbolReference: {
path: [{ navigation: "~", path: "foo" }],
meaning: undefined,
},
});
});
});
});

0 comments on commit d626468

Please # to comment.