All files / src/aggregator/metadata translated-sibling.ts

100% Statements 2/2
100% Branches 0/0
100% Functions 1/1
100% Lines 2/2

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43                                                    22x                           106x    
// SPDX-FileCopyrightText: 2024-2026 Hack23 AB
// SPDX-License-Identifier: Apache-2.0
 
/**
 * @module Aggregator/Metadata/TranslatedSibling
 * @description Filter predicate that identifies translated sibling brief
 * files (e.g. `executive-brief_ar.md`) so they can be excluded from the
 * English-only top-level artefact fallback scan in
 * {@link extractArtifactHighlight}.
 *
 * High-reuse module: import this predicate wherever translated siblings
 * must be excluded from discovery (e.g. tradecraft discovery,
 * template-frontmatter sync).
 */
 
import { ALL_LANGUAGES } from '../../constants/language-core.js';
 
/**
 * Filename suffix pattern that identifies a translated sibling brief
 * (e.g. `executive-brief_ar.md`, `synthesis-summary_zh.md`). The
 * `_<lang>` token is matched against {@link ALL_LANGUAGES} so we never
 * exclude a legitimate English artefact whose name happens to end in
 * `_<two-letter-suffix>.md`.
 *
 * Matching is case-insensitive to handle uppercase variants.
 */
export const TRANSLATED_SIBLING_SUFFIX_RE = new RegExp(`_(${ALL_LANGUAGES.join('|')})\\.md$`, 'i');
 
/**
 * Return `true` when a top-level `.md` filename looks like a translated
 * sibling of a canonical editorial artefact (e.g.
 * `executive-brief_ar.md`). These files must be excluded from the
 * top-level fallback scan in {@link extractArtifactHighlight} because
 * their localized H1s evade the English-only generic-heading detector
 * and would otherwise hijack the English SEO surfaces.
 *
 * @param filename - Run-relative `.md` filename (no path separators)
 * @returns `true` when the file is a translated sibling brief
 */
export function isTranslatedSiblingBrief(filename: string): boolean {
  return TRANSLATED_SIBLING_SUFFIX_RE.test(filename);
}