add docs to local Antora extensions

This commit is contained in:
Dan Allen 2023-01-20 18:50:05 -07:00 committed by Steve Riesenberg
parent d9bb586257
commit 53acce43bc
No known key found for this signature in database
GPG Key ID: 5F311AB48A55D521
3 changed files with 33 additions and 13 deletions

View File

@ -5,21 +5,21 @@ const JVM_ARGS='-Xmx3g -XX:+HeapDumpOnOutOfMemoryError'
const REPO_URL = 'https://github.com/spring-projects/spring-security' const REPO_URL = 'https://github.com/spring-projects/spring-security'
const TASK_NAME=':spring-security-docs:generateAntora' const TASK_NAME=':spring-security-docs:generateAntora'
/**
* The purpose of this extension is to inject the Antora Collector configuration into the parsed component version
* descriptor in tags created before Antora Collector was introduced. Antora Collector runs a command to generate a
* replacement antora.yml that a) sets the version from the value of the version property in gradle.properties and b)
* populates AsciiDoc attributes with information from the Gradle build, such as software versions and resource URLs.
*/
module.exports.register = function () { module.exports.register = function () {
this.once('contentAggregated', ({ contentAggregate }) => { this.once('contentAggregated', ({ contentAggregate }) => {
for (const { origins } of contentAggregate) { for (const { origins } of contentAggregate) {
for (const origin of origins) { for (const origin of origins) {
if (origin.url === REPO_URL && origin.descriptor.ext?.collector === undefined) { if (!(origin.url === REPO_URL && origin.descriptor.ext?.collector === undefined)) continue
origin.descriptor.ext = { origin.descriptor.ext = {
collector: { collector: {
run: { run: { command: `${BASE_COMMAND} "-Dorg.gradle.jvmargs=${JVM_ARGS}" ${TASK_NAME}`, local: true },
command: `${BASE_COMMAND} "-Dorg.gradle.jvmargs=${JVM_ARGS}" ${TASK_NAME}`, scan: { dir: './build/generateAntora' },
local: true,
},
scan: {
dir: './build/generateAntora',
},
}
} }
} }
} }

View File

@ -4,8 +4,14 @@ const fsp = require('node:fs/promises')
const ospath = require('node:path') const ospath = require('node:path')
/** /**
* An Antora extension that generates the docsearch config file from a Handlebars template and publishes it with the * An Antora extension that generates a config file that controls the behavior of the docsearch scraper.
* site, where the scraper job can retrieve it. *
* This extension generates a docsearch config file by evaluating a Handlebars template (e.g.,
* .github/actions/docsearch-config.json.hbs). It then publishes the output file to the root of the site
* (docsearch-config.json). The docsearch scraper will retrieve for the config file from the published site.
*
* This extension will only add entries for the latest version in each release line. Additionally, if the page-archived
* or page-noindex attribute is defined in the document header of the page, that page will be excluded from the index.
*/ */
module.exports.register = function ({ config: { templatePath = './docsearch/config.json.hbs' } }) { module.exports.register = function ({ config: { templatePath = './docsearch/config.json.hbs' } }) {
const expandPath = this.require('@antora/expand-path-helper') const expandPath = this.require('@antora/expand-path-helper')

View File

@ -1,5 +1,19 @@
'use strict' 'use strict'
/**
* The purpose of this extension is to fix invalid metadata saved to either antora.yml or gradle.properties in certain
* tags. This invalid metadata prevents Antora from classifying the component versions properly.
*
* This extension addresses with the following cases:
*
* . the boolean value on the prerelease key is incorrectly quoted
* . the prerelease tag is set to true for a GA version
* . the value of the name key is empty
* . the value of the displayVersion key doesn't match the actual version
* . the -SNAPSHOT suffix is appended to the value of the version key instead of the value of the prerelease key
*
* This extension should be listed directly after @antora/collector-extension.
*/
module.exports.register = function () { module.exports.register = function () {
this.once('contentAggregated', ({ contentAggregate }) => { this.once('contentAggregated', ({ contentAggregate }) => {
contentAggregate.forEach((componentVersionBucket) => { contentAggregate.forEach((componentVersionBucket) => {