@xylabs/toolchain 7.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/analyze.mjs +140 -0
- package/dist/actions/analyze.mjs.map +1 -0
- package/dist/actions/build.mjs +173 -0
- package/dist/actions/build.mjs.map +1 -0
- package/dist/actions/claude-check.mjs +199 -0
- package/dist/actions/claude-check.mjs.map +1 -0
- package/dist/actions/claude-clean.mjs +70 -0
- package/dist/actions/claude-clean.mjs.map +1 -0
- package/dist/actions/claude-commands.mjs +126 -0
- package/dist/actions/claude-commands.mjs.map +1 -0
- package/dist/actions/claude-rules.mjs +151 -0
- package/dist/actions/claude-rules.mjs.map +1 -0
- package/dist/actions/claude-settings.mjs +99 -0
- package/dist/actions/claude-settings.mjs.map +1 -0
- package/dist/actions/claude-skills.mjs +131 -0
- package/dist/actions/claude-skills.mjs.map +1 -0
- package/dist/actions/clean-docs.mjs +66 -0
- package/dist/actions/clean-docs.mjs.map +1 -0
- package/dist/actions/clean-eslint.mjs +47 -0
- package/dist/actions/clean-eslint.mjs.map +1 -0
- package/dist/actions/clean.mjs +166 -0
- package/dist/actions/clean.mjs.map +1 -0
- package/dist/actions/compile.mjs +184 -0
- package/dist/actions/compile.mjs.map +1 -0
- package/dist/actions/copy-assets.mjs +81 -0
- package/dist/actions/copy-assets.mjs.map +1 -0
- package/dist/actions/cycle.mjs +275 -0
- package/dist/actions/cycle.mjs.map +1 -0
- package/dist/actions/dead.mjs +119 -0
- package/dist/actions/dead.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/checkPackage.mjs +1556 -0
- package/dist/actions/deplint/checkPackage/checkPackage.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/checkPackageTypes.mjs +1 -0
- package/dist/actions/deplint/checkPackage/checkPackageTypes.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getMismatchedPeerDevVersions.mjs +77 -0
- package/dist/actions/deplint/checkPackage/getMismatchedPeerDevVersions.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnlistedDependencies.mjs +158 -0
- package/dist/actions/deplint/checkPackage/getUnlistedDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnlistedDevDependencies.mjs +125 -0
- package/dist/actions/deplint/checkPackage/getUnlistedDevDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnnecessaryPeerDependencies.mjs +207 -0
- package/dist/actions/deplint/checkPackage/getUnnecessaryPeerDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnsatisfiedPeerDependencies.mjs +318 -0
- package/dist/actions/deplint/checkPackage/getUnsatisfiedPeerDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnusedDependencies.mjs +163 -0
- package/dist/actions/deplint/checkPackage/getUnusedDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnusedDevDependencies.mjs +408 -0
- package/dist/actions/deplint/checkPackage/getUnusedDevDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getUnusedPeerDependencies.mjs +75 -0
- package/dist/actions/deplint/checkPackage/getUnusedPeerDependencies.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/getWorkspaceVersionProblems.mjs +128 -0
- package/dist/actions/deplint/checkPackage/getWorkspaceVersionProblems.mjs.map +1 -0
- package/dist/actions/deplint/checkPackage/index.mjs +1609 -0
- package/dist/actions/deplint/checkPackage/index.mjs.map +1 -0
- package/dist/actions/deplint/deplint.mjs +1840 -0
- package/dist/actions/deplint/deplint.mjs.map +1 -0
- package/dist/actions/deplint/engine.mjs +1736 -0
- package/dist/actions/deplint/engine.mjs.map +1 -0
- package/dist/actions/deplint/findFiles.mjs +39 -0
- package/dist/actions/deplint/findFiles.mjs.map +1 -0
- package/dist/actions/deplint/findFilesByGlob.mjs +14 -0
- package/dist/actions/deplint/findFilesByGlob.mjs.map +1 -0
- package/dist/actions/deplint/fixer.mjs +103 -0
- package/dist/actions/deplint/fixer.mjs.map +1 -0
- package/dist/actions/deplint/getBasePackageName.mjs +13 -0
- package/dist/actions/deplint/getBasePackageName.mjs.map +1 -0
- package/dist/actions/deplint/getCliReferencedPackagesFromFiles.mjs +140 -0
- package/dist/actions/deplint/getCliReferencedPackagesFromFiles.mjs.map +1 -0
- package/dist/actions/deplint/getDependenciesFromPackageJson.mjs +29 -0
- package/dist/actions/deplint/getDependenciesFromPackageJson.mjs.map +1 -0
- package/dist/actions/deplint/getExtendsFromTsconfigs.mjs +68 -0
- package/dist/actions/deplint/getExtendsFromTsconfigs.mjs.map +1 -0
- package/dist/actions/deplint/getExternalImportsFromFiles.mjs +143 -0
- package/dist/actions/deplint/getExternalImportsFromFiles.mjs.map +1 -0
- package/dist/actions/deplint/getImportsFromFile.mjs +85 -0
- package/dist/actions/deplint/getImportsFromFile.mjs.map +1 -0
- package/dist/actions/deplint/getRequiredPeerDependencies.mjs +37 -0
- package/dist/actions/deplint/getRequiredPeerDependencies.mjs.map +1 -0
- package/dist/actions/deplint/getScriptReferencedPackages.mjs +83 -0
- package/dist/actions/deplint/getScriptReferencedPackages.mjs.map +1 -0
- package/dist/actions/deplint/implicitDevDependencies.mjs +116 -0
- package/dist/actions/deplint/implicitDevDependencies.mjs.map +1 -0
- package/dist/actions/deplint/index.mjs +1848 -0
- package/dist/actions/deplint/index.mjs.map +1 -0
- package/dist/actions/deplint/packageEditor.mjs +82 -0
- package/dist/actions/deplint/packageEditor.mjs.map +1 -0
- package/dist/actions/deplint/packageJsonEditor.mjs +101 -0
- package/dist/actions/deplint/packageJsonEditor.mjs.map +1 -0
- package/dist/actions/deplint/reporters.mjs +36 -0
- package/dist/actions/deplint/reporters.mjs.map +1 -0
- package/dist/actions/deplint/rules.mjs +1223 -0
- package/dist/actions/deplint/rules.mjs.map +1 -0
- package/dist/actions/deplint/snapshot.mjs +372 -0
- package/dist/actions/deplint/snapshot.mjs.map +1 -0
- package/dist/actions/deplint/tsScriptsAliases.mjs +20 -0
- package/dist/actions/deplint/tsScriptsAliases.mjs.map +1 -0
- package/dist/actions/deplint/types.mjs +1 -0
- package/dist/actions/deplint/types.mjs.map +1 -0
- package/dist/actions/deploy.mjs +194 -0
- package/dist/actions/deploy.mjs.map +1 -0
- package/dist/actions/dupdeps.mjs +226 -0
- package/dist/actions/dupdeps.mjs.map +1 -0
- package/dist/actions/eject.mjs +142 -0
- package/dist/actions/eject.mjs.map +1 -0
- package/dist/actions/fix.mjs +359 -0
- package/dist/actions/fix.mjs.map +1 -0
- package/dist/actions/gen-docs.mjs +155 -0
- package/dist/actions/gen-docs.mjs.map +1 -0
- package/dist/actions/gitignore.mjs +159 -0
- package/dist/actions/gitignore.mjs.map +1 -0
- package/dist/actions/gitlint-fix.mjs +27 -0
- package/dist/actions/gitlint-fix.mjs.map +1 -0
- package/dist/actions/gitlint.mjs +48 -0
- package/dist/actions/gitlint.mjs.map +1 -0
- package/dist/actions/index.mjs +8259 -0
- package/dist/actions/index.mjs.map +1 -0
- package/dist/actions/knip.mjs +119 -0
- package/dist/actions/knip.mjs.map +1 -0
- package/dist/actions/license.mjs +92 -0
- package/dist/actions/license.mjs.map +1 -0
- package/dist/actions/lint-init.mjs +275 -0
- package/dist/actions/lint-init.mjs.map +1 -0
- package/dist/actions/lint.mjs +356 -0
- package/dist/actions/lint.mjs.map +1 -0
- package/dist/actions/lintNext.mjs +209 -0
- package/dist/actions/lintNext.mjs.map +1 -0
- package/dist/actions/lintlint.mjs +341 -0
- package/dist/actions/lintlint.mjs.map +1 -0
- package/dist/actions/npmignore-gen.mjs +90 -0
- package/dist/actions/npmignore-gen.mjs.map +1 -0
- package/dist/actions/orphan.mjs +110 -0
- package/dist/actions/orphan.mjs.map +1 -0
- package/dist/actions/package/clean-outputs.mjs +50 -0
- package/dist/actions/package/clean-outputs.mjs.map +1 -0
- package/dist/actions/package/clean-typescript.mjs +50 -0
- package/dist/actions/package/clean-typescript.mjs.map +1 -0
- package/dist/actions/package/clean.mjs +69 -0
- package/dist/actions/package/clean.mjs.map +1 -0
- package/dist/actions/package/compile/XyConfig.mjs +32 -0
- package/dist/actions/package/compile/XyConfig.mjs.map +1 -0
- package/dist/actions/package/compile/buildEntries.mjs +53 -0
- package/dist/actions/package/compile/buildEntries.mjs.map +1 -0
- package/dist/actions/package/compile/compile.mjs +439 -0
- package/dist/actions/package/compile/compile.mjs.map +1 -0
- package/dist/actions/package/compile/copyTypeFiles.mjs +34 -0
- package/dist/actions/package/compile/copyTypeFiles.mjs.map +1 -0
- package/dist/actions/package/compile/deepMerge.mjs +27 -0
- package/dist/actions/package/compile/deepMerge.mjs.map +1 -0
- package/dist/actions/package/compile/getCompilerOptions.mjs +12 -0
- package/dist/actions/package/compile/getCompilerOptions.mjs.map +1 -0
- package/dist/actions/package/compile/index.mjs +472 -0
- package/dist/actions/package/compile/index.mjs.map +1 -0
- package/dist/actions/package/compile/inputs.mjs +22 -0
- package/dist/actions/package/compile/inputs.mjs.map +1 -0
- package/dist/actions/package/compile/packageCompileTsc.mjs +93 -0
- package/dist/actions/package/compile/packageCompileTsc.mjs.map +1 -0
- package/dist/actions/package/compile/packageCompileTscTypes.mjs +92 -0
- package/dist/actions/package/compile/packageCompileTscTypes.mjs.map +1 -0
- package/dist/actions/package/compile/packageCompileTsup.mjs +402 -0
- package/dist/actions/package/compile/packageCompileTsup.mjs.map +1 -0
- package/dist/actions/package/copy-assets.mjs +69 -0
- package/dist/actions/package/copy-assets.mjs.map +1 -0
- package/dist/actions/package/cycle.mjs +62 -0
- package/dist/actions/package/cycle.mjs.map +1 -0
- package/dist/actions/package/gen-docs.mjs +137 -0
- package/dist/actions/package/gen-docs.mjs.map +1 -0
- package/dist/actions/package/index.mjs +1131 -0
- package/dist/actions/package/index.mjs.map +1 -0
- package/dist/actions/package/lint.mjs +87 -0
- package/dist/actions/package/lint.mjs.map +1 -0
- package/dist/actions/package/publint.mjs +336 -0
- package/dist/actions/package/publint.mjs.map +1 -0
- package/dist/actions/package/recompile.mjs +510 -0
- package/dist/actions/package/recompile.mjs.map +1 -0
- package/dist/actions/package-lint-deps.mjs +348 -0
- package/dist/actions/package-lint-deps.mjs.map +1 -0
- package/dist/actions/package-lint.mjs +774 -0
- package/dist/actions/package-lint.mjs.map +1 -0
- package/dist/actions/packman/clean.mjs +144 -0
- package/dist/actions/packman/clean.mjs.map +1 -0
- package/dist/actions/packman/convert.mjs +1331 -0
- package/dist/actions/packman/convert.mjs.map +1 -0
- package/dist/actions/packman/convertToPnpm.mjs +295 -0
- package/dist/actions/packman/convertToPnpm.mjs.map +1 -0
- package/dist/actions/packman/convertToYarn.mjs +307 -0
- package/dist/actions/packman/convertToYarn.mjs.map +1 -0
- package/dist/actions/packman/index.mjs +1493 -0
- package/dist/actions/packman/index.mjs.map +1 -0
- package/dist/actions/packman/lint.mjs +109 -0
- package/dist/actions/packman/lint.mjs.map +1 -0
- package/dist/actions/packman/rewriteScripts.mjs +52 -0
- package/dist/actions/packman/rewriteScripts.mjs.map +1 -0
- package/dist/actions/packman/rewriteSourceImports.mjs +60 -0
- package/dist/actions/packman/rewriteSourceImports.mjs.map +1 -0
- package/dist/actions/packman/swapTsScriptsDependency.mjs +57 -0
- package/dist/actions/packman/swapTsScriptsDependency.mjs.map +1 -0
- package/dist/actions/publint.mjs +748 -0
- package/dist/actions/publint.mjs.map +1 -0
- package/dist/actions/publish.mjs +208 -0
- package/dist/actions/publish.mjs.map +1 -0
- package/dist/actions/reactTest.mjs +142 -0
- package/dist/actions/reactTest.mjs.map +1 -0
- package/dist/actions/readme-gen.mjs +362 -0
- package/dist/actions/readme-gen.mjs.map +1 -0
- package/dist/actions/readme-init.mjs +89 -0
- package/dist/actions/readme-init.mjs.map +1 -0
- package/dist/actions/readme-lint.mjs +147 -0
- package/dist/actions/readme-lint.mjs.map +1 -0
- package/dist/actions/rebuild.mjs +143 -0
- package/dist/actions/rebuild.mjs.map +1 -0
- package/dist/actions/recompile.mjs +196 -0
- package/dist/actions/recompile.mjs.map +1 -0
- package/dist/actions/reinstall.mjs +283 -0
- package/dist/actions/reinstall.mjs.map +1 -0
- package/dist/actions/relint.mjs +355 -0
- package/dist/actions/relint.mjs.map +1 -0
- package/dist/actions/repo-init.mjs +217 -0
- package/dist/actions/repo-init.mjs.map +1 -0
- package/dist/actions/retest.mjs +150 -0
- package/dist/actions/retest.mjs.map +1 -0
- package/dist/actions/sitemap.mjs +121 -0
- package/dist/actions/sitemap.mjs.map +1 -0
- package/dist/actions/sonar.mjs +119 -0
- package/dist/actions/sonar.mjs.map +1 -0
- package/dist/actions/start.mjs +142 -0
- package/dist/actions/start.mjs.map +1 -0
- package/dist/actions/statics.mjs +225 -0
- package/dist/actions/statics.mjs.map +1 -0
- package/dist/actions/test.mjs +144 -0
- package/dist/actions/test.mjs.map +1 -0
- package/dist/actions/up.mjs +140 -0
- package/dist/actions/up.mjs.map +1 -0
- package/dist/actions/updo.mjs +533 -0
- package/dist/actions/updo.mjs.map +1 -0
- package/dist/actions/upplug.mjs +124 -0
- package/dist/actions/upplug.mjs.map +1 -0
- package/dist/actions/upyarn.mjs +119 -0
- package/dist/actions/upyarn.mjs.map +1 -0
- package/dist/actions/yarn3only.mjs +60 -0
- package/dist/actions/yarn3only.mjs.map +1 -0
- package/dist/bin/package/build-only.mjs +451 -0
- package/dist/bin/package/build-only.mjs.map +1 -0
- package/dist/bin/package/build.mjs +451 -0
- package/dist/bin/package/build.mjs.map +1 -0
- package/dist/bin/package/clean-outputs.mjs +50 -0
- package/dist/bin/package/clean-outputs.mjs.map +1 -0
- package/dist/bin/package/clean-typescript.mjs +50 -0
- package/dist/bin/package/clean-typescript.mjs.map +1 -0
- package/dist/bin/package/clean.mjs +75 -0
- package/dist/bin/package/clean.mjs.map +1 -0
- package/dist/bin/package/compile-only.mjs +447 -0
- package/dist/bin/package/compile-only.mjs.map +1 -0
- package/dist/bin/package/compile-tsup.mjs +409 -0
- package/dist/bin/package/compile-tsup.mjs.map +1 -0
- package/dist/bin/package/compile.mjs +451 -0
- package/dist/bin/package/compile.mjs.map +1 -0
- package/dist/bin/package/copy-assets-cjs.mjs +75 -0
- package/dist/bin/package/copy-assets-cjs.mjs.map +1 -0
- package/dist/bin/package/copy-assets-esm.mjs +75 -0
- package/dist/bin/package/copy-assets-esm.mjs.map +1 -0
- package/dist/bin/package/cycle.mjs +72 -0
- package/dist/bin/package/cycle.mjs.map +1 -0
- package/dist/bin/package/fix.mjs +97 -0
- package/dist/bin/package/fix.mjs.map +1 -0
- package/dist/bin/package/gen-docs.mjs +142 -0
- package/dist/bin/package/gen-docs.mjs.map +1 -0
- package/dist/bin/package/lint-verbose.mjs +97 -0
- package/dist/bin/package/lint-verbose.mjs.map +1 -0
- package/dist/bin/package/lint.mjs +97 -0
- package/dist/bin/package/lint.mjs.map +1 -0
- package/dist/bin/package/publint.mjs +423 -0
- package/dist/bin/package/publint.mjs.map +1 -0
- package/dist/bin/package/recompile.mjs +516 -0
- package/dist/bin/package/recompile.mjs.map +1 -0
- package/dist/bin/package/relint.mjs +97 -0
- package/dist/bin/package/relint.mjs.map +1 -0
- package/dist/bin/run-or-exec.mjs +20 -0
- package/dist/bin/run-or-exec.mjs.map +1 -0
- package/dist/bin/xy.mjs +8885 -0
- package/dist/bin/xy.mjs.map +1 -0
- package/dist/index.d.ts +1102 -0
- package/dist/index.mjs +9986 -0
- package/dist/index.mjs.map +1 -0
- package/dist/lib/checkResult.mjs +16 -0
- package/dist/lib/checkResult.mjs.map +1 -0
- package/dist/lib/claudeMdTemplate.mjs +69 -0
- package/dist/lib/claudeMdTemplate.mjs.map +1 -0
- package/dist/lib/concurrency.mjs +38 -0
- package/dist/lib/concurrency.mjs.map +1 -0
- package/dist/lib/createBuildConfig.mjs +55 -0
- package/dist/lib/createBuildConfig.mjs.map +1 -0
- package/dist/lib/defaultBuildConfig.mjs +23 -0
- package/dist/lib/defaultBuildConfig.mjs.map +1 -0
- package/dist/lib/deleteGlob.mjs +13 -0
- package/dist/lib/deleteGlob.mjs.map +1 -0
- package/dist/lib/dependencies/DuplicateDetector.mjs +99 -0
- package/dist/lib/dependencies/DuplicateDetector.mjs.map +1 -0
- package/dist/lib/dependencies/detectDuplicateDependencies.mjs +203 -0
- package/dist/lib/dependencies/detectDuplicateDependencies.mjs.map +1 -0
- package/dist/lib/dependencies/index.mjs +281 -0
- package/dist/lib/dependencies/index.mjs.map +1 -0
- package/dist/lib/dependencies/workspaceCycles.mjs +79 -0
- package/dist/lib/dependencies/workspaceCycles.mjs.map +1 -0
- package/dist/lib/file/ReadFileSyncOptions.mjs +6 -0
- package/dist/lib/file/ReadFileSyncOptions.mjs.map +1 -0
- package/dist/lib/file/constants.mjs +8 -0
- package/dist/lib/file/constants.mjs.map +1 -0
- package/dist/lib/file/fileLines.mjs +32 -0
- package/dist/lib/file/fileLines.mjs.map +1 -0
- package/dist/lib/file/index.mjs +42 -0
- package/dist/lib/file/index.mjs.map +1 -0
- package/dist/lib/file/tryReadFileSync.mjs +14 -0
- package/dist/lib/file/tryReadFileSync.mjs.map +1 -0
- package/dist/lib/fillTemplate.mjs +8 -0
- package/dist/lib/fillTemplate.mjs.map +1 -0
- package/dist/lib/generateIgnoreFiles.mjs +86 -0
- package/dist/lib/generateIgnoreFiles.mjs.map +1 -0
- package/dist/lib/generateReadmeFiles.mjs +323 -0
- package/dist/lib/generateReadmeFiles.mjs.map +1 -0
- package/dist/lib/gitignoreTemplate.mjs +12 -0
- package/dist/lib/gitignoreTemplate.mjs.map +1 -0
- package/dist/lib/index.mjs +1627 -0
- package/dist/lib/index.mjs.map +1 -0
- package/dist/lib/initCwd.mjs +8 -0
- package/dist/lib/initCwd.mjs.map +1 -0
- package/dist/lib/jsonFormatters.mjs +11 -0
- package/dist/lib/jsonFormatters.mjs.map +1 -0
- package/dist/lib/latestVersions.mjs +12 -0
- package/dist/lib/latestVersions.mjs.map +1 -0
- package/dist/lib/loadConfig.mjs +72 -0
- package/dist/lib/loadConfig.mjs.map +1 -0
- package/dist/lib/packageName.mjs +26 -0
- package/dist/lib/packageName.mjs.map +1 -0
- package/dist/lib/parsedPackageJSON.mjs +11 -0
- package/dist/lib/parsedPackageJSON.mjs.map +1 -0
- package/dist/lib/processEx.mjs +36 -0
- package/dist/lib/processEx.mjs.map +1 -0
- package/dist/lib/repoTemplates.mjs +34 -0
- package/dist/lib/repoTemplates.mjs.map +1 -0
- package/dist/lib/runInstall.mjs +30 -0
- package/dist/lib/runInstall.mjs.map +1 -0
- package/dist/lib/runSteps.mjs +118 -0
- package/dist/lib/runSteps.mjs.map +1 -0
- package/dist/lib/runStepsAsync.mjs +136 -0
- package/dist/lib/runStepsAsync.mjs.map +1 -0
- package/dist/lib/runXy.mjs +147 -0
- package/dist/lib/runXy.mjs.map +1 -0
- package/dist/lib/runXyWithWarning.mjs +36 -0
- package/dist/lib/runXyWithWarning.mjs.map +1 -0
- package/dist/lib/safeExit.mjs +61 -0
- package/dist/lib/safeExit.mjs.map +1 -0
- package/dist/lib/string/empty.mjs +8 -0
- package/dist/lib/string/empty.mjs.map +1 -0
- package/dist/lib/string/index.mjs +12 -0
- package/dist/lib/string/index.mjs.map +1 -0
- package/dist/lib/string/union.mjs +6 -0
- package/dist/lib/string/union.mjs.map +1 -0
- package/dist/lib/tryRunLocalScript.mjs +57 -0
- package/dist/lib/tryRunLocalScript.mjs.map +1 -0
- package/dist/lib/updo/applyUpdates.mjs +44 -0
- package/dist/lib/updo/applyUpdates.mjs.map +1 -0
- package/dist/lib/updo/collectWorkspaceDeps.mjs +48 -0
- package/dist/lib/updo/collectWorkspaceDeps.mjs.map +1 -0
- package/dist/lib/updo/fetchRegistryInfo.mjs +53 -0
- package/dist/lib/updo/fetchRegistryInfo.mjs.map +1 -0
- package/dist/lib/updo/index.mjs +594 -0
- package/dist/lib/updo/index.mjs.map +1 -0
- package/dist/lib/updo/interactiveSelect.mjs +185 -0
- package/dist/lib/updo/interactiveSelect.mjs.map +1 -0
- package/dist/lib/updo/interfaces.mjs +1 -0
- package/dist/lib/updo/interfaces.mjs.map +1 -0
- package/dist/lib/updo/renderTable.mjs +79 -0
- package/dist/lib/updo/renderTable.mjs.map +1 -0
- package/dist/lib/updo/resolveVersions.mjs +49 -0
- package/dist/lib/updo/resolveVersions.mjs.map +1 -0
- package/dist/lib/updo/runUpdo.mjs +511 -0
- package/dist/lib/updo/runUpdo.mjs.map +1 -0
- package/dist/lib/withErrnoException.mjs +13 -0
- package/dist/lib/withErrnoException.mjs.map +1 -0
- package/dist/lib/withError.mjs +8 -0
- package/dist/lib/withError.mjs.map +1 -0
- package/dist/lib/yarn/index.mjs +39 -0
- package/dist/lib/yarn/index.mjs.map +1 -0
- package/dist/lib/yarn/isYarnVersionOrGreater.mjs +18 -0
- package/dist/lib/yarn/isYarnVersionOrGreater.mjs.map +1 -0
- package/dist/lib/yarn/workspace/Workspace.mjs +1 -0
- package/dist/lib/yarn/workspace/Workspace.mjs.map +1 -0
- package/dist/lib/yarn/workspace/index.mjs +23 -0
- package/dist/lib/yarn/workspace/index.mjs.map +1 -0
- package/dist/lib/yarn/workspace/yarnWorkspace.mjs +22 -0
- package/dist/lib/yarn/workspace/yarnWorkspace.mjs.map +1 -0
- package/dist/lib/yarn/workspace/yarnWorkspaces.mjs +15 -0
- package/dist/lib/yarn/workspace/yarnWorkspaces.mjs.map +1 -0
- package/dist/lib/yarn/yarnInitCwd.mjs +8 -0
- package/dist/lib/yarn/yarnInitCwd.mjs.map +1 -0
- package/dist/loadPackageConfig.mjs +18 -0
- package/dist/loadPackageConfig.mjs.map +1 -0
- package/dist/pm/PackageManager.mjs +1 -0
- package/dist/pm/PackageManager.mjs.map +1 -0
- package/dist/pm/detectPackageManager.mjs +10 -0
- package/dist/pm/detectPackageManager.mjs.map +1 -0
- package/dist/pm/detectReact.mjs +52 -0
- package/dist/pm/detectReact.mjs.map +1 -0
- package/dist/pm/index.mjs +263 -0
- package/dist/pm/index.mjs.map +1 -0
- package/dist/pm/pnpmPackageManager.mjs +97 -0
- package/dist/pm/pnpmPackageManager.mjs.map +1 -0
- package/dist/pm/registry.mjs +27 -0
- package/dist/pm/registry.mjs.map +1 -0
- package/dist/pm/yarnPackageManager.mjs +112 -0
- package/dist/pm/yarnPackageManager.mjs.map +1 -0
- package/dist/types.d.mjs +1 -0
- package/dist/types.d.mjs.map +1 -0
- package/dist/xy/build/buildCommand.mjs +194 -0
- package/dist/xy/build/buildCommand.mjs.map +1 -0
- package/dist/xy/build/compileCommand.mjs +203 -0
- package/dist/xy/build/compileCommand.mjs.map +1 -0
- package/dist/xy/build/compileOnlyCommand.mjs +204 -0
- package/dist/xy/build/compileOnlyCommand.mjs.map +1 -0
- package/dist/xy/build/copyAssetsCommand.mjs +92 -0
- package/dist/xy/build/copyAssetsCommand.mjs.map +1 -0
- package/dist/xy/build/index.mjs +487 -0
- package/dist/xy/build/index.mjs.map +1 -0
- package/dist/xy/build/rebuildCommand.mjs +156 -0
- package/dist/xy/build/rebuildCommand.mjs.map +1 -0
- package/dist/xy/build/recompileCommand.mjs +215 -0
- package/dist/xy/build/recompileCommand.mjs.map +1 -0
- package/dist/xy/common/checkCommand.mjs +1909 -0
- package/dist/xy/common/checkCommand.mjs.map +1 -0
- package/dist/xy/common/claude/checkCommand.mjs +207 -0
- package/dist/xy/common/claude/checkCommand.mjs.map +1 -0
- package/dist/xy/common/claude/cleanCommand.mjs +78 -0
- package/dist/xy/common/claude/cleanCommand.mjs.map +1 -0
- package/dist/xy/common/claude/commandsCommand.mjs +134 -0
- package/dist/xy/common/claude/commandsCommand.mjs.map +1 -0
- package/dist/xy/common/claude/index.mjs +734 -0
- package/dist/xy/common/claude/index.mjs.map +1 -0
- package/dist/xy/common/claude/initCommand.mjs +458 -0
- package/dist/xy/common/claude/initCommand.mjs.map +1 -0
- package/dist/xy/common/claude/rulesCommand.mjs +167 -0
- package/dist/xy/common/claude/rulesCommand.mjs.map +1 -0
- package/dist/xy/common/claude/settingsCommand.mjs +115 -0
- package/dist/xy/common/claude/settingsCommand.mjs.map +1 -0
- package/dist/xy/common/claude/skillsCommand.mjs +140 -0
- package/dist/xy/common/claude/skillsCommand.mjs.map +1 -0
- package/dist/xy/common/cleanDocsCommand.mjs +74 -0
- package/dist/xy/common/cleanDocsCommand.mjs.map +1 -0
- package/dist/xy/common/deadCommand.mjs +137 -0
- package/dist/xy/common/deadCommand.mjs.map +1 -0
- package/dist/xy/common/genDocsCommand.mjs +175 -0
- package/dist/xy/common/genDocsCommand.mjs.map +1 -0
- package/dist/xy/common/gitignoreCommand.mjs +165 -0
- package/dist/xy/common/gitignoreCommand.mjs.map +1 -0
- package/dist/xy/common/gitlintCommand.mjs +89 -0
- package/dist/xy/common/gitlintCommand.mjs.map +1 -0
- package/dist/xy/common/index.mjs +4654 -0
- package/dist/xy/common/index.mjs.map +1 -0
- package/dist/xy/common/licenseCommand.mjs +108 -0
- package/dist/xy/common/licenseCommand.mjs.map +1 -0
- package/dist/xy/common/npmignoreGenCommand.mjs +100 -0
- package/dist/xy/common/npmignoreGenCommand.mjs.map +1 -0
- package/dist/xy/common/orphan/cleanCommand.mjs +102 -0
- package/dist/xy/common/orphan/cleanCommand.mjs.map +1 -0
- package/dist/xy/common/orphan/index.mjs +138 -0
- package/dist/xy/common/orphan/index.mjs.map +1 -0
- package/dist/xy/common/orphan/listCommand.mjs +100 -0
- package/dist/xy/common/orphan/listCommand.mjs.map +1 -0
- package/dist/xy/common/packmanCommand.mjs +1538 -0
- package/dist/xy/common/packmanCommand.mjs.map +1 -0
- package/dist/xy/common/readme/genCommand.mjs +395 -0
- package/dist/xy/common/readme/genCommand.mjs.map +1 -0
- package/dist/xy/common/readme/index.mjs +538 -0
- package/dist/xy/common/readme/index.mjs.map +1 -0
- package/dist/xy/common/readme/initCommand.mjs +109 -0
- package/dist/xy/common/readme/initCommand.mjs.map +1 -0
- package/dist/xy/common/readme/lintCommand.mjs +181 -0
- package/dist/xy/common/readme/lintCommand.mjs.map +1 -0
- package/dist/xy/common/repo/index.mjs +1070 -0
- package/dist/xy/common/repo/index.mjs.map +1 -0
- package/dist/xy/common/repo/initCommand.mjs +273 -0
- package/dist/xy/common/repo/initCommand.mjs.map +1 -0
- package/dist/xy/common/repo/lintCommand.mjs +789 -0
- package/dist/xy/common/repo/lintCommand.mjs.map +1 -0
- package/dist/xy/common/retestCommand.mjs +163 -0
- package/dist/xy/common/retestCommand.mjs.map +1 -0
- package/dist/xy/common/testCommand.mjs +157 -0
- package/dist/xy/common/testCommand.mjs.map +1 -0
- package/dist/xy/deploy/deployCommand.mjs +214 -0
- package/dist/xy/deploy/deployCommand.mjs.map +1 -0
- package/dist/xy/deploy/index.mjs +289 -0
- package/dist/xy/deploy/index.mjs.map +1 -0
- package/dist/xy/deploy/publishCommand.mjs +218 -0
- package/dist/xy/deploy/publishCommand.mjs.map +1 -0
- package/dist/xy/index.mjs +8887 -0
- package/dist/xy/index.mjs.map +1 -0
- package/dist/xy/install/cleanCommand.mjs +182 -0
- package/dist/xy/install/cleanCommand.mjs.map +1 -0
- package/dist/xy/install/dupdepsCommand.mjs +234 -0
- package/dist/xy/install/dupdepsCommand.mjs.map +1 -0
- package/dist/xy/install/index.mjs +1006 -0
- package/dist/xy/install/index.mjs.map +1 -0
- package/dist/xy/install/reinstallCommand.mjs +292 -0
- package/dist/xy/install/reinstallCommand.mjs.map +1 -0
- package/dist/xy/install/staticsCommand.mjs +233 -0
- package/dist/xy/install/staticsCommand.mjs.map +1 -0
- package/dist/xy/install/upCommand.mjs +150 -0
- package/dist/xy/install/upCommand.mjs.map +1 -0
- package/dist/xy/install/updoCommand.mjs +550 -0
- package/dist/xy/install/updoCommand.mjs.map +1 -0
- package/dist/xy/lint/cycleCommand.mjs +289 -0
- package/dist/xy/lint/cycleCommand.mjs.map +1 -0
- package/dist/xy/lint/deplintCommand.mjs +1897 -0
- package/dist/xy/lint/deplintCommand.mjs.map +1 -0
- package/dist/xy/lint/fixCommand.mjs +398 -0
- package/dist/xy/lint/fixCommand.mjs.map +1 -0
- package/dist/xy/lint/index.mjs +3759 -0
- package/dist/xy/lint/index.mjs.map +1 -0
- package/dist/xy/lint/knipCommand.mjs +142 -0
- package/dist/xy/lint/knipCommand.mjs.map +1 -0
- package/dist/xy/lint/lint/index.mjs +695 -0
- package/dist/xy/lint/lint/index.mjs.map +1 -0
- package/dist/xy/lint/lint/initCommand.mjs +282 -0
- package/dist/xy/lint/lint/initCommand.mjs.map +1 -0
- package/dist/xy/lint/lint/runCommand.mjs +405 -0
- package/dist/xy/lint/lint/runCommand.mjs.map +1 -0
- package/dist/xy/lint/lintCommand.mjs +695 -0
- package/dist/xy/lint/lintCommand.mjs.map +1 -0
- package/dist/xy/lint/lintlintCommand.mjs +359 -0
- package/dist/xy/lint/lintlintCommand.mjs.map +1 -0
- package/dist/xy/lint/publintCommand.mjs +778 -0
- package/dist/xy/lint/publintCommand.mjs.map +1 -0
- package/dist/xy/lint/relintCommand.mjs +381 -0
- package/dist/xy/lint/relintCommand.mjs.map +1 -0
- package/dist/xy/lint/sonarCommand.mjs +137 -0
- package/dist/xy/lint/sonarCommand.mjs.map +1 -0
- package/dist/xy/param.mjs +8 -0
- package/dist/xy/param.mjs.map +1 -0
- package/dist/xy/react/analyzeCommand.mjs +150 -0
- package/dist/xy/react/analyzeCommand.mjs.map +1 -0
- package/dist/xy/react/ejectCommand.mjs +150 -0
- package/dist/xy/react/ejectCommand.mjs.map +1 -0
- package/dist/xy/react/index.mjs +202 -0
- package/dist/xy/react/index.mjs.map +1 -0
- package/dist/xy/react/sitemapCommand.mjs +129 -0
- package/dist/xy/react/sitemapCommand.mjs.map +1 -0
- package/dist/xy/react/startCommand.mjs +150 -0
- package/dist/xy/react/startCommand.mjs.map +1 -0
- package/dist/xy/xy.mjs +8879 -0
- package/dist/xy/xy.mjs.map +1 -0
- package/dist/xy/xyParseOptions.mjs +117 -0
- package/dist/xy/xyParseOptions.mjs.map +1 -0
- package/dist/xy/yarn/index.mjs +188 -0
- package/dist/xy/yarn/index.mjs.map +1 -0
- package/dist/xy/yarn/upplugCommand.mjs +134 -0
- package/dist/xy/yarn/upplugCommand.mjs.map +1 -0
- package/dist/xy/yarn/upyarnCommand.mjs +129 -0
- package/dist/xy/yarn/upyarnCommand.mjs.map +1 -0
- package/dist/xy/yarn/yarn3OnlyCommand.mjs +70 -0
- package/dist/xy/yarn/yarn3OnlyCommand.mjs.map +1 -0
- package/package.json +119 -0
- package/templates/claude/CLAUDE-local.md +4 -0
- package/templates/claude/CLAUDE-project.md +4 -0
- package/templates/claude/commands/xy-build.md +7 -0
- package/templates/claude/commands/xy-clean.md +7 -0
- package/templates/claude/commands/xy-compile.md +7 -0
- package/templates/claude/commands/xy-cycle.md +7 -0
- package/templates/claude/commands/xy-dead.md +7 -0
- package/templates/claude/commands/xy-deplint.md +7 -0
- package/templates/claude/commands/xy-deps.md +24 -0
- package/templates/claude/commands/xy-dupdeps.md +7 -0
- package/templates/claude/commands/xy-fix.md +7 -0
- package/templates/claude/commands/xy-gen-docs.md +7 -0
- package/templates/claude/commands/xy-gitignore.md +7 -0
- package/templates/claude/commands/xy-gitlint.md +7 -0
- package/templates/claude/commands/xy-knip.md +7 -0
- package/templates/claude/commands/xy-license.md +7 -0
- package/templates/claude/commands/xy-lint-rules.md +44 -0
- package/templates/claude/commands/xy-lint.md +7 -0
- package/templates/claude/commands/xy-publint.md +7 -0
- package/templates/claude/commands/xy-rebuild.md +7 -0
- package/templates/claude/commands/xy-recompile.md +7 -0
- package/templates/claude/commands/xy-reinstall.md +7 -0
- package/templates/claude/commands/xy-relint.md +7 -0
- package/templates/claude/commands/xy-retest.md +7 -0
- package/templates/claude/commands/xy-sonar.md +7 -0
- package/templates/claude/commands/xy-test.md +7 -0
- package/templates/claude/commands/xy-up.md +9 -0
- package/templates/claude/rules/xylabs-architecture.md +8 -0
- package/templates/claude/rules/xylabs-git-workflow.md +7 -0
- package/templates/claude/rules/xylabs-naming.md +7 -0
- package/templates/claude/rules/xylabs-style.md +17 -0
- package/templates/claude/skills/xylabs-e2e-setup/SKILL.md +223 -0
- package/templates/claude/skills/xylabs-xy-cli/SKILL.md +236 -0
- package/templates/claude/skills/xylabs-xy-deplint-fix/SKILL.md +122 -0
- package/templates/gitignore/gitignore/template.gitignore +51 -0
- package/templates/gitignore/template.gitignore +51 -0
- package/templates/readme/README.body.md +25 -0
- package/templates/readme/README.template.md +22 -0
- package/templates/repo/cli/package/package.json.tmpl +63 -0
- package/templates/repo/cli/package/src/__packageName__.ts.tmpl +21 -0
- package/templates/repo/cli/package/src/actions/index.ts +1 -0
- package/templates/repo/cli/package/src/actions/printVersion.ts.tmpl +8 -0
- package/templates/repo/cli/package/src/bin/__packageName__.ts.tmpl +12 -0
- package/templates/repo/cli/package/src/commands/index.ts +1 -0
- package/templates/repo/cli/package/src/commands/versionCommand.ts.tmpl +11 -0
- package/templates/repo/cli/package/src/index.ts.tmpl +1 -0
- package/templates/repo/cli/package/tsconfig.build.json +25 -0
- package/templates/repo/cli/package/tsconfig.json +4 -0
- package/templates/repo/cli/package/tsup.config.ts +15 -0
- package/templates/repo/cli/package/xy.config.ts +3 -0
- package/templates/repo/cli/root/CLAUDE.md.tmpl +38 -0
- package/templates/repo/cli/root/cspell.json.tmpl +13 -0
- package/templates/repo/cli/root/eslint.config.ts +28 -0
- package/templates/repo/cli/root/github/workflows/build-pnpm.yml.tmpl +34 -0
- package/templates/repo/cli/root/github/workflows/build-yarn.yml.tmpl +32 -0
- package/templates/repo/cli/root/gitignore.tmpl +47 -0
- package/templates/repo/cli/root/knip.config.ts +16 -0
- package/templates/repo/cli/root/package.json.tmpl +54 -0
- package/templates/repo/cli/root/pnpm-workspace.yaml +2 -0
- package/templates/repo/cli/root/tsconfig.json +4 -0
- package/templates/repo/cli/root/vitest.config.ts +31 -0
- package/templates/repo/cli/root/xy.config.ts.tmpl +5 -0
|
@@ -0,0 +1,1223 @@
|
|
|
1
|
+
// src/actions/deplint/getBasePackageName.ts
|
|
2
|
+
function getBasePackageName(importName) {
|
|
3
|
+
const importNameScrubbed = importName.replaceAll('"', "").trim();
|
|
4
|
+
if (importNameScrubbed.startsWith("@")) {
|
|
5
|
+
const parts = importNameScrubbed.split("/");
|
|
6
|
+
return parts.length >= 2 ? `${parts[0]}/${parts[1]}` : importNameScrubbed;
|
|
7
|
+
}
|
|
8
|
+
return importNameScrubbed.split("/")[0];
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
// src/actions/deplint/checkPackage/getMismatchedPeerDevVersions.ts
|
|
12
|
+
import chalk2 from "chalk";
|
|
13
|
+
import semver from "semver";
|
|
14
|
+
|
|
15
|
+
// src/actions/deplint/packageJsonEditor.ts
|
|
16
|
+
import fs2 from "fs";
|
|
17
|
+
import chalk from "chalk";
|
|
18
|
+
import sortPackageJson from "sort-package-json";
|
|
19
|
+
|
|
20
|
+
// src/actions/deplint/getRequiredPeerDependencies.ts
|
|
21
|
+
import fs from "fs";
|
|
22
|
+
import path from "path";
|
|
23
|
+
function findDepPackageJson(location, dep) {
|
|
24
|
+
let dir = location;
|
|
25
|
+
while (true) {
|
|
26
|
+
const candidate = path.join(dir, "node_modules", dep, "package.json");
|
|
27
|
+
if (fs.existsSync(candidate)) return candidate;
|
|
28
|
+
const parent = path.dirname(dir);
|
|
29
|
+
if (parent === dir) return void 0;
|
|
30
|
+
dir = parent;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
function getRequiredPeerDependencies(location, allDeps) {
|
|
34
|
+
const required = /* @__PURE__ */ new Set();
|
|
35
|
+
for (const dep of allDeps) {
|
|
36
|
+
const depPkgPath = findDepPackageJson(location, dep);
|
|
37
|
+
if (!depPkgPath) continue;
|
|
38
|
+
try {
|
|
39
|
+
const raw = fs.readFileSync(depPkgPath, "utf8");
|
|
40
|
+
const pkg = JSON.parse(raw);
|
|
41
|
+
const peerDeps = pkg.peerDependencies;
|
|
42
|
+
if (peerDeps) {
|
|
43
|
+
for (const peer of Object.keys(peerDeps)) {
|
|
44
|
+
required.add(peer);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
} catch {
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return required;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// src/actions/deplint/packageJsonEditor.ts
|
|
54
|
+
function resolveDepVersion(location, dep) {
|
|
55
|
+
const depPkgPath = findDepPackageJson(location, dep);
|
|
56
|
+
if (depPkgPath) {
|
|
57
|
+
try {
|
|
58
|
+
const depPkg = JSON.parse(fs2.readFileSync(depPkgPath, "utf8"));
|
|
59
|
+
const version = depPkg.version;
|
|
60
|
+
if (version) return `~${version}`;
|
|
61
|
+
} catch {
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return "*";
|
|
65
|
+
}
|
|
66
|
+
function resolveExpectedPeerVersion(location, dep, currentRange) {
|
|
67
|
+
const depPkgPath = findDepPackageJson(location, dep);
|
|
68
|
+
if (depPkgPath) {
|
|
69
|
+
try {
|
|
70
|
+
const depPkg = JSON.parse(fs2.readFileSync(depPkgPath, "utf8"));
|
|
71
|
+
const version = depPkg.version;
|
|
72
|
+
if (version) {
|
|
73
|
+
const match = /^(\d+)\.(\d+)/.exec(version);
|
|
74
|
+
if (match) {
|
|
75
|
+
if (currentRange?.startsWith("^")) {
|
|
76
|
+
return `^${match[1]}`;
|
|
77
|
+
}
|
|
78
|
+
return `~${match[1]}.${match[2]}`;
|
|
79
|
+
}
|
|
80
|
+
return `~${version}`;
|
|
81
|
+
}
|
|
82
|
+
} catch {
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return "*";
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
// src/actions/deplint/checkPackage/getMismatchedPeerDevVersions.ts
|
|
89
|
+
function findMismatchedPeerDevVersions({
|
|
90
|
+
peerDependencies,
|
|
91
|
+
peerDependencyVersions,
|
|
92
|
+
devDependencyVersions
|
|
93
|
+
}, exclude) {
|
|
94
|
+
const mismatches = [];
|
|
95
|
+
for (const dep of peerDependencies) {
|
|
96
|
+
if (exclude?.has(dep)) continue;
|
|
97
|
+
const peerVersion = peerDependencyVersions[dep];
|
|
98
|
+
const devVersion = devDependencyVersions[dep];
|
|
99
|
+
const hasWorkspaceProtocol = devVersion?.startsWith("workspace:") || peerVersion?.startsWith("workspace:");
|
|
100
|
+
if (devVersion && peerVersion !== devVersion && !hasWorkspaceProtocol && !semver.subset(devVersion, peerVersion)) {
|
|
101
|
+
mismatches.push({
|
|
102
|
+
dep,
|
|
103
|
+
devVersion,
|
|
104
|
+
peerVersion
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
return mismatches;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// src/actions/deplint/checkPackage/getUnlistedDependencies.ts
|
|
112
|
+
import fs3 from "fs";
|
|
113
|
+
import { builtinModules } from "module";
|
|
114
|
+
import chalk3 from "chalk";
|
|
115
|
+
|
|
116
|
+
// src/actions/deplint/tsScriptsAliases.ts
|
|
117
|
+
var VARIANT_MAP = {
|
|
118
|
+
"@xylabs/ts-scripts-yarn3": "@xylabs/ts-scripts-pnpm",
|
|
119
|
+
"@xylabs/ts-scripts-pnpm": "@xylabs/ts-scripts-yarn3",
|
|
120
|
+
"@xylabs/ts-scripts-react-yarn3": "@xylabs/ts-scripts-react-pnpm",
|
|
121
|
+
"@xylabs/ts-scripts-react-pnpm": "@xylabs/ts-scripts-react-yarn3"
|
|
122
|
+
};
|
|
123
|
+
function isSatisfiedByTsScriptsVariant(imp, allDeps) {
|
|
124
|
+
const variant = VARIANT_MAP[imp];
|
|
125
|
+
return variant !== void 0 && allDeps.includes(variant);
|
|
126
|
+
}
|
|
127
|
+
function isUsedViaTsScriptsVariant(dep, imports) {
|
|
128
|
+
const variant = VARIANT_MAP[dep];
|
|
129
|
+
return variant !== void 0 && imports.includes(variant);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// src/actions/deplint/checkPackage/getUnlistedDependencies.ts
|
|
133
|
+
function isRuntimeImportListed(imp, name, dependencies, peerDependencies) {
|
|
134
|
+
return dependencies.includes(imp) || imp === name || peerDependencies.includes(imp) || builtinModules.includes(imp);
|
|
135
|
+
}
|
|
136
|
+
function isDistTypeImportListed(imp, name, dependencies, devDependencies, peerDependencies) {
|
|
137
|
+
return dependencies.includes(imp) || imp === name || dependencies.includes(`@types/${imp}`) || devDependencies.includes(`@types/${imp}`) || peerDependencies.includes(imp) || peerDependencies.includes(`@types/${imp}`) || builtinModules.includes(imp);
|
|
138
|
+
}
|
|
139
|
+
function shouldBePeerDependency(imp, location, currentPeers, distImports) {
|
|
140
|
+
if (currentPeers.length === 0) return false;
|
|
141
|
+
const depPkgPath = findDepPackageJson(location, imp);
|
|
142
|
+
if (!depPkgPath) return false;
|
|
143
|
+
try {
|
|
144
|
+
const pkg = JSON.parse(fs3.readFileSync(depPkgPath, "utf8"));
|
|
145
|
+
const importPeers = Object.keys(pkg.peerDependencies ?? {});
|
|
146
|
+
return importPeers.length > 0 && importPeers.every(
|
|
147
|
+
(peer) => currentPeers.includes(peer) && distImports.includes(peer)
|
|
148
|
+
);
|
|
149
|
+
} catch {
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
function findUnlistedDependencies(name, dependencies, devDependencies, peerDependencies, externalDistImports, externalDistTypeImports) {
|
|
154
|
+
const allDeps = [...dependencies, ...devDependencies, ...peerDependencies];
|
|
155
|
+
const results = [];
|
|
156
|
+
for (const imp of externalDistImports) {
|
|
157
|
+
if (!isRuntimeImportListed(imp, name, dependencies, peerDependencies) && !isSatisfiedByTsScriptsVariant(imp, allDeps)) {
|
|
158
|
+
results.push({ imp, section: "dependencies" });
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
for (const imp of externalDistTypeImports) {
|
|
162
|
+
if (!isDistTypeImportListed(imp, name, dependencies, devDependencies, peerDependencies) && !isSatisfiedByTsScriptsVariant(imp, allDeps)) {
|
|
163
|
+
results.push({ imp, section: "dependencies" });
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
return results;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// src/actions/deplint/checkPackage/getUnlistedDevDependencies.ts
|
|
170
|
+
import { builtinModules as builtinModules2 } from "module";
|
|
171
|
+
import chalk4 from "chalk";
|
|
172
|
+
function findUnlistedDevDeps(name, dependencies, devDependencies, peerDependencies, externalAllImports, distImports, externalDistTypeImports) {
|
|
173
|
+
const results = [];
|
|
174
|
+
for (const imp of externalAllImports) {
|
|
175
|
+
if (!distImports.includes(imp) && !externalDistTypeImports.includes(imp) && imp !== name && !dependencies.includes(imp) && !dependencies.includes(`@types/${imp}`) && !peerDependencies.includes(imp) && !peerDependencies.includes(`@types/${imp}`) && !devDependencies.includes(imp) && !devDependencies.includes(`@types/${imp}`) && !builtinModules2.includes(imp) && !isSatisfiedByTsScriptsVariant(imp, [...dependencies, ...devDependencies, ...peerDependencies])) {
|
|
176
|
+
results.push(imp);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return results;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
// src/actions/deplint/checkPackage/getUnnecessaryPeerDependencies.ts
|
|
183
|
+
import fs5 from "fs";
|
|
184
|
+
import chalk6 from "chalk";
|
|
185
|
+
|
|
186
|
+
// src/actions/deplint/checkPackage/getUnsatisfiedPeerDependencies.ts
|
|
187
|
+
import fs4 from "fs";
|
|
188
|
+
import chalk5 from "chalk";
|
|
189
|
+
import semver2 from "semver";
|
|
190
|
+
import sortPackageJson2 from "sort-package-json";
|
|
191
|
+
function readDepPackageJson(location, dep) {
|
|
192
|
+
const depPkgPath = findDepPackageJson(location, dep);
|
|
193
|
+
if (!depPkgPath) return void 0;
|
|
194
|
+
try {
|
|
195
|
+
return JSON.parse(fs4.readFileSync(depPkgPath, "utf8"));
|
|
196
|
+
} catch {
|
|
197
|
+
return void 0;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
function readPeerDeps(location, dep) {
|
|
201
|
+
const pkg = readDepPackageJson(location, dep);
|
|
202
|
+
if (!pkg) return [];
|
|
203
|
+
const peers = pkg.peerDependencies;
|
|
204
|
+
return Object.keys(peers ?? {});
|
|
205
|
+
}
|
|
206
|
+
function readPeerVersionRange(location, dep, peer) {
|
|
207
|
+
const pkg = readDepPackageJson(location, dep);
|
|
208
|
+
if (!pkg) return void 0;
|
|
209
|
+
const peers = pkg.peerDependencies;
|
|
210
|
+
return peers?.[peer];
|
|
211
|
+
}
|
|
212
|
+
function readInstalledVersion(location, dep) {
|
|
213
|
+
const pkg = readDepPackageJson(location, dep);
|
|
214
|
+
if (!pkg) return void 0;
|
|
215
|
+
return pkg.version;
|
|
216
|
+
}
|
|
217
|
+
function isPeerOptionalInAll(location, peer, sources) {
|
|
218
|
+
for (const source of sources) {
|
|
219
|
+
const pkg = readDepPackageJson(location, source.requiredBy);
|
|
220
|
+
if (!pkg) continue;
|
|
221
|
+
const meta = pkg.peerDependenciesMeta?.[peer];
|
|
222
|
+
if (!meta?.optional) return false;
|
|
223
|
+
}
|
|
224
|
+
return true;
|
|
225
|
+
}
|
|
226
|
+
var MAX_TRANSITIVE_DEPTH = 2;
|
|
227
|
+
function collectPeerSources(location, dependencies, devDependencies) {
|
|
228
|
+
const peerSources = /* @__PURE__ */ new Map();
|
|
229
|
+
const visited = /* @__PURE__ */ new Set();
|
|
230
|
+
function addPeerSource(peer, source) {
|
|
231
|
+
const sources = peerSources.get(peer) ?? [];
|
|
232
|
+
sources.push(source);
|
|
233
|
+
peerSources.set(peer, sources);
|
|
234
|
+
}
|
|
235
|
+
function collectFromDeps(deps, isRuntime, chain) {
|
|
236
|
+
for (const dep of deps) {
|
|
237
|
+
const visitKey = `${dep}:${chain.join(">")}`;
|
|
238
|
+
if (visited.has(visitKey)) continue;
|
|
239
|
+
visited.add(visitKey);
|
|
240
|
+
for (const peer of readPeerDeps(location, dep)) {
|
|
241
|
+
addPeerSource(peer, {
|
|
242
|
+
chain: chain.length > 0 ? [...chain, dep] : void 0,
|
|
243
|
+
isRuntimeDep: isRuntime,
|
|
244
|
+
requiredBy: dep
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
if (chain.length < MAX_TRANSITIVE_DEPTH) {
|
|
248
|
+
const depPkg = readDepPackageJson(location, dep);
|
|
249
|
+
if (depPkg) {
|
|
250
|
+
const transitiveDeps = Object.keys(depPkg.dependencies ?? {});
|
|
251
|
+
collectFromDeps(transitiveDeps, isRuntime, [...chain, dep]);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
collectFromDeps(dependencies, true, []);
|
|
257
|
+
const devOnly = devDependencies.filter((d) => !dependencies.includes(d));
|
|
258
|
+
collectFromDeps(devOnly, false, []);
|
|
259
|
+
return peerSources;
|
|
260
|
+
}
|
|
261
|
+
function getRequiredTransitivePeers(location, { dependencies, devDependencies }) {
|
|
262
|
+
const peerSources = collectPeerSources(location, dependencies, devDependencies);
|
|
263
|
+
return new Set(peerSources.keys());
|
|
264
|
+
}
|
|
265
|
+
function resolveVersionRange(location, sources, peer) {
|
|
266
|
+
for (const source of sources) {
|
|
267
|
+
const range = readPeerVersionRange(location, source.requiredBy, peer);
|
|
268
|
+
if (range) return range;
|
|
269
|
+
}
|
|
270
|
+
return "*";
|
|
271
|
+
}
|
|
272
|
+
function checkVersionSatisfaction(location, peer, requestedRange) {
|
|
273
|
+
const installedVersion = readInstalledVersion(location, peer);
|
|
274
|
+
if (!installedVersion) return { satisfied: true };
|
|
275
|
+
if (requestedRange === "*") return { installedVersion, satisfied: true };
|
|
276
|
+
if (requestedRange.startsWith("workspace:")) return { installedVersion, satisfied: true };
|
|
277
|
+
try {
|
|
278
|
+
const satisfied = semver2.satisfies(installedVersion, requestedRange, { includePrerelease: true });
|
|
279
|
+
return { installedVersion, satisfied };
|
|
280
|
+
} catch {
|
|
281
|
+
return { installedVersion, satisfied: true };
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
function findDeclaredPeerVersionMismatches(name, location, peerDependencies, peerDependencyVersions, exclude) {
|
|
285
|
+
const results = [];
|
|
286
|
+
for (const peer of peerDependencies) {
|
|
287
|
+
if (exclude?.has(peer) || peer === name) continue;
|
|
288
|
+
const declaredRange = peerDependencyVersions[peer];
|
|
289
|
+
if (!declaredRange || declaredRange === "*") continue;
|
|
290
|
+
const { installedVersion, satisfied } = checkVersionSatisfaction(location, peer, declaredRange);
|
|
291
|
+
if (!satisfied) {
|
|
292
|
+
results.push({
|
|
293
|
+
hasRuntimeSource: true,
|
|
294
|
+
installedVersion,
|
|
295
|
+
peer,
|
|
296
|
+
reason: "version-mismatch",
|
|
297
|
+
sources: [{ isRuntimeDep: true, requiredBy: name }],
|
|
298
|
+
versionRange: declaredRange
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
return results;
|
|
303
|
+
}
|
|
304
|
+
function findUnsatisfiedPeers({ name, location }, {
|
|
305
|
+
dependencies,
|
|
306
|
+
devDependencies,
|
|
307
|
+
peerDependencies,
|
|
308
|
+
peerDependencyVersions
|
|
309
|
+
}, exclude) {
|
|
310
|
+
const peerSources = collectPeerSources(location, dependencies, devDependencies);
|
|
311
|
+
const depsSet = new Set(dependencies);
|
|
312
|
+
const devDepsSet = new Set(devDependencies);
|
|
313
|
+
const unsatisfied = [];
|
|
314
|
+
for (const [peer, sources] of peerSources) {
|
|
315
|
+
if (exclude?.has(peer) || peer === name) continue;
|
|
316
|
+
if (isPeerOptionalInAll(location, peer, sources)) continue;
|
|
317
|
+
const hasRuntimeSource = sources.some((s) => s.isRuntimeDep);
|
|
318
|
+
const isPresent = depsSet.has(peer) || devDepsSet.has(peer);
|
|
319
|
+
if (!isPresent) {
|
|
320
|
+
const versionRange2 = resolveVersionRange(location, sources, peer);
|
|
321
|
+
unsatisfied.push({
|
|
322
|
+
hasRuntimeSource,
|
|
323
|
+
peer,
|
|
324
|
+
reason: "missing",
|
|
325
|
+
sources,
|
|
326
|
+
versionRange: versionRange2
|
|
327
|
+
});
|
|
328
|
+
continue;
|
|
329
|
+
}
|
|
330
|
+
const versionRange = resolveVersionRange(location, sources, peer);
|
|
331
|
+
const { installedVersion, satisfied } = checkVersionSatisfaction(location, peer, versionRange);
|
|
332
|
+
if (!satisfied) {
|
|
333
|
+
unsatisfied.push({
|
|
334
|
+
hasRuntimeSource,
|
|
335
|
+
installedVersion,
|
|
336
|
+
peer,
|
|
337
|
+
reason: "version-mismatch",
|
|
338
|
+
sources,
|
|
339
|
+
versionRange
|
|
340
|
+
});
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
return [
|
|
344
|
+
...unsatisfied,
|
|
345
|
+
...findDeclaredPeerVersionMismatches(name, location, peerDependencies, peerDependencyVersions, exclude)
|
|
346
|
+
];
|
|
347
|
+
}
|
|
348
|
+
function resolvePeerTargetSections(hasRuntimeSource, isTerminal) {
|
|
349
|
+
if (!hasRuntimeSource) return ["devDependencies"];
|
|
350
|
+
if (isTerminal) return ["dependencies"];
|
|
351
|
+
return ["peerDependencies", "devDependencies"];
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
// src/actions/deplint/checkPackage/getUnnecessaryPeerDependencies.ts
|
|
355
|
+
function isPeerImportedInDist(dep, externalDistImports, externalDistTypeImports) {
|
|
356
|
+
const baseName = dep.replace(/^@types\//, "");
|
|
357
|
+
return externalDistImports.includes(dep) || externalDistImports.includes(baseName) || externalDistTypeImports.includes(dep) || externalDistTypeImports.includes(baseName);
|
|
358
|
+
}
|
|
359
|
+
function findUnrequestedPeerDeps(location, packageParams, { externalDistImports, externalDistTypeImports }, exclude) {
|
|
360
|
+
const requiredPeers = getRequiredTransitivePeers(location, packageParams);
|
|
361
|
+
const unrequested = [];
|
|
362
|
+
for (const dep of packageParams.peerDependencies) {
|
|
363
|
+
if (exclude?.has(dep)) continue;
|
|
364
|
+
if (packageParams.dependencies.includes(dep)) continue;
|
|
365
|
+
if (!isPeerImportedInDist(dep, externalDistImports, externalDistTypeImports)) continue;
|
|
366
|
+
if (!requiredPeers.has(dep)) {
|
|
367
|
+
unrequested.push(dep);
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
return unrequested;
|
|
371
|
+
}
|
|
372
|
+
function findRedundantPeerDeps({ peerDependencies, dependencies }, exclude) {
|
|
373
|
+
const depsSet = new Set(dependencies);
|
|
374
|
+
const redundant = [];
|
|
375
|
+
for (const dep of peerDependencies) {
|
|
376
|
+
if (exclude?.has(dep)) continue;
|
|
377
|
+
if (depsSet.has(dep)) {
|
|
378
|
+
redundant.push(dep);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
return redundant;
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
// src/actions/deplint/checkPackage/getUnusedDependencies.ts
|
|
385
|
+
import chalk7 from "chalk";
|
|
386
|
+
function isDepImported(dep, distImports, distTypeImports) {
|
|
387
|
+
const baseName = dep.replace(/^@types\//, "");
|
|
388
|
+
return distImports.includes(dep) || distImports.includes(baseName) || distTypeImports.includes(dep) || distTypeImports.includes(baseName);
|
|
389
|
+
}
|
|
390
|
+
function findUnusedDependencies(location, dependencies, devDependencies, externalDistImports, externalDistTypeImports, externalAllImports, exclude) {
|
|
391
|
+
const runtimeRequiredPeers = getRequiredPeerDependencies(location, dependencies);
|
|
392
|
+
const devRequiredPeers = getRequiredPeerDependencies(location, devDependencies);
|
|
393
|
+
const results = [];
|
|
394
|
+
for (const dep of dependencies) {
|
|
395
|
+
if (exclude?.has(dep)) continue;
|
|
396
|
+
if (runtimeRequiredPeers.has(dep)) continue;
|
|
397
|
+
const isImported = isDepImported(dep, externalDistImports, externalDistTypeImports);
|
|
398
|
+
if (isImported || isUsedViaTsScriptsVariant(dep, [...externalDistImports, ...externalDistTypeImports])) continue;
|
|
399
|
+
if (devRequiredPeers.has(dep)) {
|
|
400
|
+
results.push({
|
|
401
|
+
dep,
|
|
402
|
+
kind: "move-to-dev",
|
|
403
|
+
reason: "only needed as peer of devDependencies"
|
|
404
|
+
});
|
|
405
|
+
} else if (externalAllImports.includes(dep)) {
|
|
406
|
+
results.push({ dep, kind: "move-to-dev" });
|
|
407
|
+
} else {
|
|
408
|
+
results.push({ dep, kind: "remove" });
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
return results;
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
// src/actions/deplint/checkPackage/getUnusedDevDependencies.ts
|
|
415
|
+
import chalk8 from "chalk";
|
|
416
|
+
|
|
417
|
+
// src/actions/deplint/getCliReferencedPackagesFromFiles.ts
|
|
418
|
+
import fs7 from "fs";
|
|
419
|
+
import path3 from "path";
|
|
420
|
+
import ts from "typescript";
|
|
421
|
+
|
|
422
|
+
// src/actions/deplint/getScriptReferencedPackages.ts
|
|
423
|
+
import fs6 from "fs";
|
|
424
|
+
import path2 from "path";
|
|
425
|
+
function getBinNames(location, dep) {
|
|
426
|
+
const depPkgPath = findDepPackageJson(location, dep);
|
|
427
|
+
if (!depPkgPath) return [];
|
|
428
|
+
try {
|
|
429
|
+
const raw = fs6.readFileSync(depPkgPath, "utf8");
|
|
430
|
+
const pkg = JSON.parse(raw);
|
|
431
|
+
if (!pkg.bin) return [];
|
|
432
|
+
if (typeof pkg.bin === "string") return [pkg.name?.split("/").pop() ?? dep];
|
|
433
|
+
return Object.keys(pkg.bin);
|
|
434
|
+
} catch {
|
|
435
|
+
return [];
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
function tokenizeScript(script) {
|
|
439
|
+
return script.split(/[&|;$()"`\s]+/).map((t) => t.trim()).filter(Boolean);
|
|
440
|
+
}
|
|
441
|
+
function getScriptReferencedPackages(location, allDeps) {
|
|
442
|
+
const pkgPath = path2.join(location, "package.json");
|
|
443
|
+
let scripts;
|
|
444
|
+
try {
|
|
445
|
+
const raw = fs6.readFileSync(pkgPath, "utf8");
|
|
446
|
+
const pkg = JSON.parse(raw);
|
|
447
|
+
scripts = pkg.scripts ?? {};
|
|
448
|
+
} catch {
|
|
449
|
+
return /* @__PURE__ */ new Set();
|
|
450
|
+
}
|
|
451
|
+
const scriptText = Object.values(scripts).join(" ");
|
|
452
|
+
const tokens = new Set(tokenizeScript(scriptText));
|
|
453
|
+
const binToPackage = /* @__PURE__ */ new Map();
|
|
454
|
+
for (const dep of allDeps) {
|
|
455
|
+
const bins = getBinNames(location, dep);
|
|
456
|
+
for (const bin of bins) {
|
|
457
|
+
binToPackage.set(bin, dep);
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
const referenced = /* @__PURE__ */ new Set();
|
|
461
|
+
for (const token of tokens) {
|
|
462
|
+
const baseName = getBasePackageName(token);
|
|
463
|
+
if (allDeps.includes(baseName)) {
|
|
464
|
+
referenced.add(baseName);
|
|
465
|
+
}
|
|
466
|
+
const pkg = binToPackage.get(token);
|
|
467
|
+
if (pkg) {
|
|
468
|
+
referenced.add(pkg);
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
return referenced;
|
|
472
|
+
}
|
|
473
|
+
|
|
474
|
+
// src/actions/deplint/getCliReferencedPackagesFromFiles.ts
|
|
475
|
+
var shellCommandFunctions = /* @__PURE__ */ new Set(["execSync", "exec"]);
|
|
476
|
+
var directExecFunctions = /* @__PURE__ */ new Set(["spawn", "spawnSync", "execFile", "execFileSync"]);
|
|
477
|
+
var allExecFunctions = /* @__PURE__ */ new Set([...shellCommandFunctions, ...directExecFunctions]);
|
|
478
|
+
function getCommandTokensFromFile(filePath) {
|
|
479
|
+
const tokens = /* @__PURE__ */ new Set();
|
|
480
|
+
let sourceCode;
|
|
481
|
+
try {
|
|
482
|
+
sourceCode = fs7.readFileSync(filePath, "utf8");
|
|
483
|
+
} catch {
|
|
484
|
+
return tokens;
|
|
485
|
+
}
|
|
486
|
+
const isMjsFile = filePath.endsWith(".mjs");
|
|
487
|
+
const sourceFile = ts.createSourceFile(
|
|
488
|
+
path3.basename(filePath),
|
|
489
|
+
sourceCode,
|
|
490
|
+
ts.ScriptTarget.Latest,
|
|
491
|
+
true,
|
|
492
|
+
isMjsFile ? ts.ScriptKind.JS : void 0
|
|
493
|
+
);
|
|
494
|
+
function visit(node) {
|
|
495
|
+
if (ts.isCallExpression(node) && node.arguments.length > 0) {
|
|
496
|
+
const fnName = getFunctionName(node.expression);
|
|
497
|
+
if (fnName && allExecFunctions.has(fnName)) {
|
|
498
|
+
const firstArg = node.arguments[0];
|
|
499
|
+
if (ts.isStringLiteral(firstArg) || ts.isNoSubstitutionTemplateLiteral(firstArg)) {
|
|
500
|
+
const value = firstArg.text;
|
|
501
|
+
if (shellCommandFunctions.has(fnName)) {
|
|
502
|
+
for (const token of tokenizeScript(value)) {
|
|
503
|
+
tokens.add(token);
|
|
504
|
+
}
|
|
505
|
+
} else {
|
|
506
|
+
tokens.add(value);
|
|
507
|
+
}
|
|
508
|
+
} else if (ts.isTemplateExpression(firstArg)) {
|
|
509
|
+
const head = firstArg.head.text;
|
|
510
|
+
if (head) {
|
|
511
|
+
for (const token of tokenizeScript(head)) {
|
|
512
|
+
tokens.add(token);
|
|
513
|
+
}
|
|
514
|
+
}
|
|
515
|
+
}
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
ts.forEachChild(node, visit);
|
|
519
|
+
}
|
|
520
|
+
visit(sourceFile);
|
|
521
|
+
return tokens;
|
|
522
|
+
}
|
|
523
|
+
function getFunctionName(expr) {
|
|
524
|
+
if (ts.isIdentifier(expr)) {
|
|
525
|
+
return expr.text;
|
|
526
|
+
}
|
|
527
|
+
if (ts.isPropertyAccessExpression(expr) && ts.isIdentifier(expr.name)) {
|
|
528
|
+
return expr.name.text;
|
|
529
|
+
}
|
|
530
|
+
return void 0;
|
|
531
|
+
}
|
|
532
|
+
function getCliReferencedPackagesFromFiles(allFiles, location, allDeps) {
|
|
533
|
+
const allTokens = /* @__PURE__ */ new Set();
|
|
534
|
+
for (const file of allFiles) {
|
|
535
|
+
for (const token of getCommandTokensFromFile(file)) {
|
|
536
|
+
allTokens.add(token);
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
if (allTokens.size === 0) return /* @__PURE__ */ new Set();
|
|
540
|
+
const binToPackage = /* @__PURE__ */ new Map();
|
|
541
|
+
for (const dep of allDeps) {
|
|
542
|
+
for (const bin of getBinNames(location, dep)) {
|
|
543
|
+
binToPackage.set(bin, dep);
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
const referenced = /* @__PURE__ */ new Set();
|
|
547
|
+
for (const token of allTokens) {
|
|
548
|
+
const baseName = getBasePackageName(token);
|
|
549
|
+
if (allDeps.includes(baseName)) {
|
|
550
|
+
referenced.add(baseName);
|
|
551
|
+
}
|
|
552
|
+
const pkg = binToPackage.get(token);
|
|
553
|
+
if (pkg) {
|
|
554
|
+
referenced.add(pkg);
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
return referenced;
|
|
558
|
+
}
|
|
559
|
+
|
|
560
|
+
// src/actions/deplint/implicitDevDependencies.ts
|
|
561
|
+
import fs8 from "fs";
|
|
562
|
+
|
|
563
|
+
// src/pm/detectPackageManager.ts
|
|
564
|
+
import { existsSync } from "fs";
|
|
565
|
+
function detectPackageManager() {
|
|
566
|
+
if (existsSync("pnpm-lock.yaml") || existsSync("pnpm-workspace.yaml")) return "pnpm";
|
|
567
|
+
return "yarn";
|
|
568
|
+
}
|
|
569
|
+
|
|
570
|
+
// src/actions/deplint/implicitDevDependencies.ts
|
|
571
|
+
var hasFileWithExtension = (files, extensions) => files.some((f) => extensions.some((ext) => f.endsWith(ext)));
|
|
572
|
+
var tsExtensions = [".ts", ".tsx", ".mts", ".cts"];
|
|
573
|
+
var hasTypescriptFiles = ({ allFiles }) => hasFileWithExtension(allFiles, tsExtensions);
|
|
574
|
+
var decoratorPattern = /^\s*@[a-zA-Z]\w*/m;
|
|
575
|
+
var hasDecorators = ({ allFiles }) => allFiles.filter((f) => tsExtensions.some((ext) => f.endsWith(ext))).some((file) => {
|
|
576
|
+
try {
|
|
577
|
+
const content = fs8.readFileSync(file, "utf8");
|
|
578
|
+
return decoratorPattern.test(content);
|
|
579
|
+
} catch {
|
|
580
|
+
return false;
|
|
581
|
+
}
|
|
582
|
+
});
|
|
583
|
+
var hasDependencyRequiringTslib = ({ location, allDependencies }) => allDependencies.some((dep) => {
|
|
584
|
+
const pkgPath = findDepPackageJson(location, dep);
|
|
585
|
+
if (!pkgPath) return false;
|
|
586
|
+
try {
|
|
587
|
+
const pkg = JSON.parse(fs8.readFileSync(pkgPath, "utf8"));
|
|
588
|
+
const peers = pkg.peerDependencies;
|
|
589
|
+
return peers !== void 0 && "tslib" in peers;
|
|
590
|
+
} catch {
|
|
591
|
+
return false;
|
|
592
|
+
}
|
|
593
|
+
});
|
|
594
|
+
var importPlugins = /* @__PURE__ */ new Set(["eslint-plugin-import-x", "eslint-plugin-import"]);
|
|
595
|
+
function hasImportPlugin({ location, allDependencies }) {
|
|
596
|
+
if (allDependencies.some((d) => importPlugins.has(d))) return true;
|
|
597
|
+
for (const dep of allDependencies) {
|
|
598
|
+
const pkgPath = findDepPackageJson(location, dep);
|
|
599
|
+
if (!pkgPath) continue;
|
|
600
|
+
try {
|
|
601
|
+
const pkg = JSON.parse(fs8.readFileSync(pkgPath, "utf8"));
|
|
602
|
+
const transitiveDeps = [
|
|
603
|
+
...Object.keys(pkg.dependencies ?? {}),
|
|
604
|
+
...Object.keys(pkg.peerDependencies ?? {})
|
|
605
|
+
];
|
|
606
|
+
if (transitiveDeps.some((d) => importPlugins.has(d))) return true;
|
|
607
|
+
} catch {
|
|
608
|
+
}
|
|
609
|
+
}
|
|
610
|
+
return false;
|
|
611
|
+
}
|
|
612
|
+
var hasVitest = ({ allDependencies }) => allDependencies.includes("vitest");
|
|
613
|
+
var isYarnRepo = () => detectPackageManager() === "yarn";
|
|
614
|
+
var isPnpmRepo = () => detectPackageManager() === "pnpm";
|
|
615
|
+
var rules = [
|
|
616
|
+
{
|
|
617
|
+
package: "typescript",
|
|
618
|
+
isNeeded: hasTypescriptFiles
|
|
619
|
+
},
|
|
620
|
+
{
|
|
621
|
+
package: "eslint-import-resolver-typescript",
|
|
622
|
+
isNeeded: (context) => hasTypescriptFiles(context) && context.allDependencies.includes("eslint") && hasImportPlugin(context)
|
|
623
|
+
},
|
|
624
|
+
{
|
|
625
|
+
package: "tslib",
|
|
626
|
+
isNeeded: (context) => hasDecorators(context) || hasDependencyRequiringTslib(context)
|
|
627
|
+
},
|
|
628
|
+
{
|
|
629
|
+
package: "@vitest/coverage-v8",
|
|
630
|
+
isNeeded: hasVitest
|
|
631
|
+
},
|
|
632
|
+
{
|
|
633
|
+
package: "@xylabs/ts-scripts-yarn3",
|
|
634
|
+
isNeeded: isYarnRepo
|
|
635
|
+
},
|
|
636
|
+
{
|
|
637
|
+
package: "@xylabs/ts-scripts-react-yarn3",
|
|
638
|
+
isNeeded: isYarnRepo
|
|
639
|
+
},
|
|
640
|
+
{
|
|
641
|
+
package: "@xylabs/ts-scripts-pnpm",
|
|
642
|
+
isNeeded: isPnpmRepo
|
|
643
|
+
},
|
|
644
|
+
{
|
|
645
|
+
package: "@xylabs/ts-scripts-react-pnpm",
|
|
646
|
+
isNeeded: isPnpmRepo
|
|
647
|
+
}
|
|
648
|
+
];
|
|
649
|
+
function getImplicitDevDependencies(context) {
|
|
650
|
+
const implicit = /* @__PURE__ */ new Set();
|
|
651
|
+
for (const rule of rules) {
|
|
652
|
+
if (rule.isNeeded(context)) {
|
|
653
|
+
implicit.add(rule.package);
|
|
654
|
+
}
|
|
655
|
+
}
|
|
656
|
+
return implicit;
|
|
657
|
+
}
|
|
658
|
+
|
|
659
|
+
// src/actions/deplint/checkPackage/getUnusedDevDependencies.ts
|
|
660
|
+
var allExternalImports = ({
|
|
661
|
+
externalAllImports,
|
|
662
|
+
externalDistImports,
|
|
663
|
+
externalDistTypeImports
|
|
664
|
+
}) => {
|
|
665
|
+
return /* @__PURE__ */ new Set([
|
|
666
|
+
...externalAllImports,
|
|
667
|
+
...externalDistImports,
|
|
668
|
+
...externalDistTypeImports
|
|
669
|
+
]);
|
|
670
|
+
};
|
|
671
|
+
function isDevDepUsed(dep, allImports, implicitDeps, requiredPeers, scriptRefs, cliRefs) {
|
|
672
|
+
if (implicitDeps.has(dep)) return true;
|
|
673
|
+
if (requiredPeers.has(dep)) return true;
|
|
674
|
+
if (scriptRefs.has(dep)) return true;
|
|
675
|
+
if (cliRefs.has(dep)) return true;
|
|
676
|
+
if (dep.startsWith("@types/")) {
|
|
677
|
+
const baseName = dep.replace(/^@types\//, "");
|
|
678
|
+
return allImports.has(baseName) || allImports.has(dep) || implicitDeps.has(baseName);
|
|
679
|
+
}
|
|
680
|
+
if (allImports.has(dep)) return true;
|
|
681
|
+
return isUsedViaTsScriptsVariant(dep, [...allImports]);
|
|
682
|
+
}
|
|
683
|
+
function findUnusedDevDeps(location, dependencies, devDependencies, peerDependencies, sourceParams, fileContext, exclude) {
|
|
684
|
+
const allImports = allExternalImports(sourceParams);
|
|
685
|
+
const allDeps = [...dependencies, ...devDependencies, ...peerDependencies];
|
|
686
|
+
const implicitDeps = getImplicitDevDependencies({
|
|
687
|
+
...fileContext,
|
|
688
|
+
allDependencies: allDeps,
|
|
689
|
+
location
|
|
690
|
+
});
|
|
691
|
+
const requiredPeers = getRequiredPeerDependencies(location, allDeps);
|
|
692
|
+
const scriptRefs = getScriptReferencedPackages(location, allDeps);
|
|
693
|
+
const cliRefs = getCliReferencedPackagesFromFiles(fileContext.allFiles, location, allDeps);
|
|
694
|
+
const unused = [];
|
|
695
|
+
for (const dep of devDependencies) {
|
|
696
|
+
if (exclude?.has(dep)) continue;
|
|
697
|
+
if (dependencies.includes(dep) || peerDependencies.includes(dep)) continue;
|
|
698
|
+
if (!isDevDepUsed(dep, allImports, implicitDeps, requiredPeers, scriptRefs, cliRefs)) {
|
|
699
|
+
unused.push(dep);
|
|
700
|
+
}
|
|
701
|
+
}
|
|
702
|
+
return unused;
|
|
703
|
+
}
|
|
704
|
+
|
|
705
|
+
// src/actions/deplint/checkPackage/getUnusedPeerDependencies.ts
|
|
706
|
+
import chalk9 from "chalk";
|
|
707
|
+
function isPeerUsed(dep, externalDistImports, externalDistTypeImports) {
|
|
708
|
+
const baseName = dep.replace(/^@types\//, "");
|
|
709
|
+
return externalDistImports.includes(dep) || externalDistImports.includes(baseName) || externalDistTypeImports.includes(dep) || externalDistTypeImports.includes(baseName);
|
|
710
|
+
}
|
|
711
|
+
function findUnusedPeerDeps(peerDependencies, externalDistImports, externalDistTypeImports, exclude) {
|
|
712
|
+
const unused = [];
|
|
713
|
+
for (const dep of peerDependencies) {
|
|
714
|
+
if (exclude?.has(dep)) continue;
|
|
715
|
+
if (!isPeerUsed(dep, externalDistImports, externalDistTypeImports)) {
|
|
716
|
+
unused.push(dep);
|
|
717
|
+
}
|
|
718
|
+
}
|
|
719
|
+
return unused;
|
|
720
|
+
}
|
|
721
|
+
|
|
722
|
+
// src/actions/deplint/checkPackage/getWorkspaceVersionProblems.ts
|
|
723
|
+
import chalk10 from "chalk";
|
|
724
|
+
import semver3 from "semver";
|
|
725
|
+
function checkSection(deps, versions, section, workspaceNames, problems) {
|
|
726
|
+
for (const dep of deps) {
|
|
727
|
+
if (!workspaceNames.has(dep)) continue;
|
|
728
|
+
const version = versions[dep];
|
|
729
|
+
if (version && !version.startsWith("workspace:")) {
|
|
730
|
+
problems.push({
|
|
731
|
+
dep,
|
|
732
|
+
section,
|
|
733
|
+
version
|
|
734
|
+
});
|
|
735
|
+
}
|
|
736
|
+
}
|
|
737
|
+
}
|
|
738
|
+
function findWorkspaceVersionProblems(packageParams, workspaceNames) {
|
|
739
|
+
const problems = [];
|
|
740
|
+
checkSection(packageParams.dependencies, packageParams.dependencyVersions, "dependencies", workspaceNames, problems);
|
|
741
|
+
checkSection(packageParams.devDependencies, packageParams.devDependencyVersions, "devDependencies", workspaceNames, problems);
|
|
742
|
+
return problems;
|
|
743
|
+
}
|
|
744
|
+
function findWorkspacePeerVersionProblems(packageParams, workspaceNames, location) {
|
|
745
|
+
const problems = [];
|
|
746
|
+
for (const dep of packageParams.peerDependencies) {
|
|
747
|
+
if (!workspaceNames.has(dep)) continue;
|
|
748
|
+
const declaredRange = packageParams.peerDependencyVersions[dep];
|
|
749
|
+
if (!declaredRange || declaredRange.startsWith("workspace:")) continue;
|
|
750
|
+
const resolved = resolveDepVersion(location, dep);
|
|
751
|
+
const actualVersion = resolved.startsWith("~") ? resolved.slice(1) : resolved;
|
|
752
|
+
if (actualVersion === "*") continue;
|
|
753
|
+
if (!semver3.satisfies(actualVersion, declaredRange)) {
|
|
754
|
+
problems.push({
|
|
755
|
+
actualVersion,
|
|
756
|
+
declaredRange,
|
|
757
|
+
dep
|
|
758
|
+
});
|
|
759
|
+
}
|
|
760
|
+
}
|
|
761
|
+
return problems;
|
|
762
|
+
}
|
|
763
|
+
|
|
764
|
+
// src/actions/deplint/rules.ts
|
|
765
|
+
function diagnostic(context, id, message, dependency, evidence, fixes) {
|
|
766
|
+
return {
|
|
767
|
+
dependency,
|
|
768
|
+
evidence,
|
|
769
|
+
file: context.packageJsonPath,
|
|
770
|
+
fixes,
|
|
771
|
+
id,
|
|
772
|
+
message,
|
|
773
|
+
severity: "error",
|
|
774
|
+
workspace: context.workspace
|
|
775
|
+
};
|
|
776
|
+
}
|
|
777
|
+
function resolvedAddFix(context, dependency, section, detail) {
|
|
778
|
+
return {
|
|
779
|
+
action: "add",
|
|
780
|
+
dependency,
|
|
781
|
+
detail,
|
|
782
|
+
section,
|
|
783
|
+
version: resolveDepVersion(context.workspace.location, dependency)
|
|
784
|
+
};
|
|
785
|
+
}
|
|
786
|
+
var unlistedDependenciesRule = {
|
|
787
|
+
category: "dependencies",
|
|
788
|
+
id: "deplint.dependencies.unlisted",
|
|
789
|
+
evaluate(context) {
|
|
790
|
+
const findings = findUnlistedDependencies(
|
|
791
|
+
context.workspace.name,
|
|
792
|
+
context.packageParams.dependencies,
|
|
793
|
+
context.packageParams.devDependencies,
|
|
794
|
+
context.packageParams.peerDependencies,
|
|
795
|
+
context.sourceParams.externalDistImports,
|
|
796
|
+
context.sourceParams.externalDistTypeImports
|
|
797
|
+
);
|
|
798
|
+
return findings.map(({ imp, section }) => {
|
|
799
|
+
const isPeer = !context.isTerminalPackage && section === "dependencies" && !context.forceDeps.has(imp) && shouldBePeerDependency(imp, context.workspace.location, context.packageParams.peerDependencies, context.sourceParams.externalDistImports);
|
|
800
|
+
const fixes = isPeer ? ["peerDependencies", "devDependencies"].map(
|
|
801
|
+
(s) => resolvedAddFix(context, imp, s, `added to ${s}`)
|
|
802
|
+
) : [resolvedAddFix(context, imp, section, `added to ${section}`)];
|
|
803
|
+
return diagnostic(
|
|
804
|
+
context,
|
|
805
|
+
"deplint.dependencies.unlisted",
|
|
806
|
+
`Missing dependency in package.json: ${imp}`,
|
|
807
|
+
imp,
|
|
808
|
+
context.sourceParams.distImportPaths[imp],
|
|
809
|
+
fixes
|
|
810
|
+
);
|
|
811
|
+
});
|
|
812
|
+
}
|
|
813
|
+
};
|
|
814
|
+
var unusedDependenciesRule = {
|
|
815
|
+
category: "dependencies",
|
|
816
|
+
id: "deplint.dependencies.unused",
|
|
817
|
+
evaluate(context) {
|
|
818
|
+
const findings = findUnusedDependencies(
|
|
819
|
+
context.workspace.location,
|
|
820
|
+
context.packageParams.dependencies,
|
|
821
|
+
context.packageParams.devDependencies,
|
|
822
|
+
context.sourceParams.externalDistImports,
|
|
823
|
+
context.sourceParams.externalDistTypeImports,
|
|
824
|
+
context.sourceParams.externalAllImports,
|
|
825
|
+
context.unusedDependencyExclude
|
|
826
|
+
);
|
|
827
|
+
return findings.map(({
|
|
828
|
+
dep,
|
|
829
|
+
kind,
|
|
830
|
+
reason
|
|
831
|
+
}) => diagnostic(
|
|
832
|
+
context,
|
|
833
|
+
"deplint.dependencies.unused",
|
|
834
|
+
kind === "move-to-dev" ? `dependency should be devDependency in package.json: ${dep}${reason ? ` (${reason})` : ""}` : `Unused dependency in package.json: ${dep}`,
|
|
835
|
+
dep,
|
|
836
|
+
void 0,
|
|
837
|
+
[kind === "move-to-dev" ? {
|
|
838
|
+
action: "move",
|
|
839
|
+
dependency: dep,
|
|
840
|
+
detail: "moved to devDependencies",
|
|
841
|
+
fromSection: "dependencies",
|
|
842
|
+
toSection: "devDependencies"
|
|
843
|
+
} : {
|
|
844
|
+
action: "remove",
|
|
845
|
+
dependency: dep,
|
|
846
|
+
detail: "removed from dependencies",
|
|
847
|
+
section: "dependencies"
|
|
848
|
+
}]
|
|
849
|
+
));
|
|
850
|
+
}
|
|
851
|
+
};
|
|
852
|
+
var unlistedDevDependenciesRule = {
|
|
853
|
+
category: "devDependencies",
|
|
854
|
+
id: "deplint.devDependencies.unlisted",
|
|
855
|
+
evaluate(context) {
|
|
856
|
+
const findings = findUnlistedDevDeps(
|
|
857
|
+
context.workspace.name,
|
|
858
|
+
context.packageParams.dependencies,
|
|
859
|
+
context.packageParams.devDependencies,
|
|
860
|
+
context.packageParams.peerDependencies,
|
|
861
|
+
context.sourceParams.externalAllImports,
|
|
862
|
+
context.sourceParams.distImports,
|
|
863
|
+
context.sourceParams.externalDistTypeImports
|
|
864
|
+
);
|
|
865
|
+
return findings.map((imp) => diagnostic(
|
|
866
|
+
context,
|
|
867
|
+
"deplint.devDependencies.unlisted",
|
|
868
|
+
`Missing devDependency in package.json: ${imp}`,
|
|
869
|
+
imp,
|
|
870
|
+
context.sourceParams.allImportPaths[imp],
|
|
871
|
+
[resolvedAddFix(context, imp, "devDependencies", "added to devDependencies")]
|
|
872
|
+
));
|
|
873
|
+
}
|
|
874
|
+
};
|
|
875
|
+
var unusedDevDependenciesRule = {
|
|
876
|
+
category: "devDependencies",
|
|
877
|
+
id: "deplint.devDependencies.unused",
|
|
878
|
+
evaluate(context) {
|
|
879
|
+
const findings = findUnusedDevDeps(
|
|
880
|
+
context.workspace.location,
|
|
881
|
+
context.packageParams.dependencies,
|
|
882
|
+
context.packageParams.devDependencies,
|
|
883
|
+
context.packageParams.peerDependencies,
|
|
884
|
+
context.sourceParams,
|
|
885
|
+
context.fileContext,
|
|
886
|
+
context.unusedDependencyExclude
|
|
887
|
+
);
|
|
888
|
+
return findings.map((dep) => diagnostic(
|
|
889
|
+
context,
|
|
890
|
+
"deplint.devDependencies.unused",
|
|
891
|
+
`Unused devDependency in package.json: ${dep}`,
|
|
892
|
+
dep,
|
|
893
|
+
void 0,
|
|
894
|
+
[{
|
|
895
|
+
action: "remove",
|
|
896
|
+
dependency: dep,
|
|
897
|
+
detail: "removed from devDependencies",
|
|
898
|
+
section: "devDependencies"
|
|
899
|
+
}]
|
|
900
|
+
));
|
|
901
|
+
}
|
|
902
|
+
};
|
|
903
|
+
var redundantDevDependenciesRule = {
|
|
904
|
+
category: "devDependencies",
|
|
905
|
+
id: "deplint.devDependencies.redundant",
|
|
906
|
+
evaluate(context) {
|
|
907
|
+
const diagnostics = [];
|
|
908
|
+
for (const dep of context.packageParams.devDependencies) {
|
|
909
|
+
if (!context.packageParams.dependencies.includes(dep)) continue;
|
|
910
|
+
if (!context.isTerminalPackage && !context.forceDeps.has(dep) && shouldBePeerDependency(dep, context.workspace.location, context.packageParams.peerDependencies, context.sourceParams.externalDistImports)) {
|
|
911
|
+
continue;
|
|
912
|
+
}
|
|
913
|
+
diagnostics.push(diagnostic(
|
|
914
|
+
context,
|
|
915
|
+
"deplint.devDependencies.redundant",
|
|
916
|
+
`Redundant devDependency ${dep} \u2014 already listed in dependencies`,
|
|
917
|
+
dep,
|
|
918
|
+
void 0,
|
|
919
|
+
[{
|
|
920
|
+
action: "remove",
|
|
921
|
+
dependency: dep,
|
|
922
|
+
detail: "removed redundant devDependency (kept in dependencies)",
|
|
923
|
+
section: "devDependencies"
|
|
924
|
+
}]
|
|
925
|
+
));
|
|
926
|
+
}
|
|
927
|
+
return diagnostics;
|
|
928
|
+
}
|
|
929
|
+
};
|
|
930
|
+
function generateVersionMismatchFixes(context, finding) {
|
|
931
|
+
const expectedVersion = resolveExpectedPeerVersion(
|
|
932
|
+
context.workspace.location,
|
|
933
|
+
finding.peer,
|
|
934
|
+
finding.versionRange
|
|
935
|
+
);
|
|
936
|
+
if (expectedVersion === "*") return [];
|
|
937
|
+
const fixes = [];
|
|
938
|
+
if (context.packageParams.peerDependencies.includes(finding.peer)) {
|
|
939
|
+
fixes.push({
|
|
940
|
+
action: "set-version",
|
|
941
|
+
dependency: finding.peer,
|
|
942
|
+
detail: `updated peerDependency version to match installed (${finding.installedVersion})`,
|
|
943
|
+
section: "peerDependencies",
|
|
944
|
+
version: expectedVersion
|
|
945
|
+
});
|
|
946
|
+
}
|
|
947
|
+
if (context.packageParams.devDependencies.includes(finding.peer)) {
|
|
948
|
+
const devVersion = context.packageParams.devDependencyVersions[finding.peer];
|
|
949
|
+
if (devVersion && !devVersion.startsWith("workspace:")) {
|
|
950
|
+
fixes.push({
|
|
951
|
+
action: "set-version",
|
|
952
|
+
dependency: finding.peer,
|
|
953
|
+
detail: `updated devDependency version to match installed (${finding.installedVersion})`,
|
|
954
|
+
section: "devDependencies",
|
|
955
|
+
version: expectedVersion
|
|
956
|
+
});
|
|
957
|
+
}
|
|
958
|
+
}
|
|
959
|
+
return fixes;
|
|
960
|
+
}
|
|
961
|
+
var unsatisfiedPeersRule = {
|
|
962
|
+
category: "peerDependencies",
|
|
963
|
+
id: "deplint.peerDependencies.unsatisfied",
|
|
964
|
+
evaluate(context) {
|
|
965
|
+
const findings = findUnsatisfiedPeers(context.workspace, context.packageParams, context.exclude);
|
|
966
|
+
return findings.map((finding) => {
|
|
967
|
+
const requiredBy = finding.sources.map((source) => source.requiredBy).join(", ");
|
|
968
|
+
const chain = finding.sources.find((source) => source.chain && source.chain.length > 0)?.chain?.join(" -> ");
|
|
969
|
+
const evidence = chain ? [`via ${chain}`] : void 0;
|
|
970
|
+
const message = finding.reason === "version-mismatch" ? `Peer dependency version mismatch ${finding.peer} \u2014 installed ${finding.installedVersion ?? "unknown"} does not satisfy ${finding.versionRange} (required by ${requiredBy})` : finding.hasRuntimeSource ? `Unsatisfied peer dependency ${finding.peer} (required by ${requiredBy}) \u2014 must be in dependencies or peerDependencies` : `Unsatisfied peer dependency ${finding.peer} (required by devDependency ${requiredBy}) \u2014 must be in dependencies, devDependencies, or peerDependencies`;
|
|
971
|
+
const fixes = finding.reason === "missing" ? resolvePeerTargetSections(finding.hasRuntimeSource, context.isTerminalPackage).map((section) => ({
|
|
972
|
+
action: "add",
|
|
973
|
+
dependency: finding.peer,
|
|
974
|
+
detail: `added to ${section}`,
|
|
975
|
+
section,
|
|
976
|
+
version: finding.versionRange
|
|
977
|
+
})) : finding.reason === "version-mismatch" ? generateVersionMismatchFixes(context, finding) : void 0;
|
|
978
|
+
return diagnostic(
|
|
979
|
+
context,
|
|
980
|
+
"deplint.peerDependencies.unsatisfied",
|
|
981
|
+
message,
|
|
982
|
+
finding.peer,
|
|
983
|
+
evidence,
|
|
984
|
+
fixes
|
|
985
|
+
);
|
|
986
|
+
});
|
|
987
|
+
}
|
|
988
|
+
};
|
|
989
|
+
var unusedPeerDependenciesRule = {
|
|
990
|
+
category: "peerDependencies",
|
|
991
|
+
id: "deplint.peerDependencies.unused",
|
|
992
|
+
evaluate(context) {
|
|
993
|
+
const findings = findUnusedPeerDeps(
|
|
994
|
+
context.packageParams.peerDependencies,
|
|
995
|
+
context.sourceParams.externalDistImports,
|
|
996
|
+
context.sourceParams.externalDistTypeImports,
|
|
997
|
+
context.unusedDependencyExclude
|
|
998
|
+
);
|
|
999
|
+
return findings.map((dep) => diagnostic(
|
|
1000
|
+
context,
|
|
1001
|
+
"deplint.peerDependencies.unused",
|
|
1002
|
+
context.packageParams.dependencies.includes(dep) ? `Unused peerDependency [already a dependency] in package.json: ${dep}` : `Unused peerDependency in package.json: ${dep}`,
|
|
1003
|
+
dep,
|
|
1004
|
+
void 0,
|
|
1005
|
+
[{
|
|
1006
|
+
action: "remove",
|
|
1007
|
+
dependency: dep,
|
|
1008
|
+
detail: "removed from peerDependencies",
|
|
1009
|
+
section: "peerDependencies"
|
|
1010
|
+
}]
|
|
1011
|
+
));
|
|
1012
|
+
}
|
|
1013
|
+
};
|
|
1014
|
+
var unrequestedPeerDependenciesRule = {
|
|
1015
|
+
category: "peerDependencies",
|
|
1016
|
+
id: "deplint.peerDependencies.unrequested",
|
|
1017
|
+
evaluate(context) {
|
|
1018
|
+
if (!context.isTerminalPackage) return [];
|
|
1019
|
+
const findings = findUnrequestedPeerDeps(
|
|
1020
|
+
context.workspace.location,
|
|
1021
|
+
context.packageParams,
|
|
1022
|
+
context.sourceParams,
|
|
1023
|
+
context.exclude
|
|
1024
|
+
);
|
|
1025
|
+
return findings.map((dep) => diagnostic(
|
|
1026
|
+
context,
|
|
1027
|
+
"deplint.peerDependencies.unrequested",
|
|
1028
|
+
`Unnecessary peerDependency ${dep} \u2014 imported in dist but no dependency requires it as a peer; should be a dependency`,
|
|
1029
|
+
dep,
|
|
1030
|
+
void 0,
|
|
1031
|
+
[{
|
|
1032
|
+
action: "move",
|
|
1033
|
+
dependency: dep,
|
|
1034
|
+
detail: "moved from peerDependencies to dependencies",
|
|
1035
|
+
fromSection: "peerDependencies",
|
|
1036
|
+
toSection: "dependencies",
|
|
1037
|
+
version: context.packageParams.peerDependencyVersions[dep] ?? "*"
|
|
1038
|
+
}]
|
|
1039
|
+
));
|
|
1040
|
+
}
|
|
1041
|
+
};
|
|
1042
|
+
var misplacedDependenciesRule = {
|
|
1043
|
+
category: "dependencies",
|
|
1044
|
+
id: "deplint.dependencies.misplaced",
|
|
1045
|
+
evaluate(context) {
|
|
1046
|
+
if (context.isTerminalPackage) return [];
|
|
1047
|
+
const diagnostics = [];
|
|
1048
|
+
for (const dep of context.packageParams.dependencies) {
|
|
1049
|
+
if (context.forceDeps.has(dep)) continue;
|
|
1050
|
+
if (context.forcePeers.has(dep) || shouldBePeerDependency(dep, context.workspace.location, context.packageParams.peerDependencies, context.sourceParams.externalDistImports)) {
|
|
1051
|
+
const fixes = [{
|
|
1052
|
+
action: "move",
|
|
1053
|
+
dependency: dep,
|
|
1054
|
+
detail: "moved from dependencies to peerDependencies",
|
|
1055
|
+
fromSection: "dependencies",
|
|
1056
|
+
toSection: "peerDependencies"
|
|
1057
|
+
}];
|
|
1058
|
+
if (!context.packageParams.devDependencies.includes(dep)) {
|
|
1059
|
+
fixes.push(resolvedAddFix(context, dep, "devDependencies", "added to devDependencies"));
|
|
1060
|
+
}
|
|
1061
|
+
const reason = context.forcePeers.has(dep) ? 'configured as refType "peer"' : "it shares peers with existing peerDependencies";
|
|
1062
|
+
diagnostics.push(diagnostic(
|
|
1063
|
+
context,
|
|
1064
|
+
"deplint.dependencies.misplaced",
|
|
1065
|
+
`dependency ${dep} should be a peerDependency \u2014 ${reason}`,
|
|
1066
|
+
dep,
|
|
1067
|
+
void 0,
|
|
1068
|
+
fixes
|
|
1069
|
+
));
|
|
1070
|
+
}
|
|
1071
|
+
}
|
|
1072
|
+
return diagnostics;
|
|
1073
|
+
}
|
|
1074
|
+
};
|
|
1075
|
+
var misplacedPeerDependenciesRule = {
|
|
1076
|
+
category: "peerDependencies",
|
|
1077
|
+
id: "deplint.peerDependencies.misplaced",
|
|
1078
|
+
evaluate(context) {
|
|
1079
|
+
const diagnostics = [];
|
|
1080
|
+
for (const dep of context.packageParams.peerDependencies) {
|
|
1081
|
+
if (context.forceDeps.has(dep)) {
|
|
1082
|
+
const fixes = [{
|
|
1083
|
+
action: "move",
|
|
1084
|
+
dependency: dep,
|
|
1085
|
+
detail: "moved from peerDependencies to dependencies",
|
|
1086
|
+
fromSection: "peerDependencies",
|
|
1087
|
+
toSection: "dependencies",
|
|
1088
|
+
version: context.packageParams.peerDependencyVersions[dep] ?? "*"
|
|
1089
|
+
}];
|
|
1090
|
+
diagnostics.push(diagnostic(
|
|
1091
|
+
context,
|
|
1092
|
+
"deplint.peerDependencies.misplaced",
|
|
1093
|
+
`peerDependency ${dep} should be a dependency \u2014 configured as refType "dep"`,
|
|
1094
|
+
dep,
|
|
1095
|
+
void 0,
|
|
1096
|
+
fixes
|
|
1097
|
+
));
|
|
1098
|
+
}
|
|
1099
|
+
}
|
|
1100
|
+
return diagnostics;
|
|
1101
|
+
}
|
|
1102
|
+
};
|
|
1103
|
+
var redundantPeerDependenciesRule = {
|
|
1104
|
+
category: "peerDependencies",
|
|
1105
|
+
id: "deplint.peerDependencies.redundant",
|
|
1106
|
+
evaluate(context) {
|
|
1107
|
+
const findings = findRedundantPeerDeps(context.packageParams, context.exclude);
|
|
1108
|
+
return findings.map((dep) => diagnostic(
|
|
1109
|
+
context,
|
|
1110
|
+
"deplint.peerDependencies.redundant",
|
|
1111
|
+
`Redundant peerDependency ${dep} \u2014 already listed in dependencies`,
|
|
1112
|
+
dep,
|
|
1113
|
+
void 0,
|
|
1114
|
+
[{
|
|
1115
|
+
action: "remove",
|
|
1116
|
+
dependency: dep,
|
|
1117
|
+
detail: "removed redundant peerDependency (kept in dependencies)",
|
|
1118
|
+
section: "peerDependencies"
|
|
1119
|
+
}]
|
|
1120
|
+
));
|
|
1121
|
+
}
|
|
1122
|
+
};
|
|
1123
|
+
var mismatchedPeerDevVersionsRule = {
|
|
1124
|
+
category: "peerDependencies",
|
|
1125
|
+
id: "deplint.peerDependencies.version-mismatch",
|
|
1126
|
+
evaluate(context) {
|
|
1127
|
+
const findings = findMismatchedPeerDevVersions(context.packageParams, context.exclude);
|
|
1128
|
+
return findings.map(({
|
|
1129
|
+
dep,
|
|
1130
|
+
devVersion,
|
|
1131
|
+
peerVersion
|
|
1132
|
+
}) => diagnostic(
|
|
1133
|
+
context,
|
|
1134
|
+
"deplint.peerDependencies.version-mismatch",
|
|
1135
|
+
`Peer/dev version mismatch ${dep} \u2014 peer: ${peerVersion}, dev: ${devVersion}`,
|
|
1136
|
+
dep,
|
|
1137
|
+
void 0,
|
|
1138
|
+
[{
|
|
1139
|
+
action: "set-version",
|
|
1140
|
+
dependency: dep,
|
|
1141
|
+
detail: "synced peerDependency to devDependency version",
|
|
1142
|
+
section: "peerDependencies",
|
|
1143
|
+
version: devVersion
|
|
1144
|
+
}]
|
|
1145
|
+
));
|
|
1146
|
+
}
|
|
1147
|
+
};
|
|
1148
|
+
var workspaceVersionProblemsRule = {
|
|
1149
|
+
category: "peerDependencies",
|
|
1150
|
+
id: "deplint.workspace.protocol",
|
|
1151
|
+
evaluate(context) {
|
|
1152
|
+
if (!context.workspaceNames) return [];
|
|
1153
|
+
const protocolFindings = findWorkspaceVersionProblems(context.packageParams, context.workspaceNames);
|
|
1154
|
+
const protocolDiagnostics = protocolFindings.map(({
|
|
1155
|
+
dep,
|
|
1156
|
+
section,
|
|
1157
|
+
version
|
|
1158
|
+
}) => diagnostic(
|
|
1159
|
+
context,
|
|
1160
|
+
"deplint.workspace.protocol",
|
|
1161
|
+
`Workspace dependency ${dep} in ${section} should use workspace: protocol \u2014 found ${version}`,
|
|
1162
|
+
dep,
|
|
1163
|
+
void 0,
|
|
1164
|
+
[{
|
|
1165
|
+
action: "set-version",
|
|
1166
|
+
dependency: dep,
|
|
1167
|
+
detail: `set workspace:~ for ${section}`,
|
|
1168
|
+
section,
|
|
1169
|
+
version: "workspace:~"
|
|
1170
|
+
}]
|
|
1171
|
+
));
|
|
1172
|
+
const peerFindings = findWorkspacePeerVersionProblems(
|
|
1173
|
+
context.packageParams,
|
|
1174
|
+
context.workspaceNames,
|
|
1175
|
+
context.workspace.location
|
|
1176
|
+
);
|
|
1177
|
+
const peerDiagnostics = peerFindings.map(({
|
|
1178
|
+
dep,
|
|
1179
|
+
actualVersion,
|
|
1180
|
+
declaredRange
|
|
1181
|
+
}) => {
|
|
1182
|
+
const expectedRange = resolveExpectedPeerVersion(
|
|
1183
|
+
context.workspace.location,
|
|
1184
|
+
dep,
|
|
1185
|
+
declaredRange
|
|
1186
|
+
);
|
|
1187
|
+
return diagnostic(
|
|
1188
|
+
context,
|
|
1189
|
+
"deplint.workspace.protocol",
|
|
1190
|
+
`Workspace peerDependency ${dep} range ${declaredRange} does not satisfy workspace version ${actualVersion}`,
|
|
1191
|
+
dep,
|
|
1192
|
+
void 0,
|
|
1193
|
+
expectedRange === "*" ? void 0 : [{
|
|
1194
|
+
action: "set-version",
|
|
1195
|
+
dependency: dep,
|
|
1196
|
+
detail: "updated peerDependency to match workspace version",
|
|
1197
|
+
section: "peerDependencies",
|
|
1198
|
+
version: expectedRange
|
|
1199
|
+
}]
|
|
1200
|
+
);
|
|
1201
|
+
});
|
|
1202
|
+
return [...protocolDiagnostics, ...peerDiagnostics];
|
|
1203
|
+
}
|
|
1204
|
+
};
|
|
1205
|
+
var deplintRules = [
|
|
1206
|
+
unlistedDependenciesRule,
|
|
1207
|
+
unusedDependenciesRule,
|
|
1208
|
+
misplacedDependenciesRule,
|
|
1209
|
+
unlistedDevDependenciesRule,
|
|
1210
|
+
unusedDevDependenciesRule,
|
|
1211
|
+
redundantDevDependenciesRule,
|
|
1212
|
+
unsatisfiedPeersRule,
|
|
1213
|
+
unusedPeerDependenciesRule,
|
|
1214
|
+
unrequestedPeerDependenciesRule,
|
|
1215
|
+
misplacedPeerDependenciesRule,
|
|
1216
|
+
redundantPeerDependenciesRule,
|
|
1217
|
+
mismatchedPeerDevVersionsRule,
|
|
1218
|
+
workspaceVersionProblemsRule
|
|
1219
|
+
];
|
|
1220
|
+
export {
|
|
1221
|
+
deplintRules
|
|
1222
|
+
};
|
|
1223
|
+
//# sourceMappingURL=rules.mjs.map
|