UNPKG

jsii-docgen

Version:

generates api docs for jsii modules

123 lines 18.1 kB
"use strict"; 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 fs = __importStar(require("fs/promises")); const path = __importStar(require("node:path")); 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 fs.writeFile(`${output}.${format}`, content.render()); } } 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 * as fs from 'fs/promises';\nimport * as path from 'node:path';\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 fs.writeFile(`${output}.${format}`, content.render());\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"]}