jsii-pacmak 1.55.1 → 1.58.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.js CHANGED
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.pacmak = exports.TargetName = void 0;
4
4
  const jsii_reflect_1 = require("jsii-reflect");
5
5
  const jsii_rosetta_1 = require("jsii-rosetta");
6
+ const path_1 = require("path");
7
+ const process_1 = require("process");
6
8
  const logging = require("./logging");
7
9
  const npm_modules_1 = require("./npm-modules");
8
10
  const targets_1 = require("./targets");
@@ -30,8 +32,11 @@ async function pacmak({ argv = {}, clean = true, codeOnly = false, fingerprint =
30
32
  return;
31
33
  }
32
34
  if (outputDirectory) {
35
+ // Ensure this is consistently interpreted as relative to cwd(). This is transparent for absolute
36
+ // paths, as those would be returned unmodified.
37
+ const absoluteOutputDirectory = path_1.resolve(process_1.cwd(), outputDirectory);
33
38
  for (const mod of modulesToPackageFlat) {
34
- mod.outputDirectory = outputDirectory;
39
+ mod.outputDirectory = absoluteOutputDirectory;
35
40
  }
36
41
  }
37
42
  else if (updateNpmIgnoreFiles) {
@@ -141,4 +146,4 @@ function describePackages(target) {
141
146
  return `${modules.length} modules`;
142
147
  }
143
148
  //#endregion
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import { TypeSystem } from 'jsii-reflect';\nimport { Rosetta, UnknownSnippetMode } from 'jsii-rosetta';\n\nimport * as logging from './logging';\nimport { findJsiiModules, updateAllNpmIgnores } from './npm-modules';\nimport { JsiiModule } from './packaging';\nimport { ALL_BUILDERS, TargetName } from './targets';\nimport { Timers } from './timer';\nimport { Toposorted } from './toposort';\nimport { flatten } from './util';\n\n//#region Exported APIs\n\nexport { TargetName };\nexport { configure as configureLogging } from './logging';\n\n/**\n * Generates code in the desired targets.\n */\nexport async function pacmak({\n  argv = {},\n  clean = true,\n  codeOnly = false,\n  fingerprint = true,\n  force = false,\n  forceSubdirectory = true,\n  forceTarget = false,\n  inputDirectories,\n  outputDirectory,\n  parallel = true,\n  recurse = false,\n  rosettaTablet,\n  targets = Object.values(TargetName),\n  timers = new Timers(),\n  rosettaUnknownSnippets = undefined,\n  updateNpmIgnoreFiles = false,\n  validateAssemblies = false,\n}: PacmakOptions): Promise<void> {\n  const rosetta = new Rosetta({\n    unknownSnippets: rosettaUnknownSnippets,\n    prefixDisclaimer: true,\n  });\n  if (rosettaTablet) {\n    await rosetta.loadTabletFromFile(rosettaTablet);\n  }\n\n  const modulesToPackageSorted = await findJsiiModules(\n    inputDirectories,\n    recurse,\n  );\n  const modulesToPackageFlat = flatten(modulesToPackageSorted);\n\n  logging.info(`Found ${modulesToPackageFlat.length} modules to package`);\n  if (modulesToPackageFlat.length === 0) {\n    logging.warn('Nothing to do');\n    return;\n  }\n\n  if (outputDirectory) {\n    for (const mod of modulesToPackageFlat) {\n      mod.outputDirectory = outputDirectory;\n    }\n  } else if (updateNpmIgnoreFiles) {\n    // if outdir is coming from package.json, verify it is excluded by .npmignore. if it is explicitly\n    // defined via --out, don't perform this verification.\n    await updateAllNpmIgnores(modulesToPackageFlat);\n  }\n\n  await timers.recordAsync('npm pack', () => {\n    logging.info('Packaging NPM bundles');\n    return Promise.all(modulesToPackageFlat.map((m) => m.npmPack()));\n  });\n\n  await timers.recordAsync('load jsii', () => {\n    logging.info('Loading jsii assemblies and translations');\n    const system = new TypeSystem();\n    return Promise.all(\n      modulesToPackageFlat.map(async (m) => {\n        await m.load(system, validateAssemblies);\n        return rosetta.addAssembly(m.assembly.spec, m.moduleDirectory);\n      }),\n    );\n  });\n\n  try {\n    const targetSets = sliceTargets(\n      modulesToPackageSorted,\n      targets,\n      forceTarget,\n    );\n    if (targetSets.every((s) => s.modulesSorted.length === 0)) {\n      throw new Error(\n        `None of the requested packages had any targets to build for '${targets.join(\n          ', ',\n        )}' (use --force-target to force)`,\n      );\n    }\n\n    const perLanguageDirectory = targetSets.length > 1 || forceSubdirectory;\n\n    // We run all target sets in parallel for minimal wall clock time\n    await Promise.all(\n      mapParallelOrSerial(\n        targetSets,\n        async (targetSet) => {\n          logging.info(\n            `Packaging '${targetSet.targetType}' for ${describePackages(\n              targetSet,\n            )}`,\n          );\n          return timers\n            .recordAsync(targetSet.targetType, () =>\n              buildTargetsForLanguage(\n                targetSet.targetType,\n                targetSet.modulesSorted,\n                {\n                  argv,\n                  clean,\n                  codeOnly,\n                  fingerprint,\n                  force,\n                  perLanguageDirectory,\n                  rosetta,\n                },\n              ),\n            )\n            .then(\n              () => logging.info(`${targetSet.targetType} finished`),\n              (err) => {\n                logging.warn(`${targetSet.targetType} failed`);\n                return Promise.reject(err);\n              },\n            );\n        },\n        { parallel },\n      ),\n    );\n  } finally {\n    if (clean) {\n      logging.debug('Cleaning up');\n      await timers.recordAsync('cleanup', () =>\n        Promise.all(modulesToPackageFlat.map((m) => m.cleanup())),\n      );\n    } else {\n      logging.info('Temporary directories retained (--no-clean)');\n    }\n  }\n\n  logging.info(`Packaged. ${timers.display()}`);\n}\n\n/**\n * Options provided to the `pacmak` function.\n */\nexport interface PacmakOptions {\n  /**\n   * All command-line arguments that were provided. This includes target-specific parameters, the\n   * handling of which is up to the code generators.\n   *\n   * @default {}\n   */\n  readonly argv?: { readonly [name: string]: any };\n\n  /**\n   * Whether to clean up temporary directories upon completion.\n   *\n   * @default true\n   */\n  readonly clean?: boolean;\n\n  /**\n   * Whether to generate source code only (as opposed to built packages).\n   *\n   * @default false\n   */\n  readonly codeOnly?: boolean;\n\n  /**\n   * Whether to opportunistically include a fingerprint in generated code, to avoid re-generating\n   * code if the source assembly has not changed.\n   *\n   * @default true\n   */\n  readonly fingerprint?: boolean;\n\n  /**\n   * Whether to always re-generate code, even if the fingerprint has not changed.\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Always emit code in a per-language subdirectory, even if there is only one target language.\n   *\n   * @default true\n   */\n  readonly forceSubdirectory?: boolean;\n\n  /**\n   * Always try to generate code for the selected targets, even if those are not configured. Use this option at your own\n   * risk, as there are significant chances code generators cannot operate without any configuration.\n   *\n   * @default false\n   */\n  readonly forceTarget?: boolean;\n\n  /**\n   * The list of directories to be considered for input assemblies.\n   */\n  readonly inputDirectories: readonly string[];\n\n  /**\n   * The directory in which to output generated packages or code (if  `codeOnly` is `true`).\n   *\n   * @default - Configured in `package.json`\n   */\n  readonly outputDirectory?: string;\n\n  /**\n   * Whether to parallelize code generation. Turning this to `false` can be beneficial in certain resource-constrained\n   * environments, such as free CI/CD offerings, as it reduces the pressure on IO.\n   *\n   * @default true\n   */\n  readonly parallel?: boolean;\n\n  /**\n   * Whether to recursively generate for the selected packages' dependencies.\n   *\n   * @default false\n   */\n  readonly recurse?: boolean;\n\n  /**\n   * How rosetta should treat snippets that cannot be loaded from a translation tablet.\n   *\n   * @default UnknownSnippetMode.VERBATIM\n   */\n  readonly rosettaUnknownSnippets?: UnknownSnippetMode;\n\n  /**\n   * A Rosetta tablet file where translations for code examples can be found.\n   *\n   * @default undefined\n   */\n  readonly rosettaTablet?: string;\n\n  /**\n   * The list of targets for which code should be generated. Unless `forceTarget` is `true`, a given target will only\n   * be generated for assemblies that have configured it.\n   *\n   * @default Object.values(TargetName)\n   */\n  readonly targets?: readonly TargetName[];\n\n  /**\n   * A `Timers` object, if you are interested in including the rosetta run in a larger set of timed operations.\n   */\n  readonly timers?: Timers;\n\n  /**\n   * Whether to update .npmignore files if `outputDirectory` comes from the `package.json` files.\n   *\n   * @default false\n   */\n  readonly updateNpmIgnoreFiles?: boolean;\n\n  /**\n   * Whether assemblies should be validated or not. Validation can be expensive and can be skipped if the assemblies\n   * can be assumed to be valid.\n   *\n   * @default false\n   */\n  readonly validateAssemblies?: boolean;\n}\n\n//#endregion\n\n//#region Building\n\nasync function buildTargetsForLanguage(\n  targetLanguage: string,\n  modules: Toposorted<JsiiModule>,\n  {\n    argv,\n    clean,\n    codeOnly,\n    fingerprint,\n    force,\n    perLanguageDirectory,\n    rosetta,\n  }: {\n    argv: { readonly [name: string]: any };\n    clean: boolean;\n    codeOnly: boolean;\n    fingerprint: boolean;\n    force: boolean;\n    perLanguageDirectory: boolean;\n    rosetta: Rosetta;\n  },\n): Promise<void> {\n  // ``argv.target`` is guaranteed valid by ``yargs`` through the ``choices`` directive.\n  const factory = ALL_BUILDERS[targetLanguage as TargetName];\n  if (!factory) {\n    throw new Error(`Unsupported target: '${targetLanguage}'`);\n  }\n\n  return factory(modules, {\n    clean: clean,\n    codeOnly: codeOnly,\n    rosetta,\n    force: force,\n    fingerprint: fingerprint,\n    arguments: argv,\n    languageSubdirectory: perLanguageDirectory,\n  }).buildModules();\n}\n\n//#endregion\n\n//#region Target Slicing\n\n/**\n * A set of packages (targets) translated into the same language\n */\ninterface TargetSet {\n  targetType: string;\n\n  // Sorted into toposorted tranches\n  modulesSorted: Toposorted<JsiiModule>;\n}\n\nfunction sliceTargets(\n  modulesSorted: Toposorted<JsiiModule>,\n  requestedTargets: readonly TargetName[],\n  force: boolean,\n): readonly TargetSet[] {\n  const ret = new Array<TargetSet>();\n  for (const target of requestedTargets) {\n    ret.push({\n      targetType: target,\n      modulesSorted: modulesSorted\n        .map((modules) =>\n          modules.filter((m) => force || m.availableTargets.includes(target)),\n        )\n        .filter((ms) => ms.length > 0),\n    });\n  }\n  return ret;\n}\n\n//#endregion\n\n//#region Parallelization\n\nfunction mapParallelOrSerial<T, R>(\n  collection: readonly T[],\n  mapper: (item: T) => Promise<R>,\n  { parallel }: { parallel: boolean },\n): Array<Promise<R>> {\n  const result = new Array<Promise<R>>();\n  for (const item of collection) {\n    result.push(\n      result.length === 0 || parallel\n        ? // Running parallel, or first element\n          mapper(item)\n        : // Wait for the previous promise, then make the next one\n          result[result.length - 1].then(\n            () => mapper(item),\n            (error) => Promise.reject(error),\n          ),\n    );\n  }\n  return result;\n}\n\n//#endregion\n\n//#region Misc. Utilities\n\nfunction describePackages(target: TargetSet) {\n  const modules = flatten(target.modulesSorted);\n  if (modules.length > 0 && modules.length < 5) {\n    return modules.map((m) => m.name).join(', ');\n  }\n  return `${modules.length} modules`;\n}\n\n//#endregion\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import { TypeSystem } from 'jsii-reflect';\nimport { Rosetta, UnknownSnippetMode } from 'jsii-rosetta';\nimport { resolve } from 'path';\nimport { cwd } from 'process';\n\nimport * as logging from './logging';\nimport { findJsiiModules, updateAllNpmIgnores } from './npm-modules';\nimport { JsiiModule } from './packaging';\nimport { ALL_BUILDERS, TargetName } from './targets';\nimport { Timers } from './timer';\nimport { Toposorted } from './toposort';\nimport { flatten } from './util';\n\n//#region Exported APIs\n\nexport { TargetName };\nexport { configure as configureLogging } from './logging';\n\n/**\n * Generates code in the desired targets.\n */\nexport async function pacmak({\n  argv = {},\n  clean = true,\n  codeOnly = false,\n  fingerprint = true,\n  force = false,\n  forceSubdirectory = true,\n  forceTarget = false,\n  inputDirectories,\n  outputDirectory,\n  parallel = true,\n  recurse = false,\n  rosettaTablet,\n  targets = Object.values(TargetName),\n  timers = new Timers(),\n  rosettaUnknownSnippets = undefined,\n  updateNpmIgnoreFiles = false,\n  validateAssemblies = false,\n}: PacmakOptions): Promise<void> {\n  const rosetta = new Rosetta({\n    unknownSnippets: rosettaUnknownSnippets,\n    prefixDisclaimer: true,\n  });\n  if (rosettaTablet) {\n    await rosetta.loadTabletFromFile(rosettaTablet);\n  }\n\n  const modulesToPackageSorted = await findJsiiModules(\n    inputDirectories,\n    recurse,\n  );\n  const modulesToPackageFlat = flatten(modulesToPackageSorted);\n\n  logging.info(`Found ${modulesToPackageFlat.length} modules to package`);\n  if (modulesToPackageFlat.length === 0) {\n    logging.warn('Nothing to do');\n    return;\n  }\n\n  if (outputDirectory) {\n    // Ensure this is consistently interpreted as relative to cwd(). This is transparent for absolute\n    // paths, as those would be returned unmodified.\n    const absoluteOutputDirectory = resolve(cwd(), outputDirectory);\n    for (const mod of modulesToPackageFlat) {\n      mod.outputDirectory = absoluteOutputDirectory;\n    }\n  } else if (updateNpmIgnoreFiles) {\n    // if outdir is coming from package.json, verify it is excluded by .npmignore. if it is explicitly\n    // defined via --out, don't perform this verification.\n    await updateAllNpmIgnores(modulesToPackageFlat);\n  }\n\n  await timers.recordAsync('npm pack', () => {\n    logging.info('Packaging NPM bundles');\n    return Promise.all(modulesToPackageFlat.map((m) => m.npmPack()));\n  });\n\n  await timers.recordAsync('load jsii', () => {\n    logging.info('Loading jsii assemblies and translations');\n    const system = new TypeSystem();\n    return Promise.all(\n      modulesToPackageFlat.map(async (m) => {\n        await m.load(system, validateAssemblies);\n        return rosetta.addAssembly(m.assembly.spec, m.moduleDirectory);\n      }),\n    );\n  });\n\n  try {\n    const targetSets = sliceTargets(\n      modulesToPackageSorted,\n      targets,\n      forceTarget,\n    );\n    if (targetSets.every((s) => s.modulesSorted.length === 0)) {\n      throw new Error(\n        `None of the requested packages had any targets to build for '${targets.join(\n          ', ',\n        )}' (use --force-target to force)`,\n      );\n    }\n\n    const perLanguageDirectory = targetSets.length > 1 || forceSubdirectory;\n\n    // We run all target sets in parallel for minimal wall clock time\n    await Promise.all(\n      mapParallelOrSerial(\n        targetSets,\n        async (targetSet) => {\n          logging.info(\n            `Packaging '${targetSet.targetType}' for ${describePackages(\n              targetSet,\n            )}`,\n          );\n          return timers\n            .recordAsync(targetSet.targetType, () =>\n              buildTargetsForLanguage(\n                targetSet.targetType,\n                targetSet.modulesSorted,\n                {\n                  argv,\n                  clean,\n                  codeOnly,\n                  fingerprint,\n                  force,\n                  perLanguageDirectory,\n                  rosetta,\n                },\n              ),\n            )\n            .then(\n              () => logging.info(`${targetSet.targetType} finished`),\n              (err) => {\n                logging.warn(`${targetSet.targetType} failed`);\n                return Promise.reject(err);\n              },\n            );\n        },\n        { parallel },\n      ),\n    );\n  } finally {\n    if (clean) {\n      logging.debug('Cleaning up');\n      await timers.recordAsync('cleanup', () =>\n        Promise.all(modulesToPackageFlat.map((m) => m.cleanup())),\n      );\n    } else {\n      logging.info('Temporary directories retained (--no-clean)');\n    }\n  }\n\n  logging.info(`Packaged. ${timers.display()}`);\n}\n\n/**\n * Options provided to the `pacmak` function.\n */\nexport interface PacmakOptions {\n  /**\n   * All command-line arguments that were provided. This includes target-specific parameters, the\n   * handling of which is up to the code generators.\n   *\n   * @default {}\n   */\n  readonly argv?: { readonly [name: string]: any };\n\n  /**\n   * Whether to clean up temporary directories upon completion.\n   *\n   * @default true\n   */\n  readonly clean?: boolean;\n\n  /**\n   * Whether to generate source code only (as opposed to built packages).\n   *\n   * @default false\n   */\n  readonly codeOnly?: boolean;\n\n  /**\n   * Whether to opportunistically include a fingerprint in generated code, to avoid re-generating\n   * code if the source assembly has not changed.\n   *\n   * @default true\n   */\n  readonly fingerprint?: boolean;\n\n  /**\n   * Whether to always re-generate code, even if the fingerprint has not changed.\n   *\n   * @default false\n   */\n  readonly force?: boolean;\n\n  /**\n   * Always emit code in a per-language subdirectory, even if there is only one target language.\n   *\n   * @default true\n   */\n  readonly forceSubdirectory?: boolean;\n\n  /**\n   * Always try to generate code for the selected targets, even if those are not configured. Use this option at your own\n   * risk, as there are significant chances code generators cannot operate without any configuration.\n   *\n   * @default false\n   */\n  readonly forceTarget?: boolean;\n\n  /**\n   * The list of directories to be considered for input assemblies.\n   */\n  readonly inputDirectories: readonly string[];\n\n  /**\n   * The directory in which to output generated packages or code (if  `codeOnly` is `true`).\n   *\n   * @default - Configured in `package.json`\n   */\n  readonly outputDirectory?: string;\n\n  /**\n   * Whether to parallelize code generation. Turning this to `false` can be beneficial in certain resource-constrained\n   * environments, such as free CI/CD offerings, as it reduces the pressure on IO.\n   *\n   * @default true\n   */\n  readonly parallel?: boolean;\n\n  /**\n   * Whether to recursively generate for the selected packages' dependencies.\n   *\n   * @default false\n   */\n  readonly recurse?: boolean;\n\n  /**\n   * How rosetta should treat snippets that cannot be loaded from a translation tablet.\n   *\n   * @default UnknownSnippetMode.VERBATIM\n   */\n  readonly rosettaUnknownSnippets?: UnknownSnippetMode;\n\n  /**\n   * A Rosetta tablet file where translations for code examples can be found.\n   *\n   * @default undefined\n   */\n  readonly rosettaTablet?: string;\n\n  /**\n   * The list of targets for which code should be generated. Unless `forceTarget` is `true`, a given target will only\n   * be generated for assemblies that have configured it.\n   *\n   * @default Object.values(TargetName)\n   */\n  readonly targets?: readonly TargetName[];\n\n  /**\n   * A `Timers` object, if you are interested in including the rosetta run in a larger set of timed operations.\n   */\n  readonly timers?: Timers;\n\n  /**\n   * Whether to update .npmignore files if `outputDirectory` comes from the `package.json` files.\n   *\n   * @default false\n   */\n  readonly updateNpmIgnoreFiles?: boolean;\n\n  /**\n   * Whether assemblies should be validated or not. Validation can be expensive and can be skipped if the assemblies\n   * can be assumed to be valid.\n   *\n   * @default false\n   */\n  readonly validateAssemblies?: boolean;\n}\n\n//#endregion\n\n//#region Building\n\nasync function buildTargetsForLanguage(\n  targetLanguage: string,\n  modules: Toposorted<JsiiModule>,\n  {\n    argv,\n    clean,\n    codeOnly,\n    fingerprint,\n    force,\n    perLanguageDirectory,\n    rosetta,\n  }: {\n    argv: { readonly [name: string]: any };\n    clean: boolean;\n    codeOnly: boolean;\n    fingerprint: boolean;\n    force: boolean;\n    perLanguageDirectory: boolean;\n    rosetta: Rosetta;\n  },\n): Promise<void> {\n  // ``argv.target`` is guaranteed valid by ``yargs`` through the ``choices`` directive.\n  const factory = ALL_BUILDERS[targetLanguage as TargetName];\n  if (!factory) {\n    throw new Error(`Unsupported target: '${targetLanguage}'`);\n  }\n\n  return factory(modules, {\n    clean: clean,\n    codeOnly: codeOnly,\n    rosetta,\n    force: force,\n    fingerprint: fingerprint,\n    arguments: argv,\n    languageSubdirectory: perLanguageDirectory,\n  }).buildModules();\n}\n\n//#endregion\n\n//#region Target Slicing\n\n/**\n * A set of packages (targets) translated into the same language\n */\ninterface TargetSet {\n  targetType: string;\n\n  // Sorted into toposorted tranches\n  modulesSorted: Toposorted<JsiiModule>;\n}\n\nfunction sliceTargets(\n  modulesSorted: Toposorted<JsiiModule>,\n  requestedTargets: readonly TargetName[],\n  force: boolean,\n): readonly TargetSet[] {\n  const ret = new Array<TargetSet>();\n  for (const target of requestedTargets) {\n    ret.push({\n      targetType: target,\n      modulesSorted: modulesSorted\n        .map((modules) =>\n          modules.filter((m) => force || m.availableTargets.includes(target)),\n        )\n        .filter((ms) => ms.length > 0),\n    });\n  }\n  return ret;\n}\n\n//#endregion\n\n//#region Parallelization\n\nfunction mapParallelOrSerial<T, R>(\n  collection: readonly T[],\n  mapper: (item: T) => Promise<R>,\n  { parallel }: { parallel: boolean },\n): Array<Promise<R>> {\n  const result = new Array<Promise<R>>();\n  for (const item of collection) {\n    result.push(\n      result.length === 0 || parallel\n        ? // Running parallel, or first element\n          mapper(item)\n        : // Wait for the previous promise, then make the next one\n          result[result.length - 1].then(\n            () => mapper(item),\n            (error) => Promise.reject(error),\n          ),\n    );\n  }\n  return result;\n}\n\n//#endregion\n\n//#region Misc. Utilities\n\nfunction describePackages(target: TargetSet) {\n  const modules = flatten(target.modulesSorted);\n  if (modules.length > 0 && modules.length < 5) {\n    return modules.map((m) => m.name).join(', ');\n  }\n  return `${modules.length} modules`;\n}\n\n//#endregion\n"]}
@@ -152,10 +152,10 @@ exports.DotNetDocGenerator = DotNetDocGenerator;
152
152
  * Uppercase the first letter
153
153
  */
154
154
  function ucFirst(x) {
155
- return x.substr(0, 1).toUpperCase() + x.substr(1);
155
+ return x.slice(0, 1).toUpperCase() + x.slice(1);
156
156
  }
157
157
  function shouldMentionStability(s) {
158
158
  // Don't render "stable" or "external", those are both stable by implication
159
159
  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;
160
160
  }
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotnetdocgenerator.js","sourceRoot":"","sources":["dotnetdocgenerator.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport { CodeMaker } from 'codemaker';\nimport {\n  Rosetta,\n  TargetLanguage,\n  enforcesStrictMode,\n  markDownToXmlDoc,\n  ApiLocation,\n} from 'jsii-rosetta';\nimport * as xmlbuilder from 'xmlbuilder';\n\nimport { renderSummary } from '../_utils';\nimport { DotNetNameUtils } from './nameutils';\n\n/**\n * Generates the Jsii attributes and calls for the .NET runtime\n *\n * Uses the same instance of CodeMaker as the rest of the code\n */\nexport class DotNetDocGenerator {\n  private readonly code: CodeMaker;\n  private readonly nameutils: DotNetNameUtils = new DotNetNameUtils();\n\n  public constructor(\n    code: CodeMaker,\n    private readonly rosetta: Rosetta,\n    private readonly assembly: spec.Assembly,\n  ) {\n    this.code = code;\n  }\n\n  /**\n   * Emits all documentation depending on what is available in the jsii model\n   *\n   * Used by all kind of members + classes, interfaces, enums\n   * Order should be\n   * Summary\n   * Param\n   * Returns\n   * Remarks (includes examples, links, deprecated)\n   */\n  public emitDocs(obj: spec.Documentable, apiLocation: ApiLocation): void {\n    const docs = obj.docs;\n\n    // The docs may be undefined at the method level but not the parameters level\n    this.emitXmlDoc('summary', renderSummary(obj.docs));\n\n    // Handling parameters only if the obj is a method\n    const objMethod = obj as spec.Method;\n    if (objMethod.parameters) {\n      objMethod.parameters.forEach((param) => {\n        // Remove any slug `@` from the parameter name - it's not supposed to show up here.\n        const paramName = this.nameutils\n          .convertParameterName(param.name)\n          .replace(/^@/, '');\n        this.emitXmlDoc('param', param.docs?.summary ?? '', {\n          attributes: { name: paramName },\n        });\n      });\n    }\n\n    // At this pdocfx namespacedocd a valid instance of docs\n    if (!docs) {\n      return;\n    }\n\n    if (docs.returns) {\n      this.emitXmlDoc('returns', docs.returns);\n    }\n\n    // Remarks does not use emitXmlDoc() because the remarks can contain code blocks\n    // which are fenced with <code> tags, which would be escaped to\n    // &lt;code&gt; if we used the xml builder.\n    const remarks = this.renderRemarks(docs, apiLocation);\n    if (remarks.length > 0) {\n      this.code.line('/// <remarks>');\n      remarks.forEach((r) => this.code.line(`/// ${r}`.trimRight()));\n      this.code.line('/// </remarks>');\n    }\n\n    if (docs.example) {\n      this.code.line('/// <example>');\n      this.emitXmlDoc('code', this.convertExample(docs.example, apiLocation));\n      this.code.line('/// </example>');\n    }\n  }\n\n  public emitMarkdownAsRemarks(\n    markdown: string | undefined,\n    apiLocation: ApiLocation,\n  ) {\n    if (!markdown) {\n      return;\n    }\n\n    const translated = markDownToXmlDoc(\n      this.convertSamplesInMarkdown(markdown, apiLocation),\n    );\n    const lines = translated.split('\\n');\n\n    this.code.line('/// <remarks>');\n    for (const line of lines) {\n      this.code.line(`/// ${line}`.trimRight());\n    }\n    this.code.line('/// </remarks>');\n  }\n\n  /**\n   * Returns the lines that should go into the <remarks> section\n   */\n  private renderRemarks(docs: spec.Docs, apiLocation: ApiLocation): string[] {\n    const ret: string[] = [];\n\n    if (docs.remarks) {\n      const translated = markDownToXmlDoc(\n        this.convertSamplesInMarkdown(docs.remarks, apiLocation),\n      );\n      ret.push(...translated.split('\\n'));\n      ret.push('');\n    }\n\n    // All the \"tags\" need to be rendered with empyt lines between them or they'll be word wrapped.\n\n    if (docs.default) {\n      emitDocAttribute('default', docs.default);\n    }\n    if (docs.stability && shouldMentionStability(docs.stability)) {\n      emitDocAttribute(\n        'stability',\n        this.nameutils.capitalizeWord(docs.stability),\n      );\n    }\n    if (docs.see) {\n      emitDocAttribute('see', docs.see);\n    }\n    if (docs.subclassable) {\n      emitDocAttribute('subclassable', '');\n    }\n    for (const [k, v] of Object.entries(docs.custom ?? {})) {\n      const extraSpace = k === 'link' ? ' ' : ''; // Extra space for '@link' to keep unit tests happy\n      emitDocAttribute(k, v + extraSpace);\n    }\n\n    // Remove leading and trailing empty lines\n    while (ret.length > 0 && ret[0] === '') {\n      ret.shift();\n    }\n    while (ret.length > 0 && ret[ret.length - 1] === '') {\n      ret.pop();\n    }\n\n    return ret;\n\n    function emitDocAttribute(name: string, contents: string) {\n      const ls = contents.split('\\n');\n      ret.push(`<strong>${ucFirst(name)}</strong>: ${ls[0]}`);\n      ret.push(...ls.slice(1));\n      ret.push('');\n    }\n  }\n\n  private convertExample(example: string, apiLocation: ApiLocation): string {\n    const translated = this.rosetta.translateExample(\n      apiLocation,\n      example,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n    );\n    return translated.source;\n  }\n\n  private convertSamplesInMarkdown(markdown: string, api: ApiLocation): string {\n    return this.rosetta.translateSnippetsInMarkdown(\n      api,\n      markdown,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n    );\n  }\n  private emitXmlDoc(\n    tag: string,\n    content: string,\n    { attributes = {} }: { attributes?: { [name: string]: string } } = {},\n  ): void {\n    if (!content) {\n      return;\n    }\n\n    const xml = xmlbuilder.create(tag, { headless: true }).text(content);\n    for (const [name, value] of Object.entries(attributes)) {\n      xml.att(name, value);\n    }\n    const xmlstring = xml.end({ allowEmpty: true, pretty: false });\n    const trimLeft = tag !== 'code';\n    for (const line of xmlstring\n      .split('\\n')\n      .map((x) => (trimLeft ? x.trim() : x.trimRight()))) {\n      this.code.line(`/// ${line}`);\n    }\n  }\n}\n\n/**\n * Uppercase the first letter\n */\nfunction ucFirst(x: string) {\n  return x.substr(0, 1).toUpperCase() + x.substr(1);\n}\n\nfunction shouldMentionStability(s: spec.Stability) {\n  // Don't render \"stable\" or \"external\", those are both stable by implication\n  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;\n}\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dotnetdocgenerator.js","sourceRoot":"","sources":["dotnetdocgenerator.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport { CodeMaker } from 'codemaker';\nimport {\n  Rosetta,\n  TargetLanguage,\n  enforcesStrictMode,\n  markDownToXmlDoc,\n  ApiLocation,\n} from 'jsii-rosetta';\nimport * as xmlbuilder from 'xmlbuilder';\n\nimport { renderSummary } from '../_utils';\nimport { DotNetNameUtils } from './nameutils';\n\n/**\n * Generates the Jsii attributes and calls for the .NET runtime\n *\n * Uses the same instance of CodeMaker as the rest of the code\n */\nexport class DotNetDocGenerator {\n  private readonly code: CodeMaker;\n  private readonly nameutils: DotNetNameUtils = new DotNetNameUtils();\n\n  public constructor(\n    code: CodeMaker,\n    private readonly rosetta: Rosetta,\n    private readonly assembly: spec.Assembly,\n  ) {\n    this.code = code;\n  }\n\n  /**\n   * Emits all documentation depending on what is available in the jsii model\n   *\n   * Used by all kind of members + classes, interfaces, enums\n   * Order should be\n   * Summary\n   * Param\n   * Returns\n   * Remarks (includes examples, links, deprecated)\n   */\n  public emitDocs(obj: spec.Documentable, apiLocation: ApiLocation): void {\n    const docs = obj.docs;\n\n    // The docs may be undefined at the method level but not the parameters level\n    this.emitXmlDoc('summary', renderSummary(obj.docs));\n\n    // Handling parameters only if the obj is a method\n    const objMethod = obj as spec.Method;\n    if (objMethod.parameters) {\n      objMethod.parameters.forEach((param) => {\n        // Remove any slug `@` from the parameter name - it's not supposed to show up here.\n        const paramName = this.nameutils\n          .convertParameterName(param.name)\n          .replace(/^@/, '');\n        this.emitXmlDoc('param', param.docs?.summary ?? '', {\n          attributes: { name: paramName },\n        });\n      });\n    }\n\n    // At this pdocfx namespacedocd a valid instance of docs\n    if (!docs) {\n      return;\n    }\n\n    if (docs.returns) {\n      this.emitXmlDoc('returns', docs.returns);\n    }\n\n    // Remarks does not use emitXmlDoc() because the remarks can contain code blocks\n    // which are fenced with <code> tags, which would be escaped to\n    // &lt;code&gt; if we used the xml builder.\n    const remarks = this.renderRemarks(docs, apiLocation);\n    if (remarks.length > 0) {\n      this.code.line('/// <remarks>');\n      remarks.forEach((r) => this.code.line(`/// ${r}`.trimRight()));\n      this.code.line('/// </remarks>');\n    }\n\n    if (docs.example) {\n      this.code.line('/// <example>');\n      this.emitXmlDoc('code', this.convertExample(docs.example, apiLocation));\n      this.code.line('/// </example>');\n    }\n  }\n\n  public emitMarkdownAsRemarks(\n    markdown: string | undefined,\n    apiLocation: ApiLocation,\n  ) {\n    if (!markdown) {\n      return;\n    }\n\n    const translated = markDownToXmlDoc(\n      this.convertSamplesInMarkdown(markdown, apiLocation),\n    );\n    const lines = translated.split('\\n');\n\n    this.code.line('/// <remarks>');\n    for (const line of lines) {\n      this.code.line(`/// ${line}`.trimRight());\n    }\n    this.code.line('/// </remarks>');\n  }\n\n  /**\n   * Returns the lines that should go into the <remarks> section\n   */\n  private renderRemarks(docs: spec.Docs, apiLocation: ApiLocation): string[] {\n    const ret: string[] = [];\n\n    if (docs.remarks) {\n      const translated = markDownToXmlDoc(\n        this.convertSamplesInMarkdown(docs.remarks, apiLocation),\n      );\n      ret.push(...translated.split('\\n'));\n      ret.push('');\n    }\n\n    // All the \"tags\" need to be rendered with empyt lines between them or they'll be word wrapped.\n\n    if (docs.default) {\n      emitDocAttribute('default', docs.default);\n    }\n    if (docs.stability && shouldMentionStability(docs.stability)) {\n      emitDocAttribute(\n        'stability',\n        this.nameutils.capitalizeWord(docs.stability),\n      );\n    }\n    if (docs.see) {\n      emitDocAttribute('see', docs.see);\n    }\n    if (docs.subclassable) {\n      emitDocAttribute('subclassable', '');\n    }\n    for (const [k, v] of Object.entries(docs.custom ?? {})) {\n      const extraSpace = k === 'link' ? ' ' : ''; // Extra space for '@link' to keep unit tests happy\n      emitDocAttribute(k, v + extraSpace);\n    }\n\n    // Remove leading and trailing empty lines\n    while (ret.length > 0 && ret[0] === '') {\n      ret.shift();\n    }\n    while (ret.length > 0 && ret[ret.length - 1] === '') {\n      ret.pop();\n    }\n\n    return ret;\n\n    function emitDocAttribute(name: string, contents: string) {\n      const ls = contents.split('\\n');\n      ret.push(`<strong>${ucFirst(name)}</strong>: ${ls[0]}`);\n      ret.push(...ls.slice(1));\n      ret.push('');\n    }\n  }\n\n  private convertExample(example: string, apiLocation: ApiLocation): string {\n    const translated = this.rosetta.translateExample(\n      apiLocation,\n      example,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n    );\n    return translated.source;\n  }\n\n  private convertSamplesInMarkdown(markdown: string, api: ApiLocation): string {\n    return this.rosetta.translateSnippetsInMarkdown(\n      api,\n      markdown,\n      TargetLanguage.CSHARP,\n      enforcesStrictMode(this.assembly),\n    );\n  }\n  private emitXmlDoc(\n    tag: string,\n    content: string,\n    { attributes = {} }: { attributes?: { [name: string]: string } } = {},\n  ): void {\n    if (!content) {\n      return;\n    }\n\n    const xml = xmlbuilder.create(tag, { headless: true }).text(content);\n    for (const [name, value] of Object.entries(attributes)) {\n      xml.att(name, value);\n    }\n    const xmlstring = xml.end({ allowEmpty: true, pretty: false });\n    const trimLeft = tag !== 'code';\n    for (const line of xmlstring\n      .split('\\n')\n      .map((x) => (trimLeft ? x.trim() : x.trimRight()))) {\n      this.code.line(`/// ${line}`);\n    }\n  }\n}\n\n/**\n * Uppercase the first letter\n */\nfunction ucFirst(x: string) {\n  return x.slice(0, 1).toUpperCase() + x.slice(1);\n}\n\nfunction shouldMentionStability(s: spec.Stability) {\n  // Don't render \"stable\" or \"external\", those are both stable by implication\n  return s === spec.Stability.Deprecated || s === spec.Stability.Experimental;\n}\n"]}