angular/tools/manual_api_docs/generate_element_api_json.mts
Paul Gschwendtner 623f5b79fb build: migrate manual_api_docs to rules_js (#61237)
Migrates `manual_api_docs` to `rules_js`. Since compiler CLI is ESM
compiled but doesn't have extensions, we can either bundle or simply use
the dependency as type only. This is easier and sufficient for this
use-case.

PR Close #61237
2025-05-09 16:01:49 +00:00

49 lines
1.4 KiB
TypeScript

/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.dev/license
*/
import type {DocEntry, EntryType} from '@angular/compiler-cli/src/ngtsc/docs';
import {readFileSync, writeFileSync} from 'fs';
import {basename, join} from 'path';
function main() {
const [paramFileExecPath] = process.argv.slice(2);
const paramFileAbsolutePath = join(process.env.JS_BINARY__EXECROOT!, paramFileExecPath);
const rawParamLines = readFileSync(paramFileAbsolutePath, {encoding: 'utf8'}).split('\n');
const [srcs, outputFileExecRootRelativePath] = rawParamLines;
const entries: DocEntry[] = srcs.split(',').map((sourceFilePath) => {
const fileContent = readFileSync(sourceFilePath, {encoding: 'utf8'});
return {
name: basename(sourceFilePath, '.md'),
source: {
filePath: '/' + sourceFilePath,
startLine: 0,
endLine: 0,
},
entryType: 'element' as EntryType.Element,
description: fileContent,
rawComment: fileContent,
jsdocTags: [],
};
});
writeFileSync(
outputFileExecRootRelativePath,
JSON.stringify({
moduleName: '@angular/core',
normalizedModuleName: 'angular_core',
moduleLabel: 'core',
entries,
}),
{encoding: 'utf8'},
);
}
main();