isolate-package 1.10.0-1 → 1.10.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/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  <!-- TOC -->
4
4
 
5
- - [TLDR](#tldr)
5
+ - [Quickstart](#quickstart)
6
6
  - [Features](#features)
7
7
  - [Installation](#installation)
8
8
  - [Usage](#usage)
@@ -35,7 +35,7 @@
35
35
 
36
36
  <!-- /TOC -->
37
37
 
38
- ## TLDR
38
+ ## Quickstart
39
39
 
40
40
  Run `npx isolate-package isolate` from the monorepo package you would like to
41
41
  isolate.
@@ -157,8 +157,8 @@ For this to work it is required that you define the `files` property in each
157
157
  package manifest, as it declares what files should be included in the published
158
158
  output.
159
159
 
160
- Typically the value contains an array with just the name of the build output
161
- directory, for example:
160
+ Typically, the value contains an array with only the name of the build output
161
+ directory. For example:
162
162
 
163
163
  ```cjson
164
164
  // package.json
@@ -167,8 +167,8 @@ directory, for example:
167
167
  }
168
168
  ```
169
169
 
170
- A few additional files from the root or your package will be included by `pack`
171
- automatically, like `package.json`, `LICENSE` and `README` files.
170
+ A few additional files from the root of your package will be included
171
+ automatically, like the `package.json`, `LICENSE` and `README` files.
172
172
 
173
173
  **Tip** If you deploy to Firebase
174
174
  [2nd generation](https://firebase.google.com/docs/firestore/extend-with-functions-2nd-gen)
package/dist/index.d.ts CHANGED
@@ -36,4 +36,4 @@ type IsolateExports = {
36
36
  isolate: typeof isolate;
37
37
  };
38
38
 
39
- export { IsolateExports, Logger, isolate };
39
+ export { type IsolateExports, type Logger, isolate };
package/dist/index.mjs CHANGED
@@ -7,7 +7,7 @@ import path16 from "node:path";
7
7
  import fs5 from "fs-extra";
8
8
  import assert from "node:assert";
9
9
  import path2 from "node:path";
10
- import { isEmpty } from "ramda";
10
+ import { isEmpty } from "remeda";
11
11
 
12
12
  // src/lib/logger.ts
13
13
  import chalk from "chalk";
@@ -138,7 +138,7 @@ async function pack(srcDir, dstDir, usePnpmPack) {
138
138
  exec(
139
139
  `pnpm pack --pack-destination "${dstDir}"`,
140
140
  execOptions,
141
- (err, stdout2, stderr) => {
141
+ (err, stdout2) => {
142
142
  if (err) {
143
143
  log.error(getErrorMessage(err));
144
144
  return reject(err);
@@ -258,7 +258,7 @@ function resolveConfig() {
258
258
  }
259
259
 
260
260
  // src/lib/lockfile/process-lockfile.ts
261
- import { mapObjIndexed } from "ramda";
261
+ import { mapValues } from "remeda";
262
262
 
263
263
  // src/lib/package-manager/helpers/infer-from-files.ts
264
264
  import fs6 from "fs-extra";
@@ -350,6 +350,7 @@ async function generateNpmLockfile({
350
350
  const origRootNodeModulesPath = path5.join(workspaceRootDir, "node_modules");
351
351
  const tempRootNodeModulesPath = path5.join(isolateDir, "node_modules");
352
352
  let hasMovedNodeModules = false;
353
+ let hasError = false;
353
354
  try {
354
355
  if (!fs8.existsSync(origRootNodeModulesPath)) {
355
356
  throw new Error(
@@ -369,12 +370,16 @@ async function generateNpmLockfile({
369
370
  } catch (err) {
370
371
  console.error(inspectValue(err));
371
372
  log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
373
+ hasError = true;
372
374
  } finally {
373
375
  if (hasMovedNodeModules) {
374
376
  log.debug(`Restoring node_modules to the workspace root`);
375
377
  await fs8.move(tempRootNodeModulesPath, origRootNodeModulesPath);
376
378
  }
377
379
  }
380
+ if (hasError) {
381
+ throw new Error("Failed to generate lockfile");
382
+ }
378
383
  }
379
384
 
380
385
  // src/lib/lockfile/helpers/generate-pnpm-lockfile.ts
@@ -385,7 +390,7 @@ import {
385
390
  } from "@pnpm/lockfile-file";
386
391
  import assert3 from "node:assert";
387
392
  import path6 from "node:path";
388
- import { pick } from "ramda";
393
+ import { pick } from "remeda";
389
394
  async function generatePnpmLockfile({
390
395
  workspaceRootDir,
391
396
  targetPackageDir,
@@ -422,7 +427,7 @@ async function generatePnpmLockfile({
422
427
  ];
423
428
  log.debug("Relevant importer ids:", relevantImporterIds);
424
429
  lockfile.importers = Object.fromEntries(
425
- Object.entries(pick(relevantImporterIds, lockfile.importers)).map(
430
+ Object.entries(pick(lockfile.importers, relevantImporterIds)).map(
426
431
  ([importerId, importer]) => {
427
432
  if (importerId === targetImporterId) {
428
433
  log.debug("Setting target package importer on root");
@@ -450,7 +455,7 @@ async function generatePnpmLockfile({
450
455
  await writeWantedLockfile(isolateDir, lockfile);
451
456
  log.debug("Created lockfile at", path6.join(isolateDir, "pnpm-lock.yaml"));
452
457
  } catch (err) {
453
- log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
458
+ throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
454
459
  }
455
460
  }
456
461
 
@@ -476,7 +481,7 @@ async function generateYarnLockfile({
476
481
  execSync2(`yarn install --cwd ${isolateDir}`);
477
482
  log.debug("Generated lockfile at", newLockfilePath);
478
483
  } catch (err) {
479
- log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
484
+ throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
480
485
  }
481
486
  }
482
487
 
@@ -505,9 +510,9 @@ function pnpmMapImporter({
505
510
  };
506
511
  }
507
512
  function pnpmMapDependenciesLinks(def, directoryByPackageName) {
508
- return mapObjIndexed(
509
- (version, name) => version.startsWith("link:") ? `link:./${directoryByPackageName[name]}` : version,
510
- def
513
+ return mapValues(
514
+ def,
515
+ (value, key) => value.startsWith("link:") ? `link:./${directoryByPackageName[key]}` : value
511
516
  );
512
517
  }
513
518
  async function processLockfile({
@@ -578,11 +583,11 @@ async function processLockfile({
578
583
  }
579
584
 
580
585
  // src/lib/manifest/adapt-target-package-manifest.ts
581
- import { omit as omit2, pick as pick2 } from "ramda";
586
+ import { omit as omit2, pick as pick2 } from "remeda";
582
587
 
583
588
  // src/lib/manifest/helpers/adapt-internal-package-manifests.ts
584
589
  import path10 from "node:path";
585
- import { omit } from "ramda";
590
+ import { omit } from "remeda";
586
591
 
587
592
  // src/lib/manifest/io.ts
588
593
  import fs10 from "fs-extra";
@@ -646,7 +651,7 @@ async function adaptInternalPackageManifests(internalPackageNames, packagesRegis
646
651
  await Promise.all(
647
652
  internalPackageNames.map(async (packageName) => {
648
653
  const { manifest, rootRelativeDir } = packagesRegistry[packageName];
649
- const inputManifest = includeDevDependencies ? omit(["peerDependencies"], manifest) : omit(["devDependencies", "peerDependencies"], manifest);
654
+ const inputManifest = includeDevDependencies ? omit(manifest, ["peerDependencies"]) : omit(manifest, ["devDependencies", "peerDependencies"]);
650
655
  const outputManifest = packageManager2.name === "pnpm" && !forceNpm ? (
651
656
  /**
652
657
  * For PNPM the output itself is a workspace so we can preserve the specifiers
@@ -670,7 +675,7 @@ async function adaptInternalPackageManifests(internalPackageNames, packagesRegis
670
675
  async function adaptTargetPackageManifest(manifest, packagesRegistry, isolateDir) {
671
676
  const packageManager2 = usePackageManager();
672
677
  const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } = useConfig();
673
- const inputManifest = includeDevDependencies ? manifest : omit2(["devDependencies"], manifest);
678
+ const inputManifest = includeDevDependencies ? manifest : omit2(manifest, ["devDependencies"]);
674
679
  const adaptedManifest = packageManager2.name === "pnpm" && !forceNpm ? (
675
680
  /**
676
681
  * For PNPM the output itself is a workspace so we can preserve the specifiers
@@ -690,7 +695,7 @@ async function adaptTargetPackageManifest(manifest, packagesRegistry, isolateDir
690
695
  * Scripts are removed by default if not explicitly picked or omitted via
691
696
  * config.
692
697
  */
693
- scripts: pickFromScripts ? pick2(pickFromScripts, manifest.scripts) : omitFromScripts ? omit2(omitFromScripts, manifest.scripts) : void 0
698
+ scripts: pickFromScripts ? pick2(manifest.scripts ?? {}, pickFromScripts) : omitFromScripts ? omit2(manifest.scripts ?? {}, omitFromScripts) : void 0
694
699
  };
695
700
  await writeManifest(isolateDir, outputManifest);
696
701
  }
@@ -907,7 +912,7 @@ async function createPackagesRegistry(workspaceRootDir, workspacePackagesOverrid
907
912
  }
908
913
 
909
914
  // src/lib/registry/list-internal-packages.ts
910
- import { uniq } from "ramda";
915
+ import { uniq } from "remeda";
911
916
  function listInternalPackages(manifest, packagesRegistry, { includeDevDependencies = false } = {}) {
912
917
  const allWorkspacePackageNames = Object.keys(packagesRegistry);
913
918
  const internalPackageNames = (includeDevDependencies ? [
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/isolate.ts","../src/lib/config.ts","../src/lib/logger.ts","../src/lib/utils/get-dirname.ts","../src/lib/utils/get-error-message.ts","../src/lib/utils/get-relative-path.ts","../src/lib/utils/inspect-value.ts","../src/lib/utils/json.ts","../src/lib/utils/pack.ts","../src/lib/utils/unpack.ts","../src/lib/utils/yaml.ts","../src/lib/lockfile/process-lockfile.ts","../src/lib/package-manager/helpers/infer-from-files.ts","../src/lib/package-manager/names.ts","../src/lib/package-manager/helpers/infer-from-manifest.ts","../src/lib/package-manager/index.ts","../src/lib/lockfile/helpers/generate-npm-lockfile.ts","../src/lib/lockfile/helpers/generate-pnpm-lockfile.ts","../src/lib/lockfile/helpers/generate-yarn-lockfile.ts","../src/lib/manifest/adapt-target-package-manifest.ts","../src/lib/manifest/helpers/adapt-internal-package-manifests.ts","../src/lib/manifest/io.ts","../src/lib/manifest/helpers/patch-internal-entries.ts","../src/lib/manifest/helpers/adapt-manifest-internal-deps.ts","../src/lib/output/get-build-output-dir.ts","../src/lib/output/pack-dependencies.ts","../src/lib/output/process-build-output-files.ts","../src/lib/output/unpack-dependencies.ts","../src/lib/registry/create-packages-registry.ts","../src/lib/registry/helpers/find-packages-globs.ts","../src/lib/registry/list-internal-packages.ts"],"sourcesContent":["import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport type { IsolateConfig } from \"./lib/config\";\nimport { resolveConfig, setUserConfig } from \"./lib/config\";\nimport { processLockfile } from \"./lib/lockfile\";\nimport type { Logger } from \"./lib/logger\";\nimport { setLogLevel, setLogger, useLogger } from \"./lib/logger\";\nimport {\n adaptInternalPackageManifests,\n adaptTargetPackageManifest,\n readManifest,\n writeManifest,\n} from \"./lib/manifest\";\nimport {\n getBuildOutputDir,\n packDependencies,\n processBuildOutputFiles,\n unpackDependencies,\n} from \"./lib/output\";\nimport { detectPackageManager } from \"./lib/package-manager\";\nimport { getVersion } from \"./lib/package-manager/helpers/infer-from-files\";\nimport { createPackagesRegistry, listInternalPackages } from \"./lib/registry\";\nimport type { PackageManifest } from \"./lib/types\";\nimport { getDirname, getRootRelativePath, readTypedJson } from \"./lib/utils\";\n\nconst __dirname = getDirname(import.meta.url);\n\nexport async function isolate(\n options: { config?: IsolateConfig; logger?: Logger } = {}\n) {\n if (options.logger) {\n setLogger(options.logger);\n }\n\n if (options.config) {\n setUserConfig(options.config);\n }\n\n const config = resolveConfig();\n\n setLogLevel(config.logLevel);\n\n const log = useLogger();\n\n const thisPackageManifest = await readTypedJson<PackageManifest>(\n path.join(path.join(__dirname, \"..\", \"package.json\"))\n );\n\n log.debug(\"Using isolate-package version\", thisPackageManifest.version);\n\n /**\n * If a targetPackagePath is set, we assume the configuration lives in the\n * root of the workspace. If targetPackagePath is undefined (the default), we\n * assume that the configuration lives in the target package directory.\n */\n const targetPackageDir = config.targetPackagePath\n ? path.join(process.cwd(), config.targetPackagePath)\n : process.cwd();\n\n /**\n * We want a trailing slash here. Functionally it doesn't matter, but it makes\n * the relative paths more correct in the debug output.\n */\n const workspaceRootDir = config.targetPackagePath\n ? process.cwd()\n : path.join(targetPackageDir, config.workspaceRoot);\n\n const buildOutputDir = await getBuildOutputDir(targetPackageDir);\n\n assert(\n fs.existsSync(buildOutputDir),\n `Failed to find build output path at ${buildOutputDir}. Please make sure you build the source before isolating it.`\n );\n\n log.debug(\"Workspace root resolved to\", workspaceRootDir);\n log.debug(\n \"Isolate target package\",\n getRootRelativePath(targetPackageDir, workspaceRootDir)\n );\n\n const isolateDir = path.join(targetPackageDir, config.isolateDirName);\n\n log.debug(\n \"Isolate output directory\",\n getRootRelativePath(isolateDir, workspaceRootDir)\n );\n\n if (fs.existsSync(isolateDir)) {\n await fs.remove(isolateDir);\n log.debug(\"Cleaned the existing isolate output directory\");\n }\n\n await fs.ensureDir(isolateDir);\n\n const tmpDir = path.join(isolateDir, \"__tmp\");\n await fs.ensureDir(tmpDir);\n\n const targetPackageManifest = await readTypedJson<PackageManifest>(\n path.join(targetPackageDir, \"package.json\")\n );\n\n const packageManager = detectPackageManager(workspaceRootDir);\n\n log.debug(\n \"Detected package manager\",\n packageManager.name,\n packageManager.version\n );\n\n /**\n * Build a packages registry so we can find the workspace packages by name and\n * have access to their manifest files and relative paths.\n */\n const packagesRegistry = await createPackagesRegistry(\n workspaceRootDir,\n config.workspacePackages\n );\n\n const internalPackageNames = listInternalPackages(\n targetPackageManifest,\n packagesRegistry,\n {\n includeDevDependencies: config.includeDevDependencies,\n }\n );\n\n const packedFilesByName = await packDependencies({\n internalPackageNames,\n packagesRegistry,\n packDestinationDir: tmpDir,\n });\n\n await unpackDependencies(\n packedFilesByName,\n packagesRegistry,\n tmpDir,\n isolateDir\n );\n\n /** Adapt the manifest files for all the unpacked local dependencies */\n await adaptInternalPackageManifests(\n internalPackageNames,\n packagesRegistry,\n isolateDir\n );\n\n /** Pack the target package directory, and unpack it in the isolate location */\n await processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n });\n\n /**\n * Copy the target manifest file to the isolate location and adapt its\n * workspace dependencies to point to the isolated packages.\n */\n await adaptTargetPackageManifest(\n targetPackageManifest,\n packagesRegistry,\n isolateDir\n );\n\n /** Generate an isolated lockfile based on the original one */\n const usedFallbackToNpm = await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n\n if (usedFallbackToNpm) {\n /**\n * When we fall back to NPM, we set the manifest package manager to the\n * available NPM version.\n */\n const manifest = await readManifest(isolateDir);\n\n const npmVersion = getVersion(\"npm\");\n manifest.packageManager = `npm@${npmVersion}`;\n\n await writeManifest(isolateDir, manifest);\n }\n\n if (packageManager.name === \"pnpm\" && !config.forceNpm) {\n /**\n * PNPM doesn't install dependencies of packages that are linked via link:\n * or file: specifiers. It requires the directory to be configured as a\n * workspace, so we copy the workspace config file to the isolate output.\n */\n fs.copyFileSync(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\"),\n path.join(isolateDir, \"pnpm-workspace.yaml\")\n );\n }\n /**\n * If there is an .npmrc file in the workspace root, copy it to the isolate\n * because the settings there could affect how the lockfile is resolved. Note\n * that .npmrc is used by both NPM and PNPM for configuration.\n *\n * See also: https://pnpm.io/npmrc\n */\n const npmrcPath = path.join(workspaceRootDir, \".npmrc\");\n\n if (fs.existsSync(npmrcPath)) {\n fs.copyFileSync(npmrcPath, path.join(isolateDir, \".npmrc\"));\n log.debug(\"Copied .npmrc file to the isolate output\");\n }\n\n /**\n * Clean up. Only so this in the happy path, so we can look at the temp folder\n * when thing go wrong.\n */\n log.debug(\n \"Deleting temp directory\",\n getRootRelativePath(tmpDir, workspaceRootDir)\n );\n await fs.remove(tmpDir);\n\n log.info(\"Isolate completed at\", isolateDir);\n\n return isolateDir;\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport { setLogLevel, useLogger } from \"./logger\";\nimport { inspectValue, readTypedJsonSync } from \"./utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n forceNpm: boolean;\n pickFromScripts?: string[];\n omitFromScripts?: string[];\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n includePatchedDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n forceNpm: false,\n pickFromScripts: undefined,\n omitFromScripts: undefined,\n};\n\n/**\n * Only initialize the configuration once, and keeping it here for subsequent\n * calls to getConfig.\n */\nlet _resolvedConfig: IsolateConfigResolved | undefined;\n\nlet _user_defined_config: IsolateConfig | undefined;\n\nconst validConfigKeys = Object.keys(configDefaults);\n\nconst CONFIG_FILE_NAME = \"isolate.config.json\";\n\nexport type LogLevel = IsolateConfigResolved[\"logLevel\"];\n\nexport function setUserConfig(config: IsolateConfig) {\n _user_defined_config = config;\n\n if (config.logLevel) {\n setLogLevel(config.logLevel);\n }\n}\n\nexport function useConfig() {\n if (_resolvedConfig) {\n return _resolvedConfig;\n } else {\n throw new Error(\"Called useConfig before config was made available\");\n }\n}\n\n/**\n * Resolve configuration based on user config and defaults. If setConfig was\n * called before this, it does not attempt to read a config file from disk.\n */\nexport function resolveConfig(): IsolateConfigResolved {\n if (_resolvedConfig) {\n return _resolvedConfig;\n }\n\n setLogLevel(process.env.DEBUG_ISOLATE_CONFIG ? \"debug\" : \"info\");\n\n const log = useLogger();\n\n const configFilePath = path.join(process.cwd(), CONFIG_FILE_NAME);\n\n if (_user_defined_config) {\n log.debug(`Using user defined config:`, inspectValue(_user_defined_config));\n } else {\n log.debug(`Attempting to load config from ${configFilePath}`);\n\n _user_defined_config = fs.existsSync(configFilePath)\n ? readTypedJsonSync<IsolateConfig>(configFilePath)\n : {};\n }\n\n const foreignKeys = Object.keys(_user_defined_config).filter(\n (key) => !validConfigKeys.includes(key)\n );\n\n if (!isEmpty(foreignKeys)) {\n log.warn(`Found invalid config settings:`, foreignKeys.join(\", \"));\n }\n\n const config = Object.assign(\n {},\n configDefaults,\n _user_defined_config\n ) satisfies IsolateConfigResolved;\n\n log.debug(\"Using configuration:\", inspectValue(config));\n\n _resolvedConfig = config;\n return config;\n}\n\n/**\n * Get only the configuration that the user set explicitly in the config file or\n * passed via arguments to isolate().\n */\nexport function getUserDefinedConfig(): IsolateConfig {\n assert(\n _user_defined_config,\n \"Called getUserDefinedConfig before user config was made available\"\n );\n\n return _user_defined_config;\n}\n","import chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"./config\";\n/**\n * The Logger defines an interface that can be used to pass in a different\n * logger object in order to intercept all the logging output. We keep the\n * handlers separate from the logger object itself, so that we can change the\n * handlers but do not bother the user with having to handle logLevel.\n */\nexport type Logger = {\n debug(...args: unknown[]): void;\n info(...args: unknown[]): void;\n warn(...args: unknown[]): void;\n error(...args: unknown[]): void;\n};\n\nlet _loggerHandlers: Logger = {\n debug(...args: unknown[]) {\n console.log(chalk.blue(\"debug\"), ...args);\n },\n info(...args: unknown[]) {\n console.log(chalk.green(\"info\"), ...args);\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(\"warning\"), ...args);\n },\n error(...args: unknown[]) {\n console.log(chalk.red(\"error\"), ...args);\n },\n};\n\nconst _logger: Logger = {\n debug(...args: unknown[]) {\n if (_logLevel === \"debug\") {\n _loggerHandlers.debug(...args);\n }\n },\n info(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\") {\n _loggerHandlers.info(...args);\n }\n },\n warn(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\" || _logLevel === \"warn\") {\n _loggerHandlers.warn(...args);\n }\n },\n error(...args: unknown[]) {\n _loggerHandlers.error(...args);\n },\n};\n\nlet _logLevel: LogLevel = \"info\";\n\nexport function setLogger(logger: Logger) {\n _loggerHandlers = logger;\n return _logger;\n}\n\nexport function setLogLevel(\n logLevel: IsolateConfigResolved[\"logLevel\"]\n): Logger {\n _logLevel = logLevel;\n return _logger;\n}\n\nexport function useLogger() {\n return _logger;\n}\n","import { fileURLToPath } from \"url\";\n\n/**\n * Calling context should pass in import.meta.url and the function will return\n * the equivalent of __dirname in Node/CommonJs.\n */\nexport function getDirname(importMetaUrl: string) {\n return fileURLToPath(new URL(\".\", importMetaUrl));\n}\n","type ErrorWithMessage = {\n message: string;\n};\n\nexport function getErrorMessage(error: unknown) {\n return toErrorWithMessage(error).message;\n}\n\nfunction isErrorWithMessage(error: unknown): error is ErrorWithMessage {\n return typeof error === \"object\" && error !== null && \"message\" in error;\n}\n\nfunction toErrorWithMessage(maybeError: unknown): ErrorWithMessage {\n if (isErrorWithMessage(maybeError)) return maybeError;\n\n try {\n return new Error(JSON.stringify(maybeError));\n } catch {\n /**\n * Fallback in case there’s an error stringifying the maybeError like with\n * circular references.\n */\n return new Error(String(maybeError));\n }\n}\n","export function getRootRelativePath(path: string, rootPath: string) {\n const strippedPath = path.replace(rootPath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(root)${strippedPath}`\n : `(root)/${strippedPath}`;\n}\n\nexport function getIsolateRelativePath(path: string, isolatePath: string) {\n const strippedPath = path.replace(isolatePath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(isolate)${strippedPath}`\n : `(isolate)/${strippedPath}`;\n}\n","import { inspect } from \"node:util\";\nimport type { JsonValue } from \"type-fest\";\n\nexport function inspectValue(value: JsonValue) {\n return inspect(value, false, 16, true);\n}\n","import fs from \"fs-extra\";\nimport stripJsonComments from \"strip-json-comments\";\nimport { getErrorMessage } from \"./get-error-message\";\n\n/** @todo Pass in zod schema and validate */\nexport function readTypedJsonSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = JSON.parse(stripJsonComments(rawContent)) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport async function readTypedJson<T>(filePath: string) {\n try {\n const rawContent = await fs.readFile(filePath, \"utf-8\");\n const data = JSON.parse(rawContent) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n","import { exec } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack?: boolean\n) {\n const execOptions = {\n maxBuffer: 10 * 1024 * 1024,\n };\n\n const log = useLogger();\n\n const previousCwd = process.cwd();\n process.chdir(srcDir);\n\n /**\n * PNPM pack seems to be a lot faster than NPM pack, so when PNPM is detected\n * we use that instead.\n */\n const stdout = usePnpmPack\n ? await new Promise<string>((resolve, reject) => {\n exec(\n `pnpm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout, stderr) => {\n if (err) {\n log.error(getErrorMessage(err));\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n })\n : await new Promise<string>((resolve, reject) => {\n exec(\n `npm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n });\n\n const fileName = path.basename(stdout.trim());\n\n const filePath = path.join(dstDir, fileName);\n\n if (!fs.existsSync(filePath)) {\n log.error(\n `The response from pack could not be resolved to an existing file: ${filePath}`\n );\n } else {\n log.debug(`Packed (temp)/${fileName}`);\n }\n\n process.chdir(previousCwd);\n\n /**\n * Return the path anyway even if it doesn't validate. A later stage will wait\n * for the file to occur still. Not sure if this makes sense. Maybe we should\n * stop at the validation error...\n */\n return filePath;\n}\n","import fs from \"fs-extra\";\nimport tar from \"tar-fs\";\nimport { createGunzip } from \"zlib\";\n\nexport async function unpack(filePath: string, unpackDir: string) {\n await new Promise<void>((resolve, reject) => {\n fs.createReadStream(filePath)\n .pipe(createGunzip())\n .pipe(tar.extract(unpackDir))\n .on(\"finish\", () => resolve())\n .on(\"error\", (err) => reject(err));\n });\n}\n","import fs from \"fs-extra\";\nimport yaml from \"yaml\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport function readTypedYamlSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = yaml.parse(rawContent);\n /** @todo Add some zod validation maybe */\n return data as T;\n } catch (err) {\n throw new Error(\n `Failed to read YAML from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport function writeTypedYamlSync<T>(filePath: string, content: T) {\n /** @todo Add some zod validation maybe */\n fs.writeFileSync(filePath, yaml.stringify(content), \"utf-8\");\n}\n","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { generateNpmLockfile } from \"./helpers/generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./helpers/generate-pnpm-lockfile\";\nimport { generateYarnLockfile } from \"./helpers/generate-yarn-lockfile\";\n\n/** Convert dependency links */\nexport function pnpmMapImporter(\n {\n dependencies,\n devDependencies,\n patchedDependencies,\n ...rest\n }: ProjectSnapshot,\n {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n directoryByPackageName: { [packageName: string]: string };\n }\n): ProjectSnapshot {\n return {\n dependencies: dependencies\n ? pnpmMapDependenciesLinks(dependencies, directoryByPackageName)\n : undefined,\n devDependencies:\n includeDevDependencies && devDependencies\n ? pnpmMapDependenciesLinks(devDependencies, directoryByPackageName)\n : undefined,\n /**\n * Don't know how to map the patched dependencies yet, so we just include\n * them but I don't think it would work like this. The important thing for\n * now is that they are omitted by default, because that is the most common\n * use case.\n */\n patchedDependencies: includePatchedDependencies\n ? patchedDependencies\n : undefined,\n ...rest,\n };\n}\n\nfunction pnpmMapDependenciesLinks(\n def: ResolvedDependencies,\n directoryByPackageName: { [packageName: string]: string }\n): ResolvedDependencies {\n return mapObjIndexed(\n (version, name) =>\n version.startsWith(\"link:\")\n ? `link:./${directoryByPackageName[name]}`\n : version,\n def\n );\n}\n\n/**\n * Adapt the lockfile and write it to the isolate directory. Because we keep the\n * structure of packages in the isolate directory the same as they were in the\n * monorepo, the lockfile is largely still correct. The only things that need to\n * be done is to remove the root dependencies and devDependencies, and rename\n * the path to the target package to act as the new root.\n */\nexport async function processLockfile({\n workspaceRootDir,\n packagesRegistry,\n isolateDir,\n internalDepPackageNames,\n targetPackageDir,\n}: {\n workspaceRootDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n internalDepPackageNames: string[];\n targetPackageDir: string;\n targetPackageName: string;\n}) {\n const log = useLogger();\n\n const { forceNpm } = useConfig();\n\n if (forceNpm) {\n log.info(\"Forcing to use NPM for isolate output\");\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n return true;\n }\n\n const { name, version } = usePackageManager();\n let usedFallbackToNpm = false;\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n break;\n }\n case \"yarn\": {\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n if (versionMajor === 1) {\n await generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n });\n } else {\n log.info(\n \"Detected modern version of Yarn. Using NPM lockfile fallback.\"\n );\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n break;\n }\n case \"pnpm\": {\n await generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n });\n break;\n }\n default:\n log.warn(`Unexpected package manager ${name}. Using NPM for output`);\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n return usedFallbackToNpm;\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport type { PackageManager, PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromFiles(workspaceRoot: string): PackageManager {\n for (const name of supportedPackageManagerNames) {\n const lockfileName = getLockfileFileName(name);\n\n if (fs.existsSync(path.join(workspaceRoot, lockfileName))) {\n return { name, version: getVersion(name) };\n }\n }\n\n /** If no lockfile was found, it could be that there is an npm shrinkwrap file. */\n if (fs.existsSync(path.join(workspaceRoot, \"npm-shrinkwrap.json\"))) {\n return { name: \"npm\", version: getVersion(\"npm\") };\n }\n\n throw new Error(`Failed to detect package manager`);\n}\n\nexport function getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\n","export const supportedPackageManagerNames = [\"pnpm\", \"yarn\", \"npm\"] as const;\n\nexport type PackageManagerName = (typeof supportedPackageManagerNames)[number];\n\nexport type PackageManager = {\n name: PackageManagerName;\n version: string;\n};\n\nexport function getLockfileFileName(name: PackageManagerName) {\n switch (name) {\n case \"pnpm\":\n return \"pnpm-lock.yaml\";\n case \"yarn\":\n return \"yarn.lock\";\n case \"npm\":\n return \"package-lock.json\";\n }\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackageManifest } from \"../../types\";\nimport { readTypedJsonSync } from \"../../utils\";\nimport type { PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromManifest(workspaceRoot: string) {\n const log = useLogger();\n\n const rootManifest = readTypedJsonSync<PackageManifest>(\n path.join(workspaceRoot, \"package.json\")\n );\n\n if (!rootManifest.packageManager) {\n log.debug(\"No packageManager field found in root manifest\");\n return;\n }\n\n const [name, version = \"*\"] = rootManifest.packageManager.split(\"@\") as [\n PackageManagerName,\n string,\n ];\n\n assert(\n supportedPackageManagerNames.includes(name),\n `Package manager \"${name}\" is not currently supported`\n );\n\n const lockfileName = getLockfileFileName(name);\n\n assert(\n fs.existsSync(path.join(workspaceRoot, lockfileName)),\n `Manifest declares ${name} to be the packageManager, but failed to find ${lockfileName} in workspace root`\n );\n\n return { name, version };\n}\n","import { inferFromFiles } from \"./helpers/infer-from-files\";\nimport { inferFromManifest } from \"./helpers/infer-from-manifest\";\nimport type { PackageManager } from \"./names\";\n\nexport * from \"./names\";\n\nexport let packageManager: PackageManager | undefined;\n\nexport function usePackageManager() {\n if (!packageManager) {\n throw Error(\n \"No package manager detected. Make sure to call detectPackageManager() before usePackageManager()\"\n );\n }\n\n return packageManager;\n}\n\n/**\n * First we check if the package manager is declared in the manifest. If it is,\n * we get the name and version from there. Otherwise we'll search for the\n * different lockfiles and ask the OS to report the installed version.\n */\nexport function detectPackageManager(workspaceRoot: string): PackageManager {\n /**\n * Disable infer from manifest for now. I doubt it is useful after all but\n * I'll keep the code as a reminder.\n */\n packageManager =\n inferFromManifest(workspaceRoot) ?? inferFromFiles(workspaceRoot);\n\n return packageManager;\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage, inspectValue } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the contents of installed\n * node_modules from the monorepo root plus the adapted package manifest in the\n * isolate directory.\n */\nexport async function generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating NPM lockfile...\");\n\n const origRootNodeModulesPath = path.join(workspaceRootDir, \"node_modules\");\n const tempRootNodeModulesPath = path.join(isolateDir, \"node_modules\");\n\n let hasMovedNodeModules = false;\n\n try {\n if (!fs.existsSync(origRootNodeModulesPath)) {\n throw new Error(\n `Failed to find node_modules at ${origRootNodeModulesPath}`\n );\n }\n\n log.debug(`Temporarily moving node_modules to the isolate output`);\n\n await fs.move(origRootNodeModulesPath, tempRootNodeModulesPath);\n hasMovedNodeModules = true;\n\n const arborist = new Arborist({ path: isolateDir });\n\n log.debug(`Building tree...`);\n const { meta } = await arborist.buildIdealTree();\n\n meta?.commit();\n\n const lockfilePath = path.join(isolateDir, \"package-lock.json\");\n\n await fs.writeFile(lockfilePath, String(meta));\n\n log.debug(\"Created lockfile at\", lockfilePath);\n } catch (err: any) {\n console.error(inspectValue(err));\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n /**\n * If lockfile creation fails we can technically still continue with the\n * rest. Not sure if that is desirable.\n */\n } finally {\n if (hasMovedNodeModules) {\n log.debug(`Restoring node_modules to the workspace root`);\n await fs.move(tempRootNodeModulesPath, origRootNodeModulesPath);\n }\n }\n}\n","import {\n getLockfileImporterId,\n readWantedLockfile,\n writeWantedLockfile,\n} from \"@pnpm/lockfile-file\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { pick } from \"ramda\";\nimport { useConfig } from \"~/lib/config\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { getErrorMessage } from \"~/lib/utils\";\nimport { pnpmMapImporter } from \"../process-lockfile\";\n\nexport async function generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n}: {\n workspaceRootDir: string;\n targetPackageDir: string;\n isolateDir: string;\n internalDepPackageNames: string[];\n packagesRegistry: PackagesRegistry;\n}) {\n const { includeDevDependencies, includePatchedDependencies } = useConfig();\n const log = useLogger();\n\n log.info(\"Generating PNPM lockfile...\");\n\n try {\n const lockfile = await readWantedLockfile(workspaceRootDir, {\n ignoreIncompatible: false,\n });\n\n assert(lockfile, `No input lockfile found at ${workspaceRootDir}`);\n\n const targetImporterId = getLockfileImporterId(\n workspaceRootDir,\n targetPackageDir\n );\n\n const directoryByPackageName = Object.fromEntries(\n internalDepPackageNames.map((name) => {\n const pkg = packagesRegistry[name];\n assert(pkg, `Package ${name} not found in packages registry`);\n return [name, pkg.rootRelativeDir];\n })\n );\n\n const relevantImporterIds = [\n targetImporterId,\n /**\n * The directory paths happen to correspond with what PNPM calls the\n * importer ids in the context of a lockfile.\n */\n ...Object.values(directoryByPackageName),\n ];\n\n log.debug(\"Relevant importer ids:\", relevantImporterIds);\n\n lockfile.importers = Object.fromEntries(\n Object.entries(pick(relevantImporterIds, lockfile.importers)).map(\n ([importerId, importer]) => {\n if (importerId === targetImporterId) {\n log.debug(\"Setting target package importer on root\");\n\n return [\n \".\",\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n )\n );\n\n await writeWantedLockfile(isolateDir, lockfile);\n\n log.debug(\"Created lockfile at\", path.join(isolateDir, \"pnpm-lock.yaml\"));\n } catch (err) {\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the existing lockfile from\n * the monorepo root plus the adapted package manifest in the isolate\n * directory.\n */\nexport async function generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating Yarn lockfile...\");\n\n const origLockfilePath = path.join(workspaceRootDir, \"yarn.lock\");\n const newLockfilePath = path.join(isolateDir, \"yarn.lock\");\n\n if (!fs.existsSync(origLockfilePath)) {\n throw new Error(`Failed to find lockfile at ${origLockfilePath}`);\n }\n\n log.debug(`Copy original yarn.lock to the isolate output`);\n\n try {\n await fs.copyFile(origLockfilePath, newLockfilePath);\n\n /**\n * Running install with the original lockfile in the same directory will\n * generate a pruned version of the lockfile.\n */\n log.debug(`Running local install`);\n execSync(`yarn install --cwd ${isolateDir}`);\n\n log.debug(\"Generated lockfile at\", newLockfilePath);\n } catch (err) {\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n /**\n * If lockfile creation fails we can technically still continue with the\n * rest. Not sure if that is desirable.\n */\n }\n}\n","import { omit, pick } from \"ramda\";\nimport { useConfig } from \"../config\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { adaptManifestInternalDeps } from \"./helpers\";\nimport { writeManifest } from \"./io\";\n\n/**\n * Adapt the output package manifest, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - The devDependencies are possibly removed\n * - Scripts are picked or omitted and otherwise removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } =\n useConfig();\n\n /** Dev dependencies are omitted by default */\n const inputManifest = includeDevDependencies\n ? manifest\n : omit([\"devDependencies\"], manifest);\n\n const adaptedManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : /** For other package managers we replace the links to internal dependencies */\n adaptManifestInternalDeps({\n manifest: inputManifest,\n packagesRegistry,\n });\n\n const outputManifest = {\n ...adaptedManifest,\n /**\n * Scripts are removed by default if not explicitly picked or omitted via\n * config.\n */\n scripts: pickFromScripts\n ? pick(pickFromScripts as never[], manifest.scripts)\n : omitFromScripts\n ? omit(omitFromScripts as never[], manifest.scripts)\n : undefined,\n };\n\n await writeManifest(isolateDir, outputManifest);\n}\n","import path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { useConfig } from \"~/lib/config\";\nimport { usePackageManager } from \"~/lib/package-manager\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { writeManifest } from \"../io\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\n\n/**\n * Adapt the manifest files of all the isolated internal packages (excluding the\n * target package), so that their dependencies point to the other isolated\n * packages in the same folder.\n */\nexport async function adaptInternalPackageManifests(\n internalPackageNames: string[],\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n /**\n * Dev dependencies are omitted by default. And also, for internal\n * dependencies we want to omit the peerDependencies, because installing\n * these is the responsibility of the consuming app / service, and\n * otherwise the frozen lockfile install will error since the package file\n * contains something that is not referenced in the lockfile.\n */\n const inputManifest = includeDevDependencies\n ? omit([\"peerDependencies\"], manifest)\n : omit([\"devDependencies\", \"peerDependencies\"], manifest);\n\n const outputManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n });\n\n await writeManifest(\n path.join(isolateDir, rootRelativeDir),\n outputManifest\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport type { PackageManifest } from \"../types\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function readManifest(packageDir: string) {\n return readTypedJson<PackageManifest>(path.join(packageDir, \"package.json\"));\n}\n\nexport async function writeManifest(\n outputDir: string,\n manifest: PackageManifest\n) {\n await fs.writeFile(\n path.join(outputDir, \"package.json\"),\n JSON.stringify(manifest, null, 2)\n );\n}\n","import path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport type { PackagesRegistry } from \"../../types\";\n\nexport function patchInternalEntries(\n dependencies: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n parentRootRelativeDir?: string\n) {\n const log = useLogger();\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n return Object.fromEntries(\n Object.entries(dependencies).map(([key, value]) => {\n if (allWorkspacePackageNames.includes(key)) {\n const def = packagesRegistry[key];\n\n /**\n * When nested internal dependencies are used (internal packages linking\n * to other internal packages), the parentRootRelativeDir will be passed\n * in, and we store the relative path to the isolate/packages\n * directory.\n *\n * For consistency we also write the other file paths starting with ./,\n * but it doesn't seem to be necessary for any package manager.\n */\n const relativePath = parentRootRelativeDir\n ? path.relative(parentRootRelativeDir, `./${def.rootRelativeDir}`)\n : `./${def.rootRelativeDir}`;\n\n const linkPath = `file:${relativePath}`;\n\n log.debug(`Linking dependency ${key} to ${linkPath}`);\n\n return [key, linkPath];\n } else {\n return [key, value];\n }\n })\n );\n}\n","import type { PackageManifest, PackagesRegistry } from \"~/lib/types\";\nimport { patchInternalEntries } from \"./patch-internal-entries\";\n\n/**\n * Replace the workspace version specifiers for internal dependency with file:\n * paths. Not needed for PNPM (because we configure the isolated output as a\n * workspace), but maybe still for NPM and Yarn.\n */\nexport function adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n}: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n}): PackageManifest {\n const { dependencies, devDependencies } = manifest;\n\n return {\n ...manifest,\n dependencies: dependencies\n ? patchInternalEntries(\n dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies: devDependencies\n ? patchInternalEntries(\n devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n };\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function getBuildOutputDir(targetPackageDir: string) {\n const config = useConfig();\n const log = useLogger();\n\n if (config.buildDirName) {\n log.debug(\"Using buildDirName from config:\", config.buildDirName);\n return path.join(targetPackageDir, config.buildDirName);\n }\n\n const tsconfigPath = path.join(targetPackageDir, config.tsconfigPath);\n\n if (fs.existsSync(tsconfigPath)) {\n log.debug(\"Found tsconfig at:\", config.tsconfigPath);\n\n const tsconfig = await readTypedJson<{\n compilerOptions?: { outDir?: string };\n }>(tsconfigPath);\n\n const outDir = tsconfig.compilerOptions?.outDir;\n\n if (outDir) {\n return path.join(targetPackageDir, outDir);\n } else {\n throw new Error(outdent`\n Failed to find outDir in tsconfig. If you are executing isolate from the root of a monorepo you should specify the buildDirName in isolate.config.json.\n `);\n }\n } else {\n log.warn(\"Failed to find tsconfig at:\", tsconfigPath);\n\n throw new Error(outdent`\n Failed to infer the build output directory from either the isolate config buildDirName or a Typescript config file. See the documentation on how to configure one of these options.\n `);\n }\n}\n","import assert from \"node:assert\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { pack } from \"../utils\";\n\n/**\n * Pack dependencies so that we extract only the files that are supposed to be\n * published by the packages.\n *\n * @returns A map of package names to the path of the packed file\n */\nexport async function packDependencies({\n /** All packages found in the monorepo by workspaces declaration */\n packagesRegistry,\n /** The dependencies that appear to be internal packages */\n internalPackageNames,\n /**\n * The directory where the isolated package and all its dependencies will end\n * up. This is also the directory from where the package will be deployed. By\n * default it is a subfolder in targetPackageDir called \"isolate\" but you can\n * configure it.\n */\n packDestinationDir,\n}: {\n packagesRegistry: PackagesRegistry;\n internalPackageNames: string[];\n packDestinationDir: string;\n}) {\n const log = useLogger();\n\n const packedFileByName: Record<string, string> = {};\n\n const { name, version } = usePackageManager();\n\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n const usePnpmPack = name === \"pnpm\" && versionMajor >= 8;\n\n if (usePnpmPack) {\n log.debug(\"Using PNPM pack instead of NPM pack\");\n }\n\n for (const dependency of internalPackageNames) {\n const def = packagesRegistry[dependency];\n\n assert(dependency, `Failed to find package definition for ${dependency}`);\n\n const { name } = def.manifest;\n\n /**\n * If this dependency has already been packed, we skip it. It could happen\n * because we are packing workspace dependencies recursively.\n */\n if (packedFileByName[name]) {\n log.debug(`Skipping ${name} because it has already been packed`);\n continue;\n }\n\n packedFileByName[name] = await pack(\n def.absoluteDir,\n packDestinationDir,\n usePnpmPack\n );\n }\n\n return packedFileByName;\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { pack, unpack } from \"../utils\";\n\nconst TIMEOUT_MS = 5000;\n\nexport async function processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n}: {\n targetPackageDir: string;\n tmpDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n const packedFilePath = await pack(targetPackageDir, tmpDir);\n const unpackDir = path.join(tmpDir, \"target\");\n\n const now = Date.now();\n let isWaitingYet = false;\n\n while (!fs.existsSync(packedFilePath) && Date.now() - now < TIMEOUT_MS) {\n if (!isWaitingYet) {\n log.debug(`Waiting for ${packedFilePath} to become available...`);\n }\n isWaitingYet = true;\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n await unpack(packedFilePath, unpackDir);\n await fs.copy(path.join(unpackDir, \"package\"), isolateDir);\n}\n","import fs from \"fs-extra\";\nimport path, { join } from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackagesRegistry } from \"../types\";\nimport { getIsolateRelativePath, unpack } from \"../utils\";\n\nexport async function unpackDependencies(\n packedFilesByName: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n tmpDir: string,\n isolateDir: string\n) {\n const log = useLogger();\n\n await Promise.all(\n Object.entries(packedFilesByName).map(async ([packageName, filePath]) => {\n const dir = packagesRegistry[packageName].rootRelativeDir;\n const unpackDir = join(tmpDir, dir);\n\n log.debug(\"Unpacking\", `(temp)/${path.basename(filePath)}`);\n\n await unpack(filePath, unpackDir);\n\n const destinationDir = join(isolateDir, dir);\n\n await fs.ensureDir(destinationDir);\n\n await fs.move(join(unpackDir, \"package\"), destinationDir, {\n overwrite: true,\n });\n\n log.debug(\n `Moved package files to ${getIsolateRelativePath(\n destinationDir,\n isolateDir\n )}`\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { readTypedJson } from \"../utils\";\nimport { findPackagesGlobs } from \"./helpers/find-packages-globs\";\n\n/**\n * Build a list of all packages in the workspace, depending on the package\n * manager used, with a possible override from the config file. The list\n * contains the manifest with some directory info mapped by module name.\n */\nexport async function createPackagesRegistry(\n workspaceRootDir: string,\n workspacePackagesOverride: string[] | undefined\n): Promise<PackagesRegistry> {\n const log = useLogger();\n\n if (workspacePackagesOverride) {\n log.debug(\n `Override workspace packages via config: ${workspacePackagesOverride}`\n );\n }\n\n const packagesGlobs =\n workspacePackagesOverride ?? findPackagesGlobs(workspaceRootDir);\n\n const cwd = process.cwd();\n process.chdir(workspaceRootDir);\n\n const allPackages = packagesGlobs\n .flatMap((glob) => globSync(glob))\n /** Make sure to filter any loose files that might hang around. */\n .filter((dir) => fs.lstatSync(dir).isDirectory());\n\n const registry: PackagesRegistry = (\n await Promise.all(\n allPackages.map(async (rootRelativeDir) => {\n const manifestPath = path.join(rootRelativeDir, \"package.json\");\n\n if (!fs.existsSync(manifestPath)) {\n log.warn(\n `Ignoring directory ./${rootRelativeDir} because it does not contain a package.json file`\n );\n return;\n } else {\n log.debug(`Registering package ./${rootRelativeDir}`);\n\n const manifest = await readTypedJson<PackageManifest>(\n path.join(rootRelativeDir, \"package.json\")\n );\n\n return {\n manifest,\n rootRelativeDir,\n absoluteDir: path.join(workspaceRootDir, rootRelativeDir),\n };\n }\n })\n )\n ).reduce<PackagesRegistry>((acc, info) => {\n if (info) {\n acc[info.manifest.name] = info;\n }\n return acc;\n }, {});\n\n process.chdir(cwd);\n\n return registry;\n}\n","import assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport { usePackageManager } from \"../../package-manager\";\nimport {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n} from \"../../utils\";\n\n/**\n * Find the globs that define where the packages are located within the\n * monorepo. This configuration is dependent on the package manager used, and I\n * don't know if we're covering all cases yet...\n */\nexport function findPackagesGlobs(workspaceRootDir: string) {\n const log = useLogger();\n\n const packageManager = usePackageManager();\n\n switch (packageManager.name) {\n case \"pnpm\": {\n const { packages: globs } = readTypedYamlSync<{ packages: string[] }>(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\")\n );\n\n log.debug(\"Detected pnpm packages globs:\", inspectValue(globs));\n return globs;\n }\n case \"yarn\":\n case \"npm\": {\n const workspaceRootManifestPath = path.join(\n workspaceRootDir,\n \"package.json\"\n );\n\n const { workspaces } = readTypedJsonSync<{ workspaces: string[] }>(\n workspaceRootManifestPath\n );\n\n if (!workspaces) {\n throw new Error(\n `No workspaces field found in ${workspaceRootManifestPath}`\n );\n }\n\n if (Array.isArray(workspaces)) {\n return workspaces;\n } else {\n /**\n * For Yarn, workspaces could be defined as an object with { packages:\n * [], nohoist: [] }. See\n * https://classic.yarnpkg.com/blog/2018/02/15/nohoist/\n */\n const workspacesObject = workspaces as { packages?: string[] };\n\n assert(\n workspacesObject.packages,\n \"workspaces.packages must be an array\"\n );\n\n return workspacesObject.packages;\n }\n }\n }\n}\n","import { uniq } from \"ramda\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\n\n/**\n * Recursively list all the packages from dependencies (and optionally\n * devDependencies) that are found in the monorepo.\n *\n * Here we do not need to rely on packages being declared with \"workspace:\" in\n * the package manifest. We can simply compare the package names with the list\n * of packages that were found via the workspace glob patterns and add them to\n * the registry.\n */\nexport function listInternalPackages(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n { includeDevDependencies = false } = {}\n): string[] {\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n const internalPackageNames = (\n includeDevDependencies\n ? [\n ...Object.keys(manifest.dependencies ?? {}),\n ...Object.keys(manifest.devDependencies ?? {}),\n ]\n : Object.keys(manifest.dependencies ?? {})\n ).filter((name) => allWorkspacePackageNames.includes(name));\n\n const nestedInternalPackageNames = internalPackageNames.flatMap(\n (packageName) =>\n listInternalPackages(\n packagesRegistry[packageName].manifest,\n packagesRegistry,\n { includeDevDependencies }\n )\n );\n\n return uniq(internalPackageNames.concat(nestedInternalPackageNames));\n}\n"],"mappings":"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","names":["fs","assert","path","fs","path","path","fs","stdout","fs","fs","fs","fs","path","fs","fs","path","fs","path","fs","assert","path","path","assert","fs","fs","path","path","fs","assert","path","assert","path","fs","execSync","path","path","fs","execSync","omit","pick","path","fs","path","path","fs","path","path","packageManager","path","packageManager","omit","pick","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","fs","path","assert","path","packageManager","path","assert","fs","path","path","assert","fs","packageManager"]}
1
+ {"version":3,"sources":["../src/isolate.ts","../src/lib/config.ts","../src/lib/logger.ts","../src/lib/utils/get-dirname.ts","../src/lib/utils/get-error-message.ts","../src/lib/utils/get-relative-path.ts","../src/lib/utils/inspect-value.ts","../src/lib/utils/json.ts","../src/lib/utils/pack.ts","../src/lib/utils/unpack.ts","../src/lib/utils/yaml.ts","../src/lib/lockfile/process-lockfile.ts","../src/lib/package-manager/helpers/infer-from-files.ts","../src/lib/package-manager/names.ts","../src/lib/package-manager/helpers/infer-from-manifest.ts","../src/lib/package-manager/index.ts","../src/lib/lockfile/helpers/generate-npm-lockfile.ts","../src/lib/lockfile/helpers/generate-pnpm-lockfile.ts","../src/lib/lockfile/helpers/generate-yarn-lockfile.ts","../src/lib/manifest/adapt-target-package-manifest.ts","../src/lib/manifest/helpers/adapt-internal-package-manifests.ts","../src/lib/manifest/io.ts","../src/lib/manifest/helpers/patch-internal-entries.ts","../src/lib/manifest/helpers/adapt-manifest-internal-deps.ts","../src/lib/output/get-build-output-dir.ts","../src/lib/output/pack-dependencies.ts","../src/lib/output/process-build-output-files.ts","../src/lib/output/unpack-dependencies.ts","../src/lib/registry/create-packages-registry.ts","../src/lib/registry/helpers/find-packages-globs.ts","../src/lib/registry/list-internal-packages.ts"],"sourcesContent":["import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport type { IsolateConfig } from \"./lib/config\";\nimport { resolveConfig, setUserConfig } from \"./lib/config\";\nimport { processLockfile } from \"./lib/lockfile\";\nimport type { Logger } from \"./lib/logger\";\nimport { setLogLevel, setLogger, useLogger } from \"./lib/logger\";\nimport {\n adaptInternalPackageManifests,\n adaptTargetPackageManifest,\n readManifest,\n writeManifest,\n} from \"./lib/manifest\";\nimport {\n getBuildOutputDir,\n packDependencies,\n processBuildOutputFiles,\n unpackDependencies,\n} from \"./lib/output\";\nimport { detectPackageManager } from \"./lib/package-manager\";\nimport { getVersion } from \"./lib/package-manager/helpers/infer-from-files\";\nimport { createPackagesRegistry, listInternalPackages } from \"./lib/registry\";\nimport type { PackageManifest } from \"./lib/types\";\nimport { getDirname, getRootRelativePath, readTypedJson } from \"./lib/utils\";\n\nconst __dirname = getDirname(import.meta.url);\n\nexport async function isolate(\n options: { config?: IsolateConfig; logger?: Logger } = {}\n) {\n if (options.logger) {\n setLogger(options.logger);\n }\n\n if (options.config) {\n setUserConfig(options.config);\n }\n\n const config = resolveConfig();\n\n setLogLevel(config.logLevel);\n\n const log = useLogger();\n\n const thisPackageManifest = await readTypedJson<PackageManifest>(\n path.join(path.join(__dirname, \"..\", \"package.json\"))\n );\n\n log.debug(\"Using isolate-package version\", thisPackageManifest.version);\n\n /**\n * If a targetPackagePath is set, we assume the configuration lives in the\n * root of the workspace. If targetPackagePath is undefined (the default), we\n * assume that the configuration lives in the target package directory.\n */\n const targetPackageDir = config.targetPackagePath\n ? path.join(process.cwd(), config.targetPackagePath)\n : process.cwd();\n\n /**\n * We want a trailing slash here. Functionally it doesn't matter, but it makes\n * the relative paths more correct in the debug output.\n */\n const workspaceRootDir = config.targetPackagePath\n ? process.cwd()\n : path.join(targetPackageDir, config.workspaceRoot);\n\n const buildOutputDir = await getBuildOutputDir(targetPackageDir);\n\n assert(\n fs.existsSync(buildOutputDir),\n `Failed to find build output path at ${buildOutputDir}. Please make sure you build the source before isolating it.`\n );\n\n log.debug(\"Workspace root resolved to\", workspaceRootDir);\n log.debug(\n \"Isolate target package\",\n getRootRelativePath(targetPackageDir, workspaceRootDir)\n );\n\n const isolateDir = path.join(targetPackageDir, config.isolateDirName);\n\n log.debug(\n \"Isolate output directory\",\n getRootRelativePath(isolateDir, workspaceRootDir)\n );\n\n if (fs.existsSync(isolateDir)) {\n await fs.remove(isolateDir);\n log.debug(\"Cleaned the existing isolate output directory\");\n }\n\n await fs.ensureDir(isolateDir);\n\n const tmpDir = path.join(isolateDir, \"__tmp\");\n await fs.ensureDir(tmpDir);\n\n const targetPackageManifest = await readTypedJson<PackageManifest>(\n path.join(targetPackageDir, \"package.json\")\n );\n\n const packageManager = detectPackageManager(workspaceRootDir);\n\n log.debug(\n \"Detected package manager\",\n packageManager.name,\n packageManager.version\n );\n\n /**\n * Build a packages registry so we can find the workspace packages by name and\n * have access to their manifest files and relative paths.\n */\n const packagesRegistry = await createPackagesRegistry(\n workspaceRootDir,\n config.workspacePackages\n );\n\n const internalPackageNames = listInternalPackages(\n targetPackageManifest,\n packagesRegistry,\n {\n includeDevDependencies: config.includeDevDependencies,\n }\n );\n\n const packedFilesByName = await packDependencies({\n internalPackageNames,\n packagesRegistry,\n packDestinationDir: tmpDir,\n });\n\n await unpackDependencies(\n packedFilesByName,\n packagesRegistry,\n tmpDir,\n isolateDir\n );\n\n /** Adapt the manifest files for all the unpacked local dependencies */\n await adaptInternalPackageManifests(\n internalPackageNames,\n packagesRegistry,\n isolateDir\n );\n\n /** Pack the target package directory, and unpack it in the isolate location */\n await processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n });\n\n /**\n * Copy the target manifest file to the isolate location and adapt its\n * workspace dependencies to point to the isolated packages.\n */\n await adaptTargetPackageManifest(\n targetPackageManifest,\n packagesRegistry,\n isolateDir\n );\n\n /** Generate an isolated lockfile based on the original one */\n const usedFallbackToNpm = await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n\n if (usedFallbackToNpm) {\n /**\n * When we fall back to NPM, we set the manifest package manager to the\n * available NPM version.\n */\n const manifest = await readManifest(isolateDir);\n\n const npmVersion = getVersion(\"npm\");\n manifest.packageManager = `npm@${npmVersion}`;\n\n await writeManifest(isolateDir, manifest);\n }\n\n if (packageManager.name === \"pnpm\" && !config.forceNpm) {\n /**\n * PNPM doesn't install dependencies of packages that are linked via link:\n * or file: specifiers. It requires the directory to be configured as a\n * workspace, so we copy the workspace config file to the isolate output.\n */\n fs.copyFileSync(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\"),\n path.join(isolateDir, \"pnpm-workspace.yaml\")\n );\n }\n /**\n * If there is an .npmrc file in the workspace root, copy it to the isolate\n * because the settings there could affect how the lockfile is resolved. Note\n * that .npmrc is used by both NPM and PNPM for configuration.\n *\n * See also: https://pnpm.io/npmrc\n */\n const npmrcPath = path.join(workspaceRootDir, \".npmrc\");\n\n if (fs.existsSync(npmrcPath)) {\n fs.copyFileSync(npmrcPath, path.join(isolateDir, \".npmrc\"));\n log.debug(\"Copied .npmrc file to the isolate output\");\n }\n\n /**\n * Clean up. Only so this in the happy path, so we can look at the temp folder\n * when thing go wrong.\n */\n log.debug(\n \"Deleting temp directory\",\n getRootRelativePath(tmpDir, workspaceRootDir)\n );\n await fs.remove(tmpDir);\n\n log.info(\"Isolate completed at\", isolateDir);\n\n return isolateDir;\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"remeda\";\nimport { setLogLevel, useLogger } from \"./logger\";\nimport { inspectValue, readTypedJsonSync } from \"./utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n forceNpm: boolean;\n pickFromScripts?: string[];\n omitFromScripts?: string[];\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n includePatchedDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n forceNpm: false,\n pickFromScripts: undefined,\n omitFromScripts: undefined,\n};\n\n/**\n * Only initialize the configuration once, and keeping it here for subsequent\n * calls to getConfig.\n */\nlet _resolvedConfig: IsolateConfigResolved | undefined;\n\nlet _user_defined_config: IsolateConfig | undefined;\n\nconst validConfigKeys = Object.keys(configDefaults);\n\nconst CONFIG_FILE_NAME = \"isolate.config.json\";\n\nexport type LogLevel = IsolateConfigResolved[\"logLevel\"];\n\nexport function setUserConfig(config: IsolateConfig) {\n _user_defined_config = config;\n\n if (config.logLevel) {\n setLogLevel(config.logLevel);\n }\n}\n\nexport function useConfig() {\n if (_resolvedConfig) {\n return _resolvedConfig;\n } else {\n throw new Error(\"Called useConfig before config was made available\");\n }\n}\n\n/**\n * Resolve configuration based on user config and defaults. If setConfig was\n * called before this, it does not attempt to read a config file from disk.\n */\nexport function resolveConfig(): IsolateConfigResolved {\n if (_resolvedConfig) {\n return _resolvedConfig;\n }\n\n setLogLevel(process.env.DEBUG_ISOLATE_CONFIG ? \"debug\" : \"info\");\n\n const log = useLogger();\n\n const configFilePath = path.join(process.cwd(), CONFIG_FILE_NAME);\n\n if (_user_defined_config) {\n log.debug(`Using user defined config:`, inspectValue(_user_defined_config));\n } else {\n log.debug(`Attempting to load config from ${configFilePath}`);\n\n _user_defined_config = fs.existsSync(configFilePath)\n ? readTypedJsonSync<IsolateConfig>(configFilePath)\n : {};\n }\n\n const foreignKeys = Object.keys(_user_defined_config).filter(\n (key) => !validConfigKeys.includes(key)\n );\n\n if (!isEmpty(foreignKeys)) {\n log.warn(`Found invalid config settings:`, foreignKeys.join(\", \"));\n }\n\n const config = Object.assign(\n {},\n configDefaults,\n _user_defined_config\n ) satisfies IsolateConfigResolved;\n\n log.debug(\"Using configuration:\", inspectValue(config));\n\n _resolvedConfig = config;\n return config;\n}\n\n/**\n * Get only the configuration that the user set explicitly in the config file or\n * passed via arguments to isolate().\n */\nexport function getUserDefinedConfig(): IsolateConfig {\n assert(\n _user_defined_config,\n \"Called getUserDefinedConfig before user config was made available\"\n );\n\n return _user_defined_config;\n}\n","import chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"./config\";\n/**\n * The Logger defines an interface that can be used to pass in a different\n * logger object in order to intercept all the logging output. We keep the\n * handlers separate from the logger object itself, so that we can change the\n * handlers but do not bother the user with having to handle logLevel.\n */\nexport type Logger = {\n debug(...args: unknown[]): void;\n info(...args: unknown[]): void;\n warn(...args: unknown[]): void;\n error(...args: unknown[]): void;\n};\n\nlet _loggerHandlers: Logger = {\n debug(...args: unknown[]) {\n console.log(chalk.blue(\"debug\"), ...args);\n },\n info(...args: unknown[]) {\n console.log(chalk.green(\"info\"), ...args);\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(\"warning\"), ...args);\n },\n error(...args: unknown[]) {\n console.log(chalk.red(\"error\"), ...args);\n },\n};\n\nconst _logger: Logger = {\n debug(...args: unknown[]) {\n if (_logLevel === \"debug\") {\n _loggerHandlers.debug(...args);\n }\n },\n info(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\") {\n _loggerHandlers.info(...args);\n }\n },\n warn(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\" || _logLevel === \"warn\") {\n _loggerHandlers.warn(...args);\n }\n },\n error(...args: unknown[]) {\n _loggerHandlers.error(...args);\n },\n};\n\nlet _logLevel: LogLevel = \"info\";\n\nexport function setLogger(logger: Logger) {\n _loggerHandlers = logger;\n return _logger;\n}\n\nexport function setLogLevel(\n logLevel: IsolateConfigResolved[\"logLevel\"]\n): Logger {\n _logLevel = logLevel;\n return _logger;\n}\n\nexport function useLogger() {\n return _logger;\n}\n","import { fileURLToPath } from \"url\";\n\n/**\n * Calling context should pass in import.meta.url and the function will return\n * the equivalent of __dirname in Node/CommonJs.\n */\nexport function getDirname(importMetaUrl: string) {\n return fileURLToPath(new URL(\".\", importMetaUrl));\n}\n","type ErrorWithMessage = {\n message: string;\n};\n\nexport function getErrorMessage(error: unknown) {\n return toErrorWithMessage(error).message;\n}\n\nfunction isErrorWithMessage(error: unknown): error is ErrorWithMessage {\n return typeof error === \"object\" && error !== null && \"message\" in error;\n}\n\nfunction toErrorWithMessage(maybeError: unknown): ErrorWithMessage {\n if (isErrorWithMessage(maybeError)) return maybeError;\n\n try {\n return new Error(JSON.stringify(maybeError));\n } catch {\n /**\n * Fallback in case there’s an error stringifying the maybeError like with\n * circular references.\n */\n return new Error(String(maybeError));\n }\n}\n","export function getRootRelativePath(path: string, rootPath: string) {\n const strippedPath = path.replace(rootPath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(root)${strippedPath}`\n : `(root)/${strippedPath}`;\n}\n\nexport function getIsolateRelativePath(path: string, isolatePath: string) {\n const strippedPath = path.replace(isolatePath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(isolate)${strippedPath}`\n : `(isolate)/${strippedPath}`;\n}\n","import { inspect } from \"node:util\";\n\nexport function inspectValue(value: unknown) {\n return inspect(value, false, 16, true);\n}\n","import fs from \"fs-extra\";\nimport stripJsonComments from \"strip-json-comments\";\nimport { getErrorMessage } from \"./get-error-message\";\n\n/** @todo Pass in zod schema and validate */\nexport function readTypedJsonSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = JSON.parse(stripJsonComments(rawContent)) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport async function readTypedJson<T>(filePath: string) {\n try {\n const rawContent = await fs.readFile(filePath, \"utf-8\");\n const data = JSON.parse(rawContent) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n","import { exec } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack?: boolean\n) {\n const execOptions = {\n maxBuffer: 10 * 1024 * 1024,\n };\n\n const log = useLogger();\n\n const previousCwd = process.cwd();\n process.chdir(srcDir);\n\n /**\n * PNPM pack seems to be a lot faster than NPM pack, so when PNPM is detected\n * we use that instead.\n */\n const stdout = usePnpmPack\n ? await new Promise<string>((resolve, reject) => {\n exec(\n `pnpm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n log.error(getErrorMessage(err));\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n })\n : await new Promise<string>((resolve, reject) => {\n exec(\n `npm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n });\n\n const fileName = path.basename(stdout.trim());\n\n const filePath = path.join(dstDir, fileName);\n\n if (!fs.existsSync(filePath)) {\n log.error(\n `The response from pack could not be resolved to an existing file: ${filePath}`\n );\n } else {\n log.debug(`Packed (temp)/${fileName}`);\n }\n\n process.chdir(previousCwd);\n\n /**\n * Return the path anyway even if it doesn't validate. A later stage will wait\n * for the file to occur still. Not sure if this makes sense. Maybe we should\n * stop at the validation error...\n */\n return filePath;\n}\n","import fs from \"fs-extra\";\nimport tar from \"tar-fs\";\nimport { createGunzip } from \"zlib\";\n\nexport async function unpack(filePath: string, unpackDir: string) {\n await new Promise<void>((resolve, reject) => {\n fs.createReadStream(filePath)\n .pipe(createGunzip())\n .pipe(tar.extract(unpackDir))\n .on(\"finish\", () => resolve())\n .on(\"error\", (err) => reject(err));\n });\n}\n","import fs from \"fs-extra\";\nimport yaml from \"yaml\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport function readTypedYamlSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = yaml.parse(rawContent);\n /** @todo Add some zod validation maybe */\n return data as T;\n } catch (err) {\n throw new Error(\n `Failed to read YAML from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport function writeTypedYamlSync<T>(filePath: string, content: T) {\n /** @todo Add some zod validation maybe */\n fs.writeFileSync(filePath, yaml.stringify(content), \"utf-8\");\n}\n","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport { mapValues } from \"remeda\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { generateNpmLockfile } from \"./helpers/generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./helpers/generate-pnpm-lockfile\";\nimport { generateYarnLockfile } from \"./helpers/generate-yarn-lockfile\";\n\n/** Convert dependency links */\nexport function pnpmMapImporter(\n {\n dependencies,\n devDependencies,\n patchedDependencies,\n ...rest\n }: ProjectSnapshot,\n {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n directoryByPackageName: { [packageName: string]: string };\n }\n): ProjectSnapshot {\n return {\n dependencies: dependencies\n ? pnpmMapDependenciesLinks(dependencies, directoryByPackageName)\n : undefined,\n devDependencies:\n includeDevDependencies && devDependencies\n ? pnpmMapDependenciesLinks(devDependencies, directoryByPackageName)\n : undefined,\n /**\n * Don't know how to map the patched dependencies yet, so we just include\n * them but I don't think it would work like this. The important thing for\n * now is that they are omitted by default, because that is the most common\n * use case.\n */\n patchedDependencies: includePatchedDependencies\n ? patchedDependencies\n : undefined,\n ...rest,\n };\n}\n\nfunction pnpmMapDependenciesLinks(\n def: ResolvedDependencies,\n directoryByPackageName: { [packageName: string]: string }\n): ResolvedDependencies {\n return mapValues(def, (value, key) =>\n value.startsWith(\"link:\") ? `link:./${directoryByPackageName[key]}` : value\n );\n}\n\n/**\n * Adapt the lockfile and write it to the isolate directory. Because we keep the\n * structure of packages in the isolate directory the same as they were in the\n * monorepo, the lockfile is largely still correct. The only things that need to\n * be done is to remove the root dependencies and devDependencies, and rename\n * the path to the target package to act as the new root.\n */\nexport async function processLockfile({\n workspaceRootDir,\n packagesRegistry,\n isolateDir,\n internalDepPackageNames,\n targetPackageDir,\n}: {\n workspaceRootDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n internalDepPackageNames: string[];\n targetPackageDir: string;\n targetPackageName: string;\n}) {\n const log = useLogger();\n\n const { forceNpm } = useConfig();\n\n if (forceNpm) {\n log.info(\"Forcing to use NPM for isolate output\");\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n return true;\n }\n\n const { name, version } = usePackageManager();\n let usedFallbackToNpm = false;\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n break;\n }\n case \"yarn\": {\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n if (versionMajor === 1) {\n await generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n });\n } else {\n log.info(\n \"Detected modern version of Yarn. Using NPM lockfile fallback.\"\n );\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n break;\n }\n case \"pnpm\": {\n await generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n });\n break;\n }\n default:\n log.warn(`Unexpected package manager ${name}. Using NPM for output`);\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n return usedFallbackToNpm;\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport type { PackageManager, PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromFiles(workspaceRoot: string): PackageManager {\n for (const name of supportedPackageManagerNames) {\n const lockfileName = getLockfileFileName(name);\n\n if (fs.existsSync(path.join(workspaceRoot, lockfileName))) {\n return { name, version: getVersion(name) };\n }\n }\n\n /** If no lockfile was found, it could be that there is an npm shrinkwrap file. */\n if (fs.existsSync(path.join(workspaceRoot, \"npm-shrinkwrap.json\"))) {\n return { name: \"npm\", version: getVersion(\"npm\") };\n }\n\n throw new Error(`Failed to detect package manager`);\n}\n\nexport function getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\n","export const supportedPackageManagerNames = [\"pnpm\", \"yarn\", \"npm\"] as const;\n\nexport type PackageManagerName = (typeof supportedPackageManagerNames)[number];\n\nexport type PackageManager = {\n name: PackageManagerName;\n version: string;\n};\n\nexport function getLockfileFileName(name: PackageManagerName) {\n switch (name) {\n case \"pnpm\":\n return \"pnpm-lock.yaml\";\n case \"yarn\":\n return \"yarn.lock\";\n case \"npm\":\n return \"package-lock.json\";\n }\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackageManifest } from \"../../types\";\nimport { readTypedJsonSync } from \"../../utils\";\nimport type { PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromManifest(workspaceRoot: string) {\n const log = useLogger();\n\n const rootManifest = readTypedJsonSync<PackageManifest>(\n path.join(workspaceRoot, \"package.json\")\n );\n\n if (!rootManifest.packageManager) {\n log.debug(\"No packageManager field found in root manifest\");\n return;\n }\n\n const [name, version = \"*\"] = rootManifest.packageManager.split(\"@\") as [\n PackageManagerName,\n string,\n ];\n\n assert(\n supportedPackageManagerNames.includes(name),\n `Package manager \"${name}\" is not currently supported`\n );\n\n const lockfileName = getLockfileFileName(name);\n\n assert(\n fs.existsSync(path.join(workspaceRoot, lockfileName)),\n `Manifest declares ${name} to be the packageManager, but failed to find ${lockfileName} in workspace root`\n );\n\n return { name, version };\n}\n","import { inferFromFiles } from \"./helpers/infer-from-files\";\nimport { inferFromManifest } from \"./helpers/infer-from-manifest\";\nimport type { PackageManager } from \"./names\";\n\nexport * from \"./names\";\n\nexport let packageManager: PackageManager | undefined;\n\nexport function usePackageManager() {\n if (!packageManager) {\n throw Error(\n \"No package manager detected. Make sure to call detectPackageManager() before usePackageManager()\"\n );\n }\n\n return packageManager;\n}\n\n/**\n * First we check if the package manager is declared in the manifest. If it is,\n * we get the name and version from there. Otherwise we'll search for the\n * different lockfiles and ask the OS to report the installed version.\n */\nexport function detectPackageManager(workspaceRoot: string): PackageManager {\n /**\n * Disable infer from manifest for now. I doubt it is useful after all but\n * I'll keep the code as a reminder.\n */\n packageManager =\n inferFromManifest(workspaceRoot) ?? inferFromFiles(workspaceRoot);\n\n return packageManager;\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage, inspectValue } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the contents of installed\n * node_modules from the monorepo root plus the adapted package manifest in the\n * isolate directory.\n */\nexport async function generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating NPM lockfile...\");\n\n const origRootNodeModulesPath = path.join(workspaceRootDir, \"node_modules\");\n const tempRootNodeModulesPath = path.join(isolateDir, \"node_modules\");\n\n let hasMovedNodeModules = false;\n\n let hasError = false;\n\n try {\n if (!fs.existsSync(origRootNodeModulesPath)) {\n throw new Error(\n `Failed to find node_modules at ${origRootNodeModulesPath}`\n );\n }\n\n log.debug(`Temporarily moving node_modules to the isolate output`);\n\n await fs.move(origRootNodeModulesPath, tempRootNodeModulesPath);\n hasMovedNodeModules = true;\n\n const arborist = new Arborist({ path: isolateDir });\n\n log.debug(`Building tree...`);\n const { meta } = await arborist.buildIdealTree();\n\n meta?.commit();\n\n const lockfilePath = path.join(isolateDir, \"package-lock.json\");\n\n await fs.writeFile(lockfilePath, String(meta));\n\n log.debug(\"Created lockfile at\", lockfilePath);\n } catch (err) {\n console.error(inspectValue(err));\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n hasError = true;\n } finally {\n /** @todo We should be able to use the new \"using\" keyword for this I think. */\n if (hasMovedNodeModules) {\n log.debug(`Restoring node_modules to the workspace root`);\n await fs.move(tempRootNodeModulesPath, origRootNodeModulesPath);\n }\n }\n\n if (hasError) {\n throw new Error(\"Failed to generate lockfile\");\n }\n}\n","import {\n getLockfileImporterId,\n readWantedLockfile,\n writeWantedLockfile,\n} from \"@pnpm/lockfile-file\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { pick } from \"remeda\";\nimport { useConfig } from \"~/lib/config\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { getErrorMessage } from \"~/lib/utils\";\nimport { pnpmMapImporter } from \"../process-lockfile\";\n\nexport async function generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n}: {\n workspaceRootDir: string;\n targetPackageDir: string;\n isolateDir: string;\n internalDepPackageNames: string[];\n packagesRegistry: PackagesRegistry;\n}) {\n const { includeDevDependencies, includePatchedDependencies } = useConfig();\n const log = useLogger();\n\n log.info(\"Generating PNPM lockfile...\");\n\n try {\n const lockfile = await readWantedLockfile(workspaceRootDir, {\n ignoreIncompatible: false,\n });\n\n assert(lockfile, `No input lockfile found at ${workspaceRootDir}`);\n\n const targetImporterId = getLockfileImporterId(\n workspaceRootDir,\n targetPackageDir\n );\n\n const directoryByPackageName = Object.fromEntries(\n internalDepPackageNames.map((name) => {\n const pkg = packagesRegistry[name];\n assert(pkg, `Package ${name} not found in packages registry`);\n return [name, pkg.rootRelativeDir];\n })\n );\n\n const relevantImporterIds = [\n targetImporterId,\n /**\n * The directory paths happen to correspond with what PNPM calls the\n * importer ids in the context of a lockfile.\n */\n ...Object.values(directoryByPackageName),\n ];\n\n log.debug(\"Relevant importer ids:\", relevantImporterIds);\n\n lockfile.importers = Object.fromEntries(\n Object.entries(pick(lockfile.importers, relevantImporterIds)).map(\n ([importerId, importer]) => {\n if (importerId === targetImporterId) {\n log.debug(\"Setting target package importer on root\");\n\n return [\n \".\",\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n )\n );\n\n await writeWantedLockfile(isolateDir, lockfile);\n\n log.debug(\"Created lockfile at\", path.join(isolateDir, \"pnpm-lock.yaml\"));\n } catch (err) {\n throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the existing lockfile from\n * the monorepo root plus the adapted package manifest in the isolate\n * directory.\n */\nexport async function generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating Yarn lockfile...\");\n\n const origLockfilePath = path.join(workspaceRootDir, \"yarn.lock\");\n const newLockfilePath = path.join(isolateDir, \"yarn.lock\");\n\n if (!fs.existsSync(origLockfilePath)) {\n throw new Error(`Failed to find lockfile at ${origLockfilePath}`);\n }\n\n log.debug(`Copy original yarn.lock to the isolate output`);\n\n try {\n await fs.copyFile(origLockfilePath, newLockfilePath);\n\n /**\n * Running install with the original lockfile in the same directory will\n * generate a pruned version of the lockfile.\n */\n log.debug(`Running local install`);\n execSync(`yarn install --cwd ${isolateDir}`);\n\n log.debug(\"Generated lockfile at\", newLockfilePath);\n } catch (err) {\n throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import { omit, pick } from \"remeda\";\nimport { useConfig } from \"../config\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { adaptManifestInternalDeps } from \"./helpers\";\nimport { writeManifest } from \"./io\";\n\n/**\n * Adapt the output package manifest, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - The devDependencies are possibly removed\n * - Scripts are picked or omitted and otherwise removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } =\n useConfig();\n\n /** Dev dependencies are omitted by default */\n const inputManifest = includeDevDependencies\n ? manifest\n : omit(manifest, [\"devDependencies\"]);\n\n const adaptedManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : /** For other package managers we replace the links to internal dependencies */\n adaptManifestInternalDeps({\n manifest: inputManifest,\n packagesRegistry,\n });\n\n const outputManifest = {\n ...adaptedManifest,\n /**\n * Scripts are removed by default if not explicitly picked or omitted via\n * config.\n */\n scripts: pickFromScripts\n ? pick(manifest.scripts ?? {}, pickFromScripts)\n : omitFromScripts\n ? omit(manifest.scripts ?? {}, omitFromScripts)\n : undefined,\n };\n\n await writeManifest(isolateDir, outputManifest);\n}\n","import path from \"node:path\";\nimport { omit } from \"remeda\";\nimport { useConfig } from \"~/lib/config\";\nimport { usePackageManager } from \"~/lib/package-manager\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { writeManifest } from \"../io\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\n\n/**\n * Adapt the manifest files of all the isolated internal packages (excluding the\n * target package), so that their dependencies point to the other isolated\n * packages in the same folder.\n */\nexport async function adaptInternalPackageManifests(\n internalPackageNames: string[],\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n /**\n * Dev dependencies are omitted by default. And also, for internal\n * dependencies we want to omit the peerDependencies, because installing\n * these is the responsibility of the consuming app / service, and\n * otherwise the frozen lockfile install will error since the package file\n * contains something that is not referenced in the lockfile.\n */\n const inputManifest = includeDevDependencies\n ? omit(manifest, [\"peerDependencies\"])\n : omit(manifest, [\"devDependencies\", \"peerDependencies\"]);\n\n const outputManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n });\n\n await writeManifest(\n path.join(isolateDir, rootRelativeDir),\n outputManifest\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport type { PackageManifest } from \"../types\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function readManifest(packageDir: string) {\n return readTypedJson<PackageManifest>(path.join(packageDir, \"package.json\"));\n}\n\nexport async function writeManifest(\n outputDir: string,\n manifest: PackageManifest\n) {\n await fs.writeFile(\n path.join(outputDir, \"package.json\"),\n JSON.stringify(manifest, null, 2)\n );\n}\n","import path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport type { PackagesRegistry } from \"../../types\";\n\nexport function patchInternalEntries(\n dependencies: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n parentRootRelativeDir?: string\n) {\n const log = useLogger();\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n return Object.fromEntries(\n Object.entries(dependencies).map(([key, value]) => {\n if (allWorkspacePackageNames.includes(key)) {\n const def = packagesRegistry[key];\n\n /**\n * When nested internal dependencies are used (internal packages linking\n * to other internal packages), the parentRootRelativeDir will be passed\n * in, and we store the relative path to the isolate/packages\n * directory.\n *\n * For consistency we also write the other file paths starting with ./,\n * but it doesn't seem to be necessary for any package manager.\n */\n const relativePath = parentRootRelativeDir\n ? path.relative(parentRootRelativeDir, `./${def.rootRelativeDir}`)\n : `./${def.rootRelativeDir}`;\n\n const linkPath = `file:${relativePath}`;\n\n log.debug(`Linking dependency ${key} to ${linkPath}`);\n\n return [key, linkPath];\n } else {\n return [key, value];\n }\n })\n );\n}\n","import type { PackageManifest, PackagesRegistry } from \"~/lib/types\";\nimport { patchInternalEntries } from \"./patch-internal-entries\";\n\n/**\n * Replace the workspace version specifiers for internal dependency with file:\n * paths. Not needed for PNPM (because we configure the isolated output as a\n * workspace), but maybe still for NPM and Yarn.\n */\nexport function adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n}: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n}): PackageManifest {\n const { dependencies, devDependencies } = manifest;\n\n return {\n ...manifest,\n dependencies: dependencies\n ? patchInternalEntries(\n dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies: devDependencies\n ? patchInternalEntries(\n devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n };\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function getBuildOutputDir(targetPackageDir: string) {\n const config = useConfig();\n const log = useLogger();\n\n if (config.buildDirName) {\n log.debug(\"Using buildDirName from config:\", config.buildDirName);\n return path.join(targetPackageDir, config.buildDirName);\n }\n\n const tsconfigPath = path.join(targetPackageDir, config.tsconfigPath);\n\n if (fs.existsSync(tsconfigPath)) {\n log.debug(\"Found tsconfig at:\", config.tsconfigPath);\n\n const tsconfig = await readTypedJson<{\n compilerOptions?: { outDir?: string };\n }>(tsconfigPath);\n\n const outDir = tsconfig.compilerOptions?.outDir;\n\n if (outDir) {\n return path.join(targetPackageDir, outDir);\n } else {\n throw new Error(outdent`\n Failed to find outDir in tsconfig. If you are executing isolate from the root of a monorepo you should specify the buildDirName in isolate.config.json.\n `);\n }\n } else {\n log.warn(\"Failed to find tsconfig at:\", tsconfigPath);\n\n throw new Error(outdent`\n Failed to infer the build output directory from either the isolate config buildDirName or a Typescript config file. See the documentation on how to configure one of these options.\n `);\n }\n}\n","import assert from \"node:assert\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { pack } from \"../utils\";\n\n/**\n * Pack dependencies so that we extract only the files that are supposed to be\n * published by the packages.\n *\n * @returns A map of package names to the path of the packed file\n */\nexport async function packDependencies({\n /** All packages found in the monorepo by workspaces declaration */\n packagesRegistry,\n /** The dependencies that appear to be internal packages */\n internalPackageNames,\n /**\n * The directory where the isolated package and all its dependencies will end\n * up. This is also the directory from where the package will be deployed. By\n * default it is a subfolder in targetPackageDir called \"isolate\" but you can\n * configure it.\n */\n packDestinationDir,\n}: {\n packagesRegistry: PackagesRegistry;\n internalPackageNames: string[];\n packDestinationDir: string;\n}) {\n const log = useLogger();\n\n const packedFileByName: Record<string, string> = {};\n\n const { name, version } = usePackageManager();\n\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n const usePnpmPack = name === \"pnpm\" && versionMajor >= 8;\n\n if (usePnpmPack) {\n log.debug(\"Using PNPM pack instead of NPM pack\");\n }\n\n for (const dependency of internalPackageNames) {\n const def = packagesRegistry[dependency];\n\n assert(dependency, `Failed to find package definition for ${dependency}`);\n\n const { name } = def.manifest;\n\n /**\n * If this dependency has already been packed, we skip it. It could happen\n * because we are packing workspace dependencies recursively.\n */\n if (packedFileByName[name]) {\n log.debug(`Skipping ${name} because it has already been packed`);\n continue;\n }\n\n packedFileByName[name] = await pack(\n def.absoluteDir,\n packDestinationDir,\n usePnpmPack\n );\n }\n\n return packedFileByName;\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { pack, unpack } from \"../utils\";\n\nconst TIMEOUT_MS = 5000;\n\nexport async function processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n}: {\n targetPackageDir: string;\n tmpDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n const packedFilePath = await pack(targetPackageDir, tmpDir);\n const unpackDir = path.join(tmpDir, \"target\");\n\n const now = Date.now();\n let isWaitingYet = false;\n\n while (!fs.existsSync(packedFilePath) && Date.now() - now < TIMEOUT_MS) {\n if (!isWaitingYet) {\n log.debug(`Waiting for ${packedFilePath} to become available...`);\n }\n isWaitingYet = true;\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n await unpack(packedFilePath, unpackDir);\n await fs.copy(path.join(unpackDir, \"package\"), isolateDir);\n}\n","import fs from \"fs-extra\";\nimport path, { join } from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackagesRegistry } from \"../types\";\nimport { getIsolateRelativePath, unpack } from \"../utils\";\n\nexport async function unpackDependencies(\n packedFilesByName: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n tmpDir: string,\n isolateDir: string\n) {\n const log = useLogger();\n\n await Promise.all(\n Object.entries(packedFilesByName).map(async ([packageName, filePath]) => {\n const dir = packagesRegistry[packageName].rootRelativeDir;\n const unpackDir = join(tmpDir, dir);\n\n log.debug(\"Unpacking\", `(temp)/${path.basename(filePath)}`);\n\n await unpack(filePath, unpackDir);\n\n const destinationDir = join(isolateDir, dir);\n\n await fs.ensureDir(destinationDir);\n\n await fs.move(join(unpackDir, \"package\"), destinationDir, {\n overwrite: true,\n });\n\n log.debug(\n `Moved package files to ${getIsolateRelativePath(\n destinationDir,\n isolateDir\n )}`\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { readTypedJson } from \"../utils\";\nimport { findPackagesGlobs } from \"./helpers/find-packages-globs\";\n\n/**\n * Build a list of all packages in the workspace, depending on the package\n * manager used, with a possible override from the config file. The list\n * contains the manifest with some directory info mapped by module name.\n */\nexport async function createPackagesRegistry(\n workspaceRootDir: string,\n workspacePackagesOverride: string[] | undefined\n): Promise<PackagesRegistry> {\n const log = useLogger();\n\n if (workspacePackagesOverride) {\n log.debug(\n `Override workspace packages via config: ${workspacePackagesOverride}`\n );\n }\n\n const packagesGlobs =\n workspacePackagesOverride ?? findPackagesGlobs(workspaceRootDir);\n\n const cwd = process.cwd();\n process.chdir(workspaceRootDir);\n\n const allPackages = packagesGlobs\n .flatMap((glob) => globSync(glob))\n /** Make sure to filter any loose files that might hang around. */\n .filter((dir) => fs.lstatSync(dir).isDirectory());\n\n const registry: PackagesRegistry = (\n await Promise.all(\n allPackages.map(async (rootRelativeDir) => {\n const manifestPath = path.join(rootRelativeDir, \"package.json\");\n\n if (!fs.existsSync(manifestPath)) {\n log.warn(\n `Ignoring directory ./${rootRelativeDir} because it does not contain a package.json file`\n );\n return;\n } else {\n log.debug(`Registering package ./${rootRelativeDir}`);\n\n const manifest = await readTypedJson<PackageManifest>(\n path.join(rootRelativeDir, \"package.json\")\n );\n\n return {\n manifest,\n rootRelativeDir,\n absoluteDir: path.join(workspaceRootDir, rootRelativeDir),\n };\n }\n })\n )\n ).reduce<PackagesRegistry>((acc, info) => {\n if (info) {\n acc[info.manifest.name] = info;\n }\n return acc;\n }, {});\n\n process.chdir(cwd);\n\n return registry;\n}\n","import assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport { usePackageManager } from \"../../package-manager\";\nimport {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n} from \"../../utils\";\n\n/**\n * Find the globs that define where the packages are located within the\n * monorepo. This configuration is dependent on the package manager used, and I\n * don't know if we're covering all cases yet...\n */\nexport function findPackagesGlobs(workspaceRootDir: string) {\n const log = useLogger();\n\n const packageManager = usePackageManager();\n\n switch (packageManager.name) {\n case \"pnpm\": {\n const { packages: globs } = readTypedYamlSync<{ packages: string[] }>(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\")\n );\n\n log.debug(\"Detected pnpm packages globs:\", inspectValue(globs));\n return globs;\n }\n case \"yarn\":\n case \"npm\": {\n const workspaceRootManifestPath = path.join(\n workspaceRootDir,\n \"package.json\"\n );\n\n const { workspaces } = readTypedJsonSync<{ workspaces: string[] }>(\n workspaceRootManifestPath\n );\n\n if (!workspaces) {\n throw new Error(\n `No workspaces field found in ${workspaceRootManifestPath}`\n );\n }\n\n if (Array.isArray(workspaces)) {\n return workspaces;\n } else {\n /**\n * For Yarn, workspaces could be defined as an object with { packages:\n * [], nohoist: [] }. See\n * https://classic.yarnpkg.com/blog/2018/02/15/nohoist/\n */\n const workspacesObject = workspaces as { packages?: string[] };\n\n assert(\n workspacesObject.packages,\n \"workspaces.packages must be an array\"\n );\n\n return workspacesObject.packages;\n }\n }\n }\n}\n","import { uniq } from \"remeda\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\n\n/**\n * Recursively list all the packages from dependencies (and optionally\n * devDependencies) that are found in the monorepo.\n *\n * Here we do not need to rely on packages being declared with \"workspace:\" in\n * the package manifest. We can simply compare the package names with the list\n * of packages that were found via the workspace glob patterns and add them to\n * the registry.\n */\nexport function listInternalPackages(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n { includeDevDependencies = false } = {}\n): string[] {\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n const internalPackageNames = (\n includeDevDependencies\n ? [\n ...Object.keys(manifest.dependencies ?? {}),\n ...Object.keys(manifest.devDependencies ?? {}),\n ]\n : Object.keys(manifest.dependencies ?? {})\n ).filter((name) => allWorkspacePackageNames.includes(name));\n\n const nestedInternalPackageNames = internalPackageNames.flatMap(\n (packageName) =>\n listInternalPackages(\n packagesRegistry[packageName].manifest,\n packagesRegistry,\n { includeDevDependencies }\n )\n );\n\n return uniq(internalPackageNames.concat(nestedInternalPackageNames));\n}\n"],"mappings":";AAAA,OAAOA,UAAQ;AACf,OAAOC,aAAY;AACnB,OAAOC,YAAU;;;ACFjB,OAAOC,SAAQ;AACf,OAAO,YAAY;AACnB,OAAOC,WAAU;AACjB,SAAS,eAAe;;;ACHxB,OAAO,WAAW;AAelB,IAAI,kBAA0B;AAAA,EAC5B,SAAS,MAAiB;AACxB,YAAQ,IAAI,MAAM,KAAK,OAAO,GAAG,GAAG,IAAI;AAAA,EAC1C;AAAA,EACA,QAAQ,MAAiB;AACvB,YAAQ,IAAI,MAAM,MAAM,MAAM,GAAG,GAAG,IAAI;AAAA,EAC1C;AAAA,EACA,QAAQ,MAAiB;AACvB,YAAQ,IAAI,MAAM,OAAO,SAAS,GAAG,GAAG,IAAI;AAAA,EAC9C;AAAA,EACA,SAAS,MAAiB;AACxB,YAAQ,IAAI,MAAM,IAAI,OAAO,GAAG,GAAG,IAAI;AAAA,EACzC;AACF;AAEA,IAAM,UAAkB;AAAA,EACtB,SAAS,MAAiB;AACxB,QAAI,cAAc,SAAS;AACzB,sBAAgB,MAAM,GAAG,IAAI;AAAA,IAC/B;AAAA,EACF;AAAA,EACA,QAAQ,MAAiB;AACvB,QAAI,cAAc,WAAW,cAAc,QAAQ;AACjD,sBAAgB,KAAK,GAAG,IAAI;AAAA,IAC9B;AAAA,EACF;AAAA,EACA,QAAQ,MAAiB;AACvB,QAAI,cAAc,WAAW,cAAc,UAAU,cAAc,QAAQ;AACzE,sBAAgB,KAAK,GAAG,IAAI;AAAA,IAC9B;AAAA,EACF;AAAA,EACA,SAAS,MAAiB;AACxB,oBAAgB,MAAM,GAAG,IAAI;AAAA,EAC/B;AACF;AAEA,IAAI,YAAsB;AAEnB,SAAS,UAAU,QAAgB;AACxC,oBAAkB;AAClB,SAAO;AACT;AAEO,SAAS,YACd,UACQ;AACR,cAAY;AACZ,SAAO;AACT;AAEO,SAAS,YAAY;AAC1B,SAAO;AACT;;;ACnEA,SAAS,qBAAqB;AAMvB,SAAS,WAAW,eAAuB;AAChD,SAAO,cAAc,IAAI,IAAI,KAAK,aAAa,CAAC;AAClD;;;ACJO,SAAS,gBAAgB,OAAgB;AAC9C,SAAO,mBAAmB,KAAK,EAAE;AACnC;AAEA,SAAS,mBAAmB,OAA2C;AACrE,SAAO,OAAO,UAAU,YAAY,UAAU,QAAQ,aAAa;AACrE;AAEA,SAAS,mBAAmB,YAAuC;AACjE,MAAI,mBAAmB,UAAU;AAAG,WAAO;AAE3C,MAAI;AACF,WAAO,IAAI,MAAM,KAAK,UAAU,UAAU,CAAC;AAAA,EAC7C,QAAQ;AAKN,WAAO,IAAI,MAAM,OAAO,UAAU,CAAC;AAAA,EACrC;AACF;;;ACxBO,SAAS,oBAAoBC,QAAc,UAAkB;AAClE,QAAM,eAAeA,OAAK,QAAQ,UAAU,EAAE;AAE9C,SAAO,aAAa,WAAW,GAAG,IAC9B,SAAS,YAAY,KACrB,UAAU,YAAY;AAC5B;AAEO,SAAS,uBAAuBA,QAAc,aAAqB;AACxE,QAAM,eAAeA,OAAK,QAAQ,aAAa,EAAE;AAEjD,SAAO,aAAa,WAAW,GAAG,IAC9B,YAAY,YAAY,KACxB,aAAa,YAAY;AAC/B;;;ACdA,SAAS,eAAe;AAEjB,SAAS,aAAa,OAAgB;AAC3C,SAAO,QAAQ,OAAO,OAAO,IAAI,IAAI;AACvC;;;ACJA,OAAO,QAAQ;AACf,OAAO,uBAAuB;AAIvB,SAAS,kBAAqB,UAAkB;AACrD,MAAI;AACF,UAAM,aAAa,GAAG,aAAa,UAAU,OAAO;AACpD,UAAM,OAAO,KAAK,MAAM,kBAAkB,UAAU,CAAC;AACrD,WAAO;AAAA,EACT,SAAS,KAAK;AACZ,UAAM,IAAI;AAAA,MACR,4BAA4B,QAAQ,KAAK,gBAAgB,GAAG,CAAC;AAAA,IAC/D;AAAA,EACF;AACF;AAEA,eAAsB,cAAiB,UAAkB;AACvD,MAAI;AACF,UAAM,aAAa,MAAM,GAAG,SAAS,UAAU,OAAO;AACtD,UAAM,OAAO,KAAK,MAAM,UAAU;AAClC,WAAO;AAAA,EACT,SAAS,KAAK;AACZ,UAAM,IAAI;AAAA,MACR,4BAA4B,QAAQ,KAAK,gBAAgB,GAAG,CAAC;AAAA,IAC/D;AAAA,EACF;AACF;;;AC3BA,SAAS,YAAY;AACrB,OAAOC,SAAQ;AACf,OAAO,UAAU;AAIjB,eAAsB,KACpB,QACA,QACA,aACA;AACA,QAAM,cAAc;AAAA,IAClB,WAAW,KAAK,OAAO;AAAA,EACzB;AAEA,QAAM,MAAM,UAAU;AAEtB,QAAM,cAAc,QAAQ,IAAI;AAChC,UAAQ,MAAM,MAAM;AAMpB,QAAM,SAAS,cACX,MAAM,IAAI,QAAgB,CAAC,SAAS,WAAW;AAC7C;AAAA,MACE,iCAAiC,MAAM;AAAA,MACvC;AAAA,MACA,CAAC,KAAKC,YAAW;AACf,YAAI,KAAK;AACP,cAAI,MAAM,gBAAgB,GAAG,CAAC;AAC9B,iBAAO,OAAO,GAAG;AAAA,QACnB;AAEA,gBAAQA,OAAM;AAAA,MAChB;AAAA,IACF;AAAA,EACF,CAAC,IACD,MAAM,IAAI,QAAgB,CAAC,SAAS,WAAW;AAC7C;AAAA,MACE,gCAAgC,MAAM;AAAA,MACtC;AAAA,MACA,CAAC,KAAKA,YAAW;AACf,YAAI,KAAK;AACP,iBAAO,OAAO,GAAG;AAAA,QACnB;AAEA,gBAAQA,OAAM;AAAA,MAChB;AAAA,IACF;AAAA,EACF,CAAC;AAEL,QAAM,WAAW,KAAK,SAAS,OAAO,KAAK,CAAC;AAE5C,QAAM,WAAW,KAAK,KAAK,QAAQ,QAAQ;AAE3C,MAAI,CAACC,IAAG,WAAW,QAAQ,GAAG;AAC5B,QAAI;AAAA,MACF,qEAAqE,QAAQ;AAAA,IAC/E;AAAA,EACF,OAAO;AACL,QAAI,MAAM,iBAAiB,QAAQ,EAAE;AAAA,EACvC;AAEA,UAAQ,MAAM,WAAW;AAOzB,SAAO;AACT;;;ACzEA,OAAOC,SAAQ;AACf,OAAO,SAAS;AAChB,SAAS,oBAAoB;AAE7B,eAAsB,OAAO,UAAkB,WAAmB;AAChE,QAAM,IAAI,QAAc,CAAC,SAAS,WAAW;AAC3C,IAAAA,IAAG,iBAAiB,QAAQ,EACzB,KAAK,aAAa,CAAC,EACnB,KAAK,IAAI,QAAQ,SAAS,CAAC,EAC3B,GAAG,UAAU,MAAM,QAAQ,CAAC,EAC5B,GAAG,SAAS,CAAC,QAAQ,OAAO,GAAG,CAAC;AAAA,EACrC,CAAC;AACH;;;ACZA,OAAOC,SAAQ;AACf,OAAO,UAAU;AAGV,SAAS,kBAAqB,UAAkB;AACrD,MAAI;AACF,UAAM,aAAaC,IAAG,aAAa,UAAU,OAAO;AACpD,UAAM,OAAO,KAAK,MAAM,UAAU;AAElC,WAAO;AAAA,EACT,SAAS,KAAK;AACZ,UAAM,IAAI;AAAA,MACR,4BAA4B,QAAQ,KAAK,gBAAgB,GAAG,CAAC;AAAA,IAC/D;AAAA,EACF;AACF;;;ATSA,IAAM,iBAAwC;AAAA,EAC5C,cAAc;AAAA,EACd,wBAAwB;AAAA,EACxB,4BAA4B;AAAA,EAC5B,gBAAgB;AAAA,EAChB,UAAU;AAAA,EACV,mBAAmB;AAAA,EACnB,cAAc;AAAA,EACd,mBAAmB;AAAA,EACnB,eAAe;AAAA,EACf,UAAU;AAAA,EACV,iBAAiB;AAAA,EACjB,iBAAiB;AACnB;AAMA,IAAI;AAEJ,IAAI;AAEJ,IAAM,kBAAkB,OAAO,KAAK,cAAc;AAElD,IAAM,mBAAmB;AAIlB,SAAS,cAAc,QAAuB;AACnD,yBAAuB;AAEvB,MAAI,OAAO,UAAU;AACnB,gBAAY,OAAO,QAAQ;AAAA,EAC7B;AACF;AAEO,SAAS,YAAY;AAC1B,MAAI,iBAAiB;AACnB,WAAO;AAAA,EACT,OAAO;AACL,UAAM,IAAI,MAAM,mDAAmD;AAAA,EACrE;AACF;AAMO,SAAS,gBAAuC;AACrD,MAAI,iBAAiB;AACnB,WAAO;AAAA,EACT;AAEA,cAAY,QAAQ,IAAI,uBAAuB,UAAU,MAAM;AAE/D,QAAM,MAAM,UAAU;AAEtB,QAAM,iBAAiBC,MAAK,KAAK,QAAQ,IAAI,GAAG,gBAAgB;AAEhE,MAAI,sBAAsB;AACxB,QAAI,MAAM,8BAA8B,aAAa,oBAAoB,CAAC;AAAA,EAC5E,OAAO;AACL,QAAI,MAAM,kCAAkC,cAAc,EAAE;AAE5D,2BAAuBC,IAAG,WAAW,cAAc,IAC/C,kBAAiC,cAAc,IAC/C,CAAC;AAAA,EACP;AAEA,QAAM,cAAc,OAAO,KAAK,oBAAoB,EAAE;AAAA,IACpD,CAAC,QAAQ,CAAC,gBAAgB,SAAS,GAAG;AAAA,EACxC;AAEA,MAAI,CAAC,QAAQ,WAAW,GAAG;AACzB,QAAI,KAAK,kCAAkC,YAAY,KAAK,IAAI,CAAC;AAAA,EACnE;AAEA,QAAM,SAAS,OAAO;AAAA,IACpB,CAAC;AAAA,IACD;AAAA,IACA;AAAA,EACF;AAEA,MAAI,MAAM,wBAAwB,aAAa,MAAM,CAAC;AAEtD,oBAAkB;AAClB,SAAO;AACT;;;AU5GA,SAAS,iBAAiB;;;ACJ1B,OAAOC,SAAQ;AACf,SAAS,gBAAgB;AACzB,OAAOC,WAAU;;;ACFV,IAAM,+BAA+B,CAAC,QAAQ,QAAQ,KAAK;AAS3D,SAAS,oBAAoB,MAA0B;AAC5D,UAAQ,MAAM;AAAA,IACZ,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,EACX;AACF;;;ADZO,SAAS,eAAe,eAAuC;AACpE,aAAW,QAAQ,8BAA8B;AAC/C,UAAM,eAAe,oBAAoB,IAAI;AAE7C,QAAIC,IAAG,WAAWC,MAAK,KAAK,eAAe,YAAY,CAAC,GAAG;AACzD,aAAO,EAAE,MAAM,SAAS,WAAW,IAAI,EAAE;AAAA,IAC3C;AAAA,EACF;AAGA,MAAID,IAAG,WAAWC,MAAK,KAAK,eAAe,qBAAqB,CAAC,GAAG;AAClE,WAAO,EAAE,MAAM,OAAO,SAAS,WAAW,KAAK,EAAE;AAAA,EACnD;AAEA,QAAM,IAAI,MAAM,kCAAkC;AACpD;AAEO,SAAS,WAAW,oBAAgD;AACzE,QAAM,SAAS,SAAS,GAAG,kBAAkB,YAAY;AACzD,SAAO,OAAO,SAAS,EAAE,KAAK;AAChC;;;AE1BA,OAAOC,SAAQ;AACf,OAAOC,aAAY;AACnB,OAAOC,WAAU;AAOV,SAAS,kBAAkB,eAAuB;AACvD,QAAM,MAAM,UAAU;AAEtB,QAAM,eAAe;AAAA,IACnBC,MAAK,KAAK,eAAe,cAAc;AAAA,EACzC;AAEA,MAAI,CAAC,aAAa,gBAAgB;AAChC,QAAI,MAAM,gDAAgD;AAC1D;AAAA,EACF;AAEA,QAAM,CAAC,MAAM,UAAU,GAAG,IAAI,aAAa,eAAe,MAAM,GAAG;AAKnE,EAAAC;AAAA,IACE,6BAA6B,SAAS,IAAI;AAAA,IAC1C,oBAAoB,IAAI;AAAA,EAC1B;AAEA,QAAM,eAAe,oBAAoB,IAAI;AAE7C,EAAAA;AAAA,IACEC,IAAG,WAAWF,MAAK,KAAK,eAAe,YAAY,CAAC;AAAA,IACpD,qBAAqB,IAAI,iDAAiD,YAAY;AAAA,EACxF;AAEA,SAAO,EAAE,MAAM,QAAQ;AACzB;;;ACjCO,IAAI;AAEJ,SAAS,oBAAoB;AAClC,MAAI,CAAC,gBAAgB;AACnB,UAAM;AAAA,MACJ;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;AAOO,SAAS,qBAAqB,eAAuC;AAK1E,mBACE,kBAAkB,aAAa,KAAK,eAAe,aAAa;AAElE,SAAO;AACT;;;AChCA,OAAO,cAAc;AACrB,OAAOG,SAAQ;AACf,OAAOC,WAAU;AASjB,eAAsB,oBAAoB;AAAA,EACxC;AAAA,EACA;AACF,GAGG;AACD,QAAM,MAAM,UAAU;AAEtB,MAAI,KAAK,4BAA4B;AAErC,QAAM,0BAA0BC,MAAK,KAAK,kBAAkB,cAAc;AAC1E,QAAM,0BAA0BA,MAAK,KAAK,YAAY,cAAc;AAEpE,MAAI,sBAAsB;AAE1B,MAAI,WAAW;AAEf,MAAI;AACF,QAAI,CAACC,IAAG,WAAW,uBAAuB,GAAG;AAC3C,YAAM,IAAI;AAAA,QACR,kCAAkC,uBAAuB;AAAA,MAC3D;AAAA,IACF;AAEA,QAAI,MAAM,uDAAuD;AAEjE,UAAMA,IAAG,KAAK,yBAAyB,uBAAuB;AAC9D,0BAAsB;AAEtB,UAAM,WAAW,IAAI,SAAS,EAAE,MAAM,WAAW,CAAC;AAElD,QAAI,MAAM,kBAAkB;AAC5B,UAAM,EAAE,KAAK,IAAI,MAAM,SAAS,eAAe;AAE/C,UAAM,OAAO;AAEb,UAAM,eAAeD,MAAK,KAAK,YAAY,mBAAmB;AAE9D,UAAMC,IAAG,UAAU,cAAc,OAAO,IAAI,CAAC;AAE7C,QAAI,MAAM,uBAAuB,YAAY;AAAA,EAC/C,SAAS,KAAK;AACZ,YAAQ,MAAM,aAAa,GAAG,CAAC;AAC/B,QAAI,MAAM,gCAAgC,gBAAgB,GAAG,CAAC,EAAE;AAChE,eAAW;AAAA,EACb,UAAE;AAEA,QAAI,qBAAqB;AACvB,UAAI,MAAM,8CAA8C;AACxD,YAAMA,IAAG,KAAK,yBAAyB,uBAAuB;AAAA,IAChE;AAAA,EACF;AAEA,MAAI,UAAU;AACZ,UAAM,IAAI,MAAM,6BAA6B;AAAA,EAC/C;AACF;;;ACpEA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,OAAOC,aAAY;AACnB,OAAOC,WAAU;AACjB,SAAS,YAAY;AAOrB,eAAsB,qBAAqB;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAMG;AACD,QAAM,EAAE,wBAAwB,2BAA2B,IAAI,UAAU;AACzE,QAAM,MAAM,UAAU;AAEtB,MAAI,KAAK,6BAA6B;AAEtC,MAAI;AACF,UAAM,WAAW,MAAM,mBAAmB,kBAAkB;AAAA,MAC1D,oBAAoB;AAAA,IACtB,CAAC;AAED,IAAAC,QAAO,UAAU,8BAA8B,gBAAgB,EAAE;AAEjE,UAAM,mBAAmB;AAAA,MACvB;AAAA,MACA;AAAA,IACF;AAEA,UAAM,yBAAyB,OAAO;AAAA,MACpC,wBAAwB,IAAI,CAAC,SAAS;AACpC,cAAM,MAAM,iBAAiB,IAAI;AACjC,QAAAA,QAAO,KAAK,WAAW,IAAI,iCAAiC;AAC5D,eAAO,CAAC,MAAM,IAAI,eAAe;AAAA,MACnC,CAAC;AAAA,IACH;AAEA,UAAM,sBAAsB;AAAA,MAC1B;AAAA;AAAA;AAAA;AAAA;AAAA,MAKA,GAAG,OAAO,OAAO,sBAAsB;AAAA,IACzC;AAEA,QAAI,MAAM,0BAA0B,mBAAmB;AAEvD,aAAS,YAAY,OAAO;AAAA,MAC1B,OAAO,QAAQ,KAAK,SAAS,WAAW,mBAAmB,CAAC,EAAE;AAAA,QAC5D,CAAC,CAAC,YAAY,QAAQ,MAAM;AAC1B,cAAI,eAAe,kBAAkB;AACnC,gBAAI,MAAM,yCAAyC;AAEnD,mBAAO;AAAA,cACL;AAAA,cACA,gBAAgB,UAAU;AAAA,gBACxB;AAAA,gBACA;AAAA,gBACA;AAAA,cACF,CAAC;AAAA,YACH;AAAA,UACF;AAEA,cAAI,MAAM,sCAAsC,UAAU;AAE1D,iBAAO;AAAA,YACL;AAAA,YACA,gBAAgB,UAAU;AAAA,cACxB;AAAA,cACA;AAAA,cACA;AAAA,YACF,CAAC;AAAA,UACH;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAEA,UAAM,oBAAoB,YAAY,QAAQ;AAE9C,QAAI,MAAM,uBAAuBC,MAAK,KAAK,YAAY,gBAAgB,CAAC;AAAA,EAC1E,SAAS,KAAK;AACZ,UAAM,IAAI,MAAM,gCAAgC,gBAAgB,GAAG,CAAC,EAAE;AAAA,EACxE;AACF;;;ACnGA,OAAOC,SAAQ;AACf,SAAS,YAAAC,iBAAgB;AACzB,OAAOC,WAAU;AASjB,eAAsB,qBAAqB;AAAA,EACzC;AAAA,EACA;AACF,GAGG;AACD,QAAM,MAAM,UAAU;AAEtB,MAAI,KAAK,6BAA6B;AAEtC,QAAM,mBAAmBC,MAAK,KAAK,kBAAkB,WAAW;AAChE,QAAM,kBAAkBA,MAAK,KAAK,YAAY,WAAW;AAEzD,MAAI,CAACC,IAAG,WAAW,gBAAgB,GAAG;AACpC,UAAM,IAAI,MAAM,8BAA8B,gBAAgB,EAAE;AAAA,EAClE;AAEA,MAAI,MAAM,+CAA+C;AAEzD,MAAI;AACF,UAAMA,IAAG,SAAS,kBAAkB,eAAe;AAMnD,QAAI,MAAM,uBAAuB;AACjC,IAAAC,UAAS,sBAAsB,UAAU,EAAE;AAE3C,QAAI,MAAM,yBAAyB,eAAe;AAAA,EACpD,SAAS,KAAK;AACZ,UAAM,IAAI,MAAM,gCAAgC,gBAAgB,GAAG,CAAC,EAAE;AAAA,EACxE;AACF;;;AP/BO,SAAS,gBACd;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GACA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AACF,GAKiB;AACjB,SAAO;AAAA,IACL,cAAc,eACV,yBAAyB,cAAc,sBAAsB,IAC7D;AAAA,IACJ,iBACE,0BAA0B,kBACtB,yBAAyB,iBAAiB,sBAAsB,IAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAON,qBAAqB,6BACjB,sBACA;AAAA,IACJ,GAAG;AAAA,EACL;AACF;AAEA,SAAS,yBACP,KACA,wBACsB;AACtB,SAAO;AAAA,IAAU;AAAA,IAAK,CAAC,OAAO,QAC5B,MAAM,WAAW,OAAO,IAAI,UAAU,uBAAuB,GAAG,CAAC,KAAK;AAAA,EACxE;AACF;AASA,eAAsB,gBAAgB;AAAA,EACpC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAOG;AACD,QAAM,MAAM,UAAU;AAEtB,QAAM,EAAE,SAAS,IAAI,UAAU;AAE/B,MAAI,UAAU;AACZ,QAAI,KAAK,uCAAuC;AAEhD,UAAM,oBAAoB;AAAA,MACxB;AAAA,MACA;AAAA,IACF,CAAC;AAED,WAAO;AAAA,EACT;AAEA,QAAM,EAAE,MAAM,QAAQ,IAAI,kBAAkB;AAC5C,MAAI,oBAAoB;AAExB,UAAQ,MAAM;AAAA,IACZ,KAAK,OAAO;AACV,YAAM,oBAAoB;AAAA,QACxB;AAAA,QACA;AAAA,MACF,CAAC;AAED;AAAA,IACF;AAAA,IACA,KAAK,QAAQ;AACX,YAAM,eAAe,SAAS,QAAQ,MAAM,GAAG,EAAE,CAAC,GAAG,EAAE;AAEvD,UAAI,iBAAiB,GAAG;AACtB,cAAM,qBAAqB;AAAA,UACzB;AAAA,UACA;AAAA,QACF,CAAC;AAAA,MACH,OAAO;AACL,YAAI;AAAA,UACF;AAAA,QACF;AAEA,cAAM,oBAAoB;AAAA,UACxB;AAAA,UACA;AAAA,QACF,CAAC;AAED,4BAAoB;AAAA,MACtB;AAEA;AAAA,IACF;AAAA,IACA,KAAK,QAAQ;AACX,YAAM,qBAAqB;AAAA,QACzB;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AACD;AAAA,IACF;AAAA,IACA;AACE,UAAI,KAAK,8BAA8B,IAAI,wBAAwB;AACnE,YAAM,oBAAoB;AAAA,QACxB;AAAA,QACA;AAAA,MACF,CAAC;AAED,0BAAoB;AAAA,EACxB;AAEA,SAAO;AACT;;;AQzJA,SAAS,QAAAC,OAAM,QAAAC,aAAY;;;ACA3B,OAAOC,YAAU;AACjB,SAAS,YAAY;;;ACDrB,OAAOC,UAAQ;AACf,OAAOC,WAAU;AAIjB,eAAsB,aAAa,YAAoB;AACrD,SAAO,cAA+BC,MAAK,KAAK,YAAY,cAAc,CAAC;AAC7E;AAEA,eAAsB,cACpB,WACA,UACA;AACA,QAAMC,KAAG;AAAA,IACPD,MAAK,KAAK,WAAW,cAAc;AAAA,IACnC,KAAK,UAAU,UAAU,MAAM,CAAC;AAAA,EAClC;AACF;;;ACjBA,OAAOE,WAAU;AAIV,SAAS,qBACd,cACA,kBACA,uBACA;AACA,QAAM,MAAM,UAAU;AACtB,QAAM,2BAA2B,OAAO,KAAK,gBAAgB;AAE7D,SAAO,OAAO;AAAA,IACZ,OAAO,QAAQ,YAAY,EAAE,IAAI,CAAC,CAAC,KAAK,KAAK,MAAM;AACjD,UAAI,yBAAyB,SAAS,GAAG,GAAG;AAC1C,cAAM,MAAM,iBAAiB,GAAG;AAWhC,cAAM,eAAe,wBACjBC,MAAK,SAAS,uBAAuB,KAAK,IAAI,eAAe,EAAE,IAC/D,KAAK,IAAI,eAAe;AAE5B,cAAM,WAAW,QAAQ,YAAY;AAErC,YAAI,MAAM,sBAAsB,GAAG,OAAO,QAAQ,EAAE;AAEpD,eAAO,CAAC,KAAK,QAAQ;AAAA,MACvB,OAAO;AACL,eAAO,CAAC,KAAK,KAAK;AAAA,MACpB;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;AChCO,SAAS,0BAA0B;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,GAIoB;AAClB,QAAM,EAAE,cAAc,gBAAgB,IAAI;AAE1C,SAAO;AAAA,IACL,GAAG;AAAA,IACH,cAAc,eACV;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,IACF,IACA;AAAA,IACJ,iBAAiB,kBACb;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,IACF,IACA;AAAA,EACN;AACF;;;AHvBA,eAAsB,8BACpB,sBACA,kBACA,YACA;AACA,QAAMC,kBAAiB,kBAAkB;AACzC,QAAM,EAAE,wBAAwB,SAAS,IAAI,UAAU;AAEvD,QAAM,QAAQ;AAAA,IACZ,qBAAqB,IAAI,OAAO,gBAAgB;AAC9C,YAAM,EAAE,UAAU,gBAAgB,IAAI,iBAAiB,WAAW;AASlE,YAAM,gBAAgB,yBAClB,KAAK,UAAU,CAAC,kBAAkB,CAAC,IACnC,KAAK,UAAU,CAAC,mBAAmB,kBAAkB,CAAC;AAE1D,YAAM,iBACJA,gBAAe,SAAS,UAAU,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,QAK/B;AAAA,UACA,0BAA0B;AAAA,QACxB;AAAA,QACA;AAAA,QACA,uBAAuB;AAAA,MACzB,CAAC;AAEP,YAAM;AAAA,QACJC,OAAK,KAAK,YAAY,eAAe;AAAA,QACrC;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;ADzCA,eAAsB,2BACpB,UACA,kBACA,YACA;AACA,QAAMC,kBAAiB,kBAAkB;AACzC,QAAM,EAAE,wBAAwB,UAAU,iBAAiB,gBAAgB,IACzE,UAAU;AAGZ,QAAM,gBAAgB,yBAClB,WACAC,MAAK,UAAU,CAAC,iBAAiB,CAAC;AAEtC,QAAM,kBACJD,gBAAe,SAAS,UAAU,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAK/B;AAAA;AAAA;AAAA,IAEA,0BAA0B;AAAA,MACxB,UAAU;AAAA,MACV;AAAA,IACF,CAAC;AAAA;AAEP,QAAM,iBAAiB;AAAA,IACrB,GAAG;AAAA;AAAA;AAAA;AAAA;AAAA,IAKH,SAAS,kBACLE,MAAK,SAAS,WAAW,CAAC,GAAG,eAAe,IAC5C,kBACED,MAAK,SAAS,WAAW,CAAC,GAAG,eAAe,IAC5C;AAAA,EACR;AAEA,QAAM,cAAc,YAAY,cAAc;AAChD;;;AKvDA,OAAOE,UAAQ;AACf,OAAOC,YAAU;AACjB,OAAO,aAAa;AAKpB,eAAsB,kBAAkB,kBAA0B;AAChE,QAAM,SAAS,UAAU;AACzB,QAAM,MAAM,UAAU;AAEtB,MAAI,OAAO,cAAc;AACvB,QAAI,MAAM,mCAAmC,OAAO,YAAY;AAChE,WAAOC,OAAK,KAAK,kBAAkB,OAAO,YAAY;AAAA,EACxD;AAEA,QAAM,eAAeA,OAAK,KAAK,kBAAkB,OAAO,YAAY;AAEpE,MAAIC,KAAG,WAAW,YAAY,GAAG;AAC/B,QAAI,MAAM,sBAAsB,OAAO,YAAY;AAEnD,UAAM,WAAW,MAAM,cAEpB,YAAY;AAEf,UAAM,SAAS,SAAS,iBAAiB;AAEzC,QAAI,QAAQ;AACV,aAAOD,OAAK,KAAK,kBAAkB,MAAM;AAAA,IAC3C,OAAO;AACL,YAAM,IAAI,MAAM;AAAA;AAAA,OAEf;AAAA,IACH;AAAA,EACF,OAAO;AACL,QAAI,KAAK,+BAA+B,YAAY;AAEpD,UAAM,IAAI,MAAM;AAAA;AAAA,KAEf;AAAA,EACH;AACF;;;ACzCA,OAAOE,aAAY;AAYnB,eAAsB,iBAAiB;AAAA;AAAA,EAErC;AAAA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA;AACF,GAIG;AACD,QAAM,MAAM,UAAU;AAEtB,QAAM,mBAA2C,CAAC;AAElD,QAAM,EAAE,MAAM,QAAQ,IAAI,kBAAkB;AAE5C,QAAM,eAAe,SAAS,QAAQ,MAAM,GAAG,EAAE,CAAC,GAAG,EAAE;AAEvD,QAAM,cAAc,SAAS,UAAU,gBAAgB;AAEvD,MAAI,aAAa;AACf,QAAI,MAAM,qCAAqC;AAAA,EACjD;AAEA,aAAW,cAAc,sBAAsB;AAC7C,UAAM,MAAM,iBAAiB,UAAU;AAEvC,IAAAC,QAAO,YAAY,yCAAyC,UAAU,EAAE;AAExE,UAAM,EAAE,MAAAC,MAAK,IAAI,IAAI;AAMrB,QAAI,iBAAiBA,KAAI,GAAG;AAC1B,UAAI,MAAM,YAAYA,KAAI,qCAAqC;AAC/D;AAAA,IACF;AAEA,qBAAiBA,KAAI,IAAI,MAAM;AAAA,MAC7B,IAAI;AAAA,MACJ;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;ACnEA,OAAOC,UAAQ;AACf,OAAOC,YAAU;AAIjB,IAAM,aAAa;AAEnB,eAAsB,wBAAwB;AAAA,EAC5C;AAAA,EACA;AAAA,EACA;AACF,GAIG;AACD,QAAM,MAAM,UAAU;AACtB,QAAM,iBAAiB,MAAM,KAAK,kBAAkB,MAAM;AAC1D,QAAM,YAAYC,OAAK,KAAK,QAAQ,QAAQ;AAE5C,QAAM,MAAM,KAAK,IAAI;AACrB,MAAI,eAAe;AAEnB,SAAO,CAACC,KAAG,WAAW,cAAc,KAAK,KAAK,IAAI,IAAI,MAAM,YAAY;AACtE,QAAI,CAAC,cAAc;AACjB,UAAI,MAAM,eAAe,cAAc,yBAAyB;AAAA,IAClE;AACA,mBAAe;AACf,UAAM,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,GAAG,CAAC;AAAA,EACzD;AAEA,QAAM,OAAO,gBAAgB,SAAS;AACtC,QAAMA,KAAG,KAAKD,OAAK,KAAK,WAAW,SAAS,GAAG,UAAU;AAC3D;;;ACjCA,OAAOE,UAAQ;AACf,OAAOC,UAAQ,YAAY;AAK3B,eAAsB,mBACpB,mBACA,kBACA,QACA,YACA;AACA,QAAM,MAAM,UAAU;AAEtB,QAAM,QAAQ;AAAA,IACZ,OAAO,QAAQ,iBAAiB,EAAE,IAAI,OAAO,CAAC,aAAa,QAAQ,MAAM;AACvE,YAAM,MAAM,iBAAiB,WAAW,EAAE;AAC1C,YAAM,YAAY,KAAK,QAAQ,GAAG;AAElC,UAAI,MAAM,aAAa,UAAUC,OAAK,SAAS,QAAQ,CAAC,EAAE;AAE1D,YAAM,OAAO,UAAU,SAAS;AAEhC,YAAM,iBAAiB,KAAK,YAAY,GAAG;AAE3C,YAAMC,KAAG,UAAU,cAAc;AAEjC,YAAMA,KAAG,KAAK,KAAK,WAAW,SAAS,GAAG,gBAAgB;AAAA,QACxD,WAAW;AAAA,MACb,CAAC;AAED,UAAI;AAAA,QACF,0BAA0B;AAAA,UACxB;AAAA,UACA;AAAA,QACF,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;ACvCA,OAAOC,UAAQ;AACf,SAAS,gBAAgB;AACzB,OAAOC,YAAU;;;ACFjB,OAAOC,aAAY;AACnB,OAAOC,YAAU;AAcV,SAAS,kBAAkB,kBAA0B;AAC1D,QAAM,MAAM,UAAU;AAEtB,QAAMC,kBAAiB,kBAAkB;AAEzC,UAAQA,gBAAe,MAAM;AAAA,IAC3B,KAAK,QAAQ;AACX,YAAM,EAAE,UAAU,MAAM,IAAI;AAAA,QAC1BC,OAAK,KAAK,kBAAkB,qBAAqB;AAAA,MACnD;AAEA,UAAI,MAAM,iCAAiC,aAAa,KAAK,CAAC;AAC9D,aAAO;AAAA,IACT;AAAA,IACA,KAAK;AAAA,IACL,KAAK,OAAO;AACV,YAAM,4BAA4BA,OAAK;AAAA,QACrC;AAAA,QACA;AAAA,MACF;AAEA,YAAM,EAAE,WAAW,IAAI;AAAA,QACrB;AAAA,MACF;AAEA,UAAI,CAAC,YAAY;AACf,cAAM,IAAI;AAAA,UACR,gCAAgC,yBAAyB;AAAA,QAC3D;AAAA,MACF;AAEA,UAAI,MAAM,QAAQ,UAAU,GAAG;AAC7B,eAAO;AAAA,MACT,OAAO;AAML,cAAM,mBAAmB;AAEzB,QAAAC;AAAA,UACE,iBAAiB;AAAA,UACjB;AAAA,QACF;AAEA,eAAO,iBAAiB;AAAA,MAC1B;AAAA,IACF;AAAA,EACF;AACF;;;ADpDA,eAAsB,uBACpB,kBACA,2BAC2B;AAC3B,QAAM,MAAM,UAAU;AAEtB,MAAI,2BAA2B;AAC7B,QAAI;AAAA,MACF,2CAA2C,yBAAyB;AAAA,IACtE;AAAA,EACF;AAEA,QAAM,gBACJ,6BAA6B,kBAAkB,gBAAgB;AAEjE,QAAM,MAAM,QAAQ,IAAI;AACxB,UAAQ,MAAM,gBAAgB;AAE9B,QAAM,cAAc,cACjB,QAAQ,CAAC,SAAS,SAAS,IAAI,CAAC,EAEhC,OAAO,CAAC,QAAQC,KAAG,UAAU,GAAG,EAAE,YAAY,CAAC;AAElD,QAAM,YACJ,MAAM,QAAQ;AAAA,IACZ,YAAY,IAAI,OAAO,oBAAoB;AACzC,YAAM,eAAeC,OAAK,KAAK,iBAAiB,cAAc;AAE9D,UAAI,CAACD,KAAG,WAAW,YAAY,GAAG;AAChC,YAAI;AAAA,UACF,wBAAwB,eAAe;AAAA,QACzC;AACA;AAAA,MACF,OAAO;AACL,YAAI,MAAM,yBAAyB,eAAe,EAAE;AAEpD,cAAM,WAAW,MAAM;AAAA,UACrBC,OAAK,KAAK,iBAAiB,cAAc;AAAA,QAC3C;AAEA,eAAO;AAAA,UACL;AAAA,UACA;AAAA,UACA,aAAaA,OAAK,KAAK,kBAAkB,eAAe;AAAA,QAC1D;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH,GACA,OAAyB,CAAC,KAAK,SAAS;AACxC,QAAI,MAAM;AACR,UAAI,KAAK,SAAS,IAAI,IAAI;AAAA,IAC5B;AACA,WAAO;AAAA,EACT,GAAG,CAAC,CAAC;AAEL,UAAQ,MAAM,GAAG;AAEjB,SAAO;AACT;;;AEvEA,SAAS,YAAY;AAYd,SAAS,qBACd,UACA,kBACA,EAAE,yBAAyB,MAAM,IAAI,CAAC,GAC5B;AACV,QAAM,2BAA2B,OAAO,KAAK,gBAAgB;AAE7D,QAAM,wBACJ,yBACI;AAAA,IACE,GAAG,OAAO,KAAK,SAAS,gBAAgB,CAAC,CAAC;AAAA,IAC1C,GAAG,OAAO,KAAK,SAAS,mBAAmB,CAAC,CAAC;AAAA,EAC/C,IACA,OAAO,KAAK,SAAS,gBAAgB,CAAC,CAAC,GAC3C,OAAO,CAAC,SAAS,yBAAyB,SAAS,IAAI,CAAC;AAE1D,QAAM,6BAA6B,qBAAqB;AAAA,IACtD,CAAC,gBACC;AAAA,MACE,iBAAiB,WAAW,EAAE;AAAA,MAC9B;AAAA,MACA,EAAE,uBAAuB;AAAA,IAC3B;AAAA,EACJ;AAEA,SAAO,KAAK,qBAAqB,OAAO,0BAA0B,CAAC;AACrE;;;A9BZA,IAAM,YAAY,WAAW,YAAY,GAAG;AAE5C,eAAsB,QACpB,UAAuD,CAAC,GACxD;AACA,MAAI,QAAQ,QAAQ;AAClB,cAAU,QAAQ,MAAM;AAAA,EAC1B;AAEA,MAAI,QAAQ,QAAQ;AAClB,kBAAc,QAAQ,MAAM;AAAA,EAC9B;AAEA,QAAM,SAAS,cAAc;AAE7B,cAAY,OAAO,QAAQ;AAE3B,QAAM,MAAM,UAAU;AAEtB,QAAM,sBAAsB,MAAM;AAAA,IAChCC,OAAK,KAAKA,OAAK,KAAK,WAAW,MAAM,cAAc,CAAC;AAAA,EACtD;AAEA,MAAI,MAAM,iCAAiC,oBAAoB,OAAO;AAOtE,QAAM,mBAAmB,OAAO,oBAC5BA,OAAK,KAAK,QAAQ,IAAI,GAAG,OAAO,iBAAiB,IACjD,QAAQ,IAAI;AAMhB,QAAM,mBAAmB,OAAO,oBAC5B,QAAQ,IAAI,IACZA,OAAK,KAAK,kBAAkB,OAAO,aAAa;AAEpD,QAAM,iBAAiB,MAAM,kBAAkB,gBAAgB;AAE/D,EAAAC;AAAA,IACEC,KAAG,WAAW,cAAc;AAAA,IAC5B,uCAAuC,cAAc;AAAA,EACvD;AAEA,MAAI,MAAM,8BAA8B,gBAAgB;AACxD,MAAI;AAAA,IACF;AAAA,IACA,oBAAoB,kBAAkB,gBAAgB;AAAA,EACxD;AAEA,QAAM,aAAaF,OAAK,KAAK,kBAAkB,OAAO,cAAc;AAEpE,MAAI;AAAA,IACF;AAAA,IACA,oBAAoB,YAAY,gBAAgB;AAAA,EAClD;AAEA,MAAIE,KAAG,WAAW,UAAU,GAAG;AAC7B,UAAMA,KAAG,OAAO,UAAU;AAC1B,QAAI,MAAM,+CAA+C;AAAA,EAC3D;AAEA,QAAMA,KAAG,UAAU,UAAU;AAE7B,QAAM,SAASF,OAAK,KAAK,YAAY,OAAO;AAC5C,QAAME,KAAG,UAAU,MAAM;AAEzB,QAAM,wBAAwB,MAAM;AAAA,IAClCF,OAAK,KAAK,kBAAkB,cAAc;AAAA,EAC5C;AAEA,QAAMG,kBAAiB,qBAAqB,gBAAgB;AAE5D,MAAI;AAAA,IACF;AAAA,IACAA,gBAAe;AAAA,IACfA,gBAAe;AAAA,EACjB;AAMA,QAAM,mBAAmB,MAAM;AAAA,IAC7B;AAAA,IACA,OAAO;AAAA,EACT;AAEA,QAAM,uBAAuB;AAAA,IAC3B;AAAA,IACA;AAAA,IACA;AAAA,MACE,wBAAwB,OAAO;AAAA,IACjC;AAAA,EACF;AAEA,QAAM,oBAAoB,MAAM,iBAAiB;AAAA,IAC/C;AAAA,IACA;AAAA,IACA,oBAAoB;AAAA,EACtB,CAAC;AAED,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAGA,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAGA,QAAM,wBAAwB;AAAA,IAC5B;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAMD,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAGA,QAAM,oBAAoB,MAAM,gBAAgB;AAAA,IAC9C;AAAA,IACA;AAAA,IACA;AAAA,IACA,yBAAyB;AAAA,IACzB;AAAA,IACA,mBAAmB,sBAAsB;AAAA,EAC3C,CAAC;AAED,MAAI,mBAAmB;AAKrB,UAAM,WAAW,MAAM,aAAa,UAAU;AAE9C,UAAM,aAAa,WAAW,KAAK;AACnC,aAAS,iBAAiB,OAAO,UAAU;AAE3C,UAAM,cAAc,YAAY,QAAQ;AAAA,EAC1C;AAEA,MAAIA,gBAAe,SAAS,UAAU,CAAC,OAAO,UAAU;AAMtD,IAAAD,KAAG;AAAA,MACDF,OAAK,KAAK,kBAAkB,qBAAqB;AAAA,MACjDA,OAAK,KAAK,YAAY,qBAAqB;AAAA,IAC7C;AAAA,EACF;AAQA,QAAM,YAAYA,OAAK,KAAK,kBAAkB,QAAQ;AAEtD,MAAIE,KAAG,WAAW,SAAS,GAAG;AAC5B,IAAAA,KAAG,aAAa,WAAWF,OAAK,KAAK,YAAY,QAAQ,CAAC;AAC1D,QAAI,MAAM,0CAA0C;AAAA,EACtD;AAMA,MAAI;AAAA,IACF;AAAA,IACA,oBAAoB,QAAQ,gBAAgB;AAAA,EAC9C;AACA,QAAME,KAAG,OAAO,MAAM;AAEtB,MAAI,KAAK,wBAAwB,UAAU;AAE3C,SAAO;AACT;","names":["fs","assert","path","fs","path","path","fs","stdout","fs","fs","fs","fs","path","fs","fs","path","fs","path","fs","assert","path","path","assert","fs","fs","path","path","fs","assert","path","assert","path","fs","execSync","path","path","fs","execSync","omit","pick","path","fs","path","path","fs","path","path","packageManager","path","packageManager","omit","pick","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","fs","path","assert","path","packageManager","path","assert","fs","path","path","assert","fs","packageManager"]}
@@ -13,7 +13,7 @@ import path16 from "node:path";
13
13
  import fs5 from "fs-extra";
14
14
  import assert from "node:assert";
15
15
  import path2 from "node:path";
16
- import { isEmpty } from "ramda";
16
+ import { isEmpty } from "remeda";
17
17
 
18
18
  // src/lib/logger.ts
19
19
  import chalk from "chalk";
@@ -144,7 +144,7 @@ async function pack(srcDir, dstDir, usePnpmPack) {
144
144
  exec(
145
145
  `pnpm pack --pack-destination "${dstDir}"`,
146
146
  execOptions,
147
- (err, stdout2, stderr) => {
147
+ (err, stdout2) => {
148
148
  if (err) {
149
149
  log.error(getErrorMessage(err));
150
150
  return reject(err);
@@ -264,7 +264,7 @@ function resolveConfig() {
264
264
  }
265
265
 
266
266
  // src/lib/lockfile/process-lockfile.ts
267
- import { mapObjIndexed } from "ramda";
267
+ import { mapValues } from "remeda";
268
268
 
269
269
  // src/lib/package-manager/helpers/infer-from-files.ts
270
270
  import fs6 from "fs-extra";
@@ -356,6 +356,7 @@ async function generateNpmLockfile({
356
356
  const origRootNodeModulesPath = path5.join(workspaceRootDir, "node_modules");
357
357
  const tempRootNodeModulesPath = path5.join(isolateDir, "node_modules");
358
358
  let hasMovedNodeModules = false;
359
+ let hasError = false;
359
360
  try {
360
361
  if (!fs8.existsSync(origRootNodeModulesPath)) {
361
362
  throw new Error(
@@ -375,12 +376,16 @@ async function generateNpmLockfile({
375
376
  } catch (err) {
376
377
  console.error(inspectValue(err));
377
378
  log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
379
+ hasError = true;
378
380
  } finally {
379
381
  if (hasMovedNodeModules) {
380
382
  log.debug(`Restoring node_modules to the workspace root`);
381
383
  await fs8.move(tempRootNodeModulesPath, origRootNodeModulesPath);
382
384
  }
383
385
  }
386
+ if (hasError) {
387
+ throw new Error("Failed to generate lockfile");
388
+ }
384
389
  }
385
390
 
386
391
  // src/lib/lockfile/helpers/generate-pnpm-lockfile.ts
@@ -391,7 +396,7 @@ import {
391
396
  } from "@pnpm/lockfile-file";
392
397
  import assert3 from "node:assert";
393
398
  import path6 from "node:path";
394
- import { pick } from "ramda";
399
+ import { pick } from "remeda";
395
400
  async function generatePnpmLockfile({
396
401
  workspaceRootDir,
397
402
  targetPackageDir,
@@ -428,7 +433,7 @@ async function generatePnpmLockfile({
428
433
  ];
429
434
  log.debug("Relevant importer ids:", relevantImporterIds);
430
435
  lockfile.importers = Object.fromEntries(
431
- Object.entries(pick(relevantImporterIds, lockfile.importers)).map(
436
+ Object.entries(pick(lockfile.importers, relevantImporterIds)).map(
432
437
  ([importerId, importer]) => {
433
438
  if (importerId === targetImporterId) {
434
439
  log.debug("Setting target package importer on root");
@@ -456,7 +461,7 @@ async function generatePnpmLockfile({
456
461
  await writeWantedLockfile(isolateDir, lockfile);
457
462
  log.debug("Created lockfile at", path6.join(isolateDir, "pnpm-lock.yaml"));
458
463
  } catch (err) {
459
- log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
464
+ throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
460
465
  }
461
466
  }
462
467
 
@@ -482,7 +487,7 @@ async function generateYarnLockfile({
482
487
  execSync2(`yarn install --cwd ${isolateDir}`);
483
488
  log.debug("Generated lockfile at", newLockfilePath);
484
489
  } catch (err) {
485
- log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
490
+ throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);
486
491
  }
487
492
  }
488
493
 
@@ -511,9 +516,9 @@ function pnpmMapImporter({
511
516
  };
512
517
  }
513
518
  function pnpmMapDependenciesLinks(def, directoryByPackageName) {
514
- return mapObjIndexed(
515
- (version, name) => version.startsWith("link:") ? `link:./${directoryByPackageName[name]}` : version,
516
- def
519
+ return mapValues(
520
+ def,
521
+ (value, key) => value.startsWith("link:") ? `link:./${directoryByPackageName[key]}` : value
517
522
  );
518
523
  }
519
524
  async function processLockfile({
@@ -584,11 +589,11 @@ async function processLockfile({
584
589
  }
585
590
 
586
591
  // src/lib/manifest/adapt-target-package-manifest.ts
587
- import { omit as omit2, pick as pick2 } from "ramda";
592
+ import { omit as omit2, pick as pick2 } from "remeda";
588
593
 
589
594
  // src/lib/manifest/helpers/adapt-internal-package-manifests.ts
590
595
  import path10 from "node:path";
591
- import { omit } from "ramda";
596
+ import { omit } from "remeda";
592
597
 
593
598
  // src/lib/manifest/io.ts
594
599
  import fs10 from "fs-extra";
@@ -652,7 +657,7 @@ async function adaptInternalPackageManifests(internalPackageNames, packagesRegis
652
657
  await Promise.all(
653
658
  internalPackageNames.map(async (packageName) => {
654
659
  const { manifest, rootRelativeDir } = packagesRegistry[packageName];
655
- const inputManifest = includeDevDependencies ? omit(["peerDependencies"], manifest) : omit(["devDependencies", "peerDependencies"], manifest);
660
+ const inputManifest = includeDevDependencies ? omit(manifest, ["peerDependencies"]) : omit(manifest, ["devDependencies", "peerDependencies"]);
656
661
  const outputManifest = packageManager2.name === "pnpm" && !forceNpm ? (
657
662
  /**
658
663
  * For PNPM the output itself is a workspace so we can preserve the specifiers
@@ -676,7 +681,7 @@ async function adaptInternalPackageManifests(internalPackageNames, packagesRegis
676
681
  async function adaptTargetPackageManifest(manifest, packagesRegistry, isolateDir) {
677
682
  const packageManager2 = usePackageManager();
678
683
  const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } = useConfig();
679
- const inputManifest = includeDevDependencies ? manifest : omit2(["devDependencies"], manifest);
684
+ const inputManifest = includeDevDependencies ? manifest : omit2(manifest, ["devDependencies"]);
680
685
  const adaptedManifest = packageManager2.name === "pnpm" && !forceNpm ? (
681
686
  /**
682
687
  * For PNPM the output itself is a workspace so we can preserve the specifiers
@@ -696,7 +701,7 @@ async function adaptTargetPackageManifest(manifest, packagesRegistry, isolateDir
696
701
  * Scripts are removed by default if not explicitly picked or omitted via
697
702
  * config.
698
703
  */
699
- scripts: pickFromScripts ? pick2(pickFromScripts, manifest.scripts) : omitFromScripts ? omit2(omitFromScripts, manifest.scripts) : void 0
704
+ scripts: pickFromScripts ? pick2(manifest.scripts ?? {}, pickFromScripts) : omitFromScripts ? omit2(manifest.scripts ?? {}, omitFromScripts) : void 0
700
705
  };
701
706
  await writeManifest(isolateDir, outputManifest);
702
707
  }
@@ -913,7 +918,7 @@ async function createPackagesRegistry(workspaceRootDir, workspacePackagesOverrid
913
918
  }
914
919
 
915
920
  // src/lib/registry/list-internal-packages.ts
916
- import { uniq } from "ramda";
921
+ import { uniq } from "remeda";
917
922
  function listInternalPackages(manifest, packagesRegistry, { includeDevDependencies = false } = {}) {
918
923
  const allWorkspacePackageNames = Object.keys(packagesRegistry);
919
924
  const internalPackageNames = (includeDevDependencies ? [
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/isolate-bin.ts","../src/isolate.ts","../src/lib/config.ts","../src/lib/logger.ts","../src/lib/utils/get-dirname.ts","../src/lib/utils/get-error-message.ts","../src/lib/utils/get-relative-path.ts","../src/lib/utils/inspect-value.ts","../src/lib/utils/json.ts","../src/lib/utils/pack.ts","../src/lib/utils/unpack.ts","../src/lib/utils/yaml.ts","../src/lib/lockfile/process-lockfile.ts","../src/lib/package-manager/helpers/infer-from-files.ts","../src/lib/package-manager/names.ts","../src/lib/package-manager/helpers/infer-from-manifest.ts","../src/lib/package-manager/index.ts","../src/lib/lockfile/helpers/generate-npm-lockfile.ts","../src/lib/lockfile/helpers/generate-pnpm-lockfile.ts","../src/lib/lockfile/helpers/generate-yarn-lockfile.ts","../src/lib/manifest/adapt-target-package-manifest.ts","../src/lib/manifest/helpers/adapt-internal-package-manifests.ts","../src/lib/manifest/io.ts","../src/lib/manifest/helpers/patch-internal-entries.ts","../src/lib/manifest/helpers/adapt-manifest-internal-deps.ts","../src/lib/output/get-build-output-dir.ts","../src/lib/output/pack-dependencies.ts","../src/lib/output/process-build-output-files.ts","../src/lib/output/unpack-dependencies.ts","../src/lib/registry/create-packages-registry.ts","../src/lib/registry/helpers/find-packages-globs.ts","../src/lib/registry/list-internal-packages.ts"],"sourcesContent":["#!/usr/bin/env node\nimport console from \"node:console\";\nimport sourceMaps from \"source-map-support\";\nimport { isolate } from \"./isolate\";\n\nsourceMaps.install();\n\nasync function run() {\n await isolate();\n}\n\nrun().catch((err) => {\n if (err instanceof Error) {\n console.error(err.stack);\n process.exit(1);\n } else {\n console.error(err);\n }\n});\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport type { IsolateConfig } from \"./lib/config\";\nimport { resolveConfig, setUserConfig } from \"./lib/config\";\nimport { processLockfile } from \"./lib/lockfile\";\nimport type { Logger } from \"./lib/logger\";\nimport { setLogLevel, setLogger, useLogger } from \"./lib/logger\";\nimport {\n adaptInternalPackageManifests,\n adaptTargetPackageManifest,\n readManifest,\n writeManifest,\n} from \"./lib/manifest\";\nimport {\n getBuildOutputDir,\n packDependencies,\n processBuildOutputFiles,\n unpackDependencies,\n} from \"./lib/output\";\nimport { detectPackageManager } from \"./lib/package-manager\";\nimport { getVersion } from \"./lib/package-manager/helpers/infer-from-files\";\nimport { createPackagesRegistry, listInternalPackages } from \"./lib/registry\";\nimport type { PackageManifest } from \"./lib/types\";\nimport { getDirname, getRootRelativePath, readTypedJson } from \"./lib/utils\";\n\nconst __dirname = getDirname(import.meta.url);\n\nexport async function isolate(\n options: { config?: IsolateConfig; logger?: Logger } = {}\n) {\n if (options.logger) {\n setLogger(options.logger);\n }\n\n if (options.config) {\n setUserConfig(options.config);\n }\n\n const config = resolveConfig();\n\n setLogLevel(config.logLevel);\n\n const log = useLogger();\n\n const thisPackageManifest = await readTypedJson<PackageManifest>(\n path.join(path.join(__dirname, \"..\", \"package.json\"))\n );\n\n log.debug(\"Using isolate-package version\", thisPackageManifest.version);\n\n /**\n * If a targetPackagePath is set, we assume the configuration lives in the\n * root of the workspace. If targetPackagePath is undefined (the default), we\n * assume that the configuration lives in the target package directory.\n */\n const targetPackageDir = config.targetPackagePath\n ? path.join(process.cwd(), config.targetPackagePath)\n : process.cwd();\n\n /**\n * We want a trailing slash here. Functionally it doesn't matter, but it makes\n * the relative paths more correct in the debug output.\n */\n const workspaceRootDir = config.targetPackagePath\n ? process.cwd()\n : path.join(targetPackageDir, config.workspaceRoot);\n\n const buildOutputDir = await getBuildOutputDir(targetPackageDir);\n\n assert(\n fs.existsSync(buildOutputDir),\n `Failed to find build output path at ${buildOutputDir}. Please make sure you build the source before isolating it.`\n );\n\n log.debug(\"Workspace root resolved to\", workspaceRootDir);\n log.debug(\n \"Isolate target package\",\n getRootRelativePath(targetPackageDir, workspaceRootDir)\n );\n\n const isolateDir = path.join(targetPackageDir, config.isolateDirName);\n\n log.debug(\n \"Isolate output directory\",\n getRootRelativePath(isolateDir, workspaceRootDir)\n );\n\n if (fs.existsSync(isolateDir)) {\n await fs.remove(isolateDir);\n log.debug(\"Cleaned the existing isolate output directory\");\n }\n\n await fs.ensureDir(isolateDir);\n\n const tmpDir = path.join(isolateDir, \"__tmp\");\n await fs.ensureDir(tmpDir);\n\n const targetPackageManifest = await readTypedJson<PackageManifest>(\n path.join(targetPackageDir, \"package.json\")\n );\n\n const packageManager = detectPackageManager(workspaceRootDir);\n\n log.debug(\n \"Detected package manager\",\n packageManager.name,\n packageManager.version\n );\n\n /**\n * Build a packages registry so we can find the workspace packages by name and\n * have access to their manifest files and relative paths.\n */\n const packagesRegistry = await createPackagesRegistry(\n workspaceRootDir,\n config.workspacePackages\n );\n\n const internalPackageNames = listInternalPackages(\n targetPackageManifest,\n packagesRegistry,\n {\n includeDevDependencies: config.includeDevDependencies,\n }\n );\n\n const packedFilesByName = await packDependencies({\n internalPackageNames,\n packagesRegistry,\n packDestinationDir: tmpDir,\n });\n\n await unpackDependencies(\n packedFilesByName,\n packagesRegistry,\n tmpDir,\n isolateDir\n );\n\n /** Adapt the manifest files for all the unpacked local dependencies */\n await adaptInternalPackageManifests(\n internalPackageNames,\n packagesRegistry,\n isolateDir\n );\n\n /** Pack the target package directory, and unpack it in the isolate location */\n await processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n });\n\n /**\n * Copy the target manifest file to the isolate location and adapt its\n * workspace dependencies to point to the isolated packages.\n */\n await adaptTargetPackageManifest(\n targetPackageManifest,\n packagesRegistry,\n isolateDir\n );\n\n /** Generate an isolated lockfile based on the original one */\n const usedFallbackToNpm = await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n\n if (usedFallbackToNpm) {\n /**\n * When we fall back to NPM, we set the manifest package manager to the\n * available NPM version.\n */\n const manifest = await readManifest(isolateDir);\n\n const npmVersion = getVersion(\"npm\");\n manifest.packageManager = `npm@${npmVersion}`;\n\n await writeManifest(isolateDir, manifest);\n }\n\n if (packageManager.name === \"pnpm\" && !config.forceNpm) {\n /**\n * PNPM doesn't install dependencies of packages that are linked via link:\n * or file: specifiers. It requires the directory to be configured as a\n * workspace, so we copy the workspace config file to the isolate output.\n */\n fs.copyFileSync(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\"),\n path.join(isolateDir, \"pnpm-workspace.yaml\")\n );\n }\n /**\n * If there is an .npmrc file in the workspace root, copy it to the isolate\n * because the settings there could affect how the lockfile is resolved. Note\n * that .npmrc is used by both NPM and PNPM for configuration.\n *\n * See also: https://pnpm.io/npmrc\n */\n const npmrcPath = path.join(workspaceRootDir, \".npmrc\");\n\n if (fs.existsSync(npmrcPath)) {\n fs.copyFileSync(npmrcPath, path.join(isolateDir, \".npmrc\"));\n log.debug(\"Copied .npmrc file to the isolate output\");\n }\n\n /**\n * Clean up. Only so this in the happy path, so we can look at the temp folder\n * when thing go wrong.\n */\n log.debug(\n \"Deleting temp directory\",\n getRootRelativePath(tmpDir, workspaceRootDir)\n );\n await fs.remove(tmpDir);\n\n log.info(\"Isolate completed at\", isolateDir);\n\n return isolateDir;\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport { setLogLevel, useLogger } from \"./logger\";\nimport { inspectValue, readTypedJsonSync } from \"./utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n forceNpm: boolean;\n pickFromScripts?: string[];\n omitFromScripts?: string[];\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n includePatchedDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n forceNpm: false,\n pickFromScripts: undefined,\n omitFromScripts: undefined,\n};\n\n/**\n * Only initialize the configuration once, and keeping it here for subsequent\n * calls to getConfig.\n */\nlet _resolvedConfig: IsolateConfigResolved | undefined;\n\nlet _user_defined_config: IsolateConfig | undefined;\n\nconst validConfigKeys = Object.keys(configDefaults);\n\nconst CONFIG_FILE_NAME = \"isolate.config.json\";\n\nexport type LogLevel = IsolateConfigResolved[\"logLevel\"];\n\nexport function setUserConfig(config: IsolateConfig) {\n _user_defined_config = config;\n\n if (config.logLevel) {\n setLogLevel(config.logLevel);\n }\n}\n\nexport function useConfig() {\n if (_resolvedConfig) {\n return _resolvedConfig;\n } else {\n throw new Error(\"Called useConfig before config was made available\");\n }\n}\n\n/**\n * Resolve configuration based on user config and defaults. If setConfig was\n * called before this, it does not attempt to read a config file from disk.\n */\nexport function resolveConfig(): IsolateConfigResolved {\n if (_resolvedConfig) {\n return _resolvedConfig;\n }\n\n setLogLevel(process.env.DEBUG_ISOLATE_CONFIG ? \"debug\" : \"info\");\n\n const log = useLogger();\n\n const configFilePath = path.join(process.cwd(), CONFIG_FILE_NAME);\n\n if (_user_defined_config) {\n log.debug(`Using user defined config:`, inspectValue(_user_defined_config));\n } else {\n log.debug(`Attempting to load config from ${configFilePath}`);\n\n _user_defined_config = fs.existsSync(configFilePath)\n ? readTypedJsonSync<IsolateConfig>(configFilePath)\n : {};\n }\n\n const foreignKeys = Object.keys(_user_defined_config).filter(\n (key) => !validConfigKeys.includes(key)\n );\n\n if (!isEmpty(foreignKeys)) {\n log.warn(`Found invalid config settings:`, foreignKeys.join(\", \"));\n }\n\n const config = Object.assign(\n {},\n configDefaults,\n _user_defined_config\n ) satisfies IsolateConfigResolved;\n\n log.debug(\"Using configuration:\", inspectValue(config));\n\n _resolvedConfig = config;\n return config;\n}\n\n/**\n * Get only the configuration that the user set explicitly in the config file or\n * passed via arguments to isolate().\n */\nexport function getUserDefinedConfig(): IsolateConfig {\n assert(\n _user_defined_config,\n \"Called getUserDefinedConfig before user config was made available\"\n );\n\n return _user_defined_config;\n}\n","import chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"./config\";\n/**\n * The Logger defines an interface that can be used to pass in a different\n * logger object in order to intercept all the logging output. We keep the\n * handlers separate from the logger object itself, so that we can change the\n * handlers but do not bother the user with having to handle logLevel.\n */\nexport type Logger = {\n debug(...args: unknown[]): void;\n info(...args: unknown[]): void;\n warn(...args: unknown[]): void;\n error(...args: unknown[]): void;\n};\n\nlet _loggerHandlers: Logger = {\n debug(...args: unknown[]) {\n console.log(chalk.blue(\"debug\"), ...args);\n },\n info(...args: unknown[]) {\n console.log(chalk.green(\"info\"), ...args);\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(\"warning\"), ...args);\n },\n error(...args: unknown[]) {\n console.log(chalk.red(\"error\"), ...args);\n },\n};\n\nconst _logger: Logger = {\n debug(...args: unknown[]) {\n if (_logLevel === \"debug\") {\n _loggerHandlers.debug(...args);\n }\n },\n info(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\") {\n _loggerHandlers.info(...args);\n }\n },\n warn(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\" || _logLevel === \"warn\") {\n _loggerHandlers.warn(...args);\n }\n },\n error(...args: unknown[]) {\n _loggerHandlers.error(...args);\n },\n};\n\nlet _logLevel: LogLevel = \"info\";\n\nexport function setLogger(logger: Logger) {\n _loggerHandlers = logger;\n return _logger;\n}\n\nexport function setLogLevel(\n logLevel: IsolateConfigResolved[\"logLevel\"]\n): Logger {\n _logLevel = logLevel;\n return _logger;\n}\n\nexport function useLogger() {\n return _logger;\n}\n","import { fileURLToPath } from \"url\";\n\n/**\n * Calling context should pass in import.meta.url and the function will return\n * the equivalent of __dirname in Node/CommonJs.\n */\nexport function getDirname(importMetaUrl: string) {\n return fileURLToPath(new URL(\".\", importMetaUrl));\n}\n","type ErrorWithMessage = {\n message: string;\n};\n\nexport function getErrorMessage(error: unknown) {\n return toErrorWithMessage(error).message;\n}\n\nfunction isErrorWithMessage(error: unknown): error is ErrorWithMessage {\n return typeof error === \"object\" && error !== null && \"message\" in error;\n}\n\nfunction toErrorWithMessage(maybeError: unknown): ErrorWithMessage {\n if (isErrorWithMessage(maybeError)) return maybeError;\n\n try {\n return new Error(JSON.stringify(maybeError));\n } catch {\n /**\n * Fallback in case there’s an error stringifying the maybeError like with\n * circular references.\n */\n return new Error(String(maybeError));\n }\n}\n","export function getRootRelativePath(path: string, rootPath: string) {\n const strippedPath = path.replace(rootPath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(root)${strippedPath}`\n : `(root)/${strippedPath}`;\n}\n\nexport function getIsolateRelativePath(path: string, isolatePath: string) {\n const strippedPath = path.replace(isolatePath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(isolate)${strippedPath}`\n : `(isolate)/${strippedPath}`;\n}\n","import { inspect } from \"node:util\";\nimport type { JsonValue } from \"type-fest\";\n\nexport function inspectValue(value: JsonValue) {\n return inspect(value, false, 16, true);\n}\n","import fs from \"fs-extra\";\nimport stripJsonComments from \"strip-json-comments\";\nimport { getErrorMessage } from \"./get-error-message\";\n\n/** @todo Pass in zod schema and validate */\nexport function readTypedJsonSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = JSON.parse(stripJsonComments(rawContent)) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport async function readTypedJson<T>(filePath: string) {\n try {\n const rawContent = await fs.readFile(filePath, \"utf-8\");\n const data = JSON.parse(rawContent) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n","import { exec } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack?: boolean\n) {\n const execOptions = {\n maxBuffer: 10 * 1024 * 1024,\n };\n\n const log = useLogger();\n\n const previousCwd = process.cwd();\n process.chdir(srcDir);\n\n /**\n * PNPM pack seems to be a lot faster than NPM pack, so when PNPM is detected\n * we use that instead.\n */\n const stdout = usePnpmPack\n ? await new Promise<string>((resolve, reject) => {\n exec(\n `pnpm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout, stderr) => {\n if (err) {\n log.error(getErrorMessage(err));\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n })\n : await new Promise<string>((resolve, reject) => {\n exec(\n `npm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n });\n\n const fileName = path.basename(stdout.trim());\n\n const filePath = path.join(dstDir, fileName);\n\n if (!fs.existsSync(filePath)) {\n log.error(\n `The response from pack could not be resolved to an existing file: ${filePath}`\n );\n } else {\n log.debug(`Packed (temp)/${fileName}`);\n }\n\n process.chdir(previousCwd);\n\n /**\n * Return the path anyway even if it doesn't validate. A later stage will wait\n * for the file to occur still. Not sure if this makes sense. Maybe we should\n * stop at the validation error...\n */\n return filePath;\n}\n","import fs from \"fs-extra\";\nimport tar from \"tar-fs\";\nimport { createGunzip } from \"zlib\";\n\nexport async function unpack(filePath: string, unpackDir: string) {\n await new Promise<void>((resolve, reject) => {\n fs.createReadStream(filePath)\n .pipe(createGunzip())\n .pipe(tar.extract(unpackDir))\n .on(\"finish\", () => resolve())\n .on(\"error\", (err) => reject(err));\n });\n}\n","import fs from \"fs-extra\";\nimport yaml from \"yaml\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport function readTypedYamlSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = yaml.parse(rawContent);\n /** @todo Add some zod validation maybe */\n return data as T;\n } catch (err) {\n throw new Error(\n `Failed to read YAML from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport function writeTypedYamlSync<T>(filePath: string, content: T) {\n /** @todo Add some zod validation maybe */\n fs.writeFileSync(filePath, yaml.stringify(content), \"utf-8\");\n}\n","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { generateNpmLockfile } from \"./helpers/generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./helpers/generate-pnpm-lockfile\";\nimport { generateYarnLockfile } from \"./helpers/generate-yarn-lockfile\";\n\n/** Convert dependency links */\nexport function pnpmMapImporter(\n {\n dependencies,\n devDependencies,\n patchedDependencies,\n ...rest\n }: ProjectSnapshot,\n {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n directoryByPackageName: { [packageName: string]: string };\n }\n): ProjectSnapshot {\n return {\n dependencies: dependencies\n ? pnpmMapDependenciesLinks(dependencies, directoryByPackageName)\n : undefined,\n devDependencies:\n includeDevDependencies && devDependencies\n ? pnpmMapDependenciesLinks(devDependencies, directoryByPackageName)\n : undefined,\n /**\n * Don't know how to map the patched dependencies yet, so we just include\n * them but I don't think it would work like this. The important thing for\n * now is that they are omitted by default, because that is the most common\n * use case.\n */\n patchedDependencies: includePatchedDependencies\n ? patchedDependencies\n : undefined,\n ...rest,\n };\n}\n\nfunction pnpmMapDependenciesLinks(\n def: ResolvedDependencies,\n directoryByPackageName: { [packageName: string]: string }\n): ResolvedDependencies {\n return mapObjIndexed(\n (version, name) =>\n version.startsWith(\"link:\")\n ? `link:./${directoryByPackageName[name]}`\n : version,\n def\n );\n}\n\n/**\n * Adapt the lockfile and write it to the isolate directory. Because we keep the\n * structure of packages in the isolate directory the same as they were in the\n * monorepo, the lockfile is largely still correct. The only things that need to\n * be done is to remove the root dependencies and devDependencies, and rename\n * the path to the target package to act as the new root.\n */\nexport async function processLockfile({\n workspaceRootDir,\n packagesRegistry,\n isolateDir,\n internalDepPackageNames,\n targetPackageDir,\n}: {\n workspaceRootDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n internalDepPackageNames: string[];\n targetPackageDir: string;\n targetPackageName: string;\n}) {\n const log = useLogger();\n\n const { forceNpm } = useConfig();\n\n if (forceNpm) {\n log.info(\"Forcing to use NPM for isolate output\");\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n return true;\n }\n\n const { name, version } = usePackageManager();\n let usedFallbackToNpm = false;\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n break;\n }\n case \"yarn\": {\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n if (versionMajor === 1) {\n await generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n });\n } else {\n log.info(\n \"Detected modern version of Yarn. Using NPM lockfile fallback.\"\n );\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n break;\n }\n case \"pnpm\": {\n await generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n });\n break;\n }\n default:\n log.warn(`Unexpected package manager ${name}. Using NPM for output`);\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n return usedFallbackToNpm;\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport type { PackageManager, PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromFiles(workspaceRoot: string): PackageManager {\n for (const name of supportedPackageManagerNames) {\n const lockfileName = getLockfileFileName(name);\n\n if (fs.existsSync(path.join(workspaceRoot, lockfileName))) {\n return { name, version: getVersion(name) };\n }\n }\n\n /** If no lockfile was found, it could be that there is an npm shrinkwrap file. */\n if (fs.existsSync(path.join(workspaceRoot, \"npm-shrinkwrap.json\"))) {\n return { name: \"npm\", version: getVersion(\"npm\") };\n }\n\n throw new Error(`Failed to detect package manager`);\n}\n\nexport function getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\n","export const supportedPackageManagerNames = [\"pnpm\", \"yarn\", \"npm\"] as const;\n\nexport type PackageManagerName = (typeof supportedPackageManagerNames)[number];\n\nexport type PackageManager = {\n name: PackageManagerName;\n version: string;\n};\n\nexport function getLockfileFileName(name: PackageManagerName) {\n switch (name) {\n case \"pnpm\":\n return \"pnpm-lock.yaml\";\n case \"yarn\":\n return \"yarn.lock\";\n case \"npm\":\n return \"package-lock.json\";\n }\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackageManifest } from \"../../types\";\nimport { readTypedJsonSync } from \"../../utils\";\nimport type { PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromManifest(workspaceRoot: string) {\n const log = useLogger();\n\n const rootManifest = readTypedJsonSync<PackageManifest>(\n path.join(workspaceRoot, \"package.json\")\n );\n\n if (!rootManifest.packageManager) {\n log.debug(\"No packageManager field found in root manifest\");\n return;\n }\n\n const [name, version = \"*\"] = rootManifest.packageManager.split(\"@\") as [\n PackageManagerName,\n string,\n ];\n\n assert(\n supportedPackageManagerNames.includes(name),\n `Package manager \"${name}\" is not currently supported`\n );\n\n const lockfileName = getLockfileFileName(name);\n\n assert(\n fs.existsSync(path.join(workspaceRoot, lockfileName)),\n `Manifest declares ${name} to be the packageManager, but failed to find ${lockfileName} in workspace root`\n );\n\n return { name, version };\n}\n","import { inferFromFiles } from \"./helpers/infer-from-files\";\nimport { inferFromManifest } from \"./helpers/infer-from-manifest\";\nimport type { PackageManager } from \"./names\";\n\nexport * from \"./names\";\n\nexport let packageManager: PackageManager | undefined;\n\nexport function usePackageManager() {\n if (!packageManager) {\n throw Error(\n \"No package manager detected. Make sure to call detectPackageManager() before usePackageManager()\"\n );\n }\n\n return packageManager;\n}\n\n/**\n * First we check if the package manager is declared in the manifest. If it is,\n * we get the name and version from there. Otherwise we'll search for the\n * different lockfiles and ask the OS to report the installed version.\n */\nexport function detectPackageManager(workspaceRoot: string): PackageManager {\n /**\n * Disable infer from manifest for now. I doubt it is useful after all but\n * I'll keep the code as a reminder.\n */\n packageManager =\n inferFromManifest(workspaceRoot) ?? inferFromFiles(workspaceRoot);\n\n return packageManager;\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage, inspectValue } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the contents of installed\n * node_modules from the monorepo root plus the adapted package manifest in the\n * isolate directory.\n */\nexport async function generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating NPM lockfile...\");\n\n const origRootNodeModulesPath = path.join(workspaceRootDir, \"node_modules\");\n const tempRootNodeModulesPath = path.join(isolateDir, \"node_modules\");\n\n let hasMovedNodeModules = false;\n\n try {\n if (!fs.existsSync(origRootNodeModulesPath)) {\n throw new Error(\n `Failed to find node_modules at ${origRootNodeModulesPath}`\n );\n }\n\n log.debug(`Temporarily moving node_modules to the isolate output`);\n\n await fs.move(origRootNodeModulesPath, tempRootNodeModulesPath);\n hasMovedNodeModules = true;\n\n const arborist = new Arborist({ path: isolateDir });\n\n log.debug(`Building tree...`);\n const { meta } = await arborist.buildIdealTree();\n\n meta?.commit();\n\n const lockfilePath = path.join(isolateDir, \"package-lock.json\");\n\n await fs.writeFile(lockfilePath, String(meta));\n\n log.debug(\"Created lockfile at\", lockfilePath);\n } catch (err: any) {\n console.error(inspectValue(err));\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n /**\n * If lockfile creation fails we can technically still continue with the\n * rest. Not sure if that is desirable.\n */\n } finally {\n if (hasMovedNodeModules) {\n log.debug(`Restoring node_modules to the workspace root`);\n await fs.move(tempRootNodeModulesPath, origRootNodeModulesPath);\n }\n }\n}\n","import {\n getLockfileImporterId,\n readWantedLockfile,\n writeWantedLockfile,\n} from \"@pnpm/lockfile-file\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { pick } from \"ramda\";\nimport { useConfig } from \"~/lib/config\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { getErrorMessage } from \"~/lib/utils\";\nimport { pnpmMapImporter } from \"../process-lockfile\";\n\nexport async function generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n}: {\n workspaceRootDir: string;\n targetPackageDir: string;\n isolateDir: string;\n internalDepPackageNames: string[];\n packagesRegistry: PackagesRegistry;\n}) {\n const { includeDevDependencies, includePatchedDependencies } = useConfig();\n const log = useLogger();\n\n log.info(\"Generating PNPM lockfile...\");\n\n try {\n const lockfile = await readWantedLockfile(workspaceRootDir, {\n ignoreIncompatible: false,\n });\n\n assert(lockfile, `No input lockfile found at ${workspaceRootDir}`);\n\n const targetImporterId = getLockfileImporterId(\n workspaceRootDir,\n targetPackageDir\n );\n\n const directoryByPackageName = Object.fromEntries(\n internalDepPackageNames.map((name) => {\n const pkg = packagesRegistry[name];\n assert(pkg, `Package ${name} not found in packages registry`);\n return [name, pkg.rootRelativeDir];\n })\n );\n\n const relevantImporterIds = [\n targetImporterId,\n /**\n * The directory paths happen to correspond with what PNPM calls the\n * importer ids in the context of a lockfile.\n */\n ...Object.values(directoryByPackageName),\n ];\n\n log.debug(\"Relevant importer ids:\", relevantImporterIds);\n\n lockfile.importers = Object.fromEntries(\n Object.entries(pick(relevantImporterIds, lockfile.importers)).map(\n ([importerId, importer]) => {\n if (importerId === targetImporterId) {\n log.debug(\"Setting target package importer on root\");\n\n return [\n \".\",\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n )\n );\n\n await writeWantedLockfile(isolateDir, lockfile);\n\n log.debug(\"Created lockfile at\", path.join(isolateDir, \"pnpm-lock.yaml\"));\n } catch (err) {\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the existing lockfile from\n * the monorepo root plus the adapted package manifest in the isolate\n * directory.\n */\nexport async function generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating Yarn lockfile...\");\n\n const origLockfilePath = path.join(workspaceRootDir, \"yarn.lock\");\n const newLockfilePath = path.join(isolateDir, \"yarn.lock\");\n\n if (!fs.existsSync(origLockfilePath)) {\n throw new Error(`Failed to find lockfile at ${origLockfilePath}`);\n }\n\n log.debug(`Copy original yarn.lock to the isolate output`);\n\n try {\n await fs.copyFile(origLockfilePath, newLockfilePath);\n\n /**\n * Running install with the original lockfile in the same directory will\n * generate a pruned version of the lockfile.\n */\n log.debug(`Running local install`);\n execSync(`yarn install --cwd ${isolateDir}`);\n\n log.debug(\"Generated lockfile at\", newLockfilePath);\n } catch (err) {\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n /**\n * If lockfile creation fails we can technically still continue with the\n * rest. Not sure if that is desirable.\n */\n }\n}\n","import { omit, pick } from \"ramda\";\nimport { useConfig } from \"../config\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { adaptManifestInternalDeps } from \"./helpers\";\nimport { writeManifest } from \"./io\";\n\n/**\n * Adapt the output package manifest, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - The devDependencies are possibly removed\n * - Scripts are picked or omitted and otherwise removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } =\n useConfig();\n\n /** Dev dependencies are omitted by default */\n const inputManifest = includeDevDependencies\n ? manifest\n : omit([\"devDependencies\"], manifest);\n\n const adaptedManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : /** For other package managers we replace the links to internal dependencies */\n adaptManifestInternalDeps({\n manifest: inputManifest,\n packagesRegistry,\n });\n\n const outputManifest = {\n ...adaptedManifest,\n /**\n * Scripts are removed by default if not explicitly picked or omitted via\n * config.\n */\n scripts: pickFromScripts\n ? pick(pickFromScripts as never[], manifest.scripts)\n : omitFromScripts\n ? omit(omitFromScripts as never[], manifest.scripts)\n : undefined,\n };\n\n await writeManifest(isolateDir, outputManifest);\n}\n","import path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { useConfig } from \"~/lib/config\";\nimport { usePackageManager } from \"~/lib/package-manager\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { writeManifest } from \"../io\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\n\n/**\n * Adapt the manifest files of all the isolated internal packages (excluding the\n * target package), so that their dependencies point to the other isolated\n * packages in the same folder.\n */\nexport async function adaptInternalPackageManifests(\n internalPackageNames: string[],\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n /**\n * Dev dependencies are omitted by default. And also, for internal\n * dependencies we want to omit the peerDependencies, because installing\n * these is the responsibility of the consuming app / service, and\n * otherwise the frozen lockfile install will error since the package file\n * contains something that is not referenced in the lockfile.\n */\n const inputManifest = includeDevDependencies\n ? omit([\"peerDependencies\"], manifest)\n : omit([\"devDependencies\", \"peerDependencies\"], manifest);\n\n const outputManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n });\n\n await writeManifest(\n path.join(isolateDir, rootRelativeDir),\n outputManifest\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport type { PackageManifest } from \"../types\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function readManifest(packageDir: string) {\n return readTypedJson<PackageManifest>(path.join(packageDir, \"package.json\"));\n}\n\nexport async function writeManifest(\n outputDir: string,\n manifest: PackageManifest\n) {\n await fs.writeFile(\n path.join(outputDir, \"package.json\"),\n JSON.stringify(manifest, null, 2)\n );\n}\n","import path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport type { PackagesRegistry } from \"../../types\";\n\nexport function patchInternalEntries(\n dependencies: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n parentRootRelativeDir?: string\n) {\n const log = useLogger();\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n return Object.fromEntries(\n Object.entries(dependencies).map(([key, value]) => {\n if (allWorkspacePackageNames.includes(key)) {\n const def = packagesRegistry[key];\n\n /**\n * When nested internal dependencies are used (internal packages linking\n * to other internal packages), the parentRootRelativeDir will be passed\n * in, and we store the relative path to the isolate/packages\n * directory.\n *\n * For consistency we also write the other file paths starting with ./,\n * but it doesn't seem to be necessary for any package manager.\n */\n const relativePath = parentRootRelativeDir\n ? path.relative(parentRootRelativeDir, `./${def.rootRelativeDir}`)\n : `./${def.rootRelativeDir}`;\n\n const linkPath = `file:${relativePath}`;\n\n log.debug(`Linking dependency ${key} to ${linkPath}`);\n\n return [key, linkPath];\n } else {\n return [key, value];\n }\n })\n );\n}\n","import type { PackageManifest, PackagesRegistry } from \"~/lib/types\";\nimport { patchInternalEntries } from \"./patch-internal-entries\";\n\n/**\n * Replace the workspace version specifiers for internal dependency with file:\n * paths. Not needed for PNPM (because we configure the isolated output as a\n * workspace), but maybe still for NPM and Yarn.\n */\nexport function adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n}: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n}): PackageManifest {\n const { dependencies, devDependencies } = manifest;\n\n return {\n ...manifest,\n dependencies: dependencies\n ? patchInternalEntries(\n dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies: devDependencies\n ? patchInternalEntries(\n devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n };\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function getBuildOutputDir(targetPackageDir: string) {\n const config = useConfig();\n const log = useLogger();\n\n if (config.buildDirName) {\n log.debug(\"Using buildDirName from config:\", config.buildDirName);\n return path.join(targetPackageDir, config.buildDirName);\n }\n\n const tsconfigPath = path.join(targetPackageDir, config.tsconfigPath);\n\n if (fs.existsSync(tsconfigPath)) {\n log.debug(\"Found tsconfig at:\", config.tsconfigPath);\n\n const tsconfig = await readTypedJson<{\n compilerOptions?: { outDir?: string };\n }>(tsconfigPath);\n\n const outDir = tsconfig.compilerOptions?.outDir;\n\n if (outDir) {\n return path.join(targetPackageDir, outDir);\n } else {\n throw new Error(outdent`\n Failed to find outDir in tsconfig. If you are executing isolate from the root of a monorepo you should specify the buildDirName in isolate.config.json.\n `);\n }\n } else {\n log.warn(\"Failed to find tsconfig at:\", tsconfigPath);\n\n throw new Error(outdent`\n Failed to infer the build output directory from either the isolate config buildDirName or a Typescript config file. See the documentation on how to configure one of these options.\n `);\n }\n}\n","import assert from \"node:assert\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { pack } from \"../utils\";\n\n/**\n * Pack dependencies so that we extract only the files that are supposed to be\n * published by the packages.\n *\n * @returns A map of package names to the path of the packed file\n */\nexport async function packDependencies({\n /** All packages found in the monorepo by workspaces declaration */\n packagesRegistry,\n /** The dependencies that appear to be internal packages */\n internalPackageNames,\n /**\n * The directory where the isolated package and all its dependencies will end\n * up. This is also the directory from where the package will be deployed. By\n * default it is a subfolder in targetPackageDir called \"isolate\" but you can\n * configure it.\n */\n packDestinationDir,\n}: {\n packagesRegistry: PackagesRegistry;\n internalPackageNames: string[];\n packDestinationDir: string;\n}) {\n const log = useLogger();\n\n const packedFileByName: Record<string, string> = {};\n\n const { name, version } = usePackageManager();\n\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n const usePnpmPack = name === \"pnpm\" && versionMajor >= 8;\n\n if (usePnpmPack) {\n log.debug(\"Using PNPM pack instead of NPM pack\");\n }\n\n for (const dependency of internalPackageNames) {\n const def = packagesRegistry[dependency];\n\n assert(dependency, `Failed to find package definition for ${dependency}`);\n\n const { name } = def.manifest;\n\n /**\n * If this dependency has already been packed, we skip it. It could happen\n * because we are packing workspace dependencies recursively.\n */\n if (packedFileByName[name]) {\n log.debug(`Skipping ${name} because it has already been packed`);\n continue;\n }\n\n packedFileByName[name] = await pack(\n def.absoluteDir,\n packDestinationDir,\n usePnpmPack\n );\n }\n\n return packedFileByName;\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { pack, unpack } from \"../utils\";\n\nconst TIMEOUT_MS = 5000;\n\nexport async function processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n}: {\n targetPackageDir: string;\n tmpDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n const packedFilePath = await pack(targetPackageDir, tmpDir);\n const unpackDir = path.join(tmpDir, \"target\");\n\n const now = Date.now();\n let isWaitingYet = false;\n\n while (!fs.existsSync(packedFilePath) && Date.now() - now < TIMEOUT_MS) {\n if (!isWaitingYet) {\n log.debug(`Waiting for ${packedFilePath} to become available...`);\n }\n isWaitingYet = true;\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n await unpack(packedFilePath, unpackDir);\n await fs.copy(path.join(unpackDir, \"package\"), isolateDir);\n}\n","import fs from \"fs-extra\";\nimport path, { join } from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackagesRegistry } from \"../types\";\nimport { getIsolateRelativePath, unpack } from \"../utils\";\n\nexport async function unpackDependencies(\n packedFilesByName: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n tmpDir: string,\n isolateDir: string\n) {\n const log = useLogger();\n\n await Promise.all(\n Object.entries(packedFilesByName).map(async ([packageName, filePath]) => {\n const dir = packagesRegistry[packageName].rootRelativeDir;\n const unpackDir = join(tmpDir, dir);\n\n log.debug(\"Unpacking\", `(temp)/${path.basename(filePath)}`);\n\n await unpack(filePath, unpackDir);\n\n const destinationDir = join(isolateDir, dir);\n\n await fs.ensureDir(destinationDir);\n\n await fs.move(join(unpackDir, \"package\"), destinationDir, {\n overwrite: true,\n });\n\n log.debug(\n `Moved package files to ${getIsolateRelativePath(\n destinationDir,\n isolateDir\n )}`\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { readTypedJson } from \"../utils\";\nimport { findPackagesGlobs } from \"./helpers/find-packages-globs\";\n\n/**\n * Build a list of all packages in the workspace, depending on the package\n * manager used, with a possible override from the config file. The list\n * contains the manifest with some directory info mapped by module name.\n */\nexport async function createPackagesRegistry(\n workspaceRootDir: string,\n workspacePackagesOverride: string[] | undefined\n): Promise<PackagesRegistry> {\n const log = useLogger();\n\n if (workspacePackagesOverride) {\n log.debug(\n `Override workspace packages via config: ${workspacePackagesOverride}`\n );\n }\n\n const packagesGlobs =\n workspacePackagesOverride ?? findPackagesGlobs(workspaceRootDir);\n\n const cwd = process.cwd();\n process.chdir(workspaceRootDir);\n\n const allPackages = packagesGlobs\n .flatMap((glob) => globSync(glob))\n /** Make sure to filter any loose files that might hang around. */\n .filter((dir) => fs.lstatSync(dir).isDirectory());\n\n const registry: PackagesRegistry = (\n await Promise.all(\n allPackages.map(async (rootRelativeDir) => {\n const manifestPath = path.join(rootRelativeDir, \"package.json\");\n\n if (!fs.existsSync(manifestPath)) {\n log.warn(\n `Ignoring directory ./${rootRelativeDir} because it does not contain a package.json file`\n );\n return;\n } else {\n log.debug(`Registering package ./${rootRelativeDir}`);\n\n const manifest = await readTypedJson<PackageManifest>(\n path.join(rootRelativeDir, \"package.json\")\n );\n\n return {\n manifest,\n rootRelativeDir,\n absoluteDir: path.join(workspaceRootDir, rootRelativeDir),\n };\n }\n })\n )\n ).reduce<PackagesRegistry>((acc, info) => {\n if (info) {\n acc[info.manifest.name] = info;\n }\n return acc;\n }, {});\n\n process.chdir(cwd);\n\n return registry;\n}\n","import assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport { usePackageManager } from \"../../package-manager\";\nimport {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n} from \"../../utils\";\n\n/**\n * Find the globs that define where the packages are located within the\n * monorepo. This configuration is dependent on the package manager used, and I\n * don't know if we're covering all cases yet...\n */\nexport function findPackagesGlobs(workspaceRootDir: string) {\n const log = useLogger();\n\n const packageManager = usePackageManager();\n\n switch (packageManager.name) {\n case \"pnpm\": {\n const { packages: globs } = readTypedYamlSync<{ packages: string[] }>(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\")\n );\n\n log.debug(\"Detected pnpm packages globs:\", inspectValue(globs));\n return globs;\n }\n case \"yarn\":\n case \"npm\": {\n const workspaceRootManifestPath = path.join(\n workspaceRootDir,\n \"package.json\"\n );\n\n const { workspaces } = readTypedJsonSync<{ workspaces: string[] }>(\n workspaceRootManifestPath\n );\n\n if (!workspaces) {\n throw new Error(\n `No workspaces field found in ${workspaceRootManifestPath}`\n );\n }\n\n if (Array.isArray(workspaces)) {\n return workspaces;\n } else {\n /**\n * For Yarn, workspaces could be defined as an object with { packages:\n * [], nohoist: [] }. See\n * https://classic.yarnpkg.com/blog/2018/02/15/nohoist/\n */\n const workspacesObject = workspaces as { packages?: string[] };\n\n assert(\n workspacesObject.packages,\n \"workspaces.packages must be an array\"\n );\n\n return workspacesObject.packages;\n }\n }\n }\n}\n","import { uniq } from \"ramda\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\n\n/**\n * Recursively list all the packages from dependencies (and optionally\n * devDependencies) that are found in the monorepo.\n *\n * Here we do not need to rely on packages being declared with \"workspace:\" in\n * the package manifest. We can simply compare the package names with the list\n * of packages that were found via the workspace glob patterns and add them to\n * the registry.\n */\nexport function listInternalPackages(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n { includeDevDependencies = false } = {}\n): string[] {\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n const internalPackageNames = (\n includeDevDependencies\n ? [\n ...Object.keys(manifest.dependencies ?? {}),\n ...Object.keys(manifest.devDependencies ?? {}),\n ]\n : Object.keys(manifest.dependencies ?? {})\n ).filter((name) => allWorkspacePackageNames.includes(name));\n\n const nestedInternalPackageNames = internalPackageNames.flatMap(\n (packageName) =>\n listInternalPackages(\n packagesRegistry[packageName].manifest,\n packagesRegistry,\n { includeDevDependencies }\n )\n );\n\n return uniq(internalPackageNames.concat(nestedInternalPackageNames));\n}\n"],"mappings":"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","names":["console","fs","assert","path","fs","path","path","fs","stdout","fs","fs","fs","fs","path","fs","fs","path","fs","path","fs","assert","path","path","assert","fs","fs","path","path","fs","assert","path","assert","path","fs","execSync","path","path","fs","execSync","omit","pick","path","fs","path","path","fs","path","path","packageManager","path","packageManager","omit","pick","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","fs","path","assert","path","packageManager","path","assert","fs","path","path","assert","fs","packageManager","console"]}
1
+ {"version":3,"sources":["../src/isolate-bin.ts","../src/isolate.ts","../src/lib/config.ts","../src/lib/logger.ts","../src/lib/utils/get-dirname.ts","../src/lib/utils/get-error-message.ts","../src/lib/utils/get-relative-path.ts","../src/lib/utils/inspect-value.ts","../src/lib/utils/json.ts","../src/lib/utils/pack.ts","../src/lib/utils/unpack.ts","../src/lib/utils/yaml.ts","../src/lib/lockfile/process-lockfile.ts","../src/lib/package-manager/helpers/infer-from-files.ts","../src/lib/package-manager/names.ts","../src/lib/package-manager/helpers/infer-from-manifest.ts","../src/lib/package-manager/index.ts","../src/lib/lockfile/helpers/generate-npm-lockfile.ts","../src/lib/lockfile/helpers/generate-pnpm-lockfile.ts","../src/lib/lockfile/helpers/generate-yarn-lockfile.ts","../src/lib/manifest/adapt-target-package-manifest.ts","../src/lib/manifest/helpers/adapt-internal-package-manifests.ts","../src/lib/manifest/io.ts","../src/lib/manifest/helpers/patch-internal-entries.ts","../src/lib/manifest/helpers/adapt-manifest-internal-deps.ts","../src/lib/output/get-build-output-dir.ts","../src/lib/output/pack-dependencies.ts","../src/lib/output/process-build-output-files.ts","../src/lib/output/unpack-dependencies.ts","../src/lib/registry/create-packages-registry.ts","../src/lib/registry/helpers/find-packages-globs.ts","../src/lib/registry/list-internal-packages.ts"],"sourcesContent":["#!/usr/bin/env node\nimport console from \"node:console\";\nimport sourceMaps from \"source-map-support\";\nimport { isolate } from \"./isolate\";\n\nsourceMaps.install();\n\nasync function run() {\n await isolate();\n}\n\nrun().catch((err) => {\n if (err instanceof Error) {\n console.error(err.stack);\n process.exit(1);\n } else {\n console.error(err);\n }\n});\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport type { IsolateConfig } from \"./lib/config\";\nimport { resolveConfig, setUserConfig } from \"./lib/config\";\nimport { processLockfile } from \"./lib/lockfile\";\nimport type { Logger } from \"./lib/logger\";\nimport { setLogLevel, setLogger, useLogger } from \"./lib/logger\";\nimport {\n adaptInternalPackageManifests,\n adaptTargetPackageManifest,\n readManifest,\n writeManifest,\n} from \"./lib/manifest\";\nimport {\n getBuildOutputDir,\n packDependencies,\n processBuildOutputFiles,\n unpackDependencies,\n} from \"./lib/output\";\nimport { detectPackageManager } from \"./lib/package-manager\";\nimport { getVersion } from \"./lib/package-manager/helpers/infer-from-files\";\nimport { createPackagesRegistry, listInternalPackages } from \"./lib/registry\";\nimport type { PackageManifest } from \"./lib/types\";\nimport { getDirname, getRootRelativePath, readTypedJson } from \"./lib/utils\";\n\nconst __dirname = getDirname(import.meta.url);\n\nexport async function isolate(\n options: { config?: IsolateConfig; logger?: Logger } = {}\n) {\n if (options.logger) {\n setLogger(options.logger);\n }\n\n if (options.config) {\n setUserConfig(options.config);\n }\n\n const config = resolveConfig();\n\n setLogLevel(config.logLevel);\n\n const log = useLogger();\n\n const thisPackageManifest = await readTypedJson<PackageManifest>(\n path.join(path.join(__dirname, \"..\", \"package.json\"))\n );\n\n log.debug(\"Using isolate-package version\", thisPackageManifest.version);\n\n /**\n * If a targetPackagePath is set, we assume the configuration lives in the\n * root of the workspace. If targetPackagePath is undefined (the default), we\n * assume that the configuration lives in the target package directory.\n */\n const targetPackageDir = config.targetPackagePath\n ? path.join(process.cwd(), config.targetPackagePath)\n : process.cwd();\n\n /**\n * We want a trailing slash here. Functionally it doesn't matter, but it makes\n * the relative paths more correct in the debug output.\n */\n const workspaceRootDir = config.targetPackagePath\n ? process.cwd()\n : path.join(targetPackageDir, config.workspaceRoot);\n\n const buildOutputDir = await getBuildOutputDir(targetPackageDir);\n\n assert(\n fs.existsSync(buildOutputDir),\n `Failed to find build output path at ${buildOutputDir}. Please make sure you build the source before isolating it.`\n );\n\n log.debug(\"Workspace root resolved to\", workspaceRootDir);\n log.debug(\n \"Isolate target package\",\n getRootRelativePath(targetPackageDir, workspaceRootDir)\n );\n\n const isolateDir = path.join(targetPackageDir, config.isolateDirName);\n\n log.debug(\n \"Isolate output directory\",\n getRootRelativePath(isolateDir, workspaceRootDir)\n );\n\n if (fs.existsSync(isolateDir)) {\n await fs.remove(isolateDir);\n log.debug(\"Cleaned the existing isolate output directory\");\n }\n\n await fs.ensureDir(isolateDir);\n\n const tmpDir = path.join(isolateDir, \"__tmp\");\n await fs.ensureDir(tmpDir);\n\n const targetPackageManifest = await readTypedJson<PackageManifest>(\n path.join(targetPackageDir, \"package.json\")\n );\n\n const packageManager = detectPackageManager(workspaceRootDir);\n\n log.debug(\n \"Detected package manager\",\n packageManager.name,\n packageManager.version\n );\n\n /**\n * Build a packages registry so we can find the workspace packages by name and\n * have access to their manifest files and relative paths.\n */\n const packagesRegistry = await createPackagesRegistry(\n workspaceRootDir,\n config.workspacePackages\n );\n\n const internalPackageNames = listInternalPackages(\n targetPackageManifest,\n packagesRegistry,\n {\n includeDevDependencies: config.includeDevDependencies,\n }\n );\n\n const packedFilesByName = await packDependencies({\n internalPackageNames,\n packagesRegistry,\n packDestinationDir: tmpDir,\n });\n\n await unpackDependencies(\n packedFilesByName,\n packagesRegistry,\n tmpDir,\n isolateDir\n );\n\n /** Adapt the manifest files for all the unpacked local dependencies */\n await adaptInternalPackageManifests(\n internalPackageNames,\n packagesRegistry,\n isolateDir\n );\n\n /** Pack the target package directory, and unpack it in the isolate location */\n await processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n });\n\n /**\n * Copy the target manifest file to the isolate location and adapt its\n * workspace dependencies to point to the isolated packages.\n */\n await adaptTargetPackageManifest(\n targetPackageManifest,\n packagesRegistry,\n isolateDir\n );\n\n /** Generate an isolated lockfile based on the original one */\n const usedFallbackToNpm = await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n\n if (usedFallbackToNpm) {\n /**\n * When we fall back to NPM, we set the manifest package manager to the\n * available NPM version.\n */\n const manifest = await readManifest(isolateDir);\n\n const npmVersion = getVersion(\"npm\");\n manifest.packageManager = `npm@${npmVersion}`;\n\n await writeManifest(isolateDir, manifest);\n }\n\n if (packageManager.name === \"pnpm\" && !config.forceNpm) {\n /**\n * PNPM doesn't install dependencies of packages that are linked via link:\n * or file: specifiers. It requires the directory to be configured as a\n * workspace, so we copy the workspace config file to the isolate output.\n */\n fs.copyFileSync(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\"),\n path.join(isolateDir, \"pnpm-workspace.yaml\")\n );\n }\n /**\n * If there is an .npmrc file in the workspace root, copy it to the isolate\n * because the settings there could affect how the lockfile is resolved. Note\n * that .npmrc is used by both NPM and PNPM for configuration.\n *\n * See also: https://pnpm.io/npmrc\n */\n const npmrcPath = path.join(workspaceRootDir, \".npmrc\");\n\n if (fs.existsSync(npmrcPath)) {\n fs.copyFileSync(npmrcPath, path.join(isolateDir, \".npmrc\"));\n log.debug(\"Copied .npmrc file to the isolate output\");\n }\n\n /**\n * Clean up. Only so this in the happy path, so we can look at the temp folder\n * when thing go wrong.\n */\n log.debug(\n \"Deleting temp directory\",\n getRootRelativePath(tmpDir, workspaceRootDir)\n );\n await fs.remove(tmpDir);\n\n log.info(\"Isolate completed at\", isolateDir);\n\n return isolateDir;\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"remeda\";\nimport { setLogLevel, useLogger } from \"./logger\";\nimport { inspectValue, readTypedJsonSync } from \"./utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n forceNpm: boolean;\n pickFromScripts?: string[];\n omitFromScripts?: string[];\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n includePatchedDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n forceNpm: false,\n pickFromScripts: undefined,\n omitFromScripts: undefined,\n};\n\n/**\n * Only initialize the configuration once, and keeping it here for subsequent\n * calls to getConfig.\n */\nlet _resolvedConfig: IsolateConfigResolved | undefined;\n\nlet _user_defined_config: IsolateConfig | undefined;\n\nconst validConfigKeys = Object.keys(configDefaults);\n\nconst CONFIG_FILE_NAME = \"isolate.config.json\";\n\nexport type LogLevel = IsolateConfigResolved[\"logLevel\"];\n\nexport function setUserConfig(config: IsolateConfig) {\n _user_defined_config = config;\n\n if (config.logLevel) {\n setLogLevel(config.logLevel);\n }\n}\n\nexport function useConfig() {\n if (_resolvedConfig) {\n return _resolvedConfig;\n } else {\n throw new Error(\"Called useConfig before config was made available\");\n }\n}\n\n/**\n * Resolve configuration based on user config and defaults. If setConfig was\n * called before this, it does not attempt to read a config file from disk.\n */\nexport function resolveConfig(): IsolateConfigResolved {\n if (_resolvedConfig) {\n return _resolvedConfig;\n }\n\n setLogLevel(process.env.DEBUG_ISOLATE_CONFIG ? \"debug\" : \"info\");\n\n const log = useLogger();\n\n const configFilePath = path.join(process.cwd(), CONFIG_FILE_NAME);\n\n if (_user_defined_config) {\n log.debug(`Using user defined config:`, inspectValue(_user_defined_config));\n } else {\n log.debug(`Attempting to load config from ${configFilePath}`);\n\n _user_defined_config = fs.existsSync(configFilePath)\n ? readTypedJsonSync<IsolateConfig>(configFilePath)\n : {};\n }\n\n const foreignKeys = Object.keys(_user_defined_config).filter(\n (key) => !validConfigKeys.includes(key)\n );\n\n if (!isEmpty(foreignKeys)) {\n log.warn(`Found invalid config settings:`, foreignKeys.join(\", \"));\n }\n\n const config = Object.assign(\n {},\n configDefaults,\n _user_defined_config\n ) satisfies IsolateConfigResolved;\n\n log.debug(\"Using configuration:\", inspectValue(config));\n\n _resolvedConfig = config;\n return config;\n}\n\n/**\n * Get only the configuration that the user set explicitly in the config file or\n * passed via arguments to isolate().\n */\nexport function getUserDefinedConfig(): IsolateConfig {\n assert(\n _user_defined_config,\n \"Called getUserDefinedConfig before user config was made available\"\n );\n\n return _user_defined_config;\n}\n","import chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"./config\";\n/**\n * The Logger defines an interface that can be used to pass in a different\n * logger object in order to intercept all the logging output. We keep the\n * handlers separate from the logger object itself, so that we can change the\n * handlers but do not bother the user with having to handle logLevel.\n */\nexport type Logger = {\n debug(...args: unknown[]): void;\n info(...args: unknown[]): void;\n warn(...args: unknown[]): void;\n error(...args: unknown[]): void;\n};\n\nlet _loggerHandlers: Logger = {\n debug(...args: unknown[]) {\n console.log(chalk.blue(\"debug\"), ...args);\n },\n info(...args: unknown[]) {\n console.log(chalk.green(\"info\"), ...args);\n },\n warn(...args: unknown[]) {\n console.log(chalk.yellow(\"warning\"), ...args);\n },\n error(...args: unknown[]) {\n console.log(chalk.red(\"error\"), ...args);\n },\n};\n\nconst _logger: Logger = {\n debug(...args: unknown[]) {\n if (_logLevel === \"debug\") {\n _loggerHandlers.debug(...args);\n }\n },\n info(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\") {\n _loggerHandlers.info(...args);\n }\n },\n warn(...args: unknown[]) {\n if (_logLevel === \"debug\" || _logLevel === \"info\" || _logLevel === \"warn\") {\n _loggerHandlers.warn(...args);\n }\n },\n error(...args: unknown[]) {\n _loggerHandlers.error(...args);\n },\n};\n\nlet _logLevel: LogLevel = \"info\";\n\nexport function setLogger(logger: Logger) {\n _loggerHandlers = logger;\n return _logger;\n}\n\nexport function setLogLevel(\n logLevel: IsolateConfigResolved[\"logLevel\"]\n): Logger {\n _logLevel = logLevel;\n return _logger;\n}\n\nexport function useLogger() {\n return _logger;\n}\n","import { fileURLToPath } from \"url\";\n\n/**\n * Calling context should pass in import.meta.url and the function will return\n * the equivalent of __dirname in Node/CommonJs.\n */\nexport function getDirname(importMetaUrl: string) {\n return fileURLToPath(new URL(\".\", importMetaUrl));\n}\n","type ErrorWithMessage = {\n message: string;\n};\n\nexport function getErrorMessage(error: unknown) {\n return toErrorWithMessage(error).message;\n}\n\nfunction isErrorWithMessage(error: unknown): error is ErrorWithMessage {\n return typeof error === \"object\" && error !== null && \"message\" in error;\n}\n\nfunction toErrorWithMessage(maybeError: unknown): ErrorWithMessage {\n if (isErrorWithMessage(maybeError)) return maybeError;\n\n try {\n return new Error(JSON.stringify(maybeError));\n } catch {\n /**\n * Fallback in case there’s an error stringifying the maybeError like with\n * circular references.\n */\n return new Error(String(maybeError));\n }\n}\n","export function getRootRelativePath(path: string, rootPath: string) {\n const strippedPath = path.replace(rootPath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(root)${strippedPath}`\n : `(root)/${strippedPath}`;\n}\n\nexport function getIsolateRelativePath(path: string, isolatePath: string) {\n const strippedPath = path.replace(isolatePath, \"\");\n\n return strippedPath.startsWith(\"/\")\n ? `(isolate)${strippedPath}`\n : `(isolate)/${strippedPath}`;\n}\n","import { inspect } from \"node:util\";\n\nexport function inspectValue(value: unknown) {\n return inspect(value, false, 16, true);\n}\n","import fs from \"fs-extra\";\nimport stripJsonComments from \"strip-json-comments\";\nimport { getErrorMessage } from \"./get-error-message\";\n\n/** @todo Pass in zod schema and validate */\nexport function readTypedJsonSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = JSON.parse(stripJsonComments(rawContent)) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport async function readTypedJson<T>(filePath: string) {\n try {\n const rawContent = await fs.readFile(filePath, \"utf-8\");\n const data = JSON.parse(rawContent) as T;\n return data;\n } catch (err) {\n throw new Error(\n `Failed to read JSON from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n","import { exec } from \"node:child_process\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack?: boolean\n) {\n const execOptions = {\n maxBuffer: 10 * 1024 * 1024,\n };\n\n const log = useLogger();\n\n const previousCwd = process.cwd();\n process.chdir(srcDir);\n\n /**\n * PNPM pack seems to be a lot faster than NPM pack, so when PNPM is detected\n * we use that instead.\n */\n const stdout = usePnpmPack\n ? await new Promise<string>((resolve, reject) => {\n exec(\n `pnpm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n log.error(getErrorMessage(err));\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n })\n : await new Promise<string>((resolve, reject) => {\n exec(\n `npm pack --pack-destination \"${dstDir}\"`,\n execOptions,\n (err, stdout) => {\n if (err) {\n return reject(err);\n }\n\n resolve(stdout);\n }\n );\n });\n\n const fileName = path.basename(stdout.trim());\n\n const filePath = path.join(dstDir, fileName);\n\n if (!fs.existsSync(filePath)) {\n log.error(\n `The response from pack could not be resolved to an existing file: ${filePath}`\n );\n } else {\n log.debug(`Packed (temp)/${fileName}`);\n }\n\n process.chdir(previousCwd);\n\n /**\n * Return the path anyway even if it doesn't validate. A later stage will wait\n * for the file to occur still. Not sure if this makes sense. Maybe we should\n * stop at the validation error...\n */\n return filePath;\n}\n","import fs from \"fs-extra\";\nimport tar from \"tar-fs\";\nimport { createGunzip } from \"zlib\";\n\nexport async function unpack(filePath: string, unpackDir: string) {\n await new Promise<void>((resolve, reject) => {\n fs.createReadStream(filePath)\n .pipe(createGunzip())\n .pipe(tar.extract(unpackDir))\n .on(\"finish\", () => resolve())\n .on(\"error\", (err) => reject(err));\n });\n}\n","import fs from \"fs-extra\";\nimport yaml from \"yaml\";\nimport { getErrorMessage } from \"./get-error-message\";\n\nexport function readTypedYamlSync<T>(filePath: string) {\n try {\n const rawContent = fs.readFileSync(filePath, \"utf-8\");\n const data = yaml.parse(rawContent);\n /** @todo Add some zod validation maybe */\n return data as T;\n } catch (err) {\n throw new Error(\n `Failed to read YAML from ${filePath}: ${getErrorMessage(err)}`\n );\n }\n}\n\nexport function writeTypedYamlSync<T>(filePath: string, content: T) {\n /** @todo Add some zod validation maybe */\n fs.writeFileSync(filePath, yaml.stringify(content), \"utf-8\");\n}\n","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport { mapValues } from \"remeda\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { generateNpmLockfile } from \"./helpers/generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./helpers/generate-pnpm-lockfile\";\nimport { generateYarnLockfile } from \"./helpers/generate-yarn-lockfile\";\n\n/** Convert dependency links */\nexport function pnpmMapImporter(\n {\n dependencies,\n devDependencies,\n patchedDependencies,\n ...rest\n }: ProjectSnapshot,\n {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: boolean;\n includePatchedDependencies: boolean;\n directoryByPackageName: { [packageName: string]: string };\n }\n): ProjectSnapshot {\n return {\n dependencies: dependencies\n ? pnpmMapDependenciesLinks(dependencies, directoryByPackageName)\n : undefined,\n devDependencies:\n includeDevDependencies && devDependencies\n ? pnpmMapDependenciesLinks(devDependencies, directoryByPackageName)\n : undefined,\n /**\n * Don't know how to map the patched dependencies yet, so we just include\n * them but I don't think it would work like this. The important thing for\n * now is that they are omitted by default, because that is the most common\n * use case.\n */\n patchedDependencies: includePatchedDependencies\n ? patchedDependencies\n : undefined,\n ...rest,\n };\n}\n\nfunction pnpmMapDependenciesLinks(\n def: ResolvedDependencies,\n directoryByPackageName: { [packageName: string]: string }\n): ResolvedDependencies {\n return mapValues(def, (value, key) =>\n value.startsWith(\"link:\") ? `link:./${directoryByPackageName[key]}` : value\n );\n}\n\n/**\n * Adapt the lockfile and write it to the isolate directory. Because we keep the\n * structure of packages in the isolate directory the same as they were in the\n * monorepo, the lockfile is largely still correct. The only things that need to\n * be done is to remove the root dependencies and devDependencies, and rename\n * the path to the target package to act as the new root.\n */\nexport async function processLockfile({\n workspaceRootDir,\n packagesRegistry,\n isolateDir,\n internalDepPackageNames,\n targetPackageDir,\n}: {\n workspaceRootDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n internalDepPackageNames: string[];\n targetPackageDir: string;\n targetPackageName: string;\n}) {\n const log = useLogger();\n\n const { forceNpm } = useConfig();\n\n if (forceNpm) {\n log.info(\"Forcing to use NPM for isolate output\");\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n return true;\n }\n\n const { name, version } = usePackageManager();\n let usedFallbackToNpm = false;\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n break;\n }\n case \"yarn\": {\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n if (versionMajor === 1) {\n await generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n });\n } else {\n log.info(\n \"Detected modern version of Yarn. Using NPM lockfile fallback.\"\n );\n\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n break;\n }\n case \"pnpm\": {\n await generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n });\n break;\n }\n default:\n log.warn(`Unexpected package manager ${name}. Using NPM for output`);\n await generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n });\n\n usedFallbackToNpm = true;\n }\n\n return usedFallbackToNpm;\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport type { PackageManager, PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromFiles(workspaceRoot: string): PackageManager {\n for (const name of supportedPackageManagerNames) {\n const lockfileName = getLockfileFileName(name);\n\n if (fs.existsSync(path.join(workspaceRoot, lockfileName))) {\n return { name, version: getVersion(name) };\n }\n }\n\n /** If no lockfile was found, it could be that there is an npm shrinkwrap file. */\n if (fs.existsSync(path.join(workspaceRoot, \"npm-shrinkwrap.json\"))) {\n return { name: \"npm\", version: getVersion(\"npm\") };\n }\n\n throw new Error(`Failed to detect package manager`);\n}\n\nexport function getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\n","export const supportedPackageManagerNames = [\"pnpm\", \"yarn\", \"npm\"] as const;\n\nexport type PackageManagerName = (typeof supportedPackageManagerNames)[number];\n\nexport type PackageManager = {\n name: PackageManagerName;\n version: string;\n};\n\nexport function getLockfileFileName(name: PackageManagerName) {\n switch (name) {\n case \"pnpm\":\n return \"pnpm-lock.yaml\";\n case \"yarn\":\n return \"yarn.lock\";\n case \"npm\":\n return \"package-lock.json\";\n }\n}\n","import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackageManifest } from \"../../types\";\nimport { readTypedJsonSync } from \"../../utils\";\nimport type { PackageManagerName } from \"../names\";\nimport { getLockfileFileName, supportedPackageManagerNames } from \"../names\";\n\nexport function inferFromManifest(workspaceRoot: string) {\n const log = useLogger();\n\n const rootManifest = readTypedJsonSync<PackageManifest>(\n path.join(workspaceRoot, \"package.json\")\n );\n\n if (!rootManifest.packageManager) {\n log.debug(\"No packageManager field found in root manifest\");\n return;\n }\n\n const [name, version = \"*\"] = rootManifest.packageManager.split(\"@\") as [\n PackageManagerName,\n string,\n ];\n\n assert(\n supportedPackageManagerNames.includes(name),\n `Package manager \"${name}\" is not currently supported`\n );\n\n const lockfileName = getLockfileFileName(name);\n\n assert(\n fs.existsSync(path.join(workspaceRoot, lockfileName)),\n `Manifest declares ${name} to be the packageManager, but failed to find ${lockfileName} in workspace root`\n );\n\n return { name, version };\n}\n","import { inferFromFiles } from \"./helpers/infer-from-files\";\nimport { inferFromManifest } from \"./helpers/infer-from-manifest\";\nimport type { PackageManager } from \"./names\";\n\nexport * from \"./names\";\n\nexport let packageManager: PackageManager | undefined;\n\nexport function usePackageManager() {\n if (!packageManager) {\n throw Error(\n \"No package manager detected. Make sure to call detectPackageManager() before usePackageManager()\"\n );\n }\n\n return packageManager;\n}\n\n/**\n * First we check if the package manager is declared in the manifest. If it is,\n * we get the name and version from there. Otherwise we'll search for the\n * different lockfiles and ask the OS to report the installed version.\n */\nexport function detectPackageManager(workspaceRoot: string): PackageManager {\n /**\n * Disable infer from manifest for now. I doubt it is useful after all but\n * I'll keep the code as a reminder.\n */\n packageManager =\n inferFromManifest(workspaceRoot) ?? inferFromFiles(workspaceRoot);\n\n return packageManager;\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage, inspectValue } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the contents of installed\n * node_modules from the monorepo root plus the adapted package manifest in the\n * isolate directory.\n */\nexport async function generateNpmLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating NPM lockfile...\");\n\n const origRootNodeModulesPath = path.join(workspaceRootDir, \"node_modules\");\n const tempRootNodeModulesPath = path.join(isolateDir, \"node_modules\");\n\n let hasMovedNodeModules = false;\n\n let hasError = false;\n\n try {\n if (!fs.existsSync(origRootNodeModulesPath)) {\n throw new Error(\n `Failed to find node_modules at ${origRootNodeModulesPath}`\n );\n }\n\n log.debug(`Temporarily moving node_modules to the isolate output`);\n\n await fs.move(origRootNodeModulesPath, tempRootNodeModulesPath);\n hasMovedNodeModules = true;\n\n const arborist = new Arborist({ path: isolateDir });\n\n log.debug(`Building tree...`);\n const { meta } = await arborist.buildIdealTree();\n\n meta?.commit();\n\n const lockfilePath = path.join(isolateDir, \"package-lock.json\");\n\n await fs.writeFile(lockfilePath, String(meta));\n\n log.debug(\"Created lockfile at\", lockfilePath);\n } catch (err) {\n console.error(inspectValue(err));\n log.error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n hasError = true;\n } finally {\n /** @todo We should be able to use the new \"using\" keyword for this I think. */\n if (hasMovedNodeModules) {\n log.debug(`Restoring node_modules to the workspace root`);\n await fs.move(tempRootNodeModulesPath, origRootNodeModulesPath);\n }\n }\n\n if (hasError) {\n throw new Error(\"Failed to generate lockfile\");\n }\n}\n","import {\n getLockfileImporterId,\n readWantedLockfile,\n writeWantedLockfile,\n} from \"@pnpm/lockfile-file\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { pick } from \"remeda\";\nimport { useConfig } from \"~/lib/config\";\nimport { useLogger } from \"~/lib/logger\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { getErrorMessage } from \"~/lib/utils\";\nimport { pnpmMapImporter } from \"../process-lockfile\";\n\nexport async function generatePnpmLockfile({\n workspaceRootDir,\n targetPackageDir,\n isolateDir,\n internalDepPackageNames,\n packagesRegistry,\n}: {\n workspaceRootDir: string;\n targetPackageDir: string;\n isolateDir: string;\n internalDepPackageNames: string[];\n packagesRegistry: PackagesRegistry;\n}) {\n const { includeDevDependencies, includePatchedDependencies } = useConfig();\n const log = useLogger();\n\n log.info(\"Generating PNPM lockfile...\");\n\n try {\n const lockfile = await readWantedLockfile(workspaceRootDir, {\n ignoreIncompatible: false,\n });\n\n assert(lockfile, `No input lockfile found at ${workspaceRootDir}`);\n\n const targetImporterId = getLockfileImporterId(\n workspaceRootDir,\n targetPackageDir\n );\n\n const directoryByPackageName = Object.fromEntries(\n internalDepPackageNames.map((name) => {\n const pkg = packagesRegistry[name];\n assert(pkg, `Package ${name} not found in packages registry`);\n return [name, pkg.rootRelativeDir];\n })\n );\n\n const relevantImporterIds = [\n targetImporterId,\n /**\n * The directory paths happen to correspond with what PNPM calls the\n * importer ids in the context of a lockfile.\n */\n ...Object.values(directoryByPackageName),\n ];\n\n log.debug(\"Relevant importer ids:\", relevantImporterIds);\n\n lockfile.importers = Object.fromEntries(\n Object.entries(pick(lockfile.importers, relevantImporterIds)).map(\n ([importerId, importer]) => {\n if (importerId === targetImporterId) {\n log.debug(\"Setting target package importer on root\");\n\n return [\n \".\",\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\n includePatchedDependencies,\n directoryByPackageName,\n }),\n ];\n }\n )\n );\n\n await writeWantedLockfile(isolateDir, lockfile);\n\n log.debug(\"Created lockfile at\", path.join(isolateDir, \"pnpm-lock.yaml\"));\n } catch (err) {\n throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import fs from \"fs-extra\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"~/lib/logger\";\nimport { getErrorMessage } from \"~/lib/utils\";\n\n/**\n * Generate an isolated / pruned lockfile, based on the existing lockfile from\n * the monorepo root plus the adapted package manifest in the isolate\n * directory.\n */\nexport async function generateYarnLockfile({\n workspaceRootDir,\n isolateDir,\n}: {\n workspaceRootDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.info(\"Generating Yarn lockfile...\");\n\n const origLockfilePath = path.join(workspaceRootDir, \"yarn.lock\");\n const newLockfilePath = path.join(isolateDir, \"yarn.lock\");\n\n if (!fs.existsSync(origLockfilePath)) {\n throw new Error(`Failed to find lockfile at ${origLockfilePath}`);\n }\n\n log.debug(`Copy original yarn.lock to the isolate output`);\n\n try {\n await fs.copyFile(origLockfilePath, newLockfilePath);\n\n /**\n * Running install with the original lockfile in the same directory will\n * generate a pruned version of the lockfile.\n */\n log.debug(`Running local install`);\n execSync(`yarn install --cwd ${isolateDir}`);\n\n log.debug(\"Generated lockfile at\", newLockfilePath);\n } catch (err) {\n throw new Error(`Failed to generate lockfile: ${getErrorMessage(err)}`);\n }\n}\n","import { omit, pick } from \"remeda\";\nimport { useConfig } from \"../config\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { adaptManifestInternalDeps } from \"./helpers\";\nimport { writeManifest } from \"./io\";\n\n/**\n * Adapt the output package manifest, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - The devDependencies are possibly removed\n * - Scripts are picked or omitted and otherwise removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm, pickFromScripts, omitFromScripts } =\n useConfig();\n\n /** Dev dependencies are omitted by default */\n const inputManifest = includeDevDependencies\n ? manifest\n : omit(manifest, [\"devDependencies\"]);\n\n const adaptedManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : /** For other package managers we replace the links to internal dependencies */\n adaptManifestInternalDeps({\n manifest: inputManifest,\n packagesRegistry,\n });\n\n const outputManifest = {\n ...adaptedManifest,\n /**\n * Scripts are removed by default if not explicitly picked or omitted via\n * config.\n */\n scripts: pickFromScripts\n ? pick(manifest.scripts ?? {}, pickFromScripts)\n : omitFromScripts\n ? omit(manifest.scripts ?? {}, omitFromScripts)\n : undefined,\n };\n\n await writeManifest(isolateDir, outputManifest);\n}\n","import path from \"node:path\";\nimport { omit } from \"remeda\";\nimport { useConfig } from \"~/lib/config\";\nimport { usePackageManager } from \"~/lib/package-manager\";\nimport type { PackagesRegistry } from \"~/lib/types\";\nimport { writeManifest } from \"../io\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\n\n/**\n * Adapt the manifest files of all the isolated internal packages (excluding the\n * target package), so that their dependencies point to the other isolated\n * packages in the same folder.\n */\nexport async function adaptInternalPackageManifests(\n internalPackageNames: string[],\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies, forceNpm } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n /**\n * Dev dependencies are omitted by default. And also, for internal\n * dependencies we want to omit the peerDependencies, because installing\n * these is the responsibility of the consuming app / service, and\n * otherwise the frozen lockfile install will error since the package file\n * contains something that is not referenced in the lockfile.\n */\n const inputManifest = includeDevDependencies\n ? omit(manifest, [\"peerDependencies\"])\n : omit(manifest, [\"devDependencies\", \"peerDependencies\"]);\n\n const outputManifest =\n packageManager.name === \"pnpm\" && !forceNpm\n ? /**\n * For PNPM the output itself is a workspace so we can preserve the specifiers\n * with \"workspace:*\" in the output manifest.\n */\n inputManifest\n : adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n });\n\n await writeManifest(\n path.join(isolateDir, rootRelativeDir),\n outputManifest\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport type { PackageManifest } from \"../types\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function readManifest(packageDir: string) {\n return readTypedJson<PackageManifest>(path.join(packageDir, \"package.json\"));\n}\n\nexport async function writeManifest(\n outputDir: string,\n manifest: PackageManifest\n) {\n await fs.writeFile(\n path.join(outputDir, \"package.json\"),\n JSON.stringify(manifest, null, 2)\n );\n}\n","import path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport type { PackagesRegistry } from \"../../types\";\n\nexport function patchInternalEntries(\n dependencies: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n parentRootRelativeDir?: string\n) {\n const log = useLogger();\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n return Object.fromEntries(\n Object.entries(dependencies).map(([key, value]) => {\n if (allWorkspacePackageNames.includes(key)) {\n const def = packagesRegistry[key];\n\n /**\n * When nested internal dependencies are used (internal packages linking\n * to other internal packages), the parentRootRelativeDir will be passed\n * in, and we store the relative path to the isolate/packages\n * directory.\n *\n * For consistency we also write the other file paths starting with ./,\n * but it doesn't seem to be necessary for any package manager.\n */\n const relativePath = parentRootRelativeDir\n ? path.relative(parentRootRelativeDir, `./${def.rootRelativeDir}`)\n : `./${def.rootRelativeDir}`;\n\n const linkPath = `file:${relativePath}`;\n\n log.debug(`Linking dependency ${key} to ${linkPath}`);\n\n return [key, linkPath];\n } else {\n return [key, value];\n }\n })\n );\n}\n","import type { PackageManifest, PackagesRegistry } from \"~/lib/types\";\nimport { patchInternalEntries } from \"./patch-internal-entries\";\n\n/**\n * Replace the workspace version specifiers for internal dependency with file:\n * paths. Not needed for PNPM (because we configure the isolated output as a\n * workspace), but maybe still for NPM and Yarn.\n */\nexport function adaptManifestInternalDeps({\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n}: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n}): PackageManifest {\n const { dependencies, devDependencies } = manifest;\n\n return {\n ...manifest,\n dependencies: dependencies\n ? patchInternalEntries(\n dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies: devDependencies\n ? patchInternalEntries(\n devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n };\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { useConfig } from \"../config\";\nimport { useLogger } from \"../logger\";\nimport { readTypedJson } from \"../utils\";\n\nexport async function getBuildOutputDir(targetPackageDir: string) {\n const config = useConfig();\n const log = useLogger();\n\n if (config.buildDirName) {\n log.debug(\"Using buildDirName from config:\", config.buildDirName);\n return path.join(targetPackageDir, config.buildDirName);\n }\n\n const tsconfigPath = path.join(targetPackageDir, config.tsconfigPath);\n\n if (fs.existsSync(tsconfigPath)) {\n log.debug(\"Found tsconfig at:\", config.tsconfigPath);\n\n const tsconfig = await readTypedJson<{\n compilerOptions?: { outDir?: string };\n }>(tsconfigPath);\n\n const outDir = tsconfig.compilerOptions?.outDir;\n\n if (outDir) {\n return path.join(targetPackageDir, outDir);\n } else {\n throw new Error(outdent`\n Failed to find outDir in tsconfig. If you are executing isolate from the root of a monorepo you should specify the buildDirName in isolate.config.json.\n `);\n }\n } else {\n log.warn(\"Failed to find tsconfig at:\", tsconfigPath);\n\n throw new Error(outdent`\n Failed to infer the build output directory from either the isolate config buildDirName or a Typescript config file. See the documentation on how to configure one of these options.\n `);\n }\n}\n","import assert from \"node:assert\";\nimport { useLogger } from \"../logger\";\nimport { usePackageManager } from \"../package-manager\";\nimport type { PackagesRegistry } from \"../types\";\nimport { pack } from \"../utils\";\n\n/**\n * Pack dependencies so that we extract only the files that are supposed to be\n * published by the packages.\n *\n * @returns A map of package names to the path of the packed file\n */\nexport async function packDependencies({\n /** All packages found in the monorepo by workspaces declaration */\n packagesRegistry,\n /** The dependencies that appear to be internal packages */\n internalPackageNames,\n /**\n * The directory where the isolated package and all its dependencies will end\n * up. This is also the directory from where the package will be deployed. By\n * default it is a subfolder in targetPackageDir called \"isolate\" but you can\n * configure it.\n */\n packDestinationDir,\n}: {\n packagesRegistry: PackagesRegistry;\n internalPackageNames: string[];\n packDestinationDir: string;\n}) {\n const log = useLogger();\n\n const packedFileByName: Record<string, string> = {};\n\n const { name, version } = usePackageManager();\n\n const versionMajor = parseInt(version.split(\".\")[0], 10);\n\n const usePnpmPack = name === \"pnpm\" && versionMajor >= 8;\n\n if (usePnpmPack) {\n log.debug(\"Using PNPM pack instead of NPM pack\");\n }\n\n for (const dependency of internalPackageNames) {\n const def = packagesRegistry[dependency];\n\n assert(dependency, `Failed to find package definition for ${dependency}`);\n\n const { name } = def.manifest;\n\n /**\n * If this dependency has already been packed, we skip it. It could happen\n * because we are packing workspace dependencies recursively.\n */\n if (packedFileByName[name]) {\n log.debug(`Skipping ${name} because it has already been packed`);\n continue;\n }\n\n packedFileByName[name] = await pack(\n def.absoluteDir,\n packDestinationDir,\n usePnpmPack\n );\n }\n\n return packedFileByName;\n}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport { pack, unpack } from \"../utils\";\n\nconst TIMEOUT_MS = 5000;\n\nexport async function processBuildOutputFiles({\n targetPackageDir,\n tmpDir,\n isolateDir,\n}: {\n targetPackageDir: string;\n tmpDir: string;\n isolateDir: string;\n}) {\n const log = useLogger();\n const packedFilePath = await pack(targetPackageDir, tmpDir);\n const unpackDir = path.join(tmpDir, \"target\");\n\n const now = Date.now();\n let isWaitingYet = false;\n\n while (!fs.existsSync(packedFilePath) && Date.now() - now < TIMEOUT_MS) {\n if (!isWaitingYet) {\n log.debug(`Waiting for ${packedFilePath} to become available...`);\n }\n isWaitingYet = true;\n await new Promise((resolve) => setTimeout(resolve, 100));\n }\n\n await unpack(packedFilePath, unpackDir);\n await fs.copy(path.join(unpackDir, \"package\"), isolateDir);\n}\n","import fs from \"fs-extra\";\nimport path, { join } from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackagesRegistry } from \"../types\";\nimport { getIsolateRelativePath, unpack } from \"../utils\";\n\nexport async function unpackDependencies(\n packedFilesByName: Record<string, string>,\n packagesRegistry: PackagesRegistry,\n tmpDir: string,\n isolateDir: string\n) {\n const log = useLogger();\n\n await Promise.all(\n Object.entries(packedFilesByName).map(async ([packageName, filePath]) => {\n const dir = packagesRegistry[packageName].rootRelativeDir;\n const unpackDir = join(tmpDir, dir);\n\n log.debug(\"Unpacking\", `(temp)/${path.basename(filePath)}`);\n\n await unpack(filePath, unpackDir);\n\n const destinationDir = join(isolateDir, dir);\n\n await fs.ensureDir(destinationDir);\n\n await fs.move(join(unpackDir, \"package\"), destinationDir, {\n overwrite: true,\n });\n\n log.debug(\n `Moved package files to ${getIsolateRelativePath(\n destinationDir,\n isolateDir\n )}`\n );\n })\n );\n}\n","import fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { useLogger } from \"../logger\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\nimport { readTypedJson } from \"../utils\";\nimport { findPackagesGlobs } from \"./helpers/find-packages-globs\";\n\n/**\n * Build a list of all packages in the workspace, depending on the package\n * manager used, with a possible override from the config file. The list\n * contains the manifest with some directory info mapped by module name.\n */\nexport async function createPackagesRegistry(\n workspaceRootDir: string,\n workspacePackagesOverride: string[] | undefined\n): Promise<PackagesRegistry> {\n const log = useLogger();\n\n if (workspacePackagesOverride) {\n log.debug(\n `Override workspace packages via config: ${workspacePackagesOverride}`\n );\n }\n\n const packagesGlobs =\n workspacePackagesOverride ?? findPackagesGlobs(workspaceRootDir);\n\n const cwd = process.cwd();\n process.chdir(workspaceRootDir);\n\n const allPackages = packagesGlobs\n .flatMap((glob) => globSync(glob))\n /** Make sure to filter any loose files that might hang around. */\n .filter((dir) => fs.lstatSync(dir).isDirectory());\n\n const registry: PackagesRegistry = (\n await Promise.all(\n allPackages.map(async (rootRelativeDir) => {\n const manifestPath = path.join(rootRelativeDir, \"package.json\");\n\n if (!fs.existsSync(manifestPath)) {\n log.warn(\n `Ignoring directory ./${rootRelativeDir} because it does not contain a package.json file`\n );\n return;\n } else {\n log.debug(`Registering package ./${rootRelativeDir}`);\n\n const manifest = await readTypedJson<PackageManifest>(\n path.join(rootRelativeDir, \"package.json\")\n );\n\n return {\n manifest,\n rootRelativeDir,\n absoluteDir: path.join(workspaceRootDir, rootRelativeDir),\n };\n }\n })\n )\n ).reduce<PackagesRegistry>((acc, info) => {\n if (info) {\n acc[info.manifest.name] = info;\n }\n return acc;\n }, {});\n\n process.chdir(cwd);\n\n return registry;\n}\n","import assert from \"node:assert\";\nimport path from \"node:path\";\nimport { useLogger } from \"../../logger\";\nimport { usePackageManager } from \"../../package-manager\";\nimport {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n} from \"../../utils\";\n\n/**\n * Find the globs that define where the packages are located within the\n * monorepo. This configuration is dependent on the package manager used, and I\n * don't know if we're covering all cases yet...\n */\nexport function findPackagesGlobs(workspaceRootDir: string) {\n const log = useLogger();\n\n const packageManager = usePackageManager();\n\n switch (packageManager.name) {\n case \"pnpm\": {\n const { packages: globs } = readTypedYamlSync<{ packages: string[] }>(\n path.join(workspaceRootDir, \"pnpm-workspace.yaml\")\n );\n\n log.debug(\"Detected pnpm packages globs:\", inspectValue(globs));\n return globs;\n }\n case \"yarn\":\n case \"npm\": {\n const workspaceRootManifestPath = path.join(\n workspaceRootDir,\n \"package.json\"\n );\n\n const { workspaces } = readTypedJsonSync<{ workspaces: string[] }>(\n workspaceRootManifestPath\n );\n\n if (!workspaces) {\n throw new Error(\n `No workspaces field found in ${workspaceRootManifestPath}`\n );\n }\n\n if (Array.isArray(workspaces)) {\n return workspaces;\n } else {\n /**\n * For Yarn, workspaces could be defined as an object with { packages:\n * [], nohoist: [] }. See\n * https://classic.yarnpkg.com/blog/2018/02/15/nohoist/\n */\n const workspacesObject = workspaces as { packages?: string[] };\n\n assert(\n workspacesObject.packages,\n \"workspaces.packages must be an array\"\n );\n\n return workspacesObject.packages;\n }\n }\n }\n}\n","import { uniq } from \"remeda\";\nimport type { PackageManifest, PackagesRegistry } from \"../types\";\n\n/**\n * Recursively list all the packages from dependencies (and optionally\n * devDependencies) that are found in the monorepo.\n *\n * Here we do not need to rely on packages being declared with \"workspace:\" in\n * the package manifest. We can simply compare the package names with the list\n * of packages that were found via the workspace glob patterns and add them to\n * the registry.\n */\nexport function listInternalPackages(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n { includeDevDependencies = false } = {}\n): string[] {\n const allWorkspacePackageNames = Object.keys(packagesRegistry);\n\n const internalPackageNames = (\n includeDevDependencies\n ? [\n ...Object.keys(manifest.dependencies ?? {}),\n ...Object.keys(manifest.devDependencies ?? {}),\n ]\n : Object.keys(manifest.dependencies ?? {})\n ).filter((name) => allWorkspacePackageNames.includes(name));\n\n const nestedInternalPackageNames = internalPackageNames.flatMap(\n (packageName) =>\n listInternalPackages(\n packagesRegistry[packageName].manifest,\n packagesRegistry,\n { includeDevDependencies }\n )\n );\n\n return uniq(internalPackageNames.concat(nestedInternalPackageNames));\n}\n"],"mappings":"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","names":["console","fs","assert","path","fs","path","path","fs","stdout","fs","fs","fs","fs","path","fs","fs","path","fs","path","fs","assert","path","path","assert","fs","fs","path","path","fs","assert","path","assert","path","fs","execSync","path","path","fs","execSync","omit","pick","path","fs","path","path","fs","path","path","packageManager","path","packageManager","omit","pick","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","fs","path","assert","path","packageManager","path","assert","fs","path","path","assert","fs","packageManager","console"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "isolate-package",
3
- "version": "1.10.0-1",
3
+ "version": "1.10.0",
4
4
  "description": "Isolate a monorepo package with its shared dependencies to form a self-contained directory, compatible with Firebase deploy",
5
5
  "author": "Thijs Koerselman",
6
6
  "license": "MIT",
@@ -34,47 +34,47 @@
34
34
  "bin": {
35
35
  "isolate": "dist/isolate-bin.mjs"
36
36
  },
37
+ "scripts": {
38
+ "build": "tsup-node",
39
+ "build:watch": "tsup-node --watch",
40
+ "test": "vitest",
41
+ "format": "prettier --write .",
42
+ "lint:format": "prettier --check .",
43
+ "type-check": "tsc --noEmit",
44
+ "publish": "np --no-cleanup"
45
+ },
37
46
  "dependencies": {
38
- "@npmcli/arborist": "^7.2.1",
47
+ "@npmcli/arborist": "^7.3.1",
39
48
  "@pnpm/exec": "^2.0.0",
40
- "@pnpm/exportable-manifest": "^5.0.9",
41
- "@pnpm/lockfile-file": "^8.1.4",
49
+ "@pnpm/exportable-manifest": "^5.0.11",
50
+ "@pnpm/lockfile-file": "^8.1.6",
42
51
  "@pnpm/logger": "^5.0.0",
43
- "@pnpm/prune-lockfile": "^5.0.7",
44
- "@pnpm/read-project-manifest": "^5.0.8",
45
- "@pnpm/types": "^9.4.0",
46
- "chalk": "^5.2.0",
47
- "fs-extra": "^11.1.1",
48
- "glob": "^10.2.2",
52
+ "@pnpm/prune-lockfile": "^5.0.9",
53
+ "@pnpm/read-project-manifest": "^5.0.10",
54
+ "@pnpm/types": "^9.4.2",
55
+ "chalk": "^5.3.0",
56
+ "fs-extra": "^11.2.0",
57
+ "glob": "^10.3.10",
49
58
  "outdent": "^0.8.0",
50
- "ramda": "^0.29.1",
51
- "rename-overwrite": "^4.0.4",
59
+ "remeda": "^1.40.1",
60
+ "rename-overwrite": "^5.0.0",
52
61
  "source-map-support": "^0.5.21",
53
62
  "strip-json-comments": "^5.0.1",
54
- "tar-fs": "^2.1.1",
55
- "type-fest": "^4.8.2",
56
- "yaml": "^2.2.2"
63
+ "tar-fs": "^3.0.5",
64
+ "type-fest": "^4.10.2",
65
+ "yaml": "^2.3.4"
57
66
  },
58
67
  "devDependencies": {
59
- "@types/fs-extra": "^11.0.1",
60
- "@types/lodash-es": "^4.17.7",
61
- "@types/node": "^18.16.2",
62
- "@types/ramda": "^0.29.9",
63
- "@types/source-map-support": "^0.5.6",
64
- "@types/tar-fs": "^2.0.1",
68
+ "@types/fs-extra": "^11.0.4",
69
+ "@types/lodash-es": "^4.17.12",
70
+ "@types/node": "^20.11.17",
71
+ "@types/source-map-support": "^0.5.10",
72
+ "@types/tar-fs": "^2.0.4",
65
73
  "eslint-config-0x80": "^0.0.0",
66
- "prettier": "^3.0.0",
67
- "prettier-plugin-jsdoc": "^1.1.1",
68
- "tsup": "^6.7.0",
69
- "typescript": "^5.0.4",
70
- "vitest": "^0.30.1"
71
- },
72
- "scripts": {
73
- "build": "tsup-node",
74
- "dev": "tsup-node --watch",
75
- "test": "vitest",
76
- "format": "prettier --write .",
77
- "lint:format": "prettier --check .",
78
- "type-check": "tsc --noEmit"
74
+ "prettier": "^3.2.5",
75
+ "prettier-plugin-jsdoc": "^1.3.0",
76
+ "tsup": "^8.0.2",
77
+ "typescript": "^5.3.3",
78
+ "vitest": "^1.2.2"
79
79
  }
80
- }
80
+ }