isolate-package 1.6.0 → 1.6.2-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
@@ -46,8 +46,8 @@ that includes internal dependencies and a compatible lockfile.
46
46
  - Isolate a monorepo package with its internal dependencies to form a
47
47
  self-contained installable package.
48
48
  - Deterministic deployment by generating an isolated lockfile based on the
49
- existing monorepo lockfile. Currently this feature is only supported for PNPM.
50
- See [lockfiles](#lockfiles) for more information.
49
+ existing monorepo lockfile. Currently this feature is only supported for NPM
50
+ and PNPM. See [lockfiles](#lockfiles) for more information.
51
51
  - Zero-config for the vast majority of use-cases, with no manual steps involved.
52
52
  - Support for PNPM, NPM and Yarn.
53
53
  - Compatible with the Firebase tools CLI, incl 1st gen and 2nd gen Firebase
@@ -337,12 +337,11 @@ Type: `boolean`, default: Depends on package manager.
337
337
 
338
338
  Sets the inclusion or exclusion of the lockfile as part of the deployment.
339
339
 
340
- PNPM lockfiles are regenerated based on the isolated output, so they are
341
- included by default.
340
+ Isolated NPM and PNPM lockfiles are generated based on the existing root
341
+ lockfile, and they are included by default.
342
342
 
343
- For NPM and Yarn the lockfiles are excluded by default because they are
344
- currently copied as-is to the isolate output and can lead to issues during
345
- deployment installs. For more information see [lockfiles](#lockfiles).
343
+ The lockfile for Yarn is excluded by default. For more information see
344
+ [lockfiles](#lockfiles).
346
345
 
347
346
  ### includeDevDependencies
348
347
 
@@ -443,9 +442,6 @@ isolate process manually with `npx isolate` and possibly
443
442
 
444
443
  ## Lockfiles
445
444
 
446
- Deploying the isolated code together with a valid lockfile turned out to be the
447
- biggest challenge of this solution.
448
-
449
445
  A lockfile in a monorepo describes the dependencies of all packages, and does
450
446
  not necessarily translate to the isolated output without altering it. Different
451
447
  package managers use very different formats, and it might not be enough to do a
@@ -458,28 +454,15 @@ it would negate the whole point of having a lockfile in the first place.
458
454
  What we need is to re-generate a lockfile for the isolated output based on the
459
455
  versions that are currently installed and locked in the monorepo lockfile.
460
456
 
461
- ### PNPM
462
-
463
- For PNPM a new isolated lockfile is generated.
464
-
465
- ### NPM
457
+ ### NPM and PNPM
466
458
 
467
- For now, NPM lockfiles are simply copied over to the isolated output. I have
468
- seen Firebase deployments work with it, but likely you are going to run into an
469
- error like this:
459
+ For NPM and PNPM a lockfile is generated and included in the isolated output.
470
460
 
471
- > `npm ci` can only install packages when your package.json and
472
- > package-lock.json or npm-shrinkwrap.json are in sync. Please update your lock
473
- > file with `npm install` before continuing.
474
-
475
- If you experience this issue, you can choose to exclude the lockfile from
476
- deployment by setting `"excludeLockfile": false` in your isolate.config.json
477
- file, or make the move to PNPM (recommended).
461
+ @TODO write about how it works an how we got there.
478
462
 
479
- A real solution, regenerating an isolated lockfile, should be possible based on
480
- the
481
- [NPM CLI Arborist](https://github.com/npm/cli/tree/latest/workspaces/arborist)
482
- code, so I plan to look into that in the near future.
463
+ If you do somehow run into a problem related to the lockfile, you can opt-out of
464
+ this by setting `excludeLockfile: true` in the `isolate.config.json`
465
+ configuration file.
483
466
 
484
467
  ### Yarn
485
468
 
@@ -494,16 +477,16 @@ file, or make the move to PNPM (recommended).
494
477
  I am not aware of any code in the official Yarn repository for re-generating a
495
478
  lockfile, and I am reluctant to work on this feature based on user-land code.
496
479
 
497
- Personally, I do not think Yarn is very relevant anymore in 2023 and I recommend
498
- switching to PNPM.
480
+ Personally, I do not think Yarn is very relevant anymore in 2023 and I
481
+ personally recommend switching to PNPM.
499
482
 
500
483
  ### A Partial Workaround
501
484
 
502
- If you can not use a lockfile, because you depend on NPM or Yarn, a partial
503
- workaround would be to declare dependencies using exact versions in your package
504
- manifest. This doesn't prevent your dependencies-dependencies from installing
505
- newer versions, like a lockfile would, but at least you minimize the risk of
506
- things breaking.
485
+ If you can not use a lockfile, because you depend on Yarn, a partial workaround
486
+ would be to declare dependencies using exact versions in your package manifest.
487
+ This doesn't prevent your dependencies-dependencies from installing newer
488
+ versions, like a lockfile would, but at least you minimize the risk of things
489
+ breaking.
507
490
 
508
491
  ## Different Package Managers
509
492
 
package/dist/index.mjs CHANGED
@@ -348,7 +348,7 @@ async function generateNpmLockfile({
348
348
  const internalPackageNames = Object.keys(packagesRegistry);
349
349
  const arborist = new Arborist({ path: targetPackageDir });
350
350
  const { meta } = await arborist.buildIdealTree({
351
- rm: internalPackageNames
351
+ // rm: internalPackageNames,
352
352
  });
353
353
  meta?.commit();
354
354
  const lockfilePath = path4.join(isolateDir, "package-lock.json");
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/isolate.ts","../src/helpers/adapt-internal-package-manifests.ts","../src/helpers/adapt-manifest-internal-deps.ts","../src/utils/filter-object-undefined.ts","../src/utils/get-dirname.ts","../src/utils/get-error-message.ts","../src/utils/get-relative-path.ts","../src/utils/inspect-value.ts","../src/utils/is-present.ts","../src/utils/json.ts","../src/utils/logger.ts","../src/utils/pack.ts","../src/utils/unpack.ts","../src/utils/yaml.ts","../src/helpers/patch-internal-entries.ts","../src/helpers/config.ts","../src/helpers/detect-package-manager.ts","../src/helpers/process-lockfile.ts","../src/helpers/generate-npm-lockfile.ts","../src/helpers/generate-pnpm-lockfile.ts","../src/helpers/adapt-target-package-manifest.ts","../src/helpers/create-packages-registry.ts","../src/helpers/find-packages-globs.ts","../src/helpers/get-build-output-dir.ts","../src/helpers/list-internal-packages.ts","../src/helpers/pack-dependencies.ts","../src/helpers/process-build-output-files.ts","../src/helpers/unpack-dependencies.ts"],"sourcesContent":["import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { adaptInternalPackageManifests } from \"./helpers/adapt-internal-package-manifests\";\nimport { adaptTargetPackageManifest } from \"./helpers/adapt-target-package-manifest\";\nimport type { IsolateConfig } from \"./helpers/config\";\nimport {\n getUserDefinedConfig,\n resolveConfig,\n setUserConfig,\n} from \"./helpers/config\";\nimport {\n createPackagesRegistry,\n type PackageManifest,\n} from \"./helpers/create-packages-registry\";\nimport { detectPackageManager } from \"./helpers/detect-package-manager\";\nimport { getBuildOutputDir } from \"./helpers/get-build-output-dir\";\nimport { listInternalPackages } from \"./helpers/list-internal-packages\";\nimport { packDependencies } from \"./helpers/pack-dependencies\";\nimport { processBuildOutputFiles } from \"./helpers/process-build-output-files\";\nimport { processLockfile } from \"./helpers/process-lockfile\";\nimport { unpackDependencies } from \"./helpers/unpack-dependencies\";\nimport type { Logger } from \"./utils\";\nimport {\n getDirname,\n getRootRelativePath,\n isDefined,\n readTypedJson,\n setLogLevel,\n setLogger,\n useLogger,\n} from \"./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 const userDefinedConfig = getUserDefinedConfig();\n\n /**\n * If the user has not explicitly set the excludeLockfile option, we will\n * exclude the lockfile for Yarn, because we still need to figure out how to\n * generate the isolated lockfile for it.\n */\n if (!isDefined(userDefinedConfig.excludeLockfile)) {\n if (packageManager.name === \"yarn\") {\n config.excludeLockfile = true;\n }\n }\n\n if (config.excludeLockfile) {\n log.warn(\"Excluding the lockfile from the isolate output\");\n } else {\n /** Copy and adapt the lockfile */\n await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n }\n\n if (packageManager.name === \"pnpm\") {\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\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 path from \"node:path\";\nimport { omit } from \"ramda\";\nimport type { PackagesRegistry } from \"../helpers/create-packages-registry\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(\n /**\n * For internal dependencies we want to omit the peerDependencies,\n * because installing these is the responsibility of the consuming\n * app / service, and otherwise the frozen lockfile install will\n * error since the package file contains something that is not\n * referenced in the lockfile.\n */\n omit([\"devDependencies\", \"peerDependencies\"], manifest),\n {\n dependencies: manifest.dependencies,\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n }\n )\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, rootRelativeDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n })\n );\n}\n","import { omit } from \"ramda\";\nimport { filterObjectUndefined } from \"../utils\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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 {\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n }: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n },\n opts: { includeDevDependencies?: boolean } = {}\n): PackageManifest {\n return Object.assign(\n omit([\"devDependencies\"], manifest),\n filterObjectUndefined({\n dependencies: manifest.dependencies\n ? patchInternalEntries(\n manifest.dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies:\n opts.includeDevDependencies && manifest.devDependencies\n ? patchInternalEntries(\n manifest.devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n })\n );\n}\n","export function filterObjectUndefined(object: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(object).filter(([_, value]) => value !== undefined)\n );\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, 4, true);\n}\n","/** Copied from ts-is-present */\nexport function isPresent<T>(t: T | undefined | null | void): t is T {\n return t !== undefined && t !== null;\n}\n\nexport function isDefined<T>(t: T | undefined): t is T {\n return t !== undefined;\n}\n\nexport function isFilled<T>(t: T | null): t is T {\n return t !== null;\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 chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"../helpers/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 fs from \"fs-extra\";\nimport { exec } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"./logger\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack = false\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(stderr);\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 path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport {\n inspectValue,\n readTypedJsonSync,\n setLogLevel,\n useLogger,\n} from \"../utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n excludeLockfile: boolean;\n avoidPnpmPack: boolean;\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n excludeLockfile: false,\n avoidPnpmPack: false,\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { readTypedJsonSync, useLogger } from \"../utils\";\nimport type { PackageManifest } from \"./create-packages-registry\";\nimport { getLockfileFileName } from \"./process-lockfile\";\n\nconst 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\nlet packageManager: PackageManager | undefined;\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\nfunction 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\nfunction 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\nfunction getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\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","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport type { PackageManagerName } from \"./detect-package-manager\";\nimport { usePackageManager } from \"./detect-package-manager\";\nimport { generateNpmLockfile } from \"./generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./generate-pnpm-lockfile\";\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\n/** Convert dependency links */\nexport function pnpmMapImporter(\n { dependencies, devDependencies, ...rest }: ProjectSnapshot,\n {\n includeDevDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: 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 ...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 { name } = usePackageManager();\n\n const fileName = getLockfileFileName(name);\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n targetPackageDir,\n isolateDir,\n packagesRegistry,\n });\n\n break;\n }\n case \"yarn\": {\n const lockfileSrcPath = path.join(workspaceRootDir, fileName);\n const lockfileDstPath = path.join(isolateDir, fileName);\n\n fs.copyFileSync(lockfileSrcPath, lockfileDstPath);\n log.debug(\"Copied lockfile to\", lockfileDstPath);\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}`);\n }\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\n\n/**\n * This code is probably not working yet. It should eventually do something\n * similar to generatePnpmLockfile, but my NPM install is giving me\n * non-descriptive errors and my patience and time for now is running out...\n */\nexport async function generateNpmLockfile({\n targetPackageDir,\n packagesRegistry,\n isolateDir,\n}: {\n targetPackageDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.debug(\"Generating NPM lockfile...\");\n\n const internalPackageNames = Object.keys(packagesRegistry);\n\n const arborist = new Arborist({ path: targetPackageDir });\n\n const { meta } = await arborist.buildIdealTree({\n rm: internalPackageNames,\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}\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 { useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 } = useConfig();\n const log = useLogger();\n\n log.debug(\"Generating PNPM lockfile...\");\n\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 directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\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}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\n\n/**\n * Change the target package manifest file, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - DevDependencies are possibly removed\n * - Scripts are possibly removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies } = useConfig();\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(omit([\"devDependencies\", \"scripts\"], manifest), {\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n })\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n}\n","import type { PackageManifest as PnpmPackageManifest } from \"@pnpm/types\";\nimport fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { findPackagesGlobs } from \"./find-packages-globs\";\n\nexport type PackageManifest = PnpmPackageManifest & {\n packageManager?: string;\n};\n\nexport type WorkspacePackageInfo = {\n absoluteDir: string;\n /**\n * The path of the package relative to the workspace root. This is the path\n * referenced in the lock file.\n */\n rootRelativeDir: string;\n /** The package.json file contents */\n manifest: PackageManifest;\n};\n\nexport type PackagesRegistry = Record<string, WorkspacePackageInfo>;\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 {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n useLogger,\n} from \"../utils\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\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 { uniq } from \"ramda\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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","import assert from \"node:assert\";\nimport { pack, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 config = useConfig();\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 =\n !config.avoidPnpmPack && 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 { pack, unpack, useLogger } 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 { getIsolateRelativePath, useLogger } from \"../utils\";\nimport { unpack } from \"../utils/unpack\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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"],"mappings":"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","names":["fs","assert","path","fs","path","omit","path","fs","stdout","fs","fs","fs","fs","path","path","fs","path","path","fs","fs","assert","path","fs","path","fs","path","path","fs","assert","path","assert","path","path","fs","path","assert","fs","packageManager","omit","fs","path","fs","path","omit","packageManager","omit","fs","path","fs","path","assert","path","packageManager","path","assert","fs","path","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","path","assert","fs","packageManager"]}
1
+ {"version":3,"sources":["../src/isolate.ts","../src/helpers/adapt-internal-package-manifests.ts","../src/helpers/adapt-manifest-internal-deps.ts","../src/utils/filter-object-undefined.ts","../src/utils/get-dirname.ts","../src/utils/get-error-message.ts","../src/utils/get-relative-path.ts","../src/utils/inspect-value.ts","../src/utils/is-present.ts","../src/utils/json.ts","../src/utils/logger.ts","../src/utils/pack.ts","../src/utils/unpack.ts","../src/utils/yaml.ts","../src/helpers/patch-internal-entries.ts","../src/helpers/config.ts","../src/helpers/detect-package-manager.ts","../src/helpers/process-lockfile.ts","../src/helpers/generate-npm-lockfile.ts","../src/helpers/generate-pnpm-lockfile.ts","../src/helpers/adapt-target-package-manifest.ts","../src/helpers/create-packages-registry.ts","../src/helpers/find-packages-globs.ts","../src/helpers/get-build-output-dir.ts","../src/helpers/list-internal-packages.ts","../src/helpers/pack-dependencies.ts","../src/helpers/process-build-output-files.ts","../src/helpers/unpack-dependencies.ts"],"sourcesContent":["import fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { adaptInternalPackageManifests } from \"./helpers/adapt-internal-package-manifests\";\nimport { adaptTargetPackageManifest } from \"./helpers/adapt-target-package-manifest\";\nimport type { IsolateConfig } from \"./helpers/config\";\nimport {\n getUserDefinedConfig,\n resolveConfig,\n setUserConfig,\n} from \"./helpers/config\";\nimport {\n createPackagesRegistry,\n type PackageManifest,\n} from \"./helpers/create-packages-registry\";\nimport { detectPackageManager } from \"./helpers/detect-package-manager\";\nimport { getBuildOutputDir } from \"./helpers/get-build-output-dir\";\nimport { listInternalPackages } from \"./helpers/list-internal-packages\";\nimport { packDependencies } from \"./helpers/pack-dependencies\";\nimport { processBuildOutputFiles } from \"./helpers/process-build-output-files\";\nimport { processLockfile } from \"./helpers/process-lockfile\";\nimport { unpackDependencies } from \"./helpers/unpack-dependencies\";\nimport type { Logger } from \"./utils\";\nimport {\n getDirname,\n getRootRelativePath,\n isDefined,\n readTypedJson,\n setLogLevel,\n setLogger,\n useLogger,\n} from \"./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 const userDefinedConfig = getUserDefinedConfig();\n\n /**\n * If the user has not explicitly set the excludeLockfile option, we will\n * exclude the lockfile for Yarn, because we still need to figure out how to\n * generate the isolated lockfile for it.\n */\n if (!isDefined(userDefinedConfig.excludeLockfile)) {\n if (packageManager.name === \"yarn\") {\n config.excludeLockfile = true;\n }\n }\n\n if (config.excludeLockfile) {\n log.warn(\"Excluding the lockfile from the isolate output\");\n } else {\n /** Copy and adapt the lockfile */\n await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n }\n\n if (packageManager.name === \"pnpm\") {\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\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 path from \"node:path\";\nimport { omit } from \"ramda\";\nimport type { PackagesRegistry } from \"../helpers/create-packages-registry\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(\n /**\n * For internal dependencies we want to omit the peerDependencies,\n * because installing these is the responsibility of the consuming\n * app / service, and otherwise the frozen lockfile install will\n * error since the package file contains something that is not\n * referenced in the lockfile.\n */\n omit([\"devDependencies\", \"peerDependencies\"], manifest),\n {\n dependencies: manifest.dependencies,\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n }\n )\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, rootRelativeDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n })\n );\n}\n","import { omit } from \"ramda\";\nimport { filterObjectUndefined } from \"../utils\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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 {\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n }: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n },\n opts: { includeDevDependencies?: boolean } = {}\n): PackageManifest {\n return Object.assign(\n omit([\"devDependencies\"], manifest),\n filterObjectUndefined({\n dependencies: manifest.dependencies\n ? patchInternalEntries(\n manifest.dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies:\n opts.includeDevDependencies && manifest.devDependencies\n ? patchInternalEntries(\n manifest.devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n })\n );\n}\n","export function filterObjectUndefined(object: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(object).filter(([_, value]) => value !== undefined)\n );\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, 4, true);\n}\n","/** Copied from ts-is-present */\nexport function isPresent<T>(t: T | undefined | null | void): t is T {\n return t !== undefined && t !== null;\n}\n\nexport function isDefined<T>(t: T | undefined): t is T {\n return t !== undefined;\n}\n\nexport function isFilled<T>(t: T | null): t is T {\n return t !== null;\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 chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"../helpers/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 fs from \"fs-extra\";\nimport { exec } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"./logger\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack = false\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(stderr);\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 path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport {\n inspectValue,\n readTypedJsonSync,\n setLogLevel,\n useLogger,\n} from \"../utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n excludeLockfile: boolean;\n avoidPnpmPack: boolean;\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n excludeLockfile: false,\n avoidPnpmPack: false,\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { readTypedJsonSync, useLogger } from \"../utils\";\nimport type { PackageManifest } from \"./create-packages-registry\";\nimport { getLockfileFileName } from \"./process-lockfile\";\n\nconst 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\nlet packageManager: PackageManager | undefined;\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\nfunction 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\nfunction 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\nfunction getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\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","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport type { PackageManagerName } from \"./detect-package-manager\";\nimport { usePackageManager } from \"./detect-package-manager\";\nimport { generateNpmLockfile } from \"./generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./generate-pnpm-lockfile\";\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\n/** Convert dependency links */\nexport function pnpmMapImporter(\n { dependencies, devDependencies, ...rest }: ProjectSnapshot,\n {\n includeDevDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: 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 ...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 { name } = usePackageManager();\n\n const fileName = getLockfileFileName(name);\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n targetPackageDir,\n isolateDir,\n packagesRegistry,\n });\n\n break;\n }\n case \"yarn\": {\n const lockfileSrcPath = path.join(workspaceRootDir, fileName);\n const lockfileDstPath = path.join(isolateDir, fileName);\n\n fs.copyFileSync(lockfileSrcPath, lockfileDstPath);\n log.debug(\"Copied lockfile to\", lockfileDstPath);\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}`);\n }\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\n\n/**\n * This code is probably not working yet. It should eventually do something\n * similar to generatePnpmLockfile, but my NPM install is giving me\n * non-descriptive errors and my patience and time for now is running out...\n */\nexport async function generateNpmLockfile({\n targetPackageDir,\n packagesRegistry,\n isolateDir,\n}: {\n targetPackageDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.debug(\"Generating NPM lockfile...\");\n\n const internalPackageNames = Object.keys(packagesRegistry);\n\n const arborist = new Arborist({ path: targetPackageDir });\n\n const { meta } = await arborist.buildIdealTree({\n // rm: internalPackageNames,\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}\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 { useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 } = useConfig();\n const log = useLogger();\n\n log.debug(\"Generating PNPM lockfile...\");\n\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 directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\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}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\n\n/**\n * Change the target package manifest file, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - DevDependencies are possibly removed\n * - Scripts are possibly removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies } = useConfig();\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(omit([\"devDependencies\", \"scripts\"], manifest), {\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n })\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n}\n","import type { PackageManifest as PnpmPackageManifest } from \"@pnpm/types\";\nimport fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { findPackagesGlobs } from \"./find-packages-globs\";\n\nexport type PackageManifest = PnpmPackageManifest & {\n packageManager?: string;\n};\n\nexport type WorkspacePackageInfo = {\n absoluteDir: string;\n /**\n * The path of the package relative to the workspace root. This is the path\n * referenced in the lock file.\n */\n rootRelativeDir: string;\n /** The package.json file contents */\n manifest: PackageManifest;\n};\n\nexport type PackagesRegistry = Record<string, WorkspacePackageInfo>;\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 {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n useLogger,\n} from \"../utils\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\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 { uniq } from \"ramda\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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","import assert from \"node:assert\";\nimport { pack, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 config = useConfig();\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 =\n !config.avoidPnpmPack && 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 { pack, unpack, useLogger } 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 { getIsolateRelativePath, useLogger } from \"../utils\";\nimport { unpack } from \"../utils/unpack\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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"],"mappings":"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","names":["fs","assert","path","fs","path","omit","path","fs","stdout","fs","fs","fs","fs","path","path","fs","path","path","fs","fs","assert","path","fs","path","fs","path","path","fs","assert","path","assert","path","path","fs","path","assert","fs","packageManager","omit","fs","path","fs","path","omit","packageManager","omit","fs","path","fs","path","assert","path","packageManager","path","assert","fs","path","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","path","assert","fs","packageManager"]}
@@ -354,7 +354,7 @@ async function generateNpmLockfile({
354
354
  const internalPackageNames = Object.keys(packagesRegistry);
355
355
  const arborist = new Arborist({ path: targetPackageDir });
356
356
  const { meta } = await arborist.buildIdealTree({
357
- rm: internalPackageNames
357
+ // rm: internalPackageNames,
358
358
  });
359
359
  meta?.commit();
360
360
  const lockfilePath = path4.join(isolateDir, "package-lock.json");
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/isolate-bin.ts","../src/isolate.ts","../src/helpers/adapt-internal-package-manifests.ts","../src/helpers/adapt-manifest-internal-deps.ts","../src/utils/filter-object-undefined.ts","../src/utils/get-dirname.ts","../src/utils/get-error-message.ts","../src/utils/get-relative-path.ts","../src/utils/inspect-value.ts","../src/utils/is-present.ts","../src/utils/json.ts","../src/utils/logger.ts","../src/utils/pack.ts","../src/utils/unpack.ts","../src/utils/yaml.ts","../src/helpers/patch-internal-entries.ts","../src/helpers/config.ts","../src/helpers/detect-package-manager.ts","../src/helpers/process-lockfile.ts","../src/helpers/generate-npm-lockfile.ts","../src/helpers/generate-pnpm-lockfile.ts","../src/helpers/adapt-target-package-manifest.ts","../src/helpers/create-packages-registry.ts","../src/helpers/find-packages-globs.ts","../src/helpers/get-build-output-dir.ts","../src/helpers/list-internal-packages.ts","../src/helpers/pack-dependencies.ts","../src/helpers/process-build-output-files.ts","../src/helpers/unpack-dependencies.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 { adaptInternalPackageManifests } from \"./helpers/adapt-internal-package-manifests\";\nimport { adaptTargetPackageManifest } from \"./helpers/adapt-target-package-manifest\";\nimport type { IsolateConfig } from \"./helpers/config\";\nimport {\n getUserDefinedConfig,\n resolveConfig,\n setUserConfig,\n} from \"./helpers/config\";\nimport {\n createPackagesRegistry,\n type PackageManifest,\n} from \"./helpers/create-packages-registry\";\nimport { detectPackageManager } from \"./helpers/detect-package-manager\";\nimport { getBuildOutputDir } from \"./helpers/get-build-output-dir\";\nimport { listInternalPackages } from \"./helpers/list-internal-packages\";\nimport { packDependencies } from \"./helpers/pack-dependencies\";\nimport { processBuildOutputFiles } from \"./helpers/process-build-output-files\";\nimport { processLockfile } from \"./helpers/process-lockfile\";\nimport { unpackDependencies } from \"./helpers/unpack-dependencies\";\nimport type { Logger } from \"./utils\";\nimport {\n getDirname,\n getRootRelativePath,\n isDefined,\n readTypedJson,\n setLogLevel,\n setLogger,\n useLogger,\n} from \"./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 const userDefinedConfig = getUserDefinedConfig();\n\n /**\n * If the user has not explicitly set the excludeLockfile option, we will\n * exclude the lockfile for Yarn, because we still need to figure out how to\n * generate the isolated lockfile for it.\n */\n if (!isDefined(userDefinedConfig.excludeLockfile)) {\n if (packageManager.name === \"yarn\") {\n config.excludeLockfile = true;\n }\n }\n\n if (config.excludeLockfile) {\n log.warn(\"Excluding the lockfile from the isolate output\");\n } else {\n /** Copy and adapt the lockfile */\n await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n }\n\n if (packageManager.name === \"pnpm\") {\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\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 path from \"node:path\";\nimport { omit } from \"ramda\";\nimport type { PackagesRegistry } from \"../helpers/create-packages-registry\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(\n /**\n * For internal dependencies we want to omit the peerDependencies,\n * because installing these is the responsibility of the consuming\n * app / service, and otherwise the frozen lockfile install will\n * error since the package file contains something that is not\n * referenced in the lockfile.\n */\n omit([\"devDependencies\", \"peerDependencies\"], manifest),\n {\n dependencies: manifest.dependencies,\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n }\n )\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, rootRelativeDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n })\n );\n}\n","import { omit } from \"ramda\";\nimport { filterObjectUndefined } from \"../utils\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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 {\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n }: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n },\n opts: { includeDevDependencies?: boolean } = {}\n): PackageManifest {\n return Object.assign(\n omit([\"devDependencies\"], manifest),\n filterObjectUndefined({\n dependencies: manifest.dependencies\n ? patchInternalEntries(\n manifest.dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies:\n opts.includeDevDependencies && manifest.devDependencies\n ? patchInternalEntries(\n manifest.devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n })\n );\n}\n","export function filterObjectUndefined(object: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(object).filter(([_, value]) => value !== undefined)\n );\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, 4, true);\n}\n","/** Copied from ts-is-present */\nexport function isPresent<T>(t: T | undefined | null | void): t is T {\n return t !== undefined && t !== null;\n}\n\nexport function isDefined<T>(t: T | undefined): t is T {\n return t !== undefined;\n}\n\nexport function isFilled<T>(t: T | null): t is T {\n return t !== null;\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 chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"../helpers/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 fs from \"fs-extra\";\nimport { exec } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"./logger\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack = false\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(stderr);\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 path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport {\n inspectValue,\n readTypedJsonSync,\n setLogLevel,\n useLogger,\n} from \"../utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n excludeLockfile: boolean;\n avoidPnpmPack: boolean;\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n excludeLockfile: false,\n avoidPnpmPack: false,\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { readTypedJsonSync, useLogger } from \"../utils\";\nimport type { PackageManifest } from \"./create-packages-registry\";\nimport { getLockfileFileName } from \"./process-lockfile\";\n\nconst 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\nlet packageManager: PackageManager | undefined;\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\nfunction 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\nfunction 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\nfunction getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\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","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport type { PackageManagerName } from \"./detect-package-manager\";\nimport { usePackageManager } from \"./detect-package-manager\";\nimport { generateNpmLockfile } from \"./generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./generate-pnpm-lockfile\";\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\n/** Convert dependency links */\nexport function pnpmMapImporter(\n { dependencies, devDependencies, ...rest }: ProjectSnapshot,\n {\n includeDevDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: 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 ...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 { name } = usePackageManager();\n\n const fileName = getLockfileFileName(name);\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n targetPackageDir,\n isolateDir,\n packagesRegistry,\n });\n\n break;\n }\n case \"yarn\": {\n const lockfileSrcPath = path.join(workspaceRootDir, fileName);\n const lockfileDstPath = path.join(isolateDir, fileName);\n\n fs.copyFileSync(lockfileSrcPath, lockfileDstPath);\n log.debug(\"Copied lockfile to\", lockfileDstPath);\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}`);\n }\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\n\n/**\n * This code is probably not working yet. It should eventually do something\n * similar to generatePnpmLockfile, but my NPM install is giving me\n * non-descriptive errors and my patience and time for now is running out...\n */\nexport async function generateNpmLockfile({\n targetPackageDir,\n packagesRegistry,\n isolateDir,\n}: {\n targetPackageDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.debug(\"Generating NPM lockfile...\");\n\n const internalPackageNames = Object.keys(packagesRegistry);\n\n const arborist = new Arborist({ path: targetPackageDir });\n\n const { meta } = await arborist.buildIdealTree({\n rm: internalPackageNames,\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}\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 { useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 } = useConfig();\n const log = useLogger();\n\n log.debug(\"Generating PNPM lockfile...\");\n\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 directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\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}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\n\n/**\n * Change the target package manifest file, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - DevDependencies are possibly removed\n * - Scripts are possibly removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies } = useConfig();\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(omit([\"devDependencies\", \"scripts\"], manifest), {\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n })\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n}\n","import type { PackageManifest as PnpmPackageManifest } from \"@pnpm/types\";\nimport fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { findPackagesGlobs } from \"./find-packages-globs\";\n\nexport type PackageManifest = PnpmPackageManifest & {\n packageManager?: string;\n};\n\nexport type WorkspacePackageInfo = {\n absoluteDir: string;\n /**\n * The path of the package relative to the workspace root. This is the path\n * referenced in the lock file.\n */\n rootRelativeDir: string;\n /** The package.json file contents */\n manifest: PackageManifest;\n};\n\nexport type PackagesRegistry = Record<string, WorkspacePackageInfo>;\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 {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n useLogger,\n} from \"../utils\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\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 { uniq } from \"ramda\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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","import assert from \"node:assert\";\nimport { pack, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 config = useConfig();\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 =\n !config.avoidPnpmPack && 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 { pack, unpack, useLogger } 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 { getIsolateRelativePath, useLogger } from \"../utils\";\nimport { unpack } from \"../utils/unpack\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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"],"mappings":";;;AACA,OAAOA,cAAa;AACpB,OAAO,gBAAgB;;;ACFvB,OAAOC,UAAQ;AACf,OAAOC,aAAY;AACnB,OAAOC,YAAU;;;ACFjB,OAAOC,SAAQ;AACf,OAAOC,WAAU;AACjB,SAAS,QAAAC,aAAY;;;ACFrB,SAAS,YAAY;;;ACAd,SAAS,sBAAsB,QAAiC;AACrE,SAAO,OAAO;AAAA,IACZ,OAAO,QAAQ,MAAM,EAAE,OAAO,CAAC,CAAC,GAAG,KAAK,MAAM,UAAU,MAAS;AAAA,EACnE;AACF;;;ACJA,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,QAAE;AAKA,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,iBACT,UAAU;AAChB;AAEO,SAAS,uBAAuBA,QAAc,aAAqB;AACxE,QAAM,eAAeA,OAAK,QAAQ,aAAa,EAAE;AAEjD,SAAO,aAAa,WAAW,GAAG,IAC9B,YAAY,iBACZ,aAAa;AACnB;;;ACdA,SAAS,eAAe;AAGjB,SAAS,aAAa,OAAkB;AAC7C,SAAO,QAAQ,OAAO,OAAO,GAAG,IAAI;AACtC;;;ACAO,SAAS,UAAa,GAA0B;AACrD,SAAO,MAAM;AACf;;;ACPA,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,KAAP;AACA,UAAM,IAAI;AAAA,MACR,4BAA4B,aAAa,gBAAgB,GAAG;AAAA,IAC9D;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,KAAP;AACA,UAAM,IAAI;AAAA,MACR,4BAA4B,aAAa,gBAAgB,GAAG;AAAA,IAC9D;AAAA,EACF;AACF;;;AC3BA,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,OAAOC,SAAQ;AACf,SAAS,YAAY;AACrB,OAAO,UAAU;AAGjB,eAAsB,KACpB,QACA,QACA,cAAc,OACd;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,gCAAgC;AAAA,MAChC;AAAA,MACA,CAAC,KAAKC,SAAQ,WAAW;AACvB,YAAI,KAAK;AACP,cAAI,MAAM,MAAM;AAChB,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,+BAA+B;AAAA,MAC/B;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;AAAA,IACvE;AAAA,EACF,OAAO;AACL,QAAI,MAAM,iBAAiB,UAAU;AAAA,EACvC;AAEA,UAAQ,MAAM,WAAW;AAOzB,SAAO;AACT;;;ACxEA,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,KAAP;AACA,UAAM,IAAI;AAAA,MACR,4BAA4B,aAAa,gBAAgB,GAAG;AAAA,IAC9D;AAAA,EACF;AACF;;;ACfA,OAAOC,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,iBAAiB,IAC/D,KAAK,IAAI;AAEb,cAAM,WAAW,QAAQ;AAEzB,YAAI,MAAM,sBAAsB,UAAU,UAAU;AAEpD,eAAO,CAAC,KAAK,QAAQ;AAAA,MACvB,OAAO;AACL,eAAO,CAAC,KAAK,KAAK;AAAA,MACpB;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;AZ3BO,SAAS,0BACd;AAAA,EACE;AAAA,EACA;AAAA,EACA;AACF,GAKA,OAA6C,CAAC,GAC7B;AACjB,SAAO,OAAO;AAAA,IACZ,KAAK,CAAC,iBAAiB,GAAG,QAAQ;AAAA,IAClC,sBAAsB;AAAA,MACpB,cAAc,SAAS,eACnB;AAAA,QACE,SAAS;AAAA,QACT;AAAA,QACA;AAAA,MACF,IACA;AAAA,MACJ,iBACE,KAAK,0BAA0B,SAAS,kBACpC;AAAA,QACE,SAAS;AAAA,QACT;AAAA,QACA;AAAA,MACF,IACA;AAAA,IACR,CAAC;AAAA,EACH;AACF;;;Aa7CA,OAAOC,SAAQ;AACf,OAAO,YAAY;AACnB,OAAOC,WAAU;AACjB,SAAS,eAAe;AAuBxB,IAAM,iBAAwC;AAAA,EAC5C,cAAc;AAAA,EACd,wBAAwB;AAAA,EACxB,gBAAgB;AAAA,EAChB,UAAU;AAAA,EACV,mBAAmB;AAAA,EACnB,cAAc;AAAA,EACd,mBAAmB;AAAA,EACnB,eAAe;AAAA,EACf,iBAAiB;AAAA,EACjB,eAAe;AACjB;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,gBAAgB;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;AAMO,SAAS,uBAAsC;AACpD;AAAA,IACE;AAAA,IACA;AAAA,EACF;AAEA,SAAO;AACT;;;AC7HA,OAAOC,SAAQ;AACf,OAAOC,aAAY;AACnB,SAAS,gBAAgB;AACzB,OAAOC,WAAU;;;ACCjB,OAAOC,SAAQ;AACf,OAAOC,WAAU;AACjB,SAAS,qBAAqB;;;ACN9B,OAAO,cAAc;AACrB,OAAOC,SAAQ;AACf,OAAOC,WAAU;AASjB,eAAsB,oBAAoB;AAAA,EACxC;AAAA,EACA;AAAA,EACA;AACF,GAIG;AACD,QAAM,MAAM,UAAU;AAEtB,MAAI,MAAM,4BAA4B;AAEtC,QAAM,uBAAuB,OAAO,KAAK,gBAAgB;AAEzD,QAAM,WAAW,IAAI,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAExD,QAAM,EAAE,KAAK,IAAI,MAAM,SAAS,eAAe;AAAA,IAC7C,IAAI;AAAA,EACN,CAAC;AACD,QAAM,OAAO;AAEb,QAAM,eAAeC,MAAK,KAAK,YAAY,mBAAmB;AAE9D,QAAMC,IAAG,UAAU,cAAc,OAAO,IAAI,CAAC;AAE7C,MAAI,MAAM,uBAAuB,YAAY;AAC/C;;;ACtCA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,OAAOC,aAAY;AACnB,OAAOC,WAAU;AACjB,SAAS,YAAY;AAMrB,eAAsB,qBAAqB;AAAA,EACzC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAMG;AACD,QAAM,EAAE,uBAAuB,IAAI,UAAU;AAC7C,QAAM,MAAM,UAAU;AAEtB,MAAI,MAAM,6BAA6B;AAEvC,QAAM,WAAW,MAAM,mBAAmB,kBAAkB;AAAA,IAC1D,oBAAoB;AAAA,EACtB,CAAC;AAED,EAAAC,QAAO,UAAU,8BAA8B,kBAAkB;AAEjE,QAAM,mBAAmB;AAAA,IACvB;AAAA,IACA;AAAA,EACF;AAEA,QAAM,yBAAyB,OAAO;AAAA,IACpC,wBAAwB,IAAI,CAAC,SAAS;AACpC,YAAM,MAAM,iBAAiB,IAAI;AACjC,MAAAA,QAAO,KAAK,WAAW,qCAAqC;AAC5D,aAAO,CAAC,MAAM,IAAI,eAAe;AAAA,IACnC,CAAC;AAAA,EACH;AAEA,QAAM,sBAAsB;AAAA,IAC1B;AAAA;AAAA;AAAA;AAAA;AAAA,IAKA,GAAG,OAAO,OAAO,sBAAsB;AAAA,EACzC;AAEA,MAAI,MAAM,0BAA0B,mBAAmB;AAEvD,WAAS,YAAY,OAAO;AAAA,IAC1B,OAAO,QAAQ,KAAK,qBAAqB,SAAS,SAAS,CAAC,EAAE;AAAA,MAC5D,CAAC,CAAC,YAAY,QAAQ,MAAM;AAC1B,YAAI,eAAe,kBAAkB;AACnC,cAAI,MAAM,yCAAyC;AAEnD,iBAAO;AAAA,YACL;AAAA,YACA,gBAAgB,UAAU;AAAA,cACxB;AAAA,cACA;AAAA,YACF,CAAC;AAAA,UACH;AAAA,QACF;AAEA,YAAI,MAAM,sCAAsC,UAAU;AAE1D,eAAO;AAAA,UACL;AAAA,UACA,gBAAgB,UAAU;AAAA,YACxB;AAAA,YACA;AAAA,UACF,CAAC;AAAA,QACH;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,QAAM,oBAAoB,YAAY,QAAQ;AAE9C,MAAI,MAAM,uBAAuBC,MAAK,KAAK,YAAY,gBAAgB,CAAC;AAC1E;;;AF9EO,SAAS,oBAAoB,MAA0B;AAC5D,UAAQ,MAAM;AAAA,IACZ,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,EACX;AACF;AAGO,SAAS,gBACd,EAAE,cAAc,iBAAiB,GAAG,KAAK,GACzC;AAAA,EACE;AAAA,EACA;AACF,GAIiB;AACjB,SAAO;AAAA,IACL,cAAc,eACV,yBAAyB,cAAc,sBAAsB,IAC7D;AAAA,IACJ,iBACE,0BAA0B,kBACtB,yBAAyB,iBAAiB,sBAAsB,IAChE;AAAA,IACN,GAAG;AAAA,EACL;AACF;AAEA,SAAS,yBACP,KACA,wBACsB;AACtB,SAAO;AAAA,IACL,CAAC,SAAS,SACR,QAAQ,WAAW,OAAO,IACtB,UAAU,uBAAuB,IAAI,MACrC;AAAA,IACN;AAAA,EACF;AACF;AASA,eAAsB,gBAAgB;AAAA,EACpC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAOG;AACD,QAAM,MAAM,UAAU;AAEtB,QAAM,EAAE,KAAK,IAAI,kBAAkB;AAEnC,QAAM,WAAW,oBAAoB,IAAI;AAEzC,UAAQ,MAAM;AAAA,IACZ,KAAK,OAAO;AACV,YAAM,oBAAoB;AAAA,QACxB;AAAA,QACA;AAAA,QACA;AAAA,MACF,CAAC;AAED;AAAA,IACF;AAAA,IACA,KAAK,QAAQ;AACX,YAAM,kBAAkBC,MAAK,KAAK,kBAAkB,QAAQ;AAC5D,YAAM,kBAAkBA,MAAK,KAAK,YAAY,QAAQ;AAEtD,MAAAC,IAAG,aAAa,iBAAiB,eAAe;AAChD,UAAI,MAAM,sBAAsB,eAAe;AAC/C;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,MAAM;AAAA,EACjD;AACF;;;AD/GA,IAAM,+BAA+B,CAAC,QAAQ,QAAQ,KAAK;AAS3D,IAAI;AAOG,SAAS,qBAAqB,eAAuC;AAK1E,mBACE,kBAAkB,aAAa,KAAK,eAAe,aAAa;AAElE,SAAO;AACT;AAEA,SAAS,kBAAkB,eAAuB;AAChD,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;AAAA,EACtB;AAEA,QAAM,eAAe,oBAAoB,IAAI;AAE7C,EAAAA;AAAA,IACEC,IAAG,WAAWF,MAAK,KAAK,eAAe,YAAY,CAAC;AAAA,IACpD,qBAAqB,qDAAqD;AAAA,EAC5E;AAEA,SAAO,EAAE,MAAM,QAAQ;AACzB;AAEA,SAAS,eAAe,eAAuC;AAC7D,aAAW,QAAQ,8BAA8B;AAC/C,UAAM,eAAe,oBAAoB,IAAI;AAE7C,QAAIE,IAAG,WAAWF,MAAK,KAAK,eAAe,YAAY,CAAC,GAAG;AACzD,aAAO,EAAE,MAAM,SAAS,WAAW,IAAI,EAAE;AAAA,IAC3C;AAAA,EACF;AAGA,MAAIE,IAAG,WAAWF,MAAK,KAAK,eAAe,qBAAqB,CAAC,GAAG;AAClE,WAAO,EAAE,MAAM,OAAO,SAAS,WAAW,KAAK,EAAE;AAAA,EACnD;AAEA,QAAM,IAAI,MAAM,kCAAkC;AACpD;AAEA,SAAS,WAAW,oBAAgD;AAClE,QAAM,SAAS,SAAS,GAAG,8BAA8B;AACzD,SAAO,OAAO,SAAS,EAAE,KAAK;AAChC;AAEO,SAAS,oBAAoB;AAClC,MAAI,CAAC,gBAAgB;AACnB,UAAM;AAAA,MACJ;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;AfpFA,eAAsB,8BACpB,sBACA,kBACA,YACA;AACA,QAAMG,kBAAiB,kBAAkB;AACzC,QAAM,EAAE,uBAAuB,IAAI,UAAU;AAE7C,QAAM,QAAQ;AAAA,IACZ,qBAAqB,IAAI,OAAO,gBAAgB;AAC9C,YAAM,EAAE,UAAU,gBAAgB,IAAI,iBAAiB,WAAW;AAElE,YAAM,iBACJA,gBAAe,SAAS,SACpB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAQLC,MAAK,CAAC,mBAAmB,kBAAkB,GAAG,QAAQ;AAAA,QACtD;AAAA,UACE,cAAc,SAAS;AAAA,UACvB,iBAAiB,yBACb,SAAS,kBACT;AAAA,QACN;AAAA,MACF,IACA;AAAA,QACE;AAAA,UACE;AAAA,UACA;AAAA,UACA,uBAAuB;AAAA,QACzB;AAAA,QACA,EAAE,uBAAuB;AAAA,MAC3B;AAEN,YAAMC,IAAG;AAAA,QACPC,MAAK,KAAK,YAAY,iBAAiB,cAAc;AAAA,QACrD,KAAK,UAAU,gBAAgB,MAAM,CAAC;AAAA,MACxC;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;AmB1DA,OAAOC,UAAQ;AACf,OAAOC,WAAU;AACjB,SAAS,QAAAC,aAAY;AAgBrB,eAAsB,2BACpB,UACA,kBACA,YACA;AACA,QAAMC,kBAAiB,kBAAkB;AACzC,QAAM,EAAE,uBAAuB,IAAI,UAAU;AAE7C,QAAM,iBACJA,gBAAe,SAAS,SACpB,OAAO,OAAOC,MAAK,CAAC,mBAAmB,SAAS,GAAG,QAAQ,GAAG;AAAA,IAC5D,iBAAiB,yBACb,SAAS,kBACT;AAAA,EACN,CAAC,IACD;AAAA,IACE;AAAA,MACE;AAAA,MACA;AAAA,IACF;AAAA,IACA,EAAE,uBAAuB;AAAA,EAC3B;AAEN,QAAMC,KAAG;AAAA,IACPC,MAAK,KAAK,YAAY,cAAc;AAAA,IACpC,KAAK,UAAU,gBAAgB,MAAM,CAAC;AAAA,EACxC;AACF;;;AC5CA,OAAOC,UAAQ;AACf,SAAS,gBAAgB;AACzB,OAAOC,YAAU;;;ACHjB,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;AAAA,QAClC;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;;;ADpCA,eAAsB,uBACpB,kBACA,2BAC2B;AAC3B,QAAM,MAAM,UAAU;AAEtB,MAAI,2BAA2B;AAC7B,QAAI;AAAA,MACF,2CAA2C;AAAA,IAC7C;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;AAAA,QAC1B;AACA;AAAA,MACF,OAAO;AACL,YAAI,MAAM,yBAAyB,iBAAiB;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;;;AEvFA,OAAOC,UAAQ;AACf,OAAOC,YAAU;AACjB,OAAO,aAAa;AAIpB,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;;;ACxCA,SAAS,YAAY;AAed,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;;;ACzCA,OAAOE,aAAY;AAYnB,eAAsB,iBAAiB;AAAA;AAAA,EAErC;AAAA;AAAA,EAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA;AACF,GAIG;AACD,QAAM,SAAS,UAAU;AACzB,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,cACJ,CAAC,OAAO,iBAAiB,SAAS,UAAU,gBAAgB;AAE9D,MAAI,aAAa;AACf,QAAI,MAAM,qCAAqC;AAAA,EACjD;AAEA,aAAW,cAAc,sBAAsB;AAC7C,UAAM,MAAM,iBAAiB,UAAU;AAEvC,IAAAC,QAAO,YAAY,yCAAyC,YAAY;AAExE,UAAM,EAAE,MAAAC,MAAK,IAAI,IAAI;AAMrB,QAAI,iBAAiBA,KAAI,GAAG;AAC1B,UAAI,MAAM,YAAYA,0CAAyC;AAC/D;AAAA,IACF;AAEA,qBAAiBA,KAAI,IAAI,MAAM;AAAA,MAC7B,IAAI;AAAA,MACJ;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;ACrEA,OAAOC,UAAQ;AACf,OAAOC,YAAU;AAGjB,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,uCAAuC;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;;;AChCA,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,GAAG;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;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH;AACF;;;A3BNA,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;AAAA,EACzC;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;AAEA,QAAM,oBAAoB,qBAAqB;AAO/C,MAAI,CAAC,UAAU,kBAAkB,eAAe,GAAG;AACjD,QAAIA,gBAAe,SAAS,QAAQ;AAClC,aAAO,kBAAkB;AAAA,IAC3B;AAAA,EACF;AAEA,MAAI,OAAO,iBAAiB;AAC1B,QAAI,KAAK,gDAAgD;AAAA,EAC3D,OAAO;AAEL,UAAM,gBAAgB;AAAA,MACpB;AAAA,MACA;AAAA,MACA;AAAA,MACA,yBAAyB;AAAA,MACzB;AAAA,MACA,mBAAmB,sBAAsB;AAAA,IAC3C,CAAC;AAAA,EACH;AAEA,MAAIA,gBAAe,SAAS,QAAQ;AAOlC,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;;;ADxOA,WAAW,QAAQ;AAEnB,eAAe,MAAM;AACnB,QAAM,QAAQ;AAChB;AAEA,IAAI,EAAE,MAAM,CAAC,QAAQ;AACnB,MAAI,eAAe,OAAO;AACxB,IAAAE,SAAQ,MAAM,IAAI,KAAK;AACvB,YAAQ,KAAK,CAAC;AAAA,EAChB,OAAO;AACL,IAAAA,SAAQ,MAAM,GAAG;AAAA,EACnB;AACF,CAAC;","names":["console","fs","assert","path","fs","path","omit","path","fs","stdout","fs","fs","fs","fs","path","path","fs","path","path","fs","fs","assert","path","fs","path","fs","path","path","fs","assert","path","assert","path","path","fs","path","assert","fs","packageManager","omit","fs","path","fs","path","omit","packageManager","omit","fs","path","fs","path","assert","path","packageManager","path","assert","fs","path","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","path","assert","fs","packageManager","console"]}
1
+ {"version":3,"sources":["../src/isolate-bin.ts","../src/isolate.ts","../src/helpers/adapt-internal-package-manifests.ts","../src/helpers/adapt-manifest-internal-deps.ts","../src/utils/filter-object-undefined.ts","../src/utils/get-dirname.ts","../src/utils/get-error-message.ts","../src/utils/get-relative-path.ts","../src/utils/inspect-value.ts","../src/utils/is-present.ts","../src/utils/json.ts","../src/utils/logger.ts","../src/utils/pack.ts","../src/utils/unpack.ts","../src/utils/yaml.ts","../src/helpers/patch-internal-entries.ts","../src/helpers/config.ts","../src/helpers/detect-package-manager.ts","../src/helpers/process-lockfile.ts","../src/helpers/generate-npm-lockfile.ts","../src/helpers/generate-pnpm-lockfile.ts","../src/helpers/adapt-target-package-manifest.ts","../src/helpers/create-packages-registry.ts","../src/helpers/find-packages-globs.ts","../src/helpers/get-build-output-dir.ts","../src/helpers/list-internal-packages.ts","../src/helpers/pack-dependencies.ts","../src/helpers/process-build-output-files.ts","../src/helpers/unpack-dependencies.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 { adaptInternalPackageManifests } from \"./helpers/adapt-internal-package-manifests\";\nimport { adaptTargetPackageManifest } from \"./helpers/adapt-target-package-manifest\";\nimport type { IsolateConfig } from \"./helpers/config\";\nimport {\n getUserDefinedConfig,\n resolveConfig,\n setUserConfig,\n} from \"./helpers/config\";\nimport {\n createPackagesRegistry,\n type PackageManifest,\n} from \"./helpers/create-packages-registry\";\nimport { detectPackageManager } from \"./helpers/detect-package-manager\";\nimport { getBuildOutputDir } from \"./helpers/get-build-output-dir\";\nimport { listInternalPackages } from \"./helpers/list-internal-packages\";\nimport { packDependencies } from \"./helpers/pack-dependencies\";\nimport { processBuildOutputFiles } from \"./helpers/process-build-output-files\";\nimport { processLockfile } from \"./helpers/process-lockfile\";\nimport { unpackDependencies } from \"./helpers/unpack-dependencies\";\nimport type { Logger } from \"./utils\";\nimport {\n getDirname,\n getRootRelativePath,\n isDefined,\n readTypedJson,\n setLogLevel,\n setLogger,\n useLogger,\n} from \"./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 const userDefinedConfig = getUserDefinedConfig();\n\n /**\n * If the user has not explicitly set the excludeLockfile option, we will\n * exclude the lockfile for Yarn, because we still need to figure out how to\n * generate the isolated lockfile for it.\n */\n if (!isDefined(userDefinedConfig.excludeLockfile)) {\n if (packageManager.name === \"yarn\") {\n config.excludeLockfile = true;\n }\n }\n\n if (config.excludeLockfile) {\n log.warn(\"Excluding the lockfile from the isolate output\");\n } else {\n /** Copy and adapt the lockfile */\n await processLockfile({\n workspaceRootDir,\n isolateDir,\n packagesRegistry,\n internalDepPackageNames: internalPackageNames,\n targetPackageDir,\n targetPackageName: targetPackageManifest.name,\n });\n }\n\n if (packageManager.name === \"pnpm\") {\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\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 path from \"node:path\";\nimport { omit } from \"ramda\";\nimport type { PackagesRegistry } from \"../helpers/create-packages-registry\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 } = useConfig();\n\n await Promise.all(\n internalPackageNames.map(async (packageName) => {\n const { manifest, rootRelativeDir } = packagesRegistry[packageName];\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(\n /**\n * For internal dependencies we want to omit the peerDependencies,\n * because installing these is the responsibility of the consuming\n * app / service, and otherwise the frozen lockfile install will\n * error since the package file contains something that is not\n * referenced in the lockfile.\n */\n omit([\"devDependencies\", \"peerDependencies\"], manifest),\n {\n dependencies: manifest.dependencies,\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n }\n )\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n parentRootRelativeDir: rootRelativeDir,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, rootRelativeDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n })\n );\n}\n","import { omit } from \"ramda\";\nimport { filterObjectUndefined } from \"../utils\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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 {\n manifest,\n packagesRegistry,\n parentRootRelativeDir,\n }: {\n manifest: PackageManifest;\n packagesRegistry: PackagesRegistry;\n parentRootRelativeDir?: string;\n },\n opts: { includeDevDependencies?: boolean } = {}\n): PackageManifest {\n return Object.assign(\n omit([\"devDependencies\"], manifest),\n filterObjectUndefined({\n dependencies: manifest.dependencies\n ? patchInternalEntries(\n manifest.dependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n devDependencies:\n opts.includeDevDependencies && manifest.devDependencies\n ? patchInternalEntries(\n manifest.devDependencies,\n packagesRegistry,\n parentRootRelativeDir\n )\n : undefined,\n })\n );\n}\n","export function filterObjectUndefined(object: Record<string, unknown>) {\n return Object.fromEntries(\n Object.entries(object).filter(([_, value]) => value !== undefined)\n );\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, 4, true);\n}\n","/** Copied from ts-is-present */\nexport function isPresent<T>(t: T | undefined | null | void): t is T {\n return t !== undefined && t !== null;\n}\n\nexport function isDefined<T>(t: T | undefined): t is T {\n return t !== undefined;\n}\n\nexport function isFilled<T>(t: T | null): t is T {\n return t !== null;\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 chalk from \"chalk\";\nimport type { IsolateConfigResolved, LogLevel } from \"../helpers/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 fs from \"fs-extra\";\nimport { exec } from \"node:child_process\";\nimport path from \"node:path\";\nimport { useLogger } from \"./logger\";\n\nexport async function pack(\n srcDir: string,\n dstDir: string,\n usePnpmPack = false\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(stderr);\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 path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport { isEmpty } from \"ramda\";\nimport {\n inspectValue,\n readTypedJsonSync,\n setLogLevel,\n useLogger,\n} from \"../utils\";\n\nexport type IsolateConfigResolved = {\n buildDirName?: string;\n includeDevDependencies: boolean;\n isolateDirName: string;\n logLevel: \"info\" | \"debug\" | \"warn\" | \"error\";\n targetPackagePath?: string;\n tsconfigPath: string;\n workspacePackages?: string[];\n workspaceRoot: string;\n excludeLockfile: boolean;\n avoidPnpmPack: boolean;\n};\n\nexport type IsolateConfig = Partial<IsolateConfigResolved>;\n\nconst configDefaults: IsolateConfigResolved = {\n buildDirName: undefined,\n includeDevDependencies: false,\n isolateDirName: \"isolate\",\n logLevel: \"info\",\n targetPackagePath: undefined,\n tsconfigPath: \"./tsconfig.json\",\n workspacePackages: undefined,\n workspaceRoot: \"../..\",\n excludeLockfile: false,\n avoidPnpmPack: false,\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 fs from \"fs-extra\";\nimport assert from \"node:assert\";\nimport { execSync } from \"node:child_process\";\nimport path from \"node:path\";\nimport { readTypedJsonSync, useLogger } from \"../utils\";\nimport type { PackageManifest } from \"./create-packages-registry\";\nimport { getLockfileFileName } from \"./process-lockfile\";\n\nconst 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\nlet packageManager: PackageManager | undefined;\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\nfunction 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\nfunction 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\nfunction getVersion(packageManagerName: PackageManagerName): string {\n const buffer = execSync(`${packageManagerName} --version`);\n return buffer.toString().trim();\n}\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","import type {\n ProjectSnapshot,\n ResolvedDependencies,\n} from \"@pnpm/lockfile-file\";\nimport fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { mapObjIndexed } from \"ramda\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport type { PackageManagerName } from \"./detect-package-manager\";\nimport { usePackageManager } from \"./detect-package-manager\";\nimport { generateNpmLockfile } from \"./generate-npm-lockfile\";\nimport { generatePnpmLockfile } from \"./generate-pnpm-lockfile\";\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\n/** Convert dependency links */\nexport function pnpmMapImporter(\n { dependencies, devDependencies, ...rest }: ProjectSnapshot,\n {\n includeDevDependencies,\n directoryByPackageName,\n }: {\n includeDevDependencies: 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 ...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 { name } = usePackageManager();\n\n const fileName = getLockfileFileName(name);\n\n switch (name) {\n case \"npm\": {\n await generateNpmLockfile({\n targetPackageDir,\n isolateDir,\n packagesRegistry,\n });\n\n break;\n }\n case \"yarn\": {\n const lockfileSrcPath = path.join(workspaceRootDir, fileName);\n const lockfileDstPath = path.join(isolateDir, fileName);\n\n fs.copyFileSync(lockfileSrcPath, lockfileDstPath);\n log.debug(\"Copied lockfile to\", lockfileDstPath);\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}`);\n }\n}\n","import Arborist from \"@npmcli/arborist\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\nimport { useLogger } from \"../utils\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\n\n/**\n * This code is probably not working yet. It should eventually do something\n * similar to generatePnpmLockfile, but my NPM install is giving me\n * non-descriptive errors and my patience and time for now is running out...\n */\nexport async function generateNpmLockfile({\n targetPackageDir,\n packagesRegistry,\n isolateDir,\n}: {\n targetPackageDir: string;\n packagesRegistry: PackagesRegistry;\n isolateDir: string;\n}) {\n const log = useLogger();\n\n log.debug(\"Generating NPM lockfile...\");\n\n const internalPackageNames = Object.keys(packagesRegistry);\n\n const arborist = new Arborist({ path: targetPackageDir });\n\n const { meta } = await arborist.buildIdealTree({\n // rm: internalPackageNames,\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}\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 { useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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 } = useConfig();\n const log = useLogger();\n\n log.debug(\"Generating PNPM lockfile...\");\n\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 directoryByPackageName,\n }),\n ];\n }\n\n log.debug(\"Setting internal package importer:\", importerId);\n\n return [\n importerId,\n pnpmMapImporter(importer, {\n includeDevDependencies,\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}\n","import fs from \"fs-extra\";\nimport path from \"node:path\";\nimport { omit } from \"ramda\";\nimport { adaptManifestInternalDeps } from \"./adapt-manifest-internal-deps\";\nimport { useConfig } from \"./config\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\n\n/**\n * Change the target package manifest file, so that:\n *\n * - Its internal dependencies point to the isolated ./packages/* directory.\n * - DevDependencies are possibly removed\n * - Scripts are possibly removed\n */\nexport async function adaptTargetPackageManifest(\n manifest: PackageManifest,\n packagesRegistry: PackagesRegistry,\n isolateDir: string\n) {\n const packageManager = usePackageManager();\n const { includeDevDependencies } = useConfig();\n\n const outputManifest =\n packageManager.name === \"pnpm\"\n ? Object.assign(omit([\"devDependencies\", \"scripts\"], manifest), {\n devDependencies: includeDevDependencies\n ? manifest.devDependencies\n : undefined,\n })\n : adaptManifestInternalDeps(\n {\n manifest,\n packagesRegistry,\n },\n { includeDevDependencies }\n );\n\n await fs.writeFile(\n path.join(isolateDir, \"package.json\"),\n JSON.stringify(outputManifest, null, 2)\n );\n}\n","import type { PackageManifest as PnpmPackageManifest } from \"@pnpm/types\";\nimport fs from \"fs-extra\";\nimport { globSync } from \"glob\";\nimport path from \"node:path\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { findPackagesGlobs } from \"./find-packages-globs\";\n\nexport type PackageManifest = PnpmPackageManifest & {\n packageManager?: string;\n};\n\nexport type WorkspacePackageInfo = {\n absoluteDir: string;\n /**\n * The path of the package relative to the workspace root. This is the path\n * referenced in the lock file.\n */\n rootRelativeDir: string;\n /** The package.json file contents */\n manifest: PackageManifest;\n};\n\nexport type PackagesRegistry = Record<string, WorkspacePackageInfo>;\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 {\n inspectValue,\n readTypedJsonSync,\n readTypedYamlSync,\n useLogger,\n} from \"../utils\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 fs from \"fs-extra\";\nimport path from \"node:path\";\nimport outdent from \"outdent\";\nimport { readTypedJson, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\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 { uniq } from \"ramda\";\nimport type {\n PackageManifest,\n PackagesRegistry,\n} from \"./create-packages-registry\";\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","import assert from \"node:assert\";\nimport { pack, useLogger } from \"../utils\";\nimport { useConfig } from \"./config\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\nimport { usePackageManager } from \"./detect-package-manager\";\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 config = useConfig();\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 =\n !config.avoidPnpmPack && 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 { pack, unpack, useLogger } 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 { getIsolateRelativePath, useLogger } from \"../utils\";\nimport { unpack } from \"../utils/unpack\";\nimport type { PackagesRegistry } from \"./create-packages-registry\";\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"],"mappings":"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","names":["console","fs","assert","path","fs","path","omit","path","fs","stdout","fs","fs","fs","fs","path","path","fs","path","path","fs","fs","assert","path","fs","path","fs","path","path","fs","assert","path","assert","path","path","fs","path","assert","fs","packageManager","omit","fs","path","fs","path","omit","packageManager","omit","fs","path","fs","path","assert","path","packageManager","path","assert","fs","path","fs","path","path","fs","assert","assert","name","fs","path","path","fs","fs","path","path","fs","path","assert","fs","packageManager","console"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "isolate-package",
3
- "version": "1.6.0",
3
+ "version": "1.6.2-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",