@eldrforge/kodrdriv 1.2.27 → 1.2.28
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/AI-FRIENDLY-LOGGING-GUIDE.md +237 -0
- package/AI-LOGGING-MIGRATION-COMPLETE.md +371 -0
- package/ALREADY-PUBLISHED-PACKAGES-FIX.md +264 -0
- package/AUDIT-BRANCHES-PROGRESS-FIX.md +90 -0
- package/AUDIT-EXAMPLE-OUTPUT.md +113 -0
- package/CHECKPOINT-RECOVERY-FIX.md +450 -0
- package/LOGGING-MIGRATION-STATUS.md +186 -0
- package/PARALLEL-PUBLISH-FIXES-IMPLEMENTED.md +405 -0
- package/PARALLEL-PUBLISH-QUICK-REFERENCE.md +375 -0
- package/PARALLEL_EXECUTION_FIX.md +2 -2
- package/PUBLISH_IMPROVEMENTS_IMPLEMENTED.md +4 -5
- package/VERSION-AUDIT-FIX.md +333 -0
- package/dist/application.js +6 -6
- package/dist/application.js.map +1 -1
- package/dist/arguments.js +43 -13
- package/dist/arguments.js.map +1 -1
- package/dist/commands/audio-commit.js +18 -18
- package/dist/commands/audio-commit.js.map +1 -1
- package/dist/commands/audio-review.js +32 -32
- package/dist/commands/audio-review.js.map +1 -1
- package/dist/commands/clean.js +9 -9
- package/dist/commands/clean.js.map +1 -1
- package/dist/commands/commit.js +20 -20
- package/dist/commands/commit.js.map +1 -1
- package/dist/commands/development.js +88 -89
- package/dist/commands/development.js.map +1 -1
- package/dist/commands/link.js +36 -36
- package/dist/commands/link.js.map +1 -1
- package/dist/commands/publish.js +318 -220
- package/dist/commands/publish.js.map +1 -1
- package/dist/commands/release.js +14 -14
- package/dist/commands/release.js.map +1 -1
- package/dist/commands/review.js +15 -17
- package/dist/commands/review.js.map +1 -1
- package/dist/commands/select-audio.js +5 -5
- package/dist/commands/select-audio.js.map +1 -1
- package/dist/commands/tree.js +75 -34
- package/dist/commands/tree.js.map +1 -1
- package/dist/commands/unlink.js +39 -39
- package/dist/commands/unlink.js.map +1 -1
- package/dist/commands/updates.js +150 -14
- package/dist/commands/updates.js.map +1 -1
- package/dist/commands/versions.js +14 -13
- package/dist/commands/versions.js.map +1 -1
- package/dist/constants.js +1 -1
- package/dist/content/diff.js +5 -5
- package/dist/content/diff.js.map +1 -1
- package/dist/content/files.js +2 -2
- package/dist/content/files.js.map +1 -1
- package/dist/content/log.js +3 -3
- package/dist/content/log.js.map +1 -1
- package/dist/execution/CommandValidator.js +6 -6
- package/dist/execution/CommandValidator.js.map +1 -1
- package/dist/execution/DynamicTaskPool.js +33 -10
- package/dist/execution/DynamicTaskPool.js.map +1 -1
- package/dist/execution/RecoveryManager.js +99 -21
- package/dist/execution/RecoveryManager.js.map +1 -1
- package/dist/execution/TreeExecutionAdapter.js +19 -19
- package/dist/execution/TreeExecutionAdapter.js.map +1 -1
- package/dist/main.js +2 -2
- package/dist/main.js.map +1 -1
- package/dist/util/checkpointManager.js +4 -4
- package/dist/util/checkpointManager.js.map +1 -1
- package/dist/util/dependencyGraph.js +2 -2
- package/dist/util/dependencyGraph.js.map +1 -1
- package/dist/util/fileLock.js +1 -1
- package/dist/util/fileLock.js.map +1 -1
- package/dist/util/general.js +148 -15
- package/dist/util/general.js.map +1 -1
- package/dist/util/interactive.js +2 -2
- package/dist/util/interactive.js.map +1 -1
- package/dist/util/performance.js.map +1 -1
- package/dist/util/safety.js +13 -13
- package/dist/util/safety.js.map +1 -1
- package/dist/utils/branchState.js +567 -0
- package/dist/utils/branchState.js.map +1 -0
- package/package.json +1 -1
- package/scripts/update-test-log-assertions.js +73 -0
package/dist/commands/unlink.js
CHANGED
|
@@ -71,7 +71,7 @@ const findLinkedDependencies = async (packagePath, packageName, storage, logger)
|
|
|
71
71
|
}
|
|
72
72
|
}
|
|
73
73
|
} catch (error) {
|
|
74
|
-
logger.warn(`
|
|
74
|
+
logger.warn(`UNLINK_CHECK_FAILED: Unable to check linked dependencies | Package: ${packageName} | Error: ${error.message}`);
|
|
75
75
|
}
|
|
76
76
|
return linkedDependencies;
|
|
77
77
|
};
|
|
@@ -119,7 +119,7 @@ const removeSymbolicLink = async (packageName, targetDir, logger, isDryRun = fal
|
|
|
119
119
|
}
|
|
120
120
|
}
|
|
121
121
|
} catch (error) {
|
|
122
|
-
logger.warn(`
|
|
122
|
+
logger.warn(`UNLINK_SYMLINK_REMOVE_FAILED: Unable to remove symlink | Package: ${packageName} | Error: ${error.message}`);
|
|
123
123
|
return false;
|
|
124
124
|
}
|
|
125
125
|
};
|
|
@@ -226,20 +226,20 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
226
226
|
process.cwd()
|
|
227
227
|
];
|
|
228
228
|
if (targetDirectories.length === 1) {
|
|
229
|
-
logger.info(`Analyzing workspace
|
|
229
|
+
logger.info(`UNLINK_WORKSPACE_ANALYSIS: Analyzing single workspace directory | Path: ${targetDirectories[0]} | Purpose: Find packages to unlink`);
|
|
230
230
|
} else {
|
|
231
|
-
logger.info(`Analyzing
|
|
231
|
+
logger.info(`UNLINK_WORKSPACE_ANALYSIS: Analyzing multiple workspace directories | Paths: ${targetDirectories.join(', ')} | Count: ${targetDirectories.length} | Purpose: Find packages to unlink`);
|
|
232
232
|
}
|
|
233
233
|
// If no package argument provided, implement new behavior for current project
|
|
234
234
|
if (!packageArgument) {
|
|
235
235
|
var _runConfig_unlink1, _runConfig_unlink2;
|
|
236
|
-
logger.info('
|
|
236
|
+
logger.info('UNLINK_SMART_MODE: Smart unlinking mode activated for current project | Mode: smart | Target: current directory | Purpose: Auto-unlink based on scope');
|
|
237
237
|
const currentDir = process.cwd();
|
|
238
238
|
const packageJsonPath = `${currentDir}/package.json`;
|
|
239
239
|
// Check if we're in a directory with package.json
|
|
240
240
|
if (!await storage.exists(packageJsonPath)) {
|
|
241
241
|
const message = `No package.json found in current directory: ${currentDir}`;
|
|
242
|
-
logger.warn(
|
|
242
|
+
logger.warn('UNLINK_NO_PACKAGE_JSON: No package.json found in current directory | Directory: ' + currentDir + ' | Action: Cannot unlink without package.json');
|
|
243
243
|
return message;
|
|
244
244
|
}
|
|
245
245
|
// Parse package.json to get package name
|
|
@@ -254,15 +254,15 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
254
254
|
packageName = packageJson.name;
|
|
255
255
|
} catch (error) {
|
|
256
256
|
const message = `Failed to parse package.json: ${error.message}`;
|
|
257
|
-
logger.error(
|
|
257
|
+
logger.error('UNLINK_PACKAGE_NAME_MISSING: package.json must have a name field | Field: name | Requirement: Required for unlinking | Action: Add name field to package.json');
|
|
258
258
|
return message;
|
|
259
259
|
}
|
|
260
|
-
logger.info(`Processing package: ${packageName}`);
|
|
260
|
+
logger.info(`UNLINK_PACKAGE_PROCESSING: Processing package for unlinking | Package: ${packageName} | Action: Remove symlinks and restore registry versions`);
|
|
261
261
|
const cleanNodeModules = ((_runConfig_unlink1 = runConfig.unlink) === null || _runConfig_unlink1 === void 0 ? void 0 : _runConfig_unlink1.cleanNodeModules) || false;
|
|
262
262
|
const externalUnlinkPatterns = ((_runConfig_unlink2 = runConfig.unlink) === null || _runConfig_unlink2 === void 0 ? void 0 : _runConfig_unlink2.externals) || [];
|
|
263
263
|
// Step 0: Handle external dependencies if patterns are specified
|
|
264
264
|
if (externalUnlinkPatterns.length > 0) {
|
|
265
|
-
logger.info(`
|
|
265
|
+
logger.info(`UNLINK_EXTERNAL_DEPS: Processing external dependencies | Patterns: ${externalUnlinkPatterns.join(', ')} | Purpose: Unlink external packages before main package`);
|
|
266
266
|
// Read package.json to get dependencies
|
|
267
267
|
const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');
|
|
268
268
|
const parsed = safeJsonParse(packageJsonContent, packageJsonPath);
|
|
@@ -273,21 +273,21 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
273
273
|
};
|
|
274
274
|
const externalDependencies = Object.keys(allDependencies).filter((depName)=>matchesExternalUnlinkPattern(depName, externalUnlinkPatterns));
|
|
275
275
|
if (externalDependencies.length > 0) {
|
|
276
|
-
logger.info(`Found ${externalDependencies.length}
|
|
276
|
+
logger.info(`UNLINK_EXTERNAL_FOUND: Found external dependencies to unlink | Count: ${externalDependencies.length} | Dependencies: ${externalDependencies.join(', ')}`);
|
|
277
277
|
for (const depName of externalDependencies){
|
|
278
278
|
try {
|
|
279
279
|
const success = await removeSymbolicLink(depName, currentDir, logger, isDryRun);
|
|
280
280
|
if (success) {
|
|
281
|
-
logger.info(
|
|
281
|
+
logger.info(`UNLINK_EXTERNAL_SUCCESS: External dependency unlinked successfully | Dependency: ${depName} | Status: unlinked`);
|
|
282
282
|
} else {
|
|
283
|
-
logger.warn(
|
|
283
|
+
logger.warn(`UNLINK_EXTERNAL_FAILED: Failed to unlink external dependency | Dependency: ${depName} | Status: failed`);
|
|
284
284
|
}
|
|
285
285
|
} catch (error) {
|
|
286
|
-
logger.warn(
|
|
286
|
+
logger.warn(`UNLINK_EXTERNAL_ERROR: Error during external dependency unlink | Dependency: ${depName} | Error: ${error.message}`);
|
|
287
287
|
}
|
|
288
288
|
}
|
|
289
289
|
} else {
|
|
290
|
-
logger.info('No external dependencies found matching
|
|
290
|
+
logger.info('UNLINK_EXTERNAL_NONE: No external dependencies found matching patterns | Patterns: ' + externalUnlinkPatterns.join(', ') + ' | Action: Skipping external unlink');
|
|
291
291
|
}
|
|
292
292
|
}
|
|
293
293
|
if (isDryRun) {
|
|
@@ -308,37 +308,37 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
308
308
|
return dryRunMessage;
|
|
309
309
|
}
|
|
310
310
|
// Step 1: Remove global link
|
|
311
|
-
logger.info('Step 1:
|
|
311
|
+
logger.info('UNLINK_GLOBAL_REMOVING: Removing global npm link | Step: 1 | Command: npm unlink -g | Purpose: Remove package from global npm');
|
|
312
312
|
try {
|
|
313
313
|
await run('npm unlink -g');
|
|
314
|
-
logger.info('
|
|
314
|
+
logger.info('UNLINK_GLOBAL_SUCCESS: Global link removed successfully | Status: unlinked | Location: global npm');
|
|
315
315
|
} catch (error) {
|
|
316
316
|
// This might fail if the package wasn't globally linked, which is OK
|
|
317
|
-
logger.warn(
|
|
317
|
+
logger.warn(`UNLINK_GLOBAL_SKIP: Failed to remove global link | Error: ${error.message} | Impact: OK if package wasn't linked | Status: continuing`);
|
|
318
318
|
}
|
|
319
319
|
if (cleanNodeModules) {
|
|
320
320
|
// Step 2: Clean node_modules and package-lock.json
|
|
321
|
-
logger.info('
|
|
321
|
+
logger.info('UNLINK_CLEANING: Cleaning node_modules and package-lock.json | Command: rm -rf | Purpose: Remove symlinked dependencies');
|
|
322
322
|
try {
|
|
323
323
|
await run('rm -rf node_modules package-lock.json');
|
|
324
|
-
logger.info('
|
|
324
|
+
logger.info('UNLINK_CLEAN_SUCCESS: Successfully cleaned node_modules and package-lock.json | Status: removed | Next: Fresh install');
|
|
325
325
|
} catch (error) {
|
|
326
|
-
logger.warn(
|
|
326
|
+
logger.warn(`UNLINK_CLEAN_FAILED: Failed to clean directories | Error: ${error.message} | Impact: May need manual cleanup`);
|
|
327
327
|
}
|
|
328
328
|
// Step 3: Install dependencies
|
|
329
|
-
logger.info('
|
|
329
|
+
logger.info('UNLINK_INSTALLING: Installing dependencies from registry | Command: npm install | Purpose: Restore registry versions');
|
|
330
330
|
try {
|
|
331
331
|
await run('npm install');
|
|
332
|
-
logger.info('
|
|
332
|
+
logger.info('UNLINK_INSTALL_SUCCESS: Dependencies installed successfully | Source: npm registry | Status: completed');
|
|
333
333
|
} catch (error) {
|
|
334
|
-
logger.error(
|
|
334
|
+
logger.error(`UNLINK_INSTALL_FAILED: Failed to install dependencies | Error: ${error.message} | Impact: Package may be in inconsistent state`);
|
|
335
335
|
throw error;
|
|
336
336
|
}
|
|
337
337
|
// Step 4: Check for remaining links (suppress output and errors)
|
|
338
|
-
logger.info('
|
|
338
|
+
logger.info('UNLINK_CHECK_REMAINING: Checking for remaining symlinks | Purpose: Verify clean unlink | Action: Scan node_modules');
|
|
339
339
|
} else {
|
|
340
340
|
// Step 2: Check for remaining links (suppress output and errors)
|
|
341
|
-
logger.info('
|
|
341
|
+
logger.info('UNLINK_CHECK_REMAINING: Checking for remaining symlinks | Mode: skip-reinstall | Purpose: Verify unlink | Action: Scan node_modules');
|
|
342
342
|
logger.info('Note: Use --clean-node-modules flag to also clean and reinstall dependencies');
|
|
343
343
|
}
|
|
344
344
|
try {
|
|
@@ -355,23 +355,23 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
355
355
|
const linkedPackages = Object.keys(linksData.dependencies || {});
|
|
356
356
|
const scopeLinkedPackages = linkedPackages.filter((pkg)=>pkg.startsWith(packageScope + '/'));
|
|
357
357
|
if (scopeLinkedPackages.length > 0) {
|
|
358
|
-
logger.warn(
|
|
359
|
-
logger.verbose('
|
|
358
|
+
logger.warn(`UNLINK_REMAINING_LINKS: Found remaining links to packages in scope | Scope: ${packageScope} | Packages: ${scopeLinkedPackages.join(', ')} | Note: May be expected if workspace packages linked`);
|
|
359
|
+
logger.verbose('UNLINK_REMAINING_NOTE: Remaining links may be expected | Reason: Other workspace packages still linked | Status: normal');
|
|
360
360
|
} else {
|
|
361
|
-
logger.info('
|
|
361
|
+
logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');
|
|
362
362
|
}
|
|
363
363
|
} catch {
|
|
364
364
|
// If JSON parsing fails, fall back to basic check
|
|
365
365
|
logger.verbose('Failed to parse npm ls --link --json output, using basic check');
|
|
366
366
|
if (result.stdout.includes(packageScope)) {
|
|
367
|
-
logger.warn(
|
|
368
|
-
logger.verbose('
|
|
367
|
+
logger.warn(`UNLINK_REMAINING_LINKS_BASIC: Found remaining links to scope | Scope: ${packageScope} | Check: basic | Note: May be expected`);
|
|
368
|
+
logger.verbose('UNLINK_REMAINING_NOTE: Remaining links may be expected | Reason: Other workspace packages still linked | Status: normal');
|
|
369
369
|
} else {
|
|
370
|
-
logger.info('
|
|
370
|
+
logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');
|
|
371
371
|
}
|
|
372
372
|
}
|
|
373
373
|
} else {
|
|
374
|
-
logger.info('
|
|
374
|
+
logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');
|
|
375
375
|
}
|
|
376
376
|
} catch {
|
|
377
377
|
// npm ls --link returns non-zero when there are no links, which is what we want
|
|
@@ -383,7 +383,7 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
383
383
|
return summary;
|
|
384
384
|
}
|
|
385
385
|
// New scope-based unlinking behavior
|
|
386
|
-
logger.info(
|
|
386
|
+
logger.info(`UNLINK_EXPLICIT_MODE: Unlinking specific scope/package | Target: ${packageArgument} | Mode: explicit | Purpose: Remove symlinks for package`);
|
|
387
387
|
const { scope, packageName } = parsePackageArgument(packageArgument);
|
|
388
388
|
logger.verbose(`Parsed scope: ${scope}, package: ${packageName || 'all packages in scope'}`);
|
|
389
389
|
// Find matching packages in the workspace
|
|
@@ -418,14 +418,14 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
418
418
|
'unlink',
|
|
419
419
|
pkg.name
|
|
420
420
|
]);
|
|
421
|
-
logger.info(
|
|
421
|
+
logger.info(`UNLINK_CONSUMER_SUCCESS: Consumer unlinked from package | Consumer: ${consumer.name} | Package: ${pkg.name} | Status: unlinked`);
|
|
422
422
|
}
|
|
423
423
|
} finally{
|
|
424
424
|
process.chdir(consumerOriginalCwd);
|
|
425
425
|
}
|
|
426
426
|
} catch (error) {
|
|
427
427
|
// npm unlink can fail if package wasn't linked, but that's OK
|
|
428
|
-
logger.warn(
|
|
428
|
+
logger.warn(`UNLINK_CONSUMER_FAILED: Failed to unlink consumer | Consumer: ${consumer.name} | Package: ${pkg.name} | Error: ${error.message}`);
|
|
429
429
|
}
|
|
430
430
|
}
|
|
431
431
|
}
|
|
@@ -439,7 +439,7 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
439
439
|
} else {
|
|
440
440
|
logger.verbose(`Running 'npm unlink' in source: ${pkg.path}`);
|
|
441
441
|
await run('npm unlink');
|
|
442
|
-
logger.info(
|
|
442
|
+
logger.info(`UNLINK_SOURCE_SUCCESS: Source package unlinked | Package: ${pkg.name} | Status: unlinked`);
|
|
443
443
|
}
|
|
444
444
|
} finally{
|
|
445
445
|
process.chdir(originalCwd);
|
|
@@ -447,7 +447,7 @@ const executeInternal = async (runConfig, packageArgument)=>{
|
|
|
447
447
|
unlinkedPackages.push(pkg.name);
|
|
448
448
|
} catch (error) {
|
|
449
449
|
// npm unlink can fail if package wasn't linked, but that's OK
|
|
450
|
-
logger.warn(
|
|
450
|
+
logger.warn(`UNLINK_SOURCE_FAILED: Failed to unlink source package | Package: ${pkg.name} | Error: ${error.message}`);
|
|
451
451
|
unlinkedPackages.push(pkg.name); // Still count as success
|
|
452
452
|
}
|
|
453
453
|
}
|
|
@@ -467,9 +467,9 @@ const executeStatus = async (runConfig)=>{
|
|
|
467
467
|
process.cwd()
|
|
468
468
|
];
|
|
469
469
|
if (targetDirectories.length === 1) {
|
|
470
|
-
logger.info(
|
|
470
|
+
logger.info(`UNLINK_STATUS_CHECK: Checking link status in directory | Directory: ${targetDirectories[0]} | Purpose: Show current symlinks`);
|
|
471
471
|
} else {
|
|
472
|
-
logger.info(
|
|
472
|
+
logger.info(`UNLINK_STATUS_CHECK: Checking link status in directories | Directories: ${targetDirectories.join(', ')} | Count: ${targetDirectories.length} | Purpose: Show current symlinks`);
|
|
473
473
|
}
|
|
474
474
|
// Find all packages in the workspace
|
|
475
475
|
let allPackageJsonFiles = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unlink.js","sources":["../../src/commands/unlink.ts"],"sourcesContent":["import { getDryRunLogger, getLogger } from '../logging';\nimport { Config } from '../types';\nimport { create as createStorage } from '../util/storage';\nimport { run, runSecure } from '@eldrforge/git-tools';\nimport {\n findAllPackageJsonFiles\n} from '../util/performance';\nimport { safeJsonParse, validatePackageJson } from '@eldrforge/git-tools';\nimport fs from 'fs/promises';\nimport path from 'path';\n\n// Helper function to check if a dependency matches any external unlink patterns\nexport const matchesExternalUnlinkPattern = (dependencyName: string, externalUnlinkPatterns: string[]): boolean => {\n if (!externalUnlinkPatterns || externalUnlinkPatterns.length === 0) {\n return false;\n }\n\n return externalUnlinkPatterns.some(pattern => {\n // Simple string matching - could be enhanced with glob patterns later\n return dependencyName === pattern || dependencyName.startsWith(pattern);\n });\n};\n\n// Helper function to check if a path is a symbolic link\nexport const isSymbolicLink = async (filePath: string): Promise<boolean> => {\n try {\n const stats = await fs.lstat(filePath);\n return stats.isSymbolicLink();\n } catch {\n return false;\n }\n};\n\n// Helper function to get the target of a symbolic link\nexport const getSymbolicLinkTarget = async (filePath: string): Promise<string | null> => {\n try {\n const target = await fs.readlink(filePath);\n return target;\n } catch {\n return null;\n }\n};\n\n// Helper function to find all linked dependencies in a package\nexport const findLinkedDependencies = async (\n packagePath: string,\n packageName: string,\n storage: any,\n logger: any\n): Promise<Array<{ dependencyName: string; targetPath: string; isExternal: boolean }>> => {\n const linkedDependencies: Array<{ dependencyName: string; targetPath: string; isExternal: boolean }> = [];\n\n try {\n const packageJsonPath = path.join(packagePath, 'package.json');\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n const allDependencies = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies\n };\n\n const nodeModulesPath = path.join(packagePath, 'node_modules');\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for (const [dependencyName, version] of Object.entries(allDependencies)) {\n let dependencyPath: string;\n\n if (dependencyName.startsWith('@')) {\n // Scoped package\n const [scope, name] = dependencyName.split('/');\n dependencyPath = path.join(nodeModulesPath, scope, name);\n } else {\n // Unscoped package\n dependencyPath = path.join(nodeModulesPath, dependencyName);\n }\n\n if (await isSymbolicLink(dependencyPath)) {\n const target = await getSymbolicLinkTarget(dependencyPath);\n if (target) {\n // Determine if this is an external dependency (not in the same workspace)\n const isExternal = !target.includes('node_modules') || target.startsWith('..');\n linkedDependencies.push({\n dependencyName,\n targetPath: target,\n isExternal\n });\n }\n }\n }\n } catch (error: any) {\n logger.warn(`Failed to check linked dependencies in ${packageName}: ${error.message}`);\n }\n\n return linkedDependencies;\n};\n\n// Helper function to remove symbolic links manually\nexport const removeSymbolicLink = async (\n packageName: string,\n targetDir: string,\n logger: any,\n isDryRun: boolean = false\n): Promise<boolean> => {\n try {\n // Parse package name to get scope and name parts\n const [scope, name] = packageName.startsWith('@')\n ? packageName.split('/')\n : [null, packageName];\n\n // Create the target path structure\n const nodeModulesPath = path.join(targetDir, 'node_modules');\n let targetPath: string;\n\n if (scope) {\n // Scoped package: node_modules/@scope/name\n targetPath = path.join(nodeModulesPath, scope, name);\n } else {\n // Unscoped package: node_modules/name\n targetPath = path.join(nodeModulesPath, name);\n }\n\n if (isDryRun) {\n logger.verbose(`DRY RUN: Would check and remove symlink: ${targetPath}`);\n return true;\n }\n\n // Check if something exists at the target path\n try {\n const stats = await fs.lstat(targetPath); // Use lstat to not follow symlinks\n\n if (stats.isSymbolicLink()) {\n // It's a symlink, remove it\n await fs.unlink(targetPath);\n logger.verbose(`Removed symlink: ${targetPath}`);\n return true;\n } else {\n logger.verbose(`Target exists but is not a symlink: ${targetPath}`);\n return false;\n }\n } catch (error: any) {\n if (error.code === 'ENOENT') {\n // Nothing exists at target path, nothing to remove\n logger.verbose(`No symlink found at: ${targetPath}`);\n return true;\n } else {\n throw error; // Re-throw unexpected errors\n }\n }\n } catch (error: any) {\n logger.warn(`Failed to remove symlink for ${packageName}: ${error.message}`);\n return false;\n }\n};\n\n// Helper function to parse package names and scopes (same as link command)\nexport const parsePackageArgument = (packageArg: string): { scope: string; packageName?: string } => {\n if (packageArg.startsWith('@')) {\n const parts = packageArg.split('/');\n if (parts.length === 1) {\n // Just a scope like \"@fjell\"\n return { scope: parts[0] };\n } else {\n // Full package name like \"@fjell/core\"\n return { scope: parts[0], packageName: packageArg };\n }\n } else {\n throw new Error(`Package argument must start with @ (scope): ${packageArg}`);\n }\n};\n\n// Find packages in the workspace that match the given scope or package name\nconst findMatchingPackages = async (\n targetDirectories: string[],\n scope: string,\n storage: any,\n logger: any,\n packageName?: string\n): Promise<Array<{ name: string; path: string; isSource: boolean }>> => {\n const matchingPackages: Array<{ name: string; path: string; isSource: boolean }> = [];\n\n // Find all package.json files in target directories\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n const isInScope = packageJson.name.startsWith(scope + '/');\n const isExactMatch = packageName && packageJson.name === packageName;\n\n if (isInScope || isExactMatch) {\n matchingPackages.push({\n name: packageJson.name,\n path: packageDir,\n isSource: packageName ? packageJson.name === packageName : isInScope\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n return matchingPackages;\n};\n\n// Find packages that depend on the target package\nconst findConsumingPackages = async (\n targetDirectories: string[],\n targetPackageName: string,\n storage: any,\n logger: any\n): Promise<Array<{ name: string; path: string }>> => {\n const consumingPackages: Array<{ name: string; path: string }> = [];\n\n // Find all package.json files in target directories\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n // Check if this package depends on the target package\n const dependencyTypes = ['dependencies', 'devDependencies', 'peerDependencies', 'optionalDependencies'];\n const hasDependency = dependencyTypes.some(depType =>\n packageJson[depType] && packageJson[depType][targetPackageName]\n );\n\n if (hasDependency && packageJson.name !== targetPackageName) {\n consumingPackages.push({\n name: packageJson.name,\n path: packageDir\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n return consumingPackages;\n};\n\nconst executeInternal = async (runConfig: Config, packageArgument?: string): Promise<string> => {\n const isDryRun = runConfig.dryRun || runConfig.unlink?.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n\n // Check if this is a status command\n if (packageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n // Get target directories from config, default to current directory\n const targetDirectories = runConfig.tree?.directories || [process.cwd()];\n\n if (targetDirectories.length === 1) {\n logger.info(`Analyzing workspace at: ${targetDirectories[0]}`);\n } else {\n logger.info(`Analyzing workspaces at: ${targetDirectories.join(', ')}`);\n }\n\n // If no package argument provided, implement new behavior for current project\n if (!packageArgument) {\n logger.info('🔓 Unlinking current project...');\n\n const currentDir = process.cwd();\n const packageJsonPath = `${currentDir}/package.json`;\n\n // Check if we're in a directory with package.json\n if (!(await storage.exists(packageJsonPath))) {\n const message = `No package.json found in current directory: ${currentDir}`;\n logger.warn(message);\n return message;\n }\n\n // Parse package.json to get package name\n let packageName: string;\n try {\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n if (!packageJson.name) {\n throw new Error('package.json has no name field');\n }\n packageName = packageJson.name;\n } catch (error: any) {\n const message = `Failed to parse package.json: ${error.message}`;\n logger.error(message);\n return message;\n }\n\n logger.info(`Processing package: ${packageName}`);\n\n const cleanNodeModules = runConfig.unlink?.cleanNodeModules || false;\n const externalUnlinkPatterns = runConfig.unlink?.externals || [];\n\n // Step 0: Handle external dependencies if patterns are specified\n if (externalUnlinkPatterns.length > 0) {\n logger.info(`Step 0: Processing external dependencies matching patterns: ${externalUnlinkPatterns.join(', ')}`);\n\n // Read package.json to get dependencies\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n const allDependencies = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies\n };\n\n const externalDependencies = Object.keys(allDependencies).filter(depName =>\n matchesExternalUnlinkPattern(depName, externalUnlinkPatterns)\n );\n\n if (externalDependencies.length > 0) {\n logger.info(`Found ${externalDependencies.length} external dependencies to unlink: ${externalDependencies.join(', ')}`);\n\n for (const depName of externalDependencies) {\n try {\n const success = await removeSymbolicLink(depName, currentDir, logger, isDryRun);\n if (success) {\n logger.info(`✅ Unlinked external dependency: ${depName}`);\n } else {\n logger.warn(`⚠️ Failed to unlink external dependency: ${depName}`);\n }\n } catch (error: any) {\n logger.warn(`⚠️ Error unlinking external dependency ${depName}: ${error.message}`);\n }\n }\n } else {\n logger.info('No external dependencies found matching the specified patterns');\n }\n }\n\n if (isDryRun) {\n let dryRunMessage = `DRY RUN: Would execute unlink steps for ${packageName}:\\n`;\n if (externalUnlinkPatterns.length > 0) {\n dryRunMessage += ` 0. Unlink external dependencies matching patterns: ${externalUnlinkPatterns.join(', ')}\\n`;\n }\n dryRunMessage += ` 1. npm unlink -g\\n`;\n if (cleanNodeModules) {\n dryRunMessage += ` 2. rm -rf node_modules package-lock.json\\n`;\n dryRunMessage += ` 3. npm install\\n`;\n dryRunMessage += ` 4. Check for remaining links with npm ls --link`;\n } else {\n dryRunMessage += ` 2. Check for remaining links with npm ls --link\\n`;\n dryRunMessage += ` Note: Use --clean-node-modules flag to also clean and reinstall dependencies`;\n }\n\n logger.info(dryRunMessage);\n return dryRunMessage;\n }\n\n // Step 1: Remove global link\n logger.info('Step 1: Removing global link...');\n try {\n await run('npm unlink -g');\n logger.info('✅ Global link removed');\n } catch (error: any) {\n // This might fail if the package wasn't globally linked, which is OK\n logger.warn(`⚠️ Failed to remove global link (this is OK if package wasn't linked): ${error.message}`);\n }\n\n if (cleanNodeModules) {\n // Step 2: Clean node_modules and package-lock.json\n logger.info('Step 2: Cleaning node_modules and package-lock.json...');\n try {\n await run('rm -rf node_modules package-lock.json');\n logger.info('✅ Cleaned node_modules and package-lock.json');\n } catch (error: any) {\n logger.warn(`⚠️ Failed to clean node_modules/package-lock.json: ${error.message}`);\n }\n\n // Step 3: Install dependencies\n logger.info('Step 3: Installing dependencies...');\n try {\n await run('npm install');\n logger.info('✅ Dependencies installed');\n } catch (error: any) {\n logger.error(`❌ Failed to install dependencies: ${error.message}`);\n throw error;\n }\n\n // Step 4: Check for remaining links (suppress output and errors)\n logger.info('Step 4: Checking for remaining links...');\n } else {\n // Step 2: Check for remaining links (suppress output and errors)\n logger.info('Step 2: Checking for remaining links...');\n logger.info('Note: Use --clean-node-modules flag to also clean and reinstall dependencies');\n }\n\n try {\n // Use child_process directly to suppress logging and get JSON output\n const util = await import('util');\n const child_process = await import('child_process');\n const execPromise = util.promisify(child_process.exec);\n\n const result = await execPromise('npm ls --link --json');\n\n // Parse JSON output to check for links to packages in the same scope\n const packageScope = packageName.includes('/') ? packageName.split('/')[0] : null;\n\n if (packageScope && result.stdout.trim()) {\n try {\n const linksData = safeJsonParse(result.stdout, 'npm ls output after unlink');\n const linkedPackages = Object.keys(linksData.dependencies || {});\n const scopeLinkedPackages = linkedPackages.filter(pkg => pkg.startsWith(packageScope + '/'));\n\n if (scopeLinkedPackages.length > 0) {\n logger.warn(`⚠️ Found remaining links to packages in scope ${packageScope}: ${scopeLinkedPackages.join(', ')}`);\n logger.verbose('This may be expected if other packages in your workspace are still linked');\n } else {\n logger.info('✅ No problematic links found');\n }\n } catch {\n // If JSON parsing fails, fall back to basic check\n logger.verbose('Failed to parse npm ls --link --json output, using basic check');\n if (result.stdout.includes(packageScope)) {\n logger.warn(`⚠️ Found remaining links to packages in scope ${packageScope}`);\n logger.verbose('This may be expected if other packages in your workspace are still linked');\n } else {\n logger.info('✅ No problematic links found');\n }\n }\n } else {\n logger.info('✅ No problematic links found');\n }\n } catch {\n // npm ls --link returns non-zero when there are no links, which is what we want\n // So we only log this at verbose level\n logger.verbose('npm ls --link check completed (non-zero exit is expected when no links exist)');\n }\n\n const summary = `Successfully unlinked ${packageName}`;\n logger.info(summary);\n return summary;\n }\n\n // New scope-based unlinking behavior\n logger.info(`🔓 Unlinking scope/package: ${packageArgument}`);\n\n const { scope, packageName } = parsePackageArgument(packageArgument);\n logger.verbose(`Parsed scope: ${scope}, package: ${packageName || 'all packages in scope'}`);\n\n // Find matching packages in the workspace\n const matchingPackages = await findMatchingPackages(targetDirectories, scope, storage, logger, packageName);\n\n if (matchingPackages.length === 0) {\n const message = packageName\n ? `No package found matching: ${packageName}`\n : `No packages found in scope: ${scope}`;\n logger.warn(message);\n return message;\n }\n\n logger.info(`Found ${matchingPackages.length} matching package(s)`);\n\n const unlinkedPackages: string[] = [];\n\n // If specific package name provided, use that; otherwise unlink all packages in scope\n const packagesToUnlink = packageName\n ? matchingPackages.filter(pkg => pkg.name === packageName)\n : matchingPackages;\n\n for (const pkg of packagesToUnlink) {\n logger.info(`Processing package: ${pkg.name}`);\n\n // Step A: Find all packages that depend on this package and unlink them first\n const consumingPackages = await findConsumingPackages(targetDirectories, pkg.name, storage, logger);\n\n if (consumingPackages.length === 0) {\n logger.info(`No consuming packages found for: ${pkg.name}`);\n } else {\n logger.info(`Found ${consumingPackages.length} consuming package(s) for: ${pkg.name}`);\n\n for (const consumer of consumingPackages) {\n try {\n const consumerOriginalCwd = process.cwd();\n process.chdir(consumer.path);\n\n try {\n if (isDryRun) {\n logger.info(`DRY RUN: Would run 'npm unlink ${pkg.name}' in: ${consumer.path}`);\n } else {\n logger.verbose(`Running 'npm unlink ${pkg.name}' in consumer: ${consumer.path}`);\n await runSecure('npm', ['unlink', pkg.name]);\n logger.info(`✅ Consumer unlinked: ${consumer.name} -/-> ${pkg.name}`);\n }\n } finally {\n process.chdir(consumerOriginalCwd);\n }\n } catch (error: any) {\n // npm unlink can fail if package wasn't linked, but that's OK\n logger.warn(`⚠️ Failed to unlink ${pkg.name} in ${consumer.name}: ${error.message}`);\n }\n }\n }\n\n // Step B: Run 'npm unlink' in the source package directory\n try {\n const originalCwd = process.cwd();\n process.chdir(pkg.path);\n\n try {\n if (isDryRun) {\n logger.info(`DRY RUN: Would run 'npm unlink' in: ${pkg.path}`);\n } else {\n logger.verbose(`Running 'npm unlink' in source: ${pkg.path}`);\n await run('npm unlink');\n logger.info(`✅ Source unlinked: ${pkg.name}`);\n }\n } finally {\n process.chdir(originalCwd);\n }\n\n unlinkedPackages.push(pkg.name);\n } catch (error: any) {\n // npm unlink can fail if package wasn't linked, but that's OK\n logger.warn(`⚠️ Failed to unlink source package ${pkg.name}: ${error.message}`);\n unlinkedPackages.push(pkg.name); // Still count as success\n }\n }\n\n const summary = `Successfully unlinked ${unlinkedPackages.length} package(s): ${unlinkedPackages.join(', ')}`;\n logger.info(summary);\n return summary;\n};\n\n// Status function to show what's currently linked (same as link command)\nconst executeStatus = async (runConfig: Config): Promise<string> => {\n const logger = getLogger();\n const storage = createStorage({ log: logger.info });\n\n // Get target directories from config, default to current directory\n const targetDirectories = runConfig.tree?.directories || [process.cwd()];\n\n if (targetDirectories.length === 1) {\n logger.info(`🔍 Checking link status in: ${targetDirectories[0]}`);\n } else {\n logger.info(`🔍 Checking link status in: ${targetDirectories.join(', ')}`);\n }\n\n // Find all packages in the workspace\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n const packageStatuses: Array<{\n name: string;\n path: string;\n linkedDependencies: Array<{ dependencyName: string; targetPath: string; isExternal: boolean }>;\n }> = [];\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n const linkedDependencies = await findLinkedDependencies(packageDir, packageJson.name, storage, logger);\n\n if (linkedDependencies.length > 0) {\n packageStatuses.push({\n name: packageJson.name,\n path: packageDir,\n linkedDependencies\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n if (packageStatuses.length === 0) {\n return 'No linked dependencies found in workspace.';\n }\n\n // Format the output\n let output = `Found ${packageStatuses.length} package(s) with linked dependencies:\\n\\n`;\n\n for (const packageStatus of packageStatuses) {\n output += `📦 ${packageStatus.name}\\n`;\n output += ` Path: ${packageStatus.path}\\n`;\n\n if (packageStatus.linkedDependencies.length > 0) {\n output += ` Linked dependencies:\\n`;\n for (const dep of packageStatus.linkedDependencies) {\n const type = dep.isExternal ? '🔗 External' : '🔗 Internal';\n output += ` ${type} ${dep.dependencyName} -> ${dep.targetPath}\\n`;\n }\n }\n output += '\\n';\n }\n\n return output;\n};\n\nexport const execute = async (runConfig: Config, packageArgument?: string): Promise<string> => {\n try {\n // Check if this is a status command from direct parameter\n if (packageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n // Use packageArgument from runConfig if not provided as parameter\n const finalPackageArgument = packageArgument || runConfig.unlink?.packageArgument;\n\n // Check if this is a status command from config\n if (finalPackageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n return await executeInternal(runConfig, finalPackageArgument);\n } catch (error: any) {\n const logger = getLogger();\n logger.error(`unlink failed: ${error.message}`);\n throw error;\n }\n};\n"],"names":["matchesExternalUnlinkPattern","dependencyName","externalUnlinkPatterns","length","some","pattern","startsWith","isSymbolicLink","filePath","stats","fs","lstat","getSymbolicLinkTarget","target","readlink","findLinkedDependencies","packagePath","packageName","storage","logger","linkedDependencies","packageJsonPath","path","join","packageJsonContent","readFile","parsed","safeJsonParse","packageJson","validatePackageJson","allDependencies","dependencies","devDependencies","nodeModulesPath","version","Object","entries","dependencyPath","scope","name","split","isExternal","includes","push","targetPath","error","warn","message","removeSymbolicLink","targetDir","isDryRun","verbose","unlink","code","parsePackageArgument","packageArg","parts","Error","findMatchingPackages","targetDirectories","matchingPackages","allPackageJsonFiles","targetDirectory","packageJsonFiles","findAllPackageJsonFiles","concat","packageJsonLocation","packageDir","replace","isInScope","isExactMatch","isSource","findConsumingPackages","targetPackageName","consumingPackages","dependencyTypes","hasDependency","depType","executeInternal","runConfig","packageArgument","dryRun","getDryRunLogger","createStorage","log","info","executeStatus","tree","directories","process","cwd","currentDir","exists","cleanNodeModules","externals","externalDependencies","keys","filter","depName","success","dryRunMessage","run","util","child_process","execPromise","promisify","exec","result","packageScope","stdout","trim","linksData","linkedPackages","scopeLinkedPackages","pkg","summary","unlinkedPackages","packagesToUnlink","consumer","consumerOriginalCwd","chdir","runSecure","originalCwd","getLogger","packageStatuses","output","packageStatus","dep","type","execute","finalPackageArgument"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"unlink.js","sources":["../../src/commands/unlink.ts"],"sourcesContent":["import { getDryRunLogger, getLogger } from '../logging';\nimport { Config } from '../types';\nimport { create as createStorage } from '../util/storage';\nimport { run, runSecure } from '@eldrforge/git-tools';\nimport {\n findAllPackageJsonFiles\n} from '../util/performance';\nimport { safeJsonParse, validatePackageJson } from '@eldrforge/git-tools';\nimport fs from 'fs/promises';\nimport path from 'path';\n\n// Helper function to check if a dependency matches any external unlink patterns\nexport const matchesExternalUnlinkPattern = (dependencyName: string, externalUnlinkPatterns: string[]): boolean => {\n if (!externalUnlinkPatterns || externalUnlinkPatterns.length === 0) {\n return false;\n }\n\n return externalUnlinkPatterns.some(pattern => {\n // Simple string matching - could be enhanced with glob patterns later\n return dependencyName === pattern || dependencyName.startsWith(pattern);\n });\n};\n\n// Helper function to check if a path is a symbolic link\nexport const isSymbolicLink = async (filePath: string): Promise<boolean> => {\n try {\n const stats = await fs.lstat(filePath);\n return stats.isSymbolicLink();\n } catch {\n return false;\n }\n};\n\n// Helper function to get the target of a symbolic link\nexport const getSymbolicLinkTarget = async (filePath: string): Promise<string | null> => {\n try {\n const target = await fs.readlink(filePath);\n return target;\n } catch {\n return null;\n }\n};\n\n// Helper function to find all linked dependencies in a package\nexport const findLinkedDependencies = async (\n packagePath: string,\n packageName: string,\n storage: any,\n logger: any\n): Promise<Array<{ dependencyName: string; targetPath: string; isExternal: boolean }>> => {\n const linkedDependencies: Array<{ dependencyName: string; targetPath: string; isExternal: boolean }> = [];\n\n try {\n const packageJsonPath = path.join(packagePath, 'package.json');\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n const allDependencies = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies\n };\n\n const nodeModulesPath = path.join(packagePath, 'node_modules');\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for (const [dependencyName, version] of Object.entries(allDependencies)) {\n let dependencyPath: string;\n\n if (dependencyName.startsWith('@')) {\n // Scoped package\n const [scope, name] = dependencyName.split('/');\n dependencyPath = path.join(nodeModulesPath, scope, name);\n } else {\n // Unscoped package\n dependencyPath = path.join(nodeModulesPath, dependencyName);\n }\n\n if (await isSymbolicLink(dependencyPath)) {\n const target = await getSymbolicLinkTarget(dependencyPath);\n if (target) {\n // Determine if this is an external dependency (not in the same workspace)\n const isExternal = !target.includes('node_modules') || target.startsWith('..');\n linkedDependencies.push({\n dependencyName,\n targetPath: target,\n isExternal\n });\n }\n }\n }\n } catch (error: any) {\n logger.warn(`UNLINK_CHECK_FAILED: Unable to check linked dependencies | Package: ${packageName} | Error: ${error.message}`);\n }\n\n return linkedDependencies;\n};\n\n// Helper function to remove symbolic links manually\nexport const removeSymbolicLink = async (\n packageName: string,\n targetDir: string,\n logger: any,\n isDryRun: boolean = false\n): Promise<boolean> => {\n try {\n // Parse package name to get scope and name parts\n const [scope, name] = packageName.startsWith('@')\n ? packageName.split('/')\n : [null, packageName];\n\n // Create the target path structure\n const nodeModulesPath = path.join(targetDir, 'node_modules');\n let targetPath: string;\n\n if (scope) {\n // Scoped package: node_modules/@scope/name\n targetPath = path.join(nodeModulesPath, scope, name);\n } else {\n // Unscoped package: node_modules/name\n targetPath = path.join(nodeModulesPath, name);\n }\n\n if (isDryRun) {\n logger.verbose(`DRY RUN: Would check and remove symlink: ${targetPath}`);\n return true;\n }\n\n // Check if something exists at the target path\n try {\n const stats = await fs.lstat(targetPath); // Use lstat to not follow symlinks\n\n if (stats.isSymbolicLink()) {\n // It's a symlink, remove it\n await fs.unlink(targetPath);\n logger.verbose(`Removed symlink: ${targetPath}`);\n return true;\n } else {\n logger.verbose(`Target exists but is not a symlink: ${targetPath}`);\n return false;\n }\n } catch (error: any) {\n if (error.code === 'ENOENT') {\n // Nothing exists at target path, nothing to remove\n logger.verbose(`No symlink found at: ${targetPath}`);\n return true;\n } else {\n throw error; // Re-throw unexpected errors\n }\n }\n } catch (error: any) {\n logger.warn(`UNLINK_SYMLINK_REMOVE_FAILED: Unable to remove symlink | Package: ${packageName} | Error: ${error.message}`);\n return false;\n }\n};\n\n// Helper function to parse package names and scopes (same as link command)\nexport const parsePackageArgument = (packageArg: string): { scope: string; packageName?: string } => {\n if (packageArg.startsWith('@')) {\n const parts = packageArg.split('/');\n if (parts.length === 1) {\n // Just a scope like \"@fjell\"\n return { scope: parts[0] };\n } else {\n // Full package name like \"@fjell/core\"\n return { scope: parts[0], packageName: packageArg };\n }\n } else {\n throw new Error(`Package argument must start with @ (scope): ${packageArg}`);\n }\n};\n\n// Find packages in the workspace that match the given scope or package name\nconst findMatchingPackages = async (\n targetDirectories: string[],\n scope: string,\n storage: any,\n logger: any,\n packageName?: string\n): Promise<Array<{ name: string; path: string; isSource: boolean }>> => {\n const matchingPackages: Array<{ name: string; path: string; isSource: boolean }> = [];\n\n // Find all package.json files in target directories\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n const isInScope = packageJson.name.startsWith(scope + '/');\n const isExactMatch = packageName && packageJson.name === packageName;\n\n if (isInScope || isExactMatch) {\n matchingPackages.push({\n name: packageJson.name,\n path: packageDir,\n isSource: packageName ? packageJson.name === packageName : isInScope\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n return matchingPackages;\n};\n\n// Find packages that depend on the target package\nconst findConsumingPackages = async (\n targetDirectories: string[],\n targetPackageName: string,\n storage: any,\n logger: any\n): Promise<Array<{ name: string; path: string }>> => {\n const consumingPackages: Array<{ name: string; path: string }> = [];\n\n // Find all package.json files in target directories\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n // Check if this package depends on the target package\n const dependencyTypes = ['dependencies', 'devDependencies', 'peerDependencies', 'optionalDependencies'];\n const hasDependency = dependencyTypes.some(depType =>\n packageJson[depType] && packageJson[depType][targetPackageName]\n );\n\n if (hasDependency && packageJson.name !== targetPackageName) {\n consumingPackages.push({\n name: packageJson.name,\n path: packageDir\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n return consumingPackages;\n};\n\nconst executeInternal = async (runConfig: Config, packageArgument?: string): Promise<string> => {\n const isDryRun = runConfig.dryRun || runConfig.unlink?.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n\n // Check if this is a status command\n if (packageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n // Get target directories from config, default to current directory\n const targetDirectories = runConfig.tree?.directories || [process.cwd()];\n\n if (targetDirectories.length === 1) {\n logger.info(`UNLINK_WORKSPACE_ANALYSIS: Analyzing single workspace directory | Path: ${targetDirectories[0]} | Purpose: Find packages to unlink`);\n } else {\n logger.info(`UNLINK_WORKSPACE_ANALYSIS: Analyzing multiple workspace directories | Paths: ${targetDirectories.join(', ')} | Count: ${targetDirectories.length} | Purpose: Find packages to unlink`);\n }\n\n // If no package argument provided, implement new behavior for current project\n if (!packageArgument) {\n logger.info('UNLINK_SMART_MODE: Smart unlinking mode activated for current project | Mode: smart | Target: current directory | Purpose: Auto-unlink based on scope');\n\n const currentDir = process.cwd();\n const packageJsonPath = `${currentDir}/package.json`;\n\n // Check if we're in a directory with package.json\n if (!(await storage.exists(packageJsonPath))) {\n const message = `No package.json found in current directory: ${currentDir}`;\n logger.warn('UNLINK_NO_PACKAGE_JSON: No package.json found in current directory | Directory: ' + currentDir + ' | Action: Cannot unlink without package.json');\n return message;\n }\n\n // Parse package.json to get package name\n let packageName: string;\n try {\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n if (!packageJson.name) {\n throw new Error('package.json has no name field');\n }\n packageName = packageJson.name;\n } catch (error: any) {\n const message = `Failed to parse package.json: ${error.message}`;\n logger.error('UNLINK_PACKAGE_NAME_MISSING: package.json must have a name field | Field: name | Requirement: Required for unlinking | Action: Add name field to package.json');\n return message;\n }\n\n logger.info(`UNLINK_PACKAGE_PROCESSING: Processing package for unlinking | Package: ${packageName} | Action: Remove symlinks and restore registry versions`);\n\n const cleanNodeModules = runConfig.unlink?.cleanNodeModules || false;\n const externalUnlinkPatterns = runConfig.unlink?.externals || [];\n\n // Step 0: Handle external dependencies if patterns are specified\n if (externalUnlinkPatterns.length > 0) {\n logger.info(`UNLINK_EXTERNAL_DEPS: Processing external dependencies | Patterns: ${externalUnlinkPatterns.join(', ')} | Purpose: Unlink external packages before main package`);\n\n // Read package.json to get dependencies\n const packageJsonContent = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonPath);\n const packageJson = validatePackageJson(parsed, packageJsonPath);\n\n const allDependencies = {\n ...packageJson.dependencies,\n ...packageJson.devDependencies\n };\n\n const externalDependencies = Object.keys(allDependencies).filter(depName =>\n matchesExternalUnlinkPattern(depName, externalUnlinkPatterns)\n );\n\n if (externalDependencies.length > 0) {\n logger.info(`UNLINK_EXTERNAL_FOUND: Found external dependencies to unlink | Count: ${externalDependencies.length} | Dependencies: ${externalDependencies.join(', ')}`);\n\n for (const depName of externalDependencies) {\n try {\n const success = await removeSymbolicLink(depName, currentDir, logger, isDryRun);\n if (success) {\n logger.info(`UNLINK_EXTERNAL_SUCCESS: External dependency unlinked successfully | Dependency: ${depName} | Status: unlinked`);\n } else {\n logger.warn(`UNLINK_EXTERNAL_FAILED: Failed to unlink external dependency | Dependency: ${depName} | Status: failed`);\n }\n } catch (error: any) {\n logger.warn(`UNLINK_EXTERNAL_ERROR: Error during external dependency unlink | Dependency: ${depName} | Error: ${error.message}`);\n }\n }\n } else {\n logger.info('UNLINK_EXTERNAL_NONE: No external dependencies found matching patterns | Patterns: ' + externalUnlinkPatterns.join(', ') + ' | Action: Skipping external unlink');\n }\n }\n\n if (isDryRun) {\n let dryRunMessage = `DRY RUN: Would execute unlink steps for ${packageName}:\\n`;\n if (externalUnlinkPatterns.length > 0) {\n dryRunMessage += ` 0. Unlink external dependencies matching patterns: ${externalUnlinkPatterns.join(', ')}\\n`;\n }\n dryRunMessage += ` 1. npm unlink -g\\n`;\n if (cleanNodeModules) {\n dryRunMessage += ` 2. rm -rf node_modules package-lock.json\\n`;\n dryRunMessage += ` 3. npm install\\n`;\n dryRunMessage += ` 4. Check for remaining links with npm ls --link`;\n } else {\n dryRunMessage += ` 2. Check for remaining links with npm ls --link\\n`;\n dryRunMessage += ` Note: Use --clean-node-modules flag to also clean and reinstall dependencies`;\n }\n\n logger.info(dryRunMessage);\n return dryRunMessage;\n }\n\n // Step 1: Remove global link\n logger.info('UNLINK_GLOBAL_REMOVING: Removing global npm link | Step: 1 | Command: npm unlink -g | Purpose: Remove package from global npm');\n try {\n await run('npm unlink -g');\n logger.info('UNLINK_GLOBAL_SUCCESS: Global link removed successfully | Status: unlinked | Location: global npm');\n } catch (error: any) {\n // This might fail if the package wasn't globally linked, which is OK\n logger.warn(`UNLINK_GLOBAL_SKIP: Failed to remove global link | Error: ${error.message} | Impact: OK if package wasn't linked | Status: continuing`);\n }\n\n if (cleanNodeModules) {\n // Step 2: Clean node_modules and package-lock.json\n logger.info('UNLINK_CLEANING: Cleaning node_modules and package-lock.json | Command: rm -rf | Purpose: Remove symlinked dependencies');\n try {\n await run('rm -rf node_modules package-lock.json');\n logger.info('UNLINK_CLEAN_SUCCESS: Successfully cleaned node_modules and package-lock.json | Status: removed | Next: Fresh install');\n } catch (error: any) {\n logger.warn(`UNLINK_CLEAN_FAILED: Failed to clean directories | Error: ${error.message} | Impact: May need manual cleanup`);\n }\n\n // Step 3: Install dependencies\n logger.info('UNLINK_INSTALLING: Installing dependencies from registry | Command: npm install | Purpose: Restore registry versions');\n try {\n await run('npm install');\n logger.info('UNLINK_INSTALL_SUCCESS: Dependencies installed successfully | Source: npm registry | Status: completed');\n } catch (error: any) {\n logger.error(`UNLINK_INSTALL_FAILED: Failed to install dependencies | Error: ${error.message} | Impact: Package may be in inconsistent state`);\n throw error;\n }\n\n // Step 4: Check for remaining links (suppress output and errors)\n logger.info('UNLINK_CHECK_REMAINING: Checking for remaining symlinks | Purpose: Verify clean unlink | Action: Scan node_modules');\n } else {\n // Step 2: Check for remaining links (suppress output and errors)\n logger.info('UNLINK_CHECK_REMAINING: Checking for remaining symlinks | Mode: skip-reinstall | Purpose: Verify unlink | Action: Scan node_modules');\n logger.info('Note: Use --clean-node-modules flag to also clean and reinstall dependencies');\n }\n\n try {\n // Use child_process directly to suppress logging and get JSON output\n const util = await import('util');\n const child_process = await import('child_process');\n const execPromise = util.promisify(child_process.exec);\n\n const result = await execPromise('npm ls --link --json');\n\n // Parse JSON output to check for links to packages in the same scope\n const packageScope = packageName.includes('/') ? packageName.split('/')[0] : null;\n\n if (packageScope && result.stdout.trim()) {\n try {\n const linksData = safeJsonParse(result.stdout, 'npm ls output after unlink');\n const linkedPackages = Object.keys(linksData.dependencies || {});\n const scopeLinkedPackages = linkedPackages.filter(pkg => pkg.startsWith(packageScope + '/'));\n\n if (scopeLinkedPackages.length > 0) {\n logger.warn(`UNLINK_REMAINING_LINKS: Found remaining links to packages in scope | Scope: ${packageScope} | Packages: ${scopeLinkedPackages.join(', ')} | Note: May be expected if workspace packages linked`);\n logger.verbose('UNLINK_REMAINING_NOTE: Remaining links may be expected | Reason: Other workspace packages still linked | Status: normal');\n } else {\n logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');\n }\n } catch {\n // If JSON parsing fails, fall back to basic check\n logger.verbose('Failed to parse npm ls --link --json output, using basic check');\n if (result.stdout.includes(packageScope)) {\n logger.warn(`UNLINK_REMAINING_LINKS_BASIC: Found remaining links to scope | Scope: ${packageScope} | Check: basic | Note: May be expected`);\n logger.verbose('UNLINK_REMAINING_NOTE: Remaining links may be expected | Reason: Other workspace packages still linked | Status: normal');\n } else {\n logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');\n }\n }\n } else {\n logger.info('UNLINK_VERIFY_CLEAN: No problematic links found | Status: clean | Verification: passed');\n }\n } catch {\n // npm ls --link returns non-zero when there are no links, which is what we want\n // So we only log this at verbose level\n logger.verbose('npm ls --link check completed (non-zero exit is expected when no links exist)');\n }\n\n const summary = `Successfully unlinked ${packageName}`;\n logger.info(summary);\n return summary;\n }\n\n // New scope-based unlinking behavior\n logger.info(`UNLINK_EXPLICIT_MODE: Unlinking specific scope/package | Target: ${packageArgument} | Mode: explicit | Purpose: Remove symlinks for package`);\n\n const { scope, packageName } = parsePackageArgument(packageArgument);\n logger.verbose(`Parsed scope: ${scope}, package: ${packageName || 'all packages in scope'}`);\n\n // Find matching packages in the workspace\n const matchingPackages = await findMatchingPackages(targetDirectories, scope, storage, logger, packageName);\n\n if (matchingPackages.length === 0) {\n const message = packageName\n ? `No package found matching: ${packageName}`\n : `No packages found in scope: ${scope}`;\n logger.warn(message);\n return message;\n }\n\n logger.info(`Found ${matchingPackages.length} matching package(s)`);\n\n const unlinkedPackages: string[] = [];\n\n // If specific package name provided, use that; otherwise unlink all packages in scope\n const packagesToUnlink = packageName\n ? matchingPackages.filter(pkg => pkg.name === packageName)\n : matchingPackages;\n\n for (const pkg of packagesToUnlink) {\n logger.info(`Processing package: ${pkg.name}`);\n\n // Step A: Find all packages that depend on this package and unlink them first\n const consumingPackages = await findConsumingPackages(targetDirectories, pkg.name, storage, logger);\n\n if (consumingPackages.length === 0) {\n logger.info(`No consuming packages found for: ${pkg.name}`);\n } else {\n logger.info(`Found ${consumingPackages.length} consuming package(s) for: ${pkg.name}`);\n\n for (const consumer of consumingPackages) {\n try {\n const consumerOriginalCwd = process.cwd();\n process.chdir(consumer.path);\n\n try {\n if (isDryRun) {\n logger.info(`DRY RUN: Would run 'npm unlink ${pkg.name}' in: ${consumer.path}`);\n } else {\n logger.verbose(`Running 'npm unlink ${pkg.name}' in consumer: ${consumer.path}`);\n await runSecure('npm', ['unlink', pkg.name]);\n logger.info(`UNLINK_CONSUMER_SUCCESS: Consumer unlinked from package | Consumer: ${consumer.name} | Package: ${pkg.name} | Status: unlinked`);\n }\n } finally {\n process.chdir(consumerOriginalCwd);\n }\n } catch (error: any) {\n // npm unlink can fail if package wasn't linked, but that's OK\n logger.warn(`UNLINK_CONSUMER_FAILED: Failed to unlink consumer | Consumer: ${consumer.name} | Package: ${pkg.name} | Error: ${error.message}`);\n }\n }\n }\n\n // Step B: Run 'npm unlink' in the source package directory\n try {\n const originalCwd = process.cwd();\n process.chdir(pkg.path);\n\n try {\n if (isDryRun) {\n logger.info(`DRY RUN: Would run 'npm unlink' in: ${pkg.path}`);\n } else {\n logger.verbose(`Running 'npm unlink' in source: ${pkg.path}`);\n await run('npm unlink');\n logger.info(`UNLINK_SOURCE_SUCCESS: Source package unlinked | Package: ${pkg.name} | Status: unlinked`);\n }\n } finally {\n process.chdir(originalCwd);\n }\n\n unlinkedPackages.push(pkg.name);\n } catch (error: any) {\n // npm unlink can fail if package wasn't linked, but that's OK\n logger.warn(`UNLINK_SOURCE_FAILED: Failed to unlink source package | Package: ${pkg.name} | Error: ${error.message}`);\n unlinkedPackages.push(pkg.name); // Still count as success\n }\n }\n\n const summary = `Successfully unlinked ${unlinkedPackages.length} package(s): ${unlinkedPackages.join(', ')}`;\n logger.info(summary);\n return summary;\n};\n\n// Status function to show what's currently linked (same as link command)\nconst executeStatus = async (runConfig: Config): Promise<string> => {\n const logger = getLogger();\n const storage = createStorage({ log: logger.info });\n\n // Get target directories from config, default to current directory\n const targetDirectories = runConfig.tree?.directories || [process.cwd()];\n\n if (targetDirectories.length === 1) {\n logger.info(`UNLINK_STATUS_CHECK: Checking link status in directory | Directory: ${targetDirectories[0]} | Purpose: Show current symlinks`);\n } else {\n logger.info(`UNLINK_STATUS_CHECK: Checking link status in directories | Directories: ${targetDirectories.join(', ')} | Count: ${targetDirectories.length} | Purpose: Show current symlinks`);\n }\n\n // Find all packages in the workspace\n let allPackageJsonFiles: any[] = [];\n for (const targetDirectory of targetDirectories) {\n const packageJsonFiles = await findAllPackageJsonFiles(targetDirectory, storage);\n allPackageJsonFiles = allPackageJsonFiles.concat(packageJsonFiles);\n }\n\n const packageStatuses: Array<{\n name: string;\n path: string;\n linkedDependencies: Array<{ dependencyName: string; targetPath: string; isExternal: boolean }>;\n }> = [];\n\n for (const packageJsonLocation of allPackageJsonFiles) {\n const packageDir = packageJsonLocation.path.replace('/package.json', '');\n\n try {\n const packageJsonContent = await storage.readFile(packageJsonLocation.path, 'utf-8');\n const parsed = safeJsonParse(packageJsonContent, packageJsonLocation.path);\n const packageJson = validatePackageJson(parsed, packageJsonLocation.path);\n\n if (!packageJson.name) continue;\n\n const linkedDependencies = await findLinkedDependencies(packageDir, packageJson.name, storage, logger);\n\n if (linkedDependencies.length > 0) {\n packageStatuses.push({\n name: packageJson.name,\n path: packageDir,\n linkedDependencies\n });\n }\n } catch (error: any) {\n logger.warn(`Failed to parse ${packageJsonLocation.path}: ${error.message}`);\n }\n }\n\n if (packageStatuses.length === 0) {\n return 'No linked dependencies found in workspace.';\n }\n\n // Format the output\n let output = `Found ${packageStatuses.length} package(s) with linked dependencies:\\n\\n`;\n\n for (const packageStatus of packageStatuses) {\n output += `📦 ${packageStatus.name}\\n`;\n output += ` Path: ${packageStatus.path}\\n`;\n\n if (packageStatus.linkedDependencies.length > 0) {\n output += ` Linked dependencies:\\n`;\n for (const dep of packageStatus.linkedDependencies) {\n const type = dep.isExternal ? '🔗 External' : '🔗 Internal';\n output += ` ${type} ${dep.dependencyName} -> ${dep.targetPath}\\n`;\n }\n }\n output += '\\n';\n }\n\n return output;\n};\n\nexport const execute = async (runConfig: Config, packageArgument?: string): Promise<string> => {\n try {\n // Check if this is a status command from direct parameter\n if (packageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n // Use packageArgument from runConfig if not provided as parameter\n const finalPackageArgument = packageArgument || runConfig.unlink?.packageArgument;\n\n // Check if this is a status command from config\n if (finalPackageArgument === 'status') {\n return await executeStatus(runConfig);\n }\n\n return await executeInternal(runConfig, finalPackageArgument);\n } catch (error: any) {\n const logger = getLogger();\n logger.error(`unlink failed: ${error.message}`);\n throw error;\n }\n};\n"],"names":["matchesExternalUnlinkPattern","dependencyName","externalUnlinkPatterns","length","some","pattern","startsWith","isSymbolicLink","filePath","stats","fs","lstat","getSymbolicLinkTarget","target","readlink","findLinkedDependencies","packagePath","packageName","storage","logger","linkedDependencies","packageJsonPath","path","join","packageJsonContent","readFile","parsed","safeJsonParse","packageJson","validatePackageJson","allDependencies","dependencies","devDependencies","nodeModulesPath","version","Object","entries","dependencyPath","scope","name","split","isExternal","includes","push","targetPath","error","warn","message","removeSymbolicLink","targetDir","isDryRun","verbose","unlink","code","parsePackageArgument","packageArg","parts","Error","findMatchingPackages","targetDirectories","matchingPackages","allPackageJsonFiles","targetDirectory","packageJsonFiles","findAllPackageJsonFiles","concat","packageJsonLocation","packageDir","replace","isInScope","isExactMatch","isSource","findConsumingPackages","targetPackageName","consumingPackages","dependencyTypes","hasDependency","depType","executeInternal","runConfig","packageArgument","dryRun","getDryRunLogger","createStorage","log","info","executeStatus","tree","directories","process","cwd","currentDir","exists","cleanNodeModules","externals","externalDependencies","keys","filter","depName","success","dryRunMessage","run","util","child_process","execPromise","promisify","exec","result","packageScope","stdout","trim","linksData","linkedPackages","scopeLinkedPackages","pkg","summary","unlinkedPackages","packagesToUnlink","consumer","consumerOriginalCwd","chdir","runSecure","originalCwd","getLogger","packageStatuses","output","packageStatus","dep","type","execute","finalPackageArgument"],"mappings":"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"}
|