jsii-pacmak 1.42.0 → 1.44.2

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.
@@ -2,6 +2,7 @@
2
2
  "use strict";
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
4
  require("@jsii/check-node/run");
5
+ const jsii_rosetta_1 = require("jsii-rosetta");
5
6
  const yargs = require("yargs");
6
7
  const lib_1 = require("../lib");
7
8
  const logging_1 = require("../lib/logging");
@@ -87,8 +88,19 @@ const version_1 = require("../lib/version");
87
88
  })
88
89
  .option('rosetta-translate-live', {
89
90
  type: 'boolean',
90
- desc: "Translate code samples on-the-fly if they can't be found in the samples tablet",
91
+ desc: "Translate code samples on-the-fly if they can't be found in the samples tablet (deprecated)",
91
92
  default: true,
93
+ })
94
+ .option('rosetta-unknown-snippets', {
95
+ type: 'string',
96
+ requiresArg: true,
97
+ optional: true,
98
+ choices: [
99
+ jsii_rosetta_1.UnknownSnippetMode.VERBATIM,
100
+ jsii_rosetta_1.UnknownSnippetMode.TRANSLATE,
101
+ jsii_rosetta_1.UnknownSnippetMode.FAIL,
102
+ ],
103
+ desc: "What to do with code samples if they can't be found in the samples tablet",
92
104
  })
93
105
  .option('parallel', {
94
106
  type: 'boolean',
@@ -127,6 +139,7 @@ const version_1 = require("../lib/version");
127
139
  parallel: argv.parallel,
128
140
  recurse: argv.recurse,
129
141
  rosettaLiveConversion: argv['rosetta-translate-live'],
142
+ rosettaUnknownSnippets: argv['rosetta-unknown-snippets'],
130
143
  rosettaTablet: argv['rosetta-tablet'],
131
144
  targets: (_a = argv.targets) === null || _a === void 0 ? void 0 : _a.map((target) => target),
132
145
  updateNpmIgnoreFiles: argv.npmignore,
@@ -136,4 +149,4 @@ const version_1 = require("../lib/version");
136
149
  process.stderr.write(`${err.stack}\n`);
137
150
  process.exit(1);
138
151
  });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsii-pacmak.js","sourceRoot":"","sources":["jsii-pacmak.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport '@jsii/check-node/run';\n\nimport * as yargs from 'yargs';\n\nimport { pacmak, configureLogging, TargetName } from '../lib';\nimport { debug } from '../lib/logging';\nimport { VERSION_DESC } from '../lib/version';\n\n(async function main() {\n  const argv = yargs\n    .env('JSII_PACMAK')\n    .command(\n      ['$0  [PROJECTS...]', 'generate [PROJECTS...]'],\n      'Generates jsii bindings for the selected project(s)',\n      (argv) =>\n        argv.positional('PROJECTS', {\n          type: 'string',\n          desc: 'Project(s) to generate',\n          normalize: true,\n          default: ['.'],\n        }),\n    )\n    .option('targets', {\n      alias: ['target', 't'],\n      type: 'array',\n      desc: 'target languages for which to generate bindings',\n      defaultDescription:\n        'all targets defined in `package.json` will be generated',\n      choices: Object.values(TargetName),\n      required: false,\n    })\n    .option('outdir', {\n      alias: 'o',\n      type: 'string',\n      desc: 'directory where artifacts will be generated',\n      defaultDescription: 'based on `jsii.output` in `package.json`',\n      required: false,\n    })\n    .option('code-only', {\n      alias: 'c',\n      type: 'boolean',\n      desc: 'generate code only (instead of building and packaging)',\n      default: false,\n    })\n    .option('fingerprint', {\n      type: 'boolean',\n      desc: 'attach a fingerprint to the generated artifacts, and skip generation if outdir contains artifacts that have a matching fingerprint',\n      default: true,\n    })\n    .option('force', {\n      alias: 'f',\n      type: 'boolean',\n      desc: 'force generation of new artifacts, even if the fingerprints match',\n      default: false,\n    })\n    .option('force-subdirectory', {\n      type: 'boolean',\n      desc: 'force generation into a target-named subdirectory, even in single-target mode',\n      default: true,\n    })\n    .option('force-target', {\n      type: 'boolean',\n      desc: 'force generation of the given targets, even if the source package.json doesnt declare it',\n      default: false,\n    })\n    .option('recurse', {\n      alias: 'R',\n      type: 'boolean',\n      desc: 'recursively generate and build all dependencies into `outdir`',\n      default: false,\n    })\n    .option('verbose', {\n      alias: 'v',\n      type: 'boolean',\n      desc: 'emit verbose build output',\n      count: true,\n      default: 0,\n    })\n    .option('clean', {\n      type: 'boolean',\n      desc: 'clean up temporary files upon success (use --no-clean to disable)',\n      default: true,\n    })\n    .option('npmignore', {\n      type: 'boolean',\n      desc: 'Auto-update .npmignore to exclude the output directory and include the .jsii file',\n      default: true,\n    })\n    .option('rosetta-tablet', {\n      type: 'string',\n      desc: \"Location of a jsii-rosetta tablet with sample translations (created using 'jsii-rosetta extract')\",\n    })\n    .option('rosetta-translate-live', {\n      type: 'boolean',\n      desc: \"Translate code samples on-the-fly if they can't be found in the samples tablet\",\n      default: true,\n    })\n    .option('parallel', {\n      type: 'boolean',\n      desc: 'Generate all configured targets in parallel (disabling this might help if you encounter EMFILE errors)',\n      default: true,\n    })\n    .option('dotnet-nuget-global-packages-folder', {\n      type: 'string',\n      desc: 'Configure a different NuGet package cache for NuGet',\n      default: undefined,\n      // This is a hidden option, folks need not bother it unless they're very advanced\n      hidden: true,\n      // This is expected to be a path, which should be normalized\n      normalize: true,\n    })\n    .option('validate-assemblies', {\n      type: 'boolean',\n      desc: 'Whether jsii assemblies should be validated. This can be expensive and is skipped by default.',\n      default: false,\n    })\n    .version(VERSION_DESC)\n    .strict().argv;\n\n  configureLogging({ level: argv.verbose !== undefined ? argv.verbose : 0 });\n\n  // Default to 4 threads in case of concurrency, good enough for most situations\n  debug('command line arguments:', argv);\n\n  return pacmak({\n    argv,\n    clean: argv.clean,\n    codeOnly: argv['code-only'],\n    fingerprint: argv.fingerprint,\n    force: argv.force,\n    forceSubdirectory: argv['force-subdirectory'],\n    forceTarget: argv['force-target'],\n    inputDirectories: argv.PROJECTS,\n    outputDirectory: argv.outdir,\n    parallel: argv.parallel,\n    recurse: argv.recurse,\n    rosettaLiveConversion: argv['rosetta-translate-live'],\n    rosettaTablet: argv['rosetta-tablet'],\n    targets: argv.targets?.map((target) => target as TargetName),\n    updateNpmIgnoreFiles: argv.npmignore,\n    validateAssemblies: argv['validate-assemblies'],\n  });\n})().catch((err) => {\n  process.stderr.write(`${err.stack}\\n`);\n  process.exit(1);\n});\n"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jsii-pacmak.js","sourceRoot":"","sources":["jsii-pacmak.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\nimport '@jsii/check-node/run';\n\nimport { UnknownSnippetMode } from 'jsii-rosetta';\nimport * as yargs from 'yargs';\n\nimport { pacmak, configureLogging, TargetName } from '../lib';\nimport { debug } from '../lib/logging';\nimport { VERSION_DESC } from '../lib/version';\n\n(async function main() {\n  const argv = yargs\n    .env('JSII_PACMAK')\n    .command(\n      ['$0  [PROJECTS...]', 'generate [PROJECTS...]'],\n      'Generates jsii bindings for the selected project(s)',\n      (argv) =>\n        argv.positional('PROJECTS', {\n          type: 'string',\n          desc: 'Project(s) to generate',\n          normalize: true,\n          default: ['.'],\n        }),\n    )\n    .option('targets', {\n      alias: ['target', 't'],\n      type: 'array',\n      desc: 'target languages for which to generate bindings',\n      defaultDescription:\n        'all targets defined in `package.json` will be generated',\n      choices: Object.values(TargetName),\n      required: false,\n    })\n    .option('outdir', {\n      alias: 'o',\n      type: 'string',\n      desc: 'directory where artifacts will be generated',\n      defaultDescription: 'based on `jsii.output` in `package.json`',\n      required: false,\n    })\n    .option('code-only', {\n      alias: 'c',\n      type: 'boolean',\n      desc: 'generate code only (instead of building and packaging)',\n      default: false,\n    })\n    .option('fingerprint', {\n      type: 'boolean',\n      desc: 'attach a fingerprint to the generated artifacts, and skip generation if outdir contains artifacts that have a matching fingerprint',\n      default: true,\n    })\n    .option('force', {\n      alias: 'f',\n      type: 'boolean',\n      desc: 'force generation of new artifacts, even if the fingerprints match',\n      default: false,\n    })\n    .option('force-subdirectory', {\n      type: 'boolean',\n      desc: 'force generation into a target-named subdirectory, even in single-target mode',\n      default: true,\n    })\n    .option('force-target', {\n      type: 'boolean',\n      desc: 'force generation of the given targets, even if the source package.json doesnt declare it',\n      default: false,\n    })\n    .option('recurse', {\n      alias: 'R',\n      type: 'boolean',\n      desc: 'recursively generate and build all dependencies into `outdir`',\n      default: false,\n    })\n    .option('verbose', {\n      alias: 'v',\n      type: 'boolean',\n      desc: 'emit verbose build output',\n      count: true,\n      default: 0,\n    })\n    .option('clean', {\n      type: 'boolean',\n      desc: 'clean up temporary files upon success (use --no-clean to disable)',\n      default: true,\n    })\n    .option('npmignore', {\n      type: 'boolean',\n      desc: 'Auto-update .npmignore to exclude the output directory and include the .jsii file',\n      default: true,\n    })\n    .option('rosetta-tablet', {\n      type: 'string',\n      desc: \"Location of a jsii-rosetta tablet with sample translations (created using 'jsii-rosetta extract')\",\n    })\n    .option('rosetta-translate-live', {\n      type: 'boolean',\n      desc: \"Translate code samples on-the-fly if they can't be found in the samples tablet (deprecated)\",\n      default: true,\n    })\n    .option('rosetta-unknown-snippets', {\n      type: 'string',\n      requiresArg: true,\n      optional: true,\n      choices: [\n        UnknownSnippetMode.VERBATIM,\n        UnknownSnippetMode.TRANSLATE,\n        UnknownSnippetMode.FAIL,\n      ],\n      desc: \"What to do with code samples if they can't be found in the samples tablet\",\n    })\n    .option('parallel', {\n      type: 'boolean',\n      desc: 'Generate all configured targets in parallel (disabling this might help if you encounter EMFILE errors)',\n      default: true,\n    })\n    .option('dotnet-nuget-global-packages-folder', {\n      type: 'string',\n      desc: 'Configure a different NuGet package cache for NuGet',\n      default: undefined,\n      // This is a hidden option, folks need not bother it unless they're very advanced\n      hidden: true,\n      // This is expected to be a path, which should be normalized\n      normalize: true,\n    })\n    .option('validate-assemblies', {\n      type: 'boolean',\n      desc: 'Whether jsii assemblies should be validated. This can be expensive and is skipped by default.',\n      default: false,\n    })\n    .version(VERSION_DESC)\n    .strict().argv;\n\n  configureLogging({ level: argv.verbose !== undefined ? argv.verbose : 0 });\n\n  // Default to 4 threads in case of concurrency, good enough for most situations\n  debug('command line arguments:', argv);\n\n  return pacmak({\n    argv,\n    clean: argv.clean,\n    codeOnly: argv['code-only'],\n    fingerprint: argv.fingerprint,\n    force: argv.force,\n    forceSubdirectory: argv['force-subdirectory'],\n    forceTarget: argv['force-target'],\n    inputDirectories: argv.PROJECTS,\n    outputDirectory: argv.outdir,\n    parallel: argv.parallel,\n    recurse: argv.recurse,\n    rosettaLiveConversion: argv['rosetta-translate-live'],\n    rosettaUnknownSnippets: argv['rosetta-unknown-snippets'] as\n      | UnknownSnippetMode\n      | undefined,\n    rosettaTablet: argv['rosetta-tablet'],\n    targets: argv.targets?.map((target) => target as TargetName),\n    updateNpmIgnoreFiles: argv.npmignore,\n    validateAssemblies: argv['validate-assemblies'],\n  });\n})().catch((err) => {\n  process.stderr.write(`${err.stack}\\n`);\n  process.exit(1);\n});\n"]}
package/lib/builder.d.ts CHANGED
@@ -2,6 +2,7 @@ import { Rosetta } from 'jsii-rosetta';
2
2
  import { JsiiModule } from './packaging';
3
3
  import { TargetConstructor } from './target';
4
4
  import { TargetName } from './targets';
5
+ import { Toposorted } from './toposort';
5
6
  export interface BuildOptions {
6
7
  /**
7
8
  * Whether to fingerprint the produced artifacts.
@@ -45,14 +46,21 @@ export interface TargetBuilder {
45
46
  buildModules(): Promise<void>;
46
47
  }
47
48
  /**
48
- * Builds the targets for the given language sequentially
49
+ * Base implementation, building the package targets for the given language independently of each other
50
+ *
51
+ * Some languages can gain substantial speedup in preparing an "uber project" for all packages
52
+ * and compiling them all in one go (Those will be implementing a custom Builder).
53
+ *
54
+ * For languages where it doesn't matter--or where we haven't figured out how to
55
+ * do that yet--this class can serve as a base class: it will build each package
56
+ * independently, taking care to build them in the right order.
49
57
  */
50
- export declare class OneByOneBuilder implements TargetBuilder {
58
+ export declare class IndependentPackageBuilder implements TargetBuilder {
51
59
  private readonly targetName;
52
60
  private readonly targetConstructor;
53
61
  private readonly modules;
54
62
  private readonly options;
55
- constructor(targetName: TargetName, targetConstructor: TargetConstructor, modules: readonly JsiiModule[], options: BuildOptions);
63
+ constructor(targetName: TargetName, targetConstructor: TargetConstructor, modules: Toposorted<JsiiModule>, options: BuildOptions);
56
64
  buildModules(): Promise<void>;
57
65
  private generateModuleCode;
58
66
  private buildModule;
package/lib/builder.js CHANGED
@@ -1,13 +1,20 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.OneByOneBuilder = void 0;
3
+ exports.IndependentPackageBuilder = void 0;
4
4
  const path = require("path");
5
5
  const logging = require("./logging");
6
6
  const util_1 = require("./util");
7
7
  /**
8
- * Builds the targets for the given language sequentially
8
+ * Base implementation, building the package targets for the given language independently of each other
9
+ *
10
+ * Some languages can gain substantial speedup in preparing an "uber project" for all packages
11
+ * and compiling them all in one go (Those will be implementing a custom Builder).
12
+ *
13
+ * For languages where it doesn't matter--or where we haven't figured out how to
14
+ * do that yet--this class can serve as a base class: it will build each package
15
+ * independently, taking care to build them in the right order.
9
16
  */
10
- class OneByOneBuilder {
17
+ class IndependentPackageBuilder {
11
18
  constructor(targetName, targetConstructor, modules, options) {
12
19
  this.targetName = targetName;
13
20
  this.targetConstructor = targetConstructor;
@@ -15,15 +22,13 @@ class OneByOneBuilder {
15
22
  this.options = options;
16
23
  }
17
24
  async buildModules() {
18
- for (const module of this.modules) {
19
- if (this.options.codeOnly) {
20
- // eslint-disable-next-line no-await-in-loop
21
- await this.generateModuleCode(module, this.options);
22
- }
23
- else {
24
- // eslint-disable-next-line no-await-in-loop
25
- await this.buildModule(module, this.options);
26
- }
25
+ if (this.options.codeOnly) {
26
+ await Promise.all(util_1.flatten(this.modules).map((module) => this.generateModuleCode(module, this.options)));
27
+ return;
28
+ }
29
+ for (const modules of this.modules) {
30
+ // eslint-disable-next-line no-await-in-loop
31
+ await Promise.all(modules.map((module) => this.buildModule(module, this.options)));
27
32
  }
28
33
  }
29
34
  async generateModuleCode(module, options) {
@@ -74,5 +79,5 @@ class OneByOneBuilder {
74
79
  return module.outputDirectory;
75
80
  }
76
81
  }
77
- exports.OneByOneBuilder = OneByOneBuilder;
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Rosetta } from 'jsii-rosetta';\nimport * as path from 'path';\n\nimport * as logging from './logging';\nimport { JsiiModule } from './packaging';\nimport { TargetConstructor, Target } from './target';\nimport { TargetName } from './targets';\nimport { Scratch } from './util';\n\nexport interface BuildOptions {\n  /**\n   * Whether to fingerprint the produced artifacts.\n   * @default true\n   */\n  fingerprint?: boolean;\n\n  /**\n   * Whether artifacts should be re-build even if their fingerprints look up-to-date.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Arguments provided by the user (how they are used is target-dependent)\n   */\n  arguments: { readonly [name: string]: any };\n\n  /**\n   * Only generate code, don't build\n   */\n  codeOnly?: boolean;\n\n  /**\n   * Whether or not to clean\n   */\n  clean?: boolean;\n\n  /**\n   * Whether to add an additional subdirectory for the target language\n   */\n  languageSubdirectory?: boolean;\n\n  /**\n   * The Rosetta instance to load examples from\n   */\n  rosetta: Rosetta;\n}\n\n/**\n * Interface for classes that can build language targets\n *\n * Building can happen one target at a time, or multiple targets at a time.\n */\nexport interface TargetBuilder {\n  buildModules(): Promise<void>;\n}\n\n/**\n * Builds the targets for the given language sequentially\n */\nexport class OneByOneBuilder implements TargetBuilder {\n  public constructor(\n    private readonly targetName: TargetName,\n    private readonly targetConstructor: TargetConstructor,\n    private readonly modules: readonly JsiiModule[],\n    private readonly options: BuildOptions,\n  ) {}\n\n  public async buildModules(): Promise<void> {\n    for (const module of this.modules) {\n      if (this.options.codeOnly) {\n        // eslint-disable-next-line no-await-in-loop\n        await this.generateModuleCode(module, this.options);\n      } else {\n        // eslint-disable-next-line no-await-in-loop\n        await this.buildModule(module, this.options);\n      }\n    }\n  }\n\n  private async generateModuleCode(module: JsiiModule, options: BuildOptions) {\n    const outputDir = this.finalOutputDir(module, options);\n    logging.debug(`Generating ${this.targetName} code into ${outputDir}`);\n    await this.makeTarget(module, options).generateCode(\n      outputDir,\n      module.tarball,\n    );\n  }\n\n  private async buildModule(module: JsiiModule, options: BuildOptions) {\n    const target = this.makeTarget(module, options);\n    const outputDir = this.finalOutputDir(module, options);\n\n    const src = await Scratch.make((tmpdir) => {\n      logging.debug(`Generating ${this.targetName} code into ${tmpdir}`);\n      return target.generateCode(tmpdir, module.tarball);\n    });\n\n    try {\n      logging.debug(`Building ${src.directory} into ${outputDir}`);\n      return await target.build(src.directory, outputDir);\n    } catch (err) {\n      logging.warn(`Failed building ${this.targetName}`);\n      return await Promise.reject(err);\n    } finally {\n      if (options.clean) {\n        logging.debug(`Cleaning ${src.directory}`);\n        await src.cleanup();\n      } else {\n        logging.info(\n          `Generated code for ${this.targetName} retained at ${src.directory}`,\n        );\n      }\n    }\n  }\n\n  private makeTarget(module: JsiiModule, options: BuildOptions): Target {\n    return new this.targetConstructor({\n      targetName: this.targetName,\n      packageDir: module.moduleDirectory,\n      assembly: module.assembly,\n      fingerprint: options.fingerprint,\n      force: options.force,\n      arguments: options.arguments,\n      rosetta: options.rosetta,\n    });\n  }\n\n  private finalOutputDir(module: JsiiModule, options: BuildOptions): string {\n    if (options.languageSubdirectory) {\n      return path.join(module.outputDirectory, this.targetName);\n    }\n    return module.outputDirectory;\n  }\n}\n"]}
82
+ exports.IndependentPackageBuilder = IndependentPackageBuilder;
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Rosetta } from 'jsii-rosetta';\nimport * as path from 'path';\n\nimport * as logging from './logging';\nimport { JsiiModule } from './packaging';\nimport { TargetConstructor, Target } from './target';\nimport { TargetName } from './targets';\nimport { Toposorted } from './toposort';\nimport { Scratch, flatten } from './util';\n\nexport interface BuildOptions {\n  /**\n   * Whether to fingerprint the produced artifacts.\n   * @default true\n   */\n  fingerprint?: boolean;\n\n  /**\n   * Whether artifacts should be re-build even if their fingerprints look up-to-date.\n   * @default false\n   */\n  force?: boolean;\n\n  /**\n   * Arguments provided by the user (how they are used is target-dependent)\n   */\n  arguments: { readonly [name: string]: any };\n\n  /**\n   * Only generate code, don't build\n   */\n  codeOnly?: boolean;\n\n  /**\n   * Whether or not to clean\n   */\n  clean?: boolean;\n\n  /**\n   * Whether to add an additional subdirectory for the target language\n   */\n  languageSubdirectory?: boolean;\n\n  /**\n   * The Rosetta instance to load examples from\n   */\n  rosetta: Rosetta;\n}\n\n/**\n * Interface for classes that can build language targets\n *\n * Building can happen one target at a time, or multiple targets at a time.\n */\nexport interface TargetBuilder {\n  buildModules(): Promise<void>;\n}\n\n/**\n * Base implementation, building the package targets for the given language independently of each other\n *\n * Some languages can gain substantial speedup in preparing an \"uber project\" for all packages\n * and compiling them all in one go (Those will be implementing a custom Builder).\n *\n * For languages where it doesn't matter--or where we haven't figured out how to\n * do that yet--this class can serve as a base class: it will build each package\n * independently, taking care to build them in the right order.\n */\nexport class IndependentPackageBuilder implements TargetBuilder {\n  public constructor(\n    private readonly targetName: TargetName,\n    private readonly targetConstructor: TargetConstructor,\n    private readonly modules: Toposorted<JsiiModule>,\n    private readonly options: BuildOptions,\n  ) {}\n\n  public async buildModules(): Promise<void> {\n    if (this.options.codeOnly) {\n      await Promise.all(\n        flatten(this.modules).map((module) =>\n          this.generateModuleCode(module, this.options),\n        ),\n      );\n      return;\n    }\n\n    for (const modules of this.modules) {\n      // eslint-disable-next-line no-await-in-loop\n      await Promise.all(\n        modules.map((module) => this.buildModule(module, this.options)),\n      );\n    }\n  }\n\n  private async generateModuleCode(module: JsiiModule, options: BuildOptions) {\n    const outputDir = this.finalOutputDir(module, options);\n    logging.debug(`Generating ${this.targetName} code into ${outputDir}`);\n    await this.makeTarget(module, options).generateCode(\n      outputDir,\n      module.tarball,\n    );\n  }\n\n  private async buildModule(module: JsiiModule, options: BuildOptions) {\n    const target = this.makeTarget(module, options);\n    const outputDir = this.finalOutputDir(module, options);\n\n    const src = await Scratch.make((tmpdir) => {\n      logging.debug(`Generating ${this.targetName} code into ${tmpdir}`);\n      return target.generateCode(tmpdir, module.tarball);\n    });\n\n    try {\n      logging.debug(`Building ${src.directory} into ${outputDir}`);\n      return await target.build(src.directory, outputDir);\n    } catch (err) {\n      logging.warn(`Failed building ${this.targetName}`);\n      return await Promise.reject(err);\n    } finally {\n      if (options.clean) {\n        logging.debug(`Cleaning ${src.directory}`);\n        await src.cleanup();\n      } else {\n        logging.info(\n          `Generated code for ${this.targetName} retained at ${src.directory}`,\n        );\n      }\n    }\n  }\n\n  private makeTarget(module: JsiiModule, options: BuildOptions): Target {\n    return new this.targetConstructor({\n      targetName: this.targetName,\n      packageDir: module.moduleDirectory,\n      assembly: module.assembly,\n      fingerprint: options.fingerprint,\n      force: options.force,\n      arguments: options.arguments,\n      rosetta: options.rosetta,\n    });\n  }\n\n  private finalOutputDir(module: JsiiModule, options: BuildOptions): string {\n    if (options.languageSubdirectory) {\n      return path.join(module.outputDirectory, this.targetName);\n    }\n    return module.outputDirectory;\n  }\n}\n"]}
package/lib/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ import { UnknownSnippetMode } from 'jsii-rosetta';
1
2
  import { TargetName } from './targets';
2
3
  import { Timers } from './timer';
3
4
  export { TargetName };
@@ -5,7 +6,7 @@ export { configure as configureLogging } from './logging';
5
6
  /**
6
7
  * Generates code in the desired targets.
7
8
  */
8
- export declare function pacmak({ argv, clean, codeOnly, fingerprint, force, forceSubdirectory, forceTarget, inputDirectories, outputDirectory, parallel, recurse, rosettaLiveConversion, rosettaTablet, targets, timers, updateNpmIgnoreFiles, validateAssemblies, }: PacmakOptions): Promise<void>;
9
+ export declare function pacmak({ argv, clean, codeOnly, fingerprint, force, forceSubdirectory, forceTarget, inputDirectories, outputDirectory, parallel, recurse, rosettaLiveConversion, rosettaTablet, targets, timers, rosettaUnknownSnippets, updateNpmIgnoreFiles, validateAssemblies, }: PacmakOptions): Promise<void>;
9
10
  /**
10
11
  * Options provided to the `pacmak` function.
11
12
  */
@@ -85,8 +86,15 @@ export interface PacmakOptions {
85
86
  * already translated in the `rosettaTablet` file.
86
87
  *
87
88
  * @default false
89
+ * @deprecated Use `rosettaUnknownSnippets` instead.
88
90
  */
89
91
  readonly rosettaLiveConversion?: boolean;
92
+ /**
93
+ * How rosetta should treat snippets that cannot be loaded from a translation tablet.
94
+ *
95
+ * @default - falls back to the default of `rosettaLiveConversion`.
96
+ */
97
+ readonly rosettaUnknownSnippets?: UnknownSnippetMode;
90
98
  /**
91
99
  * A Rosetta tablet file where translations for code examples can be found.
92
100
  *
package/lib/index.js CHANGED
@@ -8,47 +8,52 @@ const npm_modules_1 = require("./npm-modules");
8
8
  const targets_1 = require("./targets");
9
9
  Object.defineProperty(exports, "TargetName", { enumerable: true, get: function () { return targets_1.TargetName; } });
10
10
  const timer_1 = require("./timer");
11
+ const util_1 = require("./util");
11
12
  var logging_1 = require("./logging");
12
13
  Object.defineProperty(exports, "configureLogging", { enumerable: true, get: function () { return logging_1.configure; } });
13
14
  /**
14
15
  * Generates code in the desired targets.
15
16
  */
16
- async function pacmak({ argv = {}, clean = true, codeOnly = false, fingerprint = true, force = false, forceSubdirectory = true, forceTarget = false, inputDirectories, outputDirectory, parallel = true, recurse = false, rosettaLiveConversion, rosettaTablet, targets = Object.values(targets_1.TargetName), timers = new timer_1.Timers(), updateNpmIgnoreFiles = false, validateAssemblies = false, }) {
17
- const rosetta = new jsii_rosetta_1.Rosetta({ liveConversion: rosettaLiveConversion });
17
+ async function pacmak({ argv = {}, clean = true, codeOnly = false, fingerprint = true, force = false, forceSubdirectory = true, forceTarget = false, inputDirectories, outputDirectory, parallel = true, recurse = false, rosettaLiveConversion, rosettaTablet, targets = Object.values(targets_1.TargetName), timers = new timer_1.Timers(), rosettaUnknownSnippets = undefined, updateNpmIgnoreFiles = false, validateAssemblies = false, }) {
18
+ const unknownSnippets = rosettaUnknownSnippets !== null && rosettaUnknownSnippets !== void 0 ? rosettaUnknownSnippets : (rosettaLiveConversion
19
+ ? jsii_rosetta_1.UnknownSnippetMode.TRANSLATE
20
+ : jsii_rosetta_1.UnknownSnippetMode.VERBATIM);
21
+ const rosetta = new jsii_rosetta_1.Rosetta({ unknownSnippets });
18
22
  if (rosettaTablet) {
19
23
  await rosetta.loadTabletFromFile(rosettaTablet);
20
24
  }
21
- const modulesToPackage = await npm_modules_1.findJsiiModules(inputDirectories, recurse);
22
- logging.info(`Found ${modulesToPackage.length} modules to package`);
23
- if (modulesToPackage.length === 0) {
25
+ const modulesToPackageSorted = await npm_modules_1.findJsiiModules(inputDirectories, recurse);
26
+ const modulesToPackageFlat = util_1.flatten(modulesToPackageSorted);
27
+ logging.info(`Found ${modulesToPackageFlat.length} modules to package`);
28
+ if (modulesToPackageFlat.length === 0) {
24
29
  logging.warn('Nothing to do');
25
30
  return;
26
31
  }
27
32
  if (outputDirectory) {
28
- for (const mod of modulesToPackage) {
33
+ for (const mod of modulesToPackageFlat) {
29
34
  mod.outputDirectory = outputDirectory;
30
35
  }
31
36
  }
32
37
  else if (updateNpmIgnoreFiles) {
33
38
  // if outdir is coming from package.json, verify it is excluded by .npmignore. if it is explicitly
34
39
  // defined via --out, don't perform this verification.
35
- await npm_modules_1.updateAllNpmIgnores(modulesToPackage);
40
+ await npm_modules_1.updateAllNpmIgnores(modulesToPackageFlat);
36
41
  }
37
42
  await timers.recordAsync('npm pack', () => {
38
43
  logging.info('Packaging NPM bundles');
39
- return Promise.all(modulesToPackage.map((m) => m.npmPack()));
44
+ return Promise.all(modulesToPackageFlat.map((m) => m.npmPack()));
40
45
  });
41
46
  await timers.recordAsync('load jsii', () => {
42
47
  logging.info('Loading jsii assemblies and translations');
43
48
  const system = new jsii_reflect_1.TypeSystem();
44
- return Promise.all(modulesToPackage.map(async (m) => {
49
+ return Promise.all(modulesToPackageFlat.map(async (m) => {
45
50
  await m.load(system, validateAssemblies);
46
51
  return rosetta.addAssembly(m.assembly.spec, m.moduleDirectory);
47
52
  }));
48
53
  });
49
54
  try {
50
- const targetSets = sliceTargets(modulesToPackage, targets, forceTarget);
51
- if (targetSets.every((s) => s.modules.length === 0)) {
55
+ const targetSets = sliceTargets(modulesToPackageSorted, targets, forceTarget);
56
+ if (targetSets.every((s) => s.modulesSorted.length === 0)) {
52
57
  throw new Error(`None of the requested packages had any targets to build for '${targets.join(', ')}' (use --force-target to force)`);
53
58
  }
54
59
  const perLanguageDirectory = targetSets.length > 1 || forceSubdirectory;
@@ -56,7 +61,7 @@ async function pacmak({ argv = {}, clean = true, codeOnly = false, fingerprint =
56
61
  await Promise.all(mapParallelOrSerial(targetSets, async (targetSet) => {
57
62
  logging.info(`Packaging '${targetSet.targetType}' for ${describePackages(targetSet)}`);
58
63
  return timers
59
- .recordAsync(targetSet.targetType, () => buildTargetsForLanguage(targetSet.targetType, targetSet.modules, {
64
+ .recordAsync(targetSet.targetType, () => buildTargetsForLanguage(targetSet.targetType, targetSet.modulesSorted, {
60
65
  argv,
61
66
  clean,
62
67
  codeOnly,
@@ -74,10 +79,10 @@ async function pacmak({ argv = {}, clean = true, codeOnly = false, fingerprint =
74
79
  finally {
75
80
  if (clean) {
76
81
  logging.debug('Cleaning up');
77
- await timers.recordAsync('cleanup', () => Promise.all(modulesToPackage.map((m) => m.cleanup())));
82
+ await timers.recordAsync('cleanup', () => Promise.all(modulesToPackageFlat.map((m) => m.cleanup())));
78
83
  }
79
84
  else {
80
- logging.debug('Temporary directories retained (--no-clean)');
85
+ logging.info('Temporary directories retained (--no-clean)');
81
86
  }
82
87
  }
83
88
  logging.info(`Packaged. ${timers.display()}`);
@@ -101,12 +106,14 @@ async function buildTargetsForLanguage(targetLanguage, modules, { argv, clean, c
101
106
  languageSubdirectory: perLanguageDirectory,
102
107
  }).buildModules();
103
108
  }
104
- function sliceTargets(modules, requestedTargets, force) {
109
+ function sliceTargets(modulesSorted, requestedTargets, force) {
105
110
  const ret = new Array();
106
111
  for (const target of requestedTargets) {
107
112
  ret.push({
108
113
  targetType: target,
109
- modules: modules.filter((m) => force || m.availableTargets.includes(target)),
114
+ modulesSorted: modulesSorted
115
+ .map((modules) => modules.filter((m) => force || m.availableTargets.includes(target)))
116
+ .filter((ms) => ms.length > 0),
110
117
  });
111
118
  }
112
119
  return ret;
@@ -127,10 +134,11 @@ function mapParallelOrSerial(collection, mapper, { parallel }) {
127
134
  //#endregion
128
135
  //#region Misc. Utilities
129
136
  function describePackages(target) {
130
- if (target.modules.length > 0 && target.modules.length < 5) {
131
- return target.modules.map((m) => m.name).join(', ');
137
+ const modules = util_1.flatten(target.modulesSorted);
138
+ if (modules.length > 0 && modules.length < 5) {
139
+ return modules.map((m) => m.name).join(', ');
132
140
  }
133
- return `${target.modules.length} modules`;
141
+ return `${modules.length} modules`;
134
142
  }
135
143
  //#endregion
136
- //# 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 } 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';\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  rosettaLiveConversion,\n  rosettaTablet,\n  targets = Object.values(TargetName),\n  timers = new Timers(),\n  updateNpmIgnoreFiles = false,\n  validateAssemblies = false,\n}: PacmakOptions): Promise<void> {\n  const rosetta = new Rosetta({ liveConversion: rosettaLiveConversion });\n  if (rosettaTablet) {\n    await rosetta.loadTabletFromFile(rosettaTablet);\n  }\n\n  const modulesToPackage = await findJsiiModules(inputDirectories, recurse);\n  logging.info(`Found ${modulesToPackage.length} modules to package`);\n  if (modulesToPackage.length === 0) {\n    logging.warn('Nothing to do');\n    return;\n  }\n\n  if (outputDirectory) {\n    for (const mod of modulesToPackage) {\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(modulesToPackage);\n  }\n\n  await timers.recordAsync('npm pack', () => {\n    logging.info('Packaging NPM bundles');\n    return Promise.all(modulesToPackage.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      modulesToPackage.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(modulesToPackage, targets, forceTarget);\n    if (targetSets.every((s) => s.modules.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(targetSet.targetType, targetSet.modules, {\n                argv,\n                clean,\n                codeOnly,\n                fingerprint,\n                force,\n                perLanguageDirectory,\n                rosetta,\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(modulesToPackage.map((m) => m.cleanup())),\n      );\n    } else {\n      logging.debug('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   * Whether `jsii-rosetta` conversion should be performed in-band for examples found in documentation which are not\n   * already translated in the `rosettaTablet` file.\n   *\n   * @default false\n   */\n  readonly rosettaLiveConversion?: boolean;\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: readonly 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  modules: readonly JsiiModule[];\n}\n\nfunction sliceTargets(\n  modules: readonly 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      modules: modules.filter(\n        (m) => force || m.availableTargets.includes(target),\n      ),\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  if (target.modules.length > 0 && target.modules.length < 5) {\n    return target.modules.map((m) => m.name).join(', ');\n  }\n  return `${target.modules.length} modules`;\n}\n\n//#endregion\n"]}
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  rosettaLiveConversion,\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 unknownSnippets =\n    rosettaUnknownSnippets ??\n    (rosettaLiveConversion\n      ? UnknownSnippetMode.TRANSLATE\n      : UnknownSnippetMode.VERBATIM);\n\n  const rosetta = new Rosetta({ unknownSnippets });\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   * Whether `jsii-rosetta` conversion should be performed in-band for examples found in documentation which are not\n   * already translated in the `rosettaTablet` file.\n   *\n   * @default false\n   * @deprecated Use `rosettaUnknownSnippets` instead.\n   */\n  readonly rosettaLiveConversion?: boolean;\n\n  /**\n   * How rosetta should treat snippets that cannot be loaded from a translation tablet.\n   *\n   * @default - falls back to the default of `rosettaLiveConversion`.\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"]}
package/lib/logging.d.ts CHANGED
@@ -2,10 +2,12 @@ export declare enum Level {
2
2
  WARN = -1,
3
3
  QUIET = 0,
4
4
  INFO = 1,
5
- VERBOSE = 2
5
+ VERBOSE = 2,
6
+ SILLY = 3
6
7
  }
7
8
  export declare const LEVEL_INFO: number;
8
9
  export declare const LEVEL_VERBOSE: number;
10
+ export declare const LEVEL_SILLY: number;
9
11
  /** The minimal logging level for messages to be emitted. */
10
12
  export declare let level: Level;
11
13
  export declare function configure({ level: newLevel }: {
package/lib/logging.js CHANGED
@@ -1,15 +1,17 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.debug = exports.info = exports.warn = exports.configure = exports.level = exports.LEVEL_VERBOSE = exports.LEVEL_INFO = exports.Level = void 0;
3
+ exports.debug = exports.info = exports.warn = exports.configure = exports.level = exports.LEVEL_SILLY = exports.LEVEL_VERBOSE = exports.LEVEL_INFO = exports.Level = void 0;
4
4
  var Level;
5
5
  (function (Level) {
6
6
  Level[Level["WARN"] = -1] = "WARN";
7
7
  Level[Level["QUIET"] = 0] = "QUIET";
8
8
  Level[Level["INFO"] = 1] = "INFO";
9
9
  Level[Level["VERBOSE"] = 2] = "VERBOSE";
10
+ Level[Level["SILLY"] = 3] = "SILLY";
10
11
  })(Level = exports.Level || (exports.Level = {}));
11
12
  exports.LEVEL_INFO = Level.INFO;
12
13
  exports.LEVEL_VERBOSE = Level.VERBOSE;
14
+ exports.LEVEL_SILLY = Level.SILLY;
13
15
  /** The minimal logging level for messages to be emitted. */
14
16
  exports.level = Level.QUIET;
15
17
  function configure({ level: newLevel }) {
@@ -34,4 +36,4 @@ function log(messageLevel, fmt, ...args) {
34
36
  console.error(`[jsii-pacmak] [${levelName}]`, fmt, ...args);
35
37
  }
36
38
  }
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBWSxLQUtYO0FBTEQsV0FBWSxLQUFLO0lBQ2Ysa0NBQVMsQ0FBQTtJQUNULG1DQUFTLENBQUE7SUFDVCxpQ0FBUSxDQUFBO0lBQ1IsdUNBQVcsQ0FBQTtBQUNiLENBQUMsRUFMVyxLQUFLLEdBQUwsYUFBSyxLQUFMLGFBQUssUUFLaEI7QUFFWSxRQUFBLFVBQVUsR0FBVyxLQUFLLENBQUMsSUFBSSxDQUFDO0FBQ2hDLFFBQUEsYUFBYSxHQUFXLEtBQUssQ0FBQyxPQUFPLENBQUM7QUFFbkQsNERBQTREO0FBQ2pELFFBQUEsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7QUFFL0IsU0FBZ0IsU0FBUyxDQUFDLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBb0I7SUFDN0QsYUFBSyxHQUFHLFFBQVEsQ0FBQztBQUNuQixDQUFDO0FBRkQsOEJBRUM7QUFFRCxTQUFnQixJQUFJLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUM5QyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBRkQsb0JBRUM7QUFFRCxTQUFnQixJQUFJLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUM5QyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBRkQsb0JBRUM7QUFFRCxTQUFnQixLQUFLLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUMvQyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNuQyxDQUFDO0FBRkQsc0JBRUM7QUFFRCxTQUFTLEdBQUcsQ0FBQyxZQUFtQixFQUFFLEdBQVcsRUFBRSxHQUFHLElBQVc7SUFDM0QsSUFBSSxhQUFLLElBQUksWUFBWSxFQUFFO1FBQ3pCLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN0QyxPQUFPLENBQUMsS0FBSyxDQUFDLGtCQUFrQixTQUFTLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUM3RDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBMZXZlbCB7XG4gIFdBUk4gPSAtMSxcbiAgUVVJRVQgPSAwLFxuICBJTkZPID0gMSxcbiAgVkVSQk9TRSA9IDIsXG59XG5cbmV4cG9ydCBjb25zdCBMRVZFTF9JTkZPOiBudW1iZXIgPSBMZXZlbC5JTkZPO1xuZXhwb3J0IGNvbnN0IExFVkVMX1ZFUkJPU0U6IG51bWJlciA9IExldmVsLlZFUkJPU0U7XG5cbi8qKiBUaGUgbWluaW1hbCBsb2dnaW5nIGxldmVsIGZvciBtZXNzYWdlcyB0byBiZSBlbWl0dGVkLiAqL1xuZXhwb3J0IGxldCBsZXZlbCA9IExldmVsLlFVSUVUO1xuXG5leHBvcnQgZnVuY3Rpb24gY29uZmlndXJlKHsgbGV2ZWw6IG5ld0xldmVsIH06IHsgbGV2ZWw6IExldmVsIH0pIHtcbiAgbGV2ZWwgPSBuZXdMZXZlbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHdhcm4oZm10OiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKSB7XG4gIGxvZyhMZXZlbC5XQVJOLCBmbXQsIC4uLmFyZ3MpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5mbyhmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgbG9nKExldmVsLklORk8sIGZtdCwgLi4uYXJncyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWJ1ZyhmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgbG9nKExldmVsLlZFUkJPU0UsIGZtdCwgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIGxvZyhtZXNzYWdlTGV2ZWw6IExldmVsLCBmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgaWYgKGxldmVsID49IG1lc3NhZ2VMZXZlbCkge1xuICAgIGNvbnN0IGxldmVsTmFtZSA9IExldmVsW21lc3NhZ2VMZXZlbF07XG4gICAgY29uc29sZS5lcnJvcihgW2pzaWktcGFjbWFrXSBbJHtsZXZlbE5hbWV9XWAsIGZtdCwgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImxvZ2dpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsSUFBWSxLQU1YO0FBTkQsV0FBWSxLQUFLO0lBQ2Ysa0NBQVMsQ0FBQTtJQUNULG1DQUFTLENBQUE7SUFDVCxpQ0FBUSxDQUFBO0lBQ1IsdUNBQVcsQ0FBQTtJQUNYLG1DQUFTLENBQUE7QUFDWCxDQUFDLEVBTlcsS0FBSyxHQUFMLGFBQUssS0FBTCxhQUFLLFFBTWhCO0FBRVksUUFBQSxVQUFVLEdBQVcsS0FBSyxDQUFDLElBQUksQ0FBQztBQUNoQyxRQUFBLGFBQWEsR0FBVyxLQUFLLENBQUMsT0FBTyxDQUFDO0FBQ3RDLFFBQUEsV0FBVyxHQUFXLEtBQUssQ0FBQyxLQUFLLENBQUM7QUFFL0MsNERBQTREO0FBQ2pELFFBQUEsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7QUFFL0IsU0FBZ0IsU0FBUyxDQUFDLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBb0I7SUFDN0QsYUFBSyxHQUFHLFFBQVEsQ0FBQztBQUNuQixDQUFDO0FBRkQsOEJBRUM7QUFFRCxTQUFnQixJQUFJLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUM5QyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBRkQsb0JBRUM7QUFFRCxTQUFnQixJQUFJLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUM5QyxHQUFHLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNoQyxDQUFDO0FBRkQsb0JBRUM7QUFFRCxTQUFnQixLQUFLLENBQUMsR0FBVyxFQUFFLEdBQUcsSUFBVztJQUMvQyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztBQUNuQyxDQUFDO0FBRkQsc0JBRUM7QUFFRCxTQUFTLEdBQUcsQ0FBQyxZQUFtQixFQUFFLEdBQVcsRUFBRSxHQUFHLElBQVc7SUFDM0QsSUFBSSxhQUFLLElBQUksWUFBWSxFQUFFO1FBQ3pCLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN0QyxPQUFPLENBQUMsS0FBSyxDQUFDLGtCQUFrQixTQUFTLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUM3RDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBMZXZlbCB7XG4gIFdBUk4gPSAtMSxcbiAgUVVJRVQgPSAwLFxuICBJTkZPID0gMSxcbiAgVkVSQk9TRSA9IDIsXG4gIFNJTExZID0gMyxcbn1cblxuZXhwb3J0IGNvbnN0IExFVkVMX0lORk86IG51bWJlciA9IExldmVsLklORk87XG5leHBvcnQgY29uc3QgTEVWRUxfVkVSQk9TRTogbnVtYmVyID0gTGV2ZWwuVkVSQk9TRTtcbmV4cG9ydCBjb25zdCBMRVZFTF9TSUxMWTogbnVtYmVyID0gTGV2ZWwuU0lMTFk7XG5cbi8qKiBUaGUgbWluaW1hbCBsb2dnaW5nIGxldmVsIGZvciBtZXNzYWdlcyB0byBiZSBlbWl0dGVkLiAqL1xuZXhwb3J0IGxldCBsZXZlbCA9IExldmVsLlFVSUVUO1xuXG5leHBvcnQgZnVuY3Rpb24gY29uZmlndXJlKHsgbGV2ZWw6IG5ld0xldmVsIH06IHsgbGV2ZWw6IExldmVsIH0pIHtcbiAgbGV2ZWwgPSBuZXdMZXZlbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHdhcm4oZm10OiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKSB7XG4gIGxvZyhMZXZlbC5XQVJOLCBmbXQsIC4uLmFyZ3MpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaW5mbyhmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgbG9nKExldmVsLklORk8sIGZtdCwgLi4uYXJncyk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWJ1ZyhmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgbG9nKExldmVsLlZFUkJPU0UsIGZtdCwgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIGxvZyhtZXNzYWdlTGV2ZWw6IExldmVsLCBmbXQ6IHN0cmluZywgLi4uYXJnczogYW55W10pIHtcbiAgaWYgKGxldmVsID49IG1lc3NhZ2VMZXZlbCkge1xuICAgIGNvbnN0IGxldmVsTmFtZSA9IExldmVsW21lc3NhZ2VMZXZlbF07XG4gICAgY29uc29sZS5lcnJvcihgW2pzaWktcGFjbWFrXSBbJHtsZXZlbE5hbWV9XWAsIGZtdCwgLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
@@ -1,4 +1,5 @@
1
1
  import { JsiiModule } from './packaging';
2
+ import { Toposorted } from './toposort';
2
3
  /**
3
4
  * Find all modules that need to be packagerd
4
5
  *
@@ -6,5 +7,5 @@ import { JsiiModule } from './packaging';
6
7
  *
7
8
  * The result is topologically sorted.
8
9
  */
9
- export declare function findJsiiModules(directories: readonly string[], recurse: boolean): Promise<JsiiModule[]>;
10
+ export declare function findJsiiModules(directories: readonly string[], recurse: boolean): Promise<Toposorted<JsiiModule>>;
10
11
  export declare function updateAllNpmIgnores(packages: JsiiModule[]): Promise<void>;
@@ -108,4 +108,4 @@ async function updateNpmIgnore(packageDir, excludeOutdir) {
108
108
  }
109
109
  }
110
110
  }
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npm-modules.js","sourceRoot":"","sources":["npm-modules.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport * as logging from '../lib/logging';\nimport { JsiiModule } from './packaging';\nimport { topologicalSort } from './toposort';\nimport { resolveDependencyDirectory } from './util';\n\n/**\n * Find all modules that need to be packagerd\n *\n * If the input list is empty, include the current directory.\n *\n * The result is topologically sorted.\n */\nexport async function findJsiiModules(\n  directories: readonly string[],\n  recurse: boolean,\n): Promise<JsiiModule[]> {\n  const ret: JsiiModule[] = [];\n  const visited = new Set<string>();\n\n  const toVisit = directories.length > 0 ? directories : ['.'];\n  await Promise.all(toVisit.map((dir) => visitPackage(dir, true)));\n\n  return topologicalSort(\n    ret,\n    (m) => m.name,\n    (m) => m.dependencyNames,\n  );\n\n  async function visitPackage(dir: string, isRoot: boolean) {\n    const realPath = await fs.realpath(dir);\n    if (visited.has(realPath)) {\n      return;\n    } // Already visited\n    visited.add(realPath);\n\n    const pkg = await fs.readJson(path.join(realPath, 'package.json'));\n    if (!pkg.jsii?.outdir || !pkg.jsii?.targets) {\n      if (isRoot) {\n        throw new Error(\n          `Invalid \"jsii\" section in ${realPath}. Expecting \"outdir\" and \"targets\"`,\n        );\n      } else {\n        return; // just move on, this is not a jsii package\n      }\n    }\n\n    if (!pkg.name) {\n      throw new Error(\n        `package.json does not have a 'name' field: ${JSON.stringify(\n          pkg,\n          undefined,\n          2,\n        )}`,\n      );\n    }\n\n    const dependencyNames = [\n      ...Object.keys(pkg.dependencies ?? {}),\n      ...Object.keys(pkg.peerDependencies ?? {}),\n      ...Object.keys(pkg.devDependencies ?? {}),\n    ];\n\n    // if --recurse is set, find dependency dirs and build them.\n    if (recurse) {\n      await Promise.all(\n        dependencyNames\n          .map((dep) => resolveDependencyDirectory(realPath, dep))\n          .map((depDir) => visitPackage(depDir, false)),\n      );\n    }\n\n    // outdir is either by package.json/jsii.outdir (relative to package root) or via command line (relative to cwd)\n    const outputDirectory =\n      pkg.jsii.outdir && path.resolve(realPath, pkg.jsii.outdir);\n    const targets = [...Object.keys(pkg.jsii.targets), 'js']; // \"js\" is an implicit target.\n\n    ret.push(\n      new JsiiModule({\n        name: pkg.name,\n        moduleDirectory: realPath,\n        defaultOutputDirectory: outputDirectory,\n        availableTargets: targets,\n        dependencyNames,\n      }),\n    );\n  }\n}\n\nexport async function updateAllNpmIgnores(\n  packages: JsiiModule[],\n): Promise<void> {\n  await Promise.all(\n    packages.map((pkg) =>\n      updateNpmIgnore(pkg.moduleDirectory, pkg.outputDirectory),\n    ),\n  );\n}\n\nasync function updateNpmIgnore(\n  packageDir: string,\n  excludeOutdir: string | undefined,\n) {\n  const npmIgnorePath = path.join(packageDir, '.npmignore');\n  let lines = new Array<string>();\n  let modified = false;\n  if (await fs.pathExists(npmIgnorePath)) {\n    lines = (await fs.readFile(npmIgnorePath)).toString().split('\\n');\n  }\n\n  // if this is a fresh .npmignore, we can be a bit more opinionated\n  // otherwise, we add just add stuff that's critical\n  if (lines.length === 0) {\n    excludePattern(\n      'Exclude typescript source and config',\n      '*.ts',\n      'tsconfig.json',\n    );\n    includePattern(\n      'Include javascript files and typescript declarations',\n      '*.js',\n      '*.d.ts',\n    );\n  }\n\n  if (excludeOutdir) {\n    excludePattern(\n      'Exclude jsii outdir',\n      path.relative(packageDir, excludeOutdir),\n    );\n  }\n\n  includePattern('Include .jsii', spec.SPEC_FILE_NAME);\n\n  if (modified) {\n    await fs.writeFile(npmIgnorePath, `${lines.join('\\n')}\\n`);\n    logging.info('Updated .npmignore');\n  }\n\n  function includePattern(comment: string, ...patterns: string[]) {\n    excludePattern(comment, ...patterns.map((p) => `!${p}`));\n  }\n\n  function excludePattern(comment: string, ...patterns: string[]) {\n    let first = true;\n    for (const pattern of patterns) {\n      if (lines.includes(pattern)) {\n        return; // already in .npmignore\n      }\n\n      modified = true;\n\n      if (first) {\n        lines.push('');\n        lines.push(`# ${comment}`);\n        first = false;\n      }\n\n      lines.push(pattern);\n    }\n  }\n}\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"npm-modules.js","sourceRoot":"","sources":["npm-modules.ts"],"names":[],"mappings":"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","sourcesContent":["import * as spec from '@jsii/spec';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport * as logging from '../lib/logging';\nimport { JsiiModule } from './packaging';\nimport { topologicalSort, Toposorted } from './toposort';\nimport { resolveDependencyDirectory } from './util';\n\n/**\n * Find all modules that need to be packagerd\n *\n * If the input list is empty, include the current directory.\n *\n * The result is topologically sorted.\n */\nexport async function findJsiiModules(\n  directories: readonly string[],\n  recurse: boolean,\n): Promise<Toposorted<JsiiModule>> {\n  const ret: JsiiModule[] = [];\n  const visited = new Set<string>();\n\n  const toVisit = directories.length > 0 ? directories : ['.'];\n  await Promise.all(toVisit.map((dir) => visitPackage(dir, true)));\n\n  return topologicalSort(\n    ret,\n    (m) => m.name,\n    (m) => m.dependencyNames,\n  );\n\n  async function visitPackage(dir: string, isRoot: boolean) {\n    const realPath = await fs.realpath(dir);\n    if (visited.has(realPath)) {\n      return;\n    } // Already visited\n    visited.add(realPath);\n\n    const pkg = await fs.readJson(path.join(realPath, 'package.json'));\n    if (!pkg.jsii?.outdir || !pkg.jsii?.targets) {\n      if (isRoot) {\n        throw new Error(\n          `Invalid \"jsii\" section in ${realPath}. Expecting \"outdir\" and \"targets\"`,\n        );\n      } else {\n        return; // just move on, this is not a jsii package\n      }\n    }\n\n    if (!pkg.name) {\n      throw new Error(\n        `package.json does not have a 'name' field: ${JSON.stringify(\n          pkg,\n          undefined,\n          2,\n        )}`,\n      );\n    }\n\n    const dependencyNames = [\n      ...Object.keys(pkg.dependencies ?? {}),\n      ...Object.keys(pkg.peerDependencies ?? {}),\n      ...Object.keys(pkg.devDependencies ?? {}),\n    ];\n\n    // if --recurse is set, find dependency dirs and build them.\n    if (recurse) {\n      await Promise.all(\n        dependencyNames\n          .map((dep) => resolveDependencyDirectory(realPath, dep))\n          .map((depDir) => visitPackage(depDir, false)),\n      );\n    }\n\n    // outdir is either by package.json/jsii.outdir (relative to package root) or via command line (relative to cwd)\n    const outputDirectory =\n      pkg.jsii.outdir && path.resolve(realPath, pkg.jsii.outdir);\n    const targets = [...Object.keys(pkg.jsii.targets), 'js']; // \"js\" is an implicit target.\n\n    ret.push(\n      new JsiiModule({\n        name: pkg.name,\n        moduleDirectory: realPath,\n        defaultOutputDirectory: outputDirectory,\n        availableTargets: targets,\n        dependencyNames,\n      }),\n    );\n  }\n}\n\nexport async function updateAllNpmIgnores(\n  packages: JsiiModule[],\n): Promise<void> {\n  await Promise.all(\n    packages.map((pkg) =>\n      updateNpmIgnore(pkg.moduleDirectory, pkg.outputDirectory),\n    ),\n  );\n}\n\nasync function updateNpmIgnore(\n  packageDir: string,\n  excludeOutdir: string | undefined,\n) {\n  const npmIgnorePath = path.join(packageDir, '.npmignore');\n  let lines = new Array<string>();\n  let modified = false;\n  if (await fs.pathExists(npmIgnorePath)) {\n    lines = (await fs.readFile(npmIgnorePath)).toString().split('\\n');\n  }\n\n  // if this is a fresh .npmignore, we can be a bit more opinionated\n  // otherwise, we add just add stuff that's critical\n  if (lines.length === 0) {\n    excludePattern(\n      'Exclude typescript source and config',\n      '*.ts',\n      'tsconfig.json',\n    );\n    includePattern(\n      'Include javascript files and typescript declarations',\n      '*.js',\n      '*.d.ts',\n    );\n  }\n\n  if (excludeOutdir) {\n    excludePattern(\n      'Exclude jsii outdir',\n      path.relative(packageDir, excludeOutdir),\n    );\n  }\n\n  includePattern('Include .jsii', spec.SPEC_FILE_NAME);\n\n  if (modified) {\n    await fs.writeFile(npmIgnorePath, `${lines.join('\\n')}\\n`);\n    logging.info('Updated .npmignore');\n  }\n\n  function includePattern(comment: string, ...patterns: string[]) {\n    excludePattern(comment, ...patterns.map((p) => `!${p}`));\n  }\n\n  function excludePattern(comment: string, ...patterns: string[]) {\n    let first = true;\n    for (const pattern of patterns) {\n      if (lines.includes(pattern)) {\n        return; // already in .npmignore\n      }\n\n      modified = true;\n\n      if (first) {\n        lines.push('');\n        lines.push(`# ${comment}`);\n        first = false;\n      }\n\n      lines.push(pattern);\n    }\n  }\n}\n"]}