From 6e7622eb5abba77ccb87c8874d900debdae7f000 Mon Sep 17 00:00:00 2001 From: Richard Gibson Date: Tue, 10 Jan 2023 14:11:55 -0500 Subject: [PATCH 1/3] Clarify logic for construction version content --- src/Spec.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Spec.ts b/src/Spec.ts index 95315b90..97237ec9 100644 --- a/src/Spec.ts +++ b/src/Spec.ts @@ -1456,14 +1456,14 @@ ${this.opts.multipage ? `
  • Navigate to/from multipagem Date: Tue, 10 Jan 2023 14:14:40 -0500 Subject: [PATCH 2/3] Require SOURCE_DATE_EPOCH to be a string of digits https://reproducible-builds.org/specs/source-date-epoch/ > The value MUST be an ASCII representation of an integer with no fractional component, identical to the output format of **date +%s**. --- src/cli.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/cli.ts b/src/cli.ts index 8d02b300..d7099cd5 100644 --- a/src/cli.ts +++ b/src/cli.ts @@ -156,9 +156,11 @@ const build = debounce(async function build() { warnings.push(err); }; + // Respect a reproducible build timestamp. + // https://reproducible-builds.org/specs/source-date-epoch/ if (process.env.SOURCE_DATE_EPOCH) { const sde = process.env.SOURCE_DATE_EPOCH.trim(); - if (!/^[0-9]+/.test(sde)) { + if (!/^[0-9]+$/.test(sde)) { fail(`SOURCE_DATE_EPOCH value ${sde} is not valid`); } const ts = +sde; From bcbfd6302170590214528cd7d4b08502b61793d1 Mon Sep 17 00:00:00 2001 From: Richard Gibson Date: Tue, 10 Jan 2023 14:19:20 -0500 Subject: [PATCH 3/3] Consistently trim comma-separated list items --- src/Meta.ts | 3 ++- src/Spec.ts | 2 +- src/Xref.ts | 10 ++++++++-- 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/src/Meta.ts b/src/Meta.ts index 61be6dc4..6728eb3f 100644 --- a/src/Meta.ts +++ b/src/Meta.ts @@ -17,7 +17,7 @@ export default class Meta extends Builder { node .getAttribute('effects')! .split(',') - .map(c => c.trim()), + .map(e => e.trim()), node ); for (const effect of effects) { @@ -40,6 +40,7 @@ export default class Meta extends Builder { const classNames = node .getAttribute('effects')! .split(',') + .map(e => e.trim()) .map(e => `e-${e}`) .join(' '); const span = spec.doc.createElement('span'); diff --git a/src/Spec.ts b/src/Spec.ts index 97237ec9..c11256d0 100644 --- a/src/Spec.ts +++ b/src/Spec.ts @@ -2005,7 +2005,7 @@ async function walk(walker: TreeWalker, context: Context) { throw new Error('oldids found on unsupported element: ' + context.node.nodeName); } oldids - .split(/,/g) + .split(',') .map(s => s.trim()) .forEach(oid => { const s = spec.doc.createElement('span'); diff --git a/src/Xref.ts b/src/Xref.ts index 936e60d9..64902074 100644 --- a/src/Xref.ts +++ b/src/Xref.ts @@ -46,13 +46,19 @@ export default class Xref extends Builder { node.parentElement.children[0] === node ) { if (node.parentElement.hasAttribute('effects')) { - const addEffects = node.parentElement.getAttribute('effects')!.split(','); + const addEffects = node.parentElement + .getAttribute('effects')! + .split(',') + .map(e => e.trim()); if (addEffects.length !== 0) { this.addEffects = validateEffects(spec, addEffects, node.parentElement); } } if (node.parentElement.hasAttribute('suppress-effects')) { - const suppressEffects = node.parentElement.getAttribute('suppress-effects')!.split(','); + const suppressEffects = node.parentElement + .getAttribute('suppress-effects')! + .split(',') + .map(e => e.trim()); if (suppressEffects.length !== 0) { this.suppressEffects = validateEffects(spec, suppressEffects, node.parentElement); }