From 13d2132c2cc59185d52394754ea007ef60f1e133 Mon Sep 17 00:00:00 2001 From: Phillip Webb Date: Tue, 12 Nov 2024 13:12:57 -0800 Subject: [PATCH] Support javadoc lookup when package name has a single component Fix `lib/javadoc-extension.js` so that package lookups also work when the package has a single component. Prior to this commit, a lookup such as `javadoc-location-java: '{url-jdk-javadoc}'` would not work. Fixes gh- --- lib/javadoc-extension.js | 7 +++---- package-lock.json | 4 ++-- test/include-code-extension-test.js | 1 + test/javadoc-extension-test.js | 19 +++++++++++++++++++ 4 files changed, 25 insertions(+), 6 deletions(-) diff --git a/lib/javadoc-extension.js b/lib/javadoc-extension.js index 4225109..c966bef 100644 --- a/lib/javadoc-extension.js +++ b/lib/javadoc-extension.js @@ -54,12 +54,11 @@ function createLinkMarkup (document, target, description, attributes) { function getTargetLocation (document, target) { let name = target.packageReference - let lastDot = name.lastIndexOf('.') - while (lastDot > 0) { + while (name !== '') { const location = document.getAttribute('javadoc-location-' + name.replaceAll('.', '-')) if (location) return location - name = name.substring(0, lastDot) - lastDot = name.lastIndexOf('.') + const lastDot = name.lastIndexOf('.') + name = (lastDot > 0) ? name.substring(0, lastDot) : '' } return document.getAttribute('javadoc-location', 'xref:attachment$api/java') } diff --git a/package-lock.json b/package-lock.json index 59bc536..37d73ea 100644 --- a/package-lock.json +++ b/package-lock.json @@ -12,8 +12,8 @@ "js-yaml": "~4.1" }, "devDependencies": { - "@antora/asciidoc-loader": "*", - "@asciidoctor/core": "*", + "@antora/asciidoc-loader": "latest", + "@asciidoctor/core": "latest", "@asciidoctor/tabs": "1.0.0-beta.6", "chai": "~4.3", "chai-fs": "~2.0", diff --git a/test/include-code-extension-test.js b/test/include-code-extension-test.js index 31444c4..5929504 100644 --- a/test/include-code-extension-test.js +++ b/test/include-code-extension-test.js @@ -307,6 +307,7 @@ describe('include-code-extension', () => { include-code::hello[sync-group-id=thisisauniqueid] ` const actual = run(input, { registerAsciidoctorTabs: true }) + console.log(actual.convert()) expect(actual.convert()).to.contain( 'class="openblock tabs is-sync data-sync-group-id=thisisauniqueid is-loading"' ) diff --git a/test/javadoc-extension-test.js b/test/javadoc-extension-test.js index f7556a8..0bd06c5 100644 --- a/test/javadoc-extension-test.js +++ b/test/javadoc-extension-test.js @@ -159,6 +159,25 @@ describe('javadoc-extension', () => { ) }) + it('should convert with specified location when has single name package specific javadoc-location attributes', () => { + const input = heredoc` + = Page Title + :javadoc-location: xref:api:java + :javadoc-location-java: xref:api:e1 + :javadoc-location-graphql: xref:api:e2 + + javadoc:java.util.ZipFile[] + javadoc:graphql.collect.ImmutableKit[] + ` + const actual = run(input) + expect(actual).to.include( + 'ZipFile' + ) + expect(actual).to.include( + 'ImmutableKit' + ) + }) + it('should convert with specified location when has xref location in macro', () => { const input = heredoc` = Page Title