mirror of
https://github.com/zebrajr/node.git
synced 2025-12-06 12:20:27 +01:00
PR-URL: https://github.com/nodejs/node/pull/37092 Reviewed-By: Zijian Liu <lxxyxzj@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Richard Lau <rlau@redhat.com> Reviewed-By: James M Snell <jasnell@gmail.com>
112 lines
3.0 KiB
JavaScript
112 lines
3.0 KiB
JavaScript
'use strict';
|
|
|
|
// Build stability table to documentation.html/json/md by generated all.json
|
|
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
const unified = require('unified');
|
|
const raw = require('rehype-raw');
|
|
const markdown = require('remark-parse');
|
|
const htmlStringify = require('rehype-stringify');
|
|
const gfm = require('remark-gfm');
|
|
const remark2rehype = require('remark-rehype');
|
|
const visit = require('unist-util-visit');
|
|
|
|
const source = `${__dirname}/../../out/doc/api`;
|
|
const data = require(path.join(source, 'all.json'));
|
|
const mark = '<!-- STABILITY_OVERVIEW_SLOT -->';
|
|
|
|
const output = {
|
|
json: path.join(source, 'stability.json'),
|
|
docHTML: path.join(source, 'documentation.html'),
|
|
docJSON: path.join(source, 'documentation.json'),
|
|
docMarkdown: path.join(source, 'documentation.md'),
|
|
};
|
|
|
|
function collectStability(data) {
|
|
const stability = [];
|
|
|
|
for (const mod of data.modules) {
|
|
if (mod.displayName && mod.stability >= 0) {
|
|
const link = mod.source.replace('doc/api/', '').replace('.md', '.html');
|
|
|
|
stability.push({
|
|
api: mod.name,
|
|
link: link,
|
|
stability: mod.stability,
|
|
stabilityText: `(${mod.stability}) ${mod.stabilityText}`,
|
|
});
|
|
}
|
|
}
|
|
|
|
stability.sort((a, b) => a.api.localeCompare(b.api));
|
|
return stability;
|
|
}
|
|
|
|
function createMarkdownTable(data) {
|
|
const md = ['| API | Stability |', '| --- | --------- |'];
|
|
|
|
for (const mod of data) {
|
|
md.push(`| [${mod.api}](${mod.link}) | ${mod.stabilityText} |`);
|
|
}
|
|
|
|
return md.join('\n');
|
|
}
|
|
|
|
function createHTML(md) {
|
|
const file = unified()
|
|
.use(markdown)
|
|
.use(gfm)
|
|
.use(remark2rehype, { allowDangerousHtml: true })
|
|
.use(raw)
|
|
.use(htmlStringify)
|
|
.use(processStability)
|
|
.processSync(md);
|
|
|
|
return file.contents.trim();
|
|
}
|
|
|
|
function processStability() {
|
|
return (tree) => {
|
|
visit(tree, { type: 'element', tagName: 'tr' }, (node) => {
|
|
const [api, stability] = node.children;
|
|
if (api.tagName !== 'td') {
|
|
return;
|
|
}
|
|
|
|
api.properties.class = 'module_stability';
|
|
|
|
const level = stability.children[0].value[1];
|
|
stability.properties.class = `api_stability api_stability_${level}`;
|
|
});
|
|
};
|
|
}
|
|
|
|
function updateStabilityMark(file, value, mark) {
|
|
const fd = fs.openSync(file, 'r+');
|
|
const content = fs.readFileSync(fd);
|
|
|
|
// Find the position of the `mark`.
|
|
const index = content.indexOf(mark);
|
|
|
|
// Overwrite the mark with `value` parameter.
|
|
const offset = fs.writeSync(fd, value, index, 'utf-8');
|
|
|
|
// Re-write the end of the file after `value`.
|
|
fs.writeSync(fd, content, index + mark.length, undefined, index + offset);
|
|
fs.closeSync(fd);
|
|
}
|
|
|
|
const stability = collectStability(data);
|
|
|
|
// add markdown
|
|
const markdownTable = createMarkdownTable(stability);
|
|
updateStabilityMark(output.docMarkdown, markdownTable, mark);
|
|
|
|
// add html table
|
|
const html = createHTML(markdownTable);
|
|
updateStabilityMark(output.docHTML, html, mark);
|
|
|
|
// add json output
|
|
updateStabilityMark(output.docJSON, JSON.stringify(html), JSON.stringify(mark));
|