jsii-docgen
Version:
generates api docs for jsii modules
125 lines • 18.5 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.main = main;
const node_fs_1 = require("node:fs");
const fs = __importStar(require("node:fs/promises"));
const path = __importStar(require("node:path"));
const promises_1 = require("node:stream/promises");
const yargs = __importStar(require("yargs"));
const transpile_1 = require("./docgen/transpile/transpile");
const index_1 = require("./index");
async function generateForLanguage(docs, options) {
const { format, output } = options;
// e.g. API.typescript as name
const splitByLanguage = output.endsWith(`.${options.language.name}`);
const submoduleSuffix = splitByLanguage ? `${options.language.name}.${format}` : format;
// Ensure the output path exists
const outputPath = path.dirname(output);
await fs.mkdir(outputPath, { recursive: true });
if (options.splitBySubmodules) {
if (format !== 'md') {
throw new Error('split-by-submodule is only supported for markdown');
}
const submodules = await docs.listSubmodules();
for (const submodule of submodules) {
const content = await docs.toMarkdown({
...options,
submodule: submodule.fqn,
allSubmodules: false,
header: { title: `\`${(0, transpile_1.submoduleRelName)(submodule)}\` Submodule`, id: submodule.fqn },
});
await fs.writeFile(path.join(outputPath, `${(0, transpile_1.submoduleRelName)(submodule)}.${submoduleSuffix}`), content.render());
}
await fs.writeFile(`${output}.${format}`, await (await docs.toIndexMarkdown(submoduleSuffix, options)).render());
}
else {
const content = await (format === 'md' ? docs.toMarkdown(options) : docs.toJson(options));
await (0, promises_1.pipeline)(content.stream(), (0, node_fs_1.createWriteStream)(`${output}.${format}`));
}
}
async function main() {
const args = await yargs
.usage('Usage: $0')
.option('output', { alias: 'o', type: 'string', required: false, desc: 'Output filename, the file type is automatically added. Defaults to API.md if format is markdown (-f md) or API.json if format is JSON (-f json). If more than one language is passed, then the language will be included in the filename e.g. API.typescript.md' })
.option('format', { alias: 'f', default: 'md', choices: ['md', 'json'], desc: 'Output format, markdown or json' })
.option('language', { array: true, alias: 'l', default: ['typescript'], choices: transpile_1.Language.values().map(x => x.toString()), desc: 'Output language' })
.option('package', { alias: 'p', type: 'string', required: false, desc: 'The name@version of an NPM package to document', defaultDescription: 'The package in the current directory' })
.option('readme', { alias: 'r', type: 'boolean', required: false, desc: 'Include the user defined README.md in the documentation.' })
.option('submodule', { alias: 's', type: 'string', required: false, desc: 'Generate docs for a specific submodule (or "root")' })
.option('split-by-submodule', { type: 'boolean', required: false, desc: 'Generate a separate file for each submodule' })
.example('$0', 'Generate documentation for the current module as a single file (auto-resolves node dependencies)')
.argv;
const submodule = args.submodule === 'root' ? undefined : args.submodule;
const allSubmodules = !args.submodule;
const readme = args.readme;
const splitBySubmodules = args['split-by-submodule'];
const docs = await (args.package
? index_1.Documentation.forPackage(args.package)
: index_1.Documentation.forProject(process.cwd()));
const options = (lang, output = 'API', includeLanguageInOutputName = false) => {
const format = args.format === 'md' ? 'md' : 'json';
// Clean the user provided output of a possible file ending
let outputFileName = output.endsWith(`.${format}`)
? output.slice(0, -(format.length + 1))
: output;
// for multi language docs, include the language in the filename
if (includeLanguageInOutputName) {
outputFileName = `${outputFileName}.${lang}`;
}
return ({
readme,
language: transpile_1.Language.fromString(lang),
submodule,
allSubmodules,
splitBySubmodules,
format,
output: outputFileName,
});
};
if (args.language.length <= 1) {
await generateForLanguage(docs, options(args.language[0], args.output));
}
else {
for (const lang of args.language) {
await generateForLanguage(docs, options(lang, args.output, true));
}
}
}
main().catch(e => {
console.error(e);
process.exit(1);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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","sourcesContent":["import { createWriteStream } from 'node:fs';\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { pipeline } from 'node:stream/promises';\nimport * as yargs from 'yargs';\nimport { Language, submoduleRelName } from './docgen/transpile/transpile';\nimport { Documentation } from './index';\n\ntype GenerateOptions = {\n  readme?: boolean;\n  language: Language;\n  submodule?: string;\n  allSubmodules?: boolean;\n  splitBySubmodules?: boolean;\n  format: 'md' | 'json';\n  output: string;\n};\n\nasync function generateForLanguage(docs: Documentation, options: GenerateOptions) {\n  const { format, output } = options;\n  // e.g. API.typescript as name\n  const splitByLanguage = output.endsWith(`.${options.language.name}`);\n  const submoduleSuffix = splitByLanguage ? `${options.language.name}.${format}` : format;\n\n  // Ensure the output path exists\n  const outputPath = path.dirname(output);\n  await fs.mkdir(outputPath, { recursive: true });\n\n  if (options.splitBySubmodules) {\n    if (format !== 'md') {\n      throw new Error('split-by-submodule is only supported for markdown');\n    }\n\n    const submodules = await docs.listSubmodules();\n    for (const submodule of submodules) {\n      const content = await docs.toMarkdown({\n        ...options,\n        submodule: submodule.fqn,\n        allSubmodules: false,\n        header: { title: `\\`${submoduleRelName(submodule)}\\` Submodule`, id: submodule.fqn },\n      });\n\n      await fs.writeFile(path.join(outputPath, `${submoduleRelName(submodule)}.${submoduleSuffix}`), content.render());\n    }\n\n    await fs.writeFile(`${output}.${format}`, await (await docs.toIndexMarkdown(submoduleSuffix, options)).render());\n  } else {\n    const content = await (format === 'md' ? docs.toMarkdown(options) : docs.toJson(options));\n    await pipeline(\n      content.stream(),\n      createWriteStream(`${output}.${format}`),\n    );\n  }\n}\n\n\nexport async function main() {\n  const args = await yargs\n    .usage('Usage: $0')\n    .option('output', { alias: 'o', type: 'string', required: false, desc: 'Output filename, the file type is automatically added. Defaults to API.md if format is markdown (-f md) or API.json if format is JSON (-f json). If more than one language is passed, then the language will be included in the filename e.g. API.typescript.md' })\n    .option('format', { alias: 'f', default: 'md', choices: ['md', 'json'], desc: 'Output format, markdown or json' })\n    .option('language', { array: true, alias: 'l', default: ['typescript'], choices: Language.values().map(x => x.toString()), desc: 'Output language' })\n    .option('package', { alias: 'p', type: 'string', required: false, desc: 'The name@version of an NPM package to document', defaultDescription: 'The package in the current directory' })\n    .option('readme', { alias: 'r', type: 'boolean', required: false, desc: 'Include the user defined README.md in the documentation.' })\n    .option('submodule', { alias: 's', type: 'string', required: false, desc: 'Generate docs for a specific submodule (or \"root\")' })\n    .option('split-by-submodule', { type: 'boolean', required: false, desc: 'Generate a separate file for each submodule' })\n    .example('$0', 'Generate documentation for the current module as a single file (auto-resolves node dependencies)')\n    .argv;\n\n  const submodule = args.submodule === 'root' ? undefined : args.submodule;\n  const allSubmodules = !args.submodule;\n  const readme = args.readme;\n  const splitBySubmodules = args['split-by-submodule'];\n  const docs = await (args.package\n    ? Documentation.forPackage(args.package)\n    : Documentation.forProject(process.cwd()));\n\n  const options = (lang: string, output: string = 'API', includeLanguageInOutputName = false): GenerateOptions => {\n    const format = args.format === 'md' ? 'md' : 'json';\n\n    // Clean the user provided output of a possible file ending\n    let outputFileName = output.endsWith(`.${format}`)\n      ? output.slice(0, -(format.length + 1))\n      : output;\n\n    // for multi language docs, include the language in the filename\n    if (includeLanguageInOutputName) {\n      outputFileName = `${outputFileName}.${lang}`;\n    }\n\n    return ({\n      readme,\n      language: Language.fromString(lang),\n      submodule,\n      allSubmodules,\n      splitBySubmodules,\n      format,\n      output: outputFileName,\n    });\n  };\n\n  if (args.language.length <= 1) {\n    await generateForLanguage(docs, options(args.language[0], args.output));\n  } else {\n    for (const lang of args.language) {\n      await generateForLanguage(docs, options(lang, args.output, true));\n    }\n  }\n}\n\nmain().catch(e => {\n  console.error(e);\n  process.exit(1);\n});\n\n"]}