@xylabs/toolchain 7.10.0 → 7.10.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/index.mjs +162 -30
- package/dist/actions/index.mjs.map +1 -1
- package/dist/actions/package/compile/XyConfig.mjs.map +1 -1
- package/dist/actions/package/compile/index.mjs.map +1 -1
- package/dist/actions/package/index.mjs.map +1 -1
- package/dist/actions/package/publint.mjs.map +1 -1
- package/dist/actions/packman/index.mjs +270 -112
- package/dist/actions/packman/index.mjs.map +1 -1
- package/dist/actions/packman/lint.mjs +203 -36
- package/dist/actions/packman/lint.mjs.map +1 -1
- package/dist/actions/publint.mjs.map +1 -1
- package/dist/bin/package/publint.mjs.map +1 -1
- package/dist/bin/xy.mjs +164 -32
- package/dist/bin/xy.mjs.map +1 -1
- package/dist/index.d.ts +23 -2
- package/dist/index.mjs +1040 -811
- package/dist/index.mjs.map +1 -1
- package/dist/lib/deprecationMigrate.mjs +99 -0
- package/dist/lib/deprecationMigrate.mjs.map +1 -0
- package/dist/lib/index.mjs +238 -141
- package/dist/lib/index.mjs.map +1 -1
- package/dist/xy/common/checkCommand.mjs.map +1 -1
- package/dist/xy/common/index.mjs +164 -32
- package/dist/xy/common/index.mjs.map +1 -1
- package/dist/xy/common/packmanCommand.mjs +272 -114
- package/dist/xy/common/packmanCommand.mjs.map +1 -1
- package/dist/xy/index.mjs +164 -32
- package/dist/xy/index.mjs.map +1 -1
- package/dist/xy/lint/index.mjs.map +1 -1
- package/dist/xy/lint/publintCommand.mjs.map +1 -1
- package/dist/xy/xy.mjs +164 -32
- package/dist/xy/xy.mjs.map +1 -1
- package/package.json +4 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/lib/concurrency.ts","../../../src/pm/detectPackageManager.ts","../../../src/pm/registry.ts","../../../src/lib/initCwd.ts","../../../src/lib/loadConfig.ts","../../../src/lib/runInstall.ts","../../../src/actions/package-lint-deps.ts","../../../src/actions/package/compile/XyConfig.ts","../../../src/actions/package/publint.ts","../../../src/actions/publint.ts","../../../src/xy/param.ts","../../../src/xy/lint/publintCommand.ts"],"sourcesContent":["import { AsyncLocalStorage } from 'node:async_hooks'\n\nexport const outputStorage = new AsyncLocalStorage<string[]>()\n\nlet captureInstalled = false\n\nexport function installOutputCapture(): void {\n if (captureInstalled) return\n captureInstalled = true\n\n const originalStdoutWrite = process.stdout.write.bind(process.stdout)\n const originalStderrWrite = process.stderr.write.bind(process.stderr)\n\n function intercept(\n original: typeof process.stdout.write,\n ): typeof process.stdout.write {\n return function (chunk: string | Uint8Array, ...args: unknown[]) {\n const buffer = outputStorage.getStore()\n if (buffer) {\n buffer.push(typeof chunk === 'string' ? chunk : new TextDecoder().decode(chunk))\n return true\n }\n return (original as (...params: unknown[]) => boolean)(chunk, ...args)\n } as typeof process.stdout.write\n }\n\n process.stdout.write = intercept(originalStdoutWrite)\n process.stderr.write = intercept(originalStderrWrite)\n}\n\nexport async function runWithConcurrency<T>(\n items: T[],\n concurrency: number,\n fn: (item: T) => Promise<void>,\n): Promise<void> {\n let next = 0\n async function worker(): Promise<void> {\n while (next < items.length) {\n const i = next++\n await fn(items[i])\n }\n }\n await Promise.all(Array.from({ length: Math.min(concurrency, items.length) }, () => worker()))\n}\n","import { existsSync } from 'node:fs'\n\nexport type PackageManagerName = 'pnpm' | 'yarn'\n\nexport function detectPackageManager(): PackageManagerName {\n if (existsSync('pnpm-lock.yaml') || existsSync('pnpm-workspace.yaml')) return 'pnpm'\n return 'yarn'\n}\n","import type { PackageManagerName } from './detectPackageManager.ts'\nimport { detectPackageManager } from './detectPackageManager.ts'\nimport type { PackageManager } from './PackageManager.ts'\n\nconst implementations = new Map<PackageManagerName, PackageManager>()\n\nexport function registerPackageManager(pm: PackageManager): void {\n implementations.set(pm.name, pm)\n}\n\nexport function getPackageManager(name?: PackageManagerName): PackageManager {\n const pmName = name ?? detectPackageManager()\n const pm = implementations.get(pmName)\n if (!pm) {\n throw new Error(\n `No package manager implementation registered for \"${pmName}\". `\n + 'Ensure registerPackageManager() has been called before getPackageManager().',\n )\n }\n return pm\n}\n","export function INIT_CWD(): string {\n return process.env.INIT_CWD ?? process.cwd()\n}\n","import chalk from 'chalk'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { TypeScriptLoader } from 'cosmiconfig-typescript-loader'\nimport deepmerge from 'deepmerge'\n\nlet config: Record<string, unknown>\nlet rootConfigPath: string | undefined\n\nconst workspaceConfigCache = new Map<string, Record<string, unknown>>()\nconst deprecationWarned = new Set<string>()\n\nfunction createExplorer() {\n return cosmiconfig('xy', { cache: true, loaders: { '.ts': TypeScriptLoader() } })\n}\n\nexport const loadConfig = async <T extends object>(params?: T): Promise<T> => {\n if (config === undefined) {\n const cosmicConfigResult = await createExplorer().search()\n config = (cosmicConfigResult?.config ?? {}) as Record<string, unknown>\n rootConfigPath = cosmicConfigResult?.filepath\n const configFilePath = cosmicConfigResult?.filepath\n if (configFilePath !== undefined) {\n console.log(chalk.green(`Loaded config from ${configFilePath}`))\n if (config.verbose) {\n console.log(chalk.gray(`${JSON.stringify(config, null, 2)}`))\n }\n }\n }\n return deepmerge(config, params ?? {}) as T\n}\n\n/**\n * Loads the xy.config from a specific workspace directory.\n * Returns an empty object if the workspace has no config or if\n * the found config is the root config (avoids double-applying).\n */\nasync function loadWorkspaceConfig(workspaceDir: string): Promise<Record<string, unknown>> {\n const cached = workspaceConfigCache.get(workspaceDir)\n if (cached !== undefined) return cached\n\n const result = await createExplorer().search(workspaceDir)\n\n // If no config found or it's the root config, no workspace override\n if (!result || result.filepath === rootConfigPath) {\n workspaceConfigCache.set(workspaceDir, {})\n return {}\n }\n\n const wsConfig = (result.config ?? {}) as Record<string, unknown>\n workspaceConfigCache.set(workspaceDir, wsConfig)\n return wsConfig\n}\n\n/** Deprecated top-level fields that should be under `commands`. */\nconst DEPRECATED_COMMAND_FIELDS = new Set(['deplint', 'publint'])\n\n/**\n * Resolves a command's config field from a config object.\n * Prefers `commands.[name]` over top-level `[name]`.\n * Warns once per config file when a deprecated top-level field is used.\n */\nfunction resolveCommandField(\n cfg: Record<string, unknown>,\n commandName: string,\n configPath?: string,\n): Record<string, unknown> {\n const commands = cfg.commands as Record<string, unknown> | undefined\n const fromCommands = commands?.[commandName]\n const fromTopLevel = cfg[commandName]\n\n if (fromCommands !== undefined && typeof fromCommands === 'object') {\n return fromCommands as Record<string, unknown>\n }\n\n if (fromTopLevel !== undefined && typeof fromTopLevel === 'object'\n && DEPRECATED_COMMAND_FIELDS.has(commandName)) {\n const key = `${configPath ?? 'unknown'}:${commandName}`\n if (!deprecationWarned.has(key)) {\n deprecationWarned.add(key)\n console.warn(chalk.yellow(\n `[xy] Deprecated: top-level \"${commandName}\" in ${configPath ?? 'xy.config'} — move to \"commands.${commandName}\"`,\n ))\n }\n return fromTopLevel as Record<string, unknown>\n }\n\n return {}\n}\n\n/**\n * Loads a command-specific config merged from root and workspace levels.\n * The root config provides defaults; the workspace config extends/overrides.\n * Arrays (e.g. `exclude`) are unioned and maps (e.g. `packages`) are merged\n * via deepmerge, with workspace entries overriding root entries for the same key.\n */\nexport async function loadWorkspaceCommandConfig<C>(\n workspaceDir: string,\n commandName: string,\n): Promise<C> {\n // Ensure root config is loaded\n const root = await loadConfig()\n const rootCmd = resolveCommandField(root as Record<string, unknown>, commandName, rootConfigPath)\n\n const wsConfig = await loadWorkspaceConfig(workspaceDir)\n const wsConfigPath = workspaceConfigCache.has(workspaceDir) ? workspaceDir : undefined\n const wsCmd = resolveCommandField(wsConfig, commandName, wsConfigPath)\n\n return deepmerge(rootCmd, wsCmd) as C\n}\n","import { spawnSync } from 'node:child_process'\n\nimport chalk from 'chalk'\n\nimport { detectPackageManager } from '../pm/index.ts'\n\nexport function runInstall(cwd?: string): boolean {\n const pm = detectPackageManager()\n console.log(chalk.gray(`Running ${pm} install...`))\n const result = spawnSync(pm, ['install'], {\n cwd,\n stdio: 'inherit',\n })\n if (result.status !== 0) {\n console.warn(chalk.yellow(`${pm} install failed`))\n return false\n }\n console.log(chalk.green('Dependencies installed'))\n return true\n}\n","import { readFileSync, writeFileSync } from 'node:fs'\nimport PATH from 'node:path'\n\nimport chalk from 'chalk'\nimport semver from 'semver'\n\nimport { INIT_CWD } from '../lib/index.ts'\nimport { getPackageManager } from '../pm/index.ts'\nimport type { LintResult } from './package-lint.ts'\n\nfunction readWorkspacePackageJson(cwd: string, location: string): Record<string, unknown> | undefined {\n const pkgPath = PATH.resolve(cwd, location, 'package.json')\n try {\n return JSON.parse(readFileSync(pkgPath, 'utf8')) as Record<string, unknown>\n } catch {\n return undefined\n }\n}\n\nfunction writeWorkspacePackageJson(cwd: string, location: string, pkg: Record<string, unknown>) {\n const pkgPath = PATH.resolve(cwd, location, 'package.json')\n writeFileSync(pkgPath, `${JSON.stringify(pkg, null, 2)}\\n`, 'utf8')\n}\n\nfunction buildWorkspaceVersionMap(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): Map<string, string> {\n const map = new Map<string, string>()\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) map.set(name, version)\n }\n return map\n}\n\n/**\n * Derives the expected peerDep range from the workspace protocol used in\n * the matching devDependency and the current version of the target package.\n *\n * workspace:~ + version 7.6.21 → ~7.6\n * workspace:^ + version 7.6.21 → ^7\n *\n * Falls back to ~major.minor if no matching devDep is found.\n */\nfunction expectedPeerRange(devDepVersion: string | undefined, targetVersion: string): string {\n const parsed = semver.parse(targetVersion)\n if (!parsed) return `~${targetVersion}`\n\n if (devDepVersion === 'workspace:^') {\n return `^${parsed.major}`\n }\n return `~${parsed.major}.${parsed.minor}`\n}\n\n// --- Version consistency checks ---\n\nexport function checkVersionConsistency(\n cwd: string,\n rootPkg: Record<string, unknown>,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n\n if (rootPkg.version !== undefined) {\n result.fixable.push('Root package.json should not have a \"version\" field in a monorepo')\n }\n\n const versions = new Map<string, string>()\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) {\n versions.set(name, version)\n } else {\n result.errors.push(`${name} (${location}) is missing a \"version\" field`)\n }\n }\n\n const uniqueVersions = new Set(versions.values())\n if (uniqueVersions.size > 1) {\n const versionList = [...uniqueVersions].toSorted(semver.rcompare)\n for (const [name, version] of versions) {\n if (version !== versionList[0]) {\n result.fixable.push(`${name} has version ${version} (expected ${versionList[0]})`)\n }\n }\n }\n\n return result\n}\n\nexport function fixVersionConsistency(\n cwd: string,\n rootPkg: Record<string, unknown>,\n writeRootPackageJson: (cwd: string, pkg: Record<string, unknown>) => void,\n workspaces: { location: string; name: string }[],\n): void {\n if (rootPkg.version !== undefined) {\n delete rootPkg.version\n writeRootPackageJson(cwd, rootPkg)\n console.log(chalk.green(' ✔ Fixed: removed \"version\" from root package.json'))\n }\n\n const versions: string[] = []\n for (const { location } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version && semver.valid(version)) {\n versions.push(version)\n }\n }\n\n if (versions.length === 0) return\n\n const highest = versions.toSorted(semver.rcompare)[0]\n\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n if (pkg.version !== highest) {\n pkg.version = highest\n writeWorkspacePackageJson(cwd, location, pkg)\n console.log(chalk.green(` ✔ Fixed: set version to ${highest} in ${name} (${location})`))\n }\n }\n}\n\n// --- Internal dependency version checks (dependencies and devDependencies only) ---\n\nfunction expectedDepVersion(targetVersion: string): string {\n const parsed = semver.parse(targetVersion)\n if (!parsed) return `~${targetVersion}`\n return `~${targetVersion}`\n}\n\nexport function checkInternalDepVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n const expected = expectedDepVersion(targetVersion)\n if (version.startsWith('workspace:')) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should be \"${expected}\" (not workspace: protocol)`,\n )\n } else if (version !== expected) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should be \"${expected}\"`,\n )\n }\n }\n }\n }\n\n return result\n}\n\nexport function fixInternalDepVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n let modified = false\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n const expected = expectedDepVersion(targetVersion)\n if (version !== expected) {\n deps[dep] = expected\n console.log(chalk.green(` ✔ Fixed: set ${depField}.${dep} to \"${expected}\" in ${name} (${location})`))\n modified = true\n }\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n// --- Workspace protocol checks (pnpm — dependencies and devDependencies only) ---\n\nexport function checkWorkspaceProtocol(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceNames = new Set(workspaces.map(w => w.name))\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n if (!workspaceNames.has(dep)) continue\n if (!version.startsWith('workspace:')) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should use workspace: protocol`,\n )\n }\n }\n }\n }\n\n return result\n}\n\nexport function fixWorkspaceProtocol(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceNames = new Set(workspaces.map(w => w.name))\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n let modified = false\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n if (!workspaceNames.has(dep)) continue\n if (!version.startsWith('workspace:')) {\n deps[dep] = 'workspace:~'\n console.log(chalk.green(` ✔ Fixed: set ${depField}.${dep} to \"workspace:~\" in ${name} (${location})`))\n modified = true\n }\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n// --- Internal peerDependency version checks ---\n\nexport function checkInternalPeerVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n if (version.startsWith('workspace:')) {\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n result.fixable.push(\n `${name} (${location}) peerDependencies.${dep} uses workspace: protocol — should be \"${expected}\"`,\n )\n continue\n }\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected && !semver.satisfies(targetVersion, version)) {\n result.fixable.push(\n `${name} (${location}) peerDependencies.${dep} is \"${version}\" — current version ${targetVersion} is not satisfied; expected \"${expected}\"`,\n )\n }\n }\n }\n\n return result\n}\n\nexport function fixInternalPeerVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n let modified = false\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected) {\n peerDeps[dep] = expected\n console.log(chalk.green(` ✔ Fixed: set peerDependencies.${dep} to \"${expected}\" in ${name} (${location})`))\n modified = true\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n/**\n * Syncs all internal peerDependency versions to match current workspace versions.\n * Called by xy publish to ensure peerDeps are correct before publishing.\n */\nexport function syncInternalPeerVersions(): number {\n const cwd = INIT_CWD()\n const workspaces = getPackageManager().listWorkspaces()\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n let updated = 0\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n let modified = false\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected) {\n peerDeps[dep] = expected\n console.log(chalk.green(`Publish: updated ${name} peerDependencies.${dep} to \"${expected}\"`))\n modified = true\n updated++\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n\n return updated\n}\n\n/**\n * Reads the shared monorepo version from the first non-root workspace\n * and logs it. Call at the end of deploy to report the new version.\n */\nexport function logMonorepoVersion(): void {\n const cwd = INIT_CWD()\n const workspaces = getPackageManager().listWorkspaces()\n\n for (const { location } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) {\n console.log(chalk.green(`\\nDeployed version: ${chalk.bold(version)}`))\n return\n }\n }\n}\n","import type { Options } from 'tsup'\n\nexport type EntryMode = 'all' | 'single' | 'auto' | 'platform' | 'custom'\n\n/**\n * Configuration for specifying which paths are targeted.\n */\nexport interface PathConfig {\n /**\n * Glob patterns to exclude (takes precedence over include).\n */\n exclude?: string[]\n /**\n * Glob patterns to include.\n */\n include?: string[]\n}\n\n/**\n * Configuration for Dynamic Share.\n */\n\nexport interface DynamicShareConfig extends PathConfig {}\n\n/**\n * Configuration for Live Share.\n */\n\nexport interface LiveShareConfig extends PathConfig {}\n\nexport interface CompileConfig {\n bundleTypes?: boolean\n /** @param entryMode all, single, custom, platform, or auto */\n entryMode?: EntryMode\n /** @param when building types with tsc, should it use the outDir to write to? */\n outDirAsBuildDir?: boolean\n}\n\nexport type PackageCompileTsupConfig = CompileConfig & {\n browser?: Record<string, Options | boolean>\n neutral?: Record<string, Options | boolean>\n node?: Record<string, Options | boolean>\n tsup?: { options?: Options }\n verbose?: boolean\n}\n\nexport type PackageCompileTscConfig = CompileConfig & { mode: 'tsc' }\n\n/**\n * How deplint should classify a dependency.\n * - `dep`: must stay in `dependencies` (never promoted to peerDependencies)\n * - `peer`: should be treated as a peerDependency (overrides a parent `dep` setting)\n */\nexport type DeplintRefType = 'dep' | 'peer'\n\n/**\n * Per-package configuration within deplint.\n */\nexport interface DeplintPackageConfig {\n /** How this dependency should be classified. */\n refType: DeplintRefType\n}\n\n/**\n * Configuration for deplint (dependency linting).\n */\nexport interface DeplintConfig {\n /**\n * Package names to exclude from unused-dependency checks.\n * Packages listed here will never be reported as \"unused\" by deplint,\n * even if no import for them is detected in source or dist files.\n * Useful for packages that are used implicitly (e.g. runtime plugins,\n * CSS-in-JS themes, or polyfills that have side effects on import).\n */\n exclude?: string[]\n /**\n * Per-dependency configuration keyed by package name.\n * Cascades from root to package configs (maps are merged, with\n * package-level entries overriding root-level entries for the same key).\n */\n packages?: Record<string, DeplintPackageConfig>\n}\n\n/**\n * Canonical names for individually toggleable publint checks.\n */\nexport type PublintCheckName\n = | 'files'\n | 'importToDefault'\n | 'main'\n | 'module'\n | 'peerDeps'\n | 'publint'\n | 'resolutions'\n | 'rootSource'\n | 'rootTypes'\n | 'sideEffects'\n | 'source'\n | 'types'\n\nexport const ALL_PUBLINT_CHECKS: PublintCheckName[] = [\n 'files', 'importToDefault', 'main', 'module', 'peerDeps', 'publint', 'resolutions', 'rootSource', 'rootTypes', 'sideEffects', 'source', 'types',\n]\n\n/** Checks that only apply to published (non-private) packages */\nexport const PUBLISH_ONLY_CHECKS: PublintCheckName[] = [\n 'files', 'importToDefault', 'main', 'module', 'publint', 'rootSource', 'rootTypes', 'sideEffects', 'source', 'types',\n]\n\n/**\n * Configuration for publint (package publishing linting).\n */\nexport interface PublintConfig {\n /**\n * Check names to exclude from publint runs.\n * All checks run by default; listed names are skipped.\n * Cannot be used together with `include`.\n */\n exclude?: PublintCheckName[]\n /**\n * Check names to include (whitelist) in publint runs.\n * Only listed checks will run; all others are skipped.\n * Cannot be used together with `exclude`.\n */\n include?: PublintCheckName[]\n /**\n * Whether to run `pack` when invoking the publint library.\n * When true (default), the package manager is used to determine which\n * files would be published. Set to false to skip packing for faster runs.\n */\n pack?: boolean\n}\n\n/**\n * Configuration for readme generation.\n */\nexport interface ReadmeConfig {\n /**\n * URL that the logo links to when clicked.\n * Replaces the placeholder in the template's [![logo][]](url) link.\n */\n logoLinkUrl?: string\n /**\n * Public URL for the logo image displayed at the top of generated READMEs.\n * Replaces the placeholder in the template's [logo] reference link.\n */\n logoUrl?: string\n}\n\n/**\n * Command-specific configuration that cascades from root to package.\n * Settings here override the legacy top-level equivalents.\n */\nexport interface CommandsConfig {\n deplint?: DeplintConfig\n publint?: boolean | PublintConfig\n}\n\nexport interface XyConfigBase {\n /**\n * Command-specific settings grouped under `commands`.\n * These cascade from root xy.config down to per-package xy.config files.\n * Takes precedence over the legacy top-level `deplint`/`publint` fields.\n */\n commands?: CommandsConfig\n compile?: CompileConfig\n /** @deprecated Use `commands.deplint` instead. */\n deplint?: DeplintConfig\n dynamicShare?: DynamicShareConfig\n liveShare?: LiveShareConfig\n /** @deprecated Use `commands.publint` instead. */\n publint?: boolean | PublintConfig\n\n readme?: ReadmeConfig\n verbose?: boolean\n}\n\nexport interface XyTsupConfig extends XyConfigBase { compile?: PackageCompileTsupConfig }\n\nexport interface XyTscConfig extends XyConfigBase { compile?: PackageCompileTscConfig }\n\nexport type XyConfigLegacy = XyTsupConfig | XyTscConfig\n\nexport type XyConfig = XyConfigLegacy & {\n dev?: {\n build?: {\n clean?: boolean /* default: true */\n compile?: boolean /* default: true */\n deplint?: boolean /* default: true */\n gendocs?: boolean /* default: false */\n gitlint?: boolean /* default: true */\n knip?: boolean /* default: true */\n license?: boolean /* default: true */\n lint?: boolean /* default: true */\n publint?: boolean /* default: true */\n statics?: boolean /* default: true */\n verbose?: boolean\n }\n compile?: PackageCompileTsupConfig\n verbose?: boolean\n }\n verbose?: boolean\n}\n","import { promises as fs } from 'node:fs'\nimport path from 'node:path'\n\nimport chalk from 'chalk'\nimport { glob } from 'glob'\nimport sortPackageJson from 'sort-package-json'\n\nimport { INIT_CWD } from '../../lib/index.ts'\n// eslint-disable-next-line import-x/no-internal-modules\nimport type { PublintCheckName } from './compile/XyConfig.ts'\n// eslint-disable-next-line import-x/no-internal-modules\nimport { PUBLISH_ONLY_CHECKS } from './compile/XyConfig.ts'\n\nexport interface PackagePublintParams {\n exclude?: Set<PublintCheckName>\n fix?: boolean\n pack?: boolean\n pkgDir?: string\n strict?: boolean\n verbose?: boolean\n}\n\nconst removeSourceFromExports = (exports: Record<string, unknown>): boolean => {\n let removed = false\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'source') {\n delete exports[key]\n removed = true\n } else if (typeof value === 'object' && value !== null && removeSourceFromExports(value as Record<string, unknown>)) removed = true\n }\n return removed\n}\n\nconst hasSourceInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'source') return true\n if (typeof value === 'object' && value !== null && hasSourceInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nconst hasImportKeyInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'import' && typeof value === 'string' && value.endsWith('.mjs')) return true\n if (typeof value === 'object' && value !== null && hasImportKeyInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nconst replaceImportWithDefault = (exports: Record<string, unknown>): boolean => {\n let modified = false\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'import' && typeof value === 'string' && value.endsWith('.mjs')) {\n if (exports.default === undefined) {\n exports.default = value\n }\n delete exports.import\n if (exports.types === undefined) {\n exports.types = value.replace(/\\.mjs$/, '.d.ts')\n }\n modified = true\n } else if (typeof value === 'object' && value !== null && replaceImportWithDefault(value as Record<string, unknown>)) modified = true\n }\n return modified\n}\n\nconst hasTypesInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'types') return true\n if (typeof value === 'object' && value !== null && hasTypesInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nfunction ensureExportsPath(value: string): string {\n if (value.startsWith('./') || value.startsWith('../')) return value\n return `./${value}`\n}\n\ninterface CustomLintResult {\n errors: number\n modified: boolean\n warnings: number\n}\n\nfunction emptyCustomResult(): CustomLintResult {\n return {\n errors: 0, modified: false, warnings: 0,\n }\n}\n\nfunction mergeResults(target: CustomLintResult, source: CustomLintResult): void {\n target.errors += source.errors\n target.warnings += source.warnings\n target.modified = target.modified || source.modified\n}\n\nfunction checkFiles(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const files = pkg.files as string[] | undefined\n if (files === undefined) {\n console.warn(chalk.yellow('Publint [custom]: \"files\" field is missing'))\n result.warnings++\n }\n if (Array.isArray(files) && !files.includes('README.md')) {\n files.push('README.md')\n console.warn(chalk.yellow('Publint [custom]: added \"README.md\" to \"files\"'))\n result.modified = true\n result.warnings++\n }\n if (Array.isArray(files) && files.includes('src')) {\n if (fix) {\n pkg.files = files.filter((f: string) => f !== 'src')\n console.warn(chalk.yellow('Publint [custom]: removed \"src\" from \"files\"'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"src\" should not be in \"files\" (use --fix to remove)'))\n }\n result.warnings++\n }\n return result\n}\n\nfunction checkExportsSource(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (exports && typeof exports === 'object' && hasSourceInExports(exports)) {\n if (fix) {\n removeSourceFromExports(exports)\n console.warn(chalk.yellow('Publint [custom]: removed \"source\" entries from \"exports\"'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"source\" entries should not be in \"exports\" (use --fix to remove)'))\n }\n result.warnings++\n }\n return result\n}\n\nfunction migrateFieldToExports(\n pkg: Record<string, unknown>,\n field: string,\n exportKey: string,\n fix: boolean,\n): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg[field] === undefined) return result\n\n // Skip non-JS files (e.g. tsconfig packages use \"main\": \"./tsconfig.json\")\n const fieldValue = pkg[field] as string\n if (!fieldValue.endsWith('.js') && !fieldValue.endsWith('.mjs') && !fieldValue.endsWith('.cjs')) return result\n\n if (fix) {\n const exportValue = ensureExportsPath(fieldValue)\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (exports && typeof exports === 'object') {\n const dot = exports['.']\n if (dot && typeof dot === 'object' && !(dot as Record<string, unknown>)[exportKey]) {\n (dot as Record<string, unknown>)[exportKey] = exportValue\n console.warn(chalk.yellow(`Publint [custom]: migrated \"${field}\" to \"exports['.'].${exportKey}\" (${fieldValue})`))\n }\n } else if (!pkg.exports) {\n pkg.exports = { '.': { [exportKey]: exportValue } }\n console.warn(chalk.yellow(`Publint [custom]: migrated \"${field}\" to \"exports\" (.→${fieldValue})`))\n }\n delete pkg[field]\n console.warn(chalk.yellow(`Publint [custom]: removed deprecated \"${field}\" field`))\n result.modified = true\n } else {\n console.warn(chalk.yellow(`Publint [custom]: \"${field}\" field is deprecated, use \"exports\" instead (use --fix to remove)`))\n }\n result.warnings++\n return result\n}\n\nfunction checkSideEffects(pkg: Record<string, unknown>): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.sideEffects !== false) {\n console.warn(chalk.yellow('Publint [custom]: \"sideEffects\" field should be set to false'))\n result.warnings++\n }\n return result\n}\n\nfunction checkRootSource(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n for (const field of ['source', 'src']) {\n if (pkg[field] !== undefined) {\n if (fix) {\n delete pkg[field]\n console.warn(chalk.yellow(`Publint [custom]: removed root-level \"${field}\" field`))\n result.modified = true\n } else {\n console.warn(chalk.yellow(`Publint [custom]: root-level \"${field}\" field should not be in package.json (use --fix to remove)`))\n }\n result.warnings++\n }\n }\n return result\n}\n\nfunction checkResolutions(pkg: Record<string, unknown>): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.resolutions !== undefined) {\n console.warn(chalk.yellow('Publint [custom]: \"resolutions\" in use'))\n console.warn(chalk.gray(JSON.stringify(pkg.resolutions, null, 2)))\n result.warnings++\n }\n return result\n}\n\nfunction checkImportToDefault(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (!exports || typeof exports !== 'object') return result\n if (!hasImportKeyInExports(exports)) return result\n\n if (fix) {\n replaceImportWithDefault(exports)\n console.warn(chalk.yellow('Publint [custom]: renamed \"import\" to \"default\" in \"exports\" and ensured \"types\" siblings'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"import\" entries in \"exports\" should use \"default\" instead (use --fix to rename)'))\n }\n result.warnings++\n return result\n}\n\nfunction checkRootTypes(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.types === undefined) return result\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (!exports || typeof exports !== 'object' || !hasTypesInExports(exports)) return result\n\n if (fix) {\n delete pkg.types\n console.warn(chalk.yellow('Publint [custom]: removed redundant root \"types\" field (already defined in \"exports\")'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: root \"types\" field is redundant when \"exports\" defines types (use --fix to remove)'))\n }\n result.warnings++\n return result\n}\n\nfunction customPubLint(\n pkg: Record<string, unknown>,\n fix = false,\n exclude = new Set<PublintCheckName>(),\n): [number, number, boolean] {\n const result = emptyCustomResult()\n if (!exclude.has('files')) mergeResults(result, checkFiles(pkg, fix))\n if (!exclude.has('source')) mergeResults(result, checkExportsSource(pkg, fix))\n if (!exclude.has('rootSource')) mergeResults(result, checkRootSource(pkg, fix))\n if (!exclude.has('main')) mergeResults(result, migrateFieldToExports(pkg, 'main', 'default', fix))\n if (!exclude.has('types')) mergeResults(result, migrateFieldToExports(pkg, 'types', 'types', fix))\n if (!exclude.has('module')) mergeResults(result, migrateFieldToExports(pkg, 'module', 'default', fix))\n if (!exclude.has('importToDefault')) mergeResults(result, checkImportToDefault(pkg, fix))\n if (!exclude.has('rootTypes')) mergeResults(result, checkRootTypes(pkg, fix))\n if (!exclude.has('sideEffects')) mergeResults(result, checkSideEffects(pkg))\n if (!exclude.has('resolutions')) mergeResults(result, checkResolutions(pkg))\n return [result.errors, result.warnings, result.modified]\n}\n\n// Always-included files that npm packs regardless of the \"files\" field\nconst ALWAYS_INCLUDED_PATTERNS = [\n 'package.json',\n 'README',\n 'README.*',\n 'LICENCE',\n 'LICENCE.*',\n 'LICENSE',\n 'LICENSE.*',\n 'CHANGELOG',\n 'CHANGELOG.*',\n]\n\ninterface PackFile {\n data: string\n name: string\n}\n\nasync function resolvePackFiles(pkgDir: string, filesField?: string[]): Promise<PackFile[]> {\n const patterns = [...ALWAYS_INCLUDED_PATTERNS]\n if (filesField) {\n for (const pattern of filesField) {\n // Negation patterns (e.g. \"!**/*.spec.*\") are exclusions, pass through as-is\n if (pattern.startsWith('!')) {\n patterns.push(pattern)\n } else {\n // Include pattern — glob both the pattern itself and its contents if it's a directory\n patterns.push(pattern, `${pattern}/**`)\n }\n }\n }\n\n const matched = await glob(patterns, {\n cwd: pkgDir,\n nodir: true,\n dot: false,\n })\n\n const files: PackFile[] = await Promise.all(\n matched.map(async (rel) => {\n const abs = path.join(pkgDir, rel)\n const data = await fs.readFile(abs, 'utf8').catch(() => '')\n // publint's tarball VFS looks up files by path.join(pkgDir, rel),\n // so names must be prefixed with pkgDir to match\n return { name: path.join(pkgDir, rel), data }\n }),\n )\n return files\n}\n\nasync function runPublintLibrary(pkgDir: string, pkg: Record<string, unknown>, strict: boolean, pack: boolean): Promise<{ errors: number; total: number }> {\n const { publint } = await import('publint')\n\n let packOption: { files: PackFile[] } | false = false\n if (pack) {\n const files = await resolvePackFiles(pkgDir, pkg.files as string[] | undefined)\n packOption = { files }\n }\n\n const { messages } = await publint({\n level: 'suggestion',\n pack: packOption,\n pkgDir,\n strict,\n })\n\n // eslint-disable-next-line import-x/no-internal-modules\n const { formatMessage } = await import('publint/utils')\n\n for (const message of messages) {\n switch (message.type) {\n case 'error': {\n console.error(chalk.red(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n case 'warning': {\n console.warn(chalk.yellow(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n default: {\n console.log(chalk.white(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n }\n }\n\n return {\n errors: messages.filter(message => message.type === 'error').length,\n total: messages.length,\n }\n}\n\nexport const packagePublint = async ({\n exclude = new Set(), fix = false, pack = true, pkgDir: pkgDirParam, strict = true, verbose: _verbose = false,\n}: PackagePublintParams = {}): Promise<number> => {\n const pkgDir = pkgDirParam ?? INIT_CWD()\n\n const sortedPkg = sortPackageJson(await fs.readFile(`${pkgDir}/package.json`, 'utf8'))\n await fs.writeFile(`${pkgDir}/package.json`, sortedPkg)\n\n const pkg = JSON.parse(await fs.readFile(`${pkgDir}/package.json`, 'utf8')) as Record<string, unknown>\n\n const effectiveExclude = pkg.private\n ? new Set([...exclude, ...PUBLISH_ONLY_CHECKS])\n : exclude\n\n console.log(chalk.green(`Publint: ${String(pkg.name)}${pkg.private ? chalk.gray(' (private)') : ''}`))\n console.log(chalk.gray(pkgDir))\n\n let libraryErrors = 0\n if (!effectiveExclude.has('publint')) {\n const library = await runPublintLibrary(pkgDir, pkg, strict, pack)\n libraryErrors = library.errors\n }\n\n const [errorCount, _warningCount, modified] = customPubLint(pkg, fix, effectiveExclude)\n\n if (modified) {\n const sorted = sortPackageJson(JSON.stringify(pkg, null, 2))\n await fs.writeFile(`${pkgDir}/package.json`, sorted)\n }\n\n return libraryErrors + errorCount\n}\n","import chalk from 'chalk'\n\nimport {\n INIT_CWD,\n installOutputCapture,\n loadConfig,\n loadWorkspaceCommandConfig,\n outputStorage,\n runInstall,\n runWithConcurrency,\n} from '../lib/index.ts'\nimport { getPackageManager } from '../pm/index.ts'\nimport type {\n PublintCheckName, PublintConfig, XyConfig,\n} from './package/index.ts'\nimport { ALL_PUBLINT_CHECKS, packagePublint } from './package/index.ts'\nimport {\n checkInternalPeerVersions,\n fixInternalPeerVersions,\n} from './package-lint-deps.ts'\n\nexport interface PublintParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n jobs: number\n pack?: boolean\n pkg?: string\n verbose?: boolean\n}\n\nexport interface PublintPackageParams {\n exclude: Set<PublintCheckName>\n fix?: boolean\n pack?: boolean\n pkg: string\n verbose?: boolean\n}\n\nfunction resolveExclude(\n publintConfig: { exclude?: PublintCheckName[]; include?: PublintCheckName[] },\n cliExclude?: string[],\n cliInclude?: string[],\n): Set<PublintCheckName> | undefined {\n const hasExclude = (publintConfig.exclude?.length ?? 0) > 0 || (cliExclude?.length ?? 0) > 0\n const hasInclude = (publintConfig.include?.length ?? 0) > 0 || (cliInclude?.length ?? 0) > 0\n\n if (hasExclude && hasInclude) {\n console.error(chalk.red('Publint: --include and --exclude cannot be used together'))\n return undefined\n }\n\n if (hasInclude) {\n const include = new Set<PublintCheckName>([\n ...((publintConfig.include ?? [])),\n ...((cliInclude ?? []) as PublintCheckName[]),\n ])\n return new Set(ALL_PUBLINT_CHECKS.filter(c => !include.has(c)))\n }\n\n return new Set<PublintCheckName>([\n ...(publintConfig.exclude ?? []),\n ...((cliExclude ?? []) as PublintCheckName[]),\n ])\n}\n\nfunction normalizePublintConfig(value: boolean | PublintConfig | undefined): PublintConfig {\n if (typeof value === 'object') return value\n return {}\n}\n\nexport interface ResolvedPublintOptions {\n exclude: Set<PublintCheckName>\n pack: boolean\n}\n\nexport async function loadPublintOptions(): Promise<ResolvedPublintOptions> {\n const config = await loadConfig<XyConfig>()\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const publintConfig = normalizePublintConfig(config.commands?.publint ?? config.publint)\n const exclude = resolveExclude(publintConfig) ?? new Set<PublintCheckName>()\n return { exclude, pack: publintConfig.pack ?? true }\n}\n\nexport const publint = async ({\n cliExclude, cliInclude, fix, jobs, pack, verbose, pkg,\n}: PublintParams) => {\n return pkg === undefined\n ? await publintAll({\n cliExclude, cliInclude, fix, jobs, pack, verbose,\n })\n : await publintSingle({\n cliExclude, cliInclude, fix, pack, pkg, verbose,\n })\n}\n\nfunction logPublintSummary(packages: number, errors: number, ms: number): void {\n const color = errors > 0 ? chalk.red : chalk.blue\n console.log(color(`Checked ${packages} package(s) in ${ms.toFixed(0)}ms with ${errors} issue(s) found.`))\n}\n\ninterface PublintSingleParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n pack?: boolean\n pkg: string\n verbose?: boolean\n}\n\nexport const publintSingle = async ({\n cliExclude, cliInclude, fix, pack, pkg, verbose,\n}: PublintSingleParams) => {\n const start = performance.now()\n const pm = getPackageManager()\n const workspace = pm.findWorkspace(pkg)\n if (!workspace) {\n console.error(chalk.red(`Publint: workspace \"${pkg}\" not found`))\n return 1\n }\n const wsPublintConfig = normalizePublintConfig(\n await loadWorkspaceCommandConfig<boolean | PublintConfig>(workspace.location, 'publint'),\n )\n const exclude = resolveExclude(wsPublintConfig, cliExclude, cliInclude)\n if (!exclude) return 1\n const shouldPack = pack ?? wsPublintConfig.pack ?? true\n\n const errors = await packagePublint({\n exclude, fix, pack: shouldPack, pkgDir: workspace.location, verbose,\n })\n logPublintSummary(1, errors, performance.now() - start)\n return errors\n}\n\ninterface PublintAllParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n jobs: number\n pack?: boolean\n verbose?: boolean\n}\n\ninterface CapturedResult {\n errors: number\n output: string[]\n}\n\nexport const publintAll = async ({\n cliExclude, cliInclude, fix, jobs, pack, verbose,\n}: PublintAllParams) => {\n const start = performance.now()\n const pm = getPackageManager()\n const workspaces = pm.listWorkspaces()\n const concurrency = jobs\n\n const results: CapturedResult[] = Array.from({ length: workspaces.length }, () => ({ errors: 0, output: [] }))\n\n installOutputCapture()\n\n await runWithConcurrency(\n workspaces.map((ws, i) => ({ i, ws })),\n concurrency,\n async ({ i, ws }) => {\n const output: string[] = []\n await outputStorage.run(output, async () => {\n try {\n const wsPublintConfig = normalizePublintConfig(\n await loadWorkspaceCommandConfig<boolean | PublintConfig>(ws.location, 'publint'),\n )\n const exclude = resolveExclude(wsPublintConfig, cliExclude, cliInclude)\n ?? new Set<PublintCheckName>()\n const shouldPack = pack ?? wsPublintConfig.pack ?? true\n\n const errors = await packagePublint({\n exclude, fix, pack: shouldPack, pkgDir: ws.location, verbose,\n })\n results[i] = { errors, output }\n } catch (ex) {\n output.push(chalk.red(`Publint failed for ${ws.name}: ${(ex as Error).message}\\n`))\n results[i] = { errors: 1, output }\n }\n })\n },\n )\n\n let totalErrors = 0\n for (const { errors, output } of results) {\n for (const line of output) {\n process.stdout.write(line)\n }\n totalErrors += errors\n }\n\n // Check internal peerDependencies use semver ranges (not workspace: protocol)\n const allExclude = resolveExclude({}, cliExclude, cliInclude) ?? new Set<PublintCheckName>()\n if (!allExclude.has('peerDeps')) {\n const cwd = INIT_CWD()\n const peerResult = checkInternalPeerVersions(cwd, workspaces)\n if (peerResult.fixable.length > 0) {\n if (fix) {\n fixInternalPeerVersions(cwd, workspaces)\n runInstall()\n } else {\n for (const msg of peerResult.fixable) {\n console.log(chalk.red(` ✗ ${msg} (fixable)`))\n }\n totalErrors += peerResult.fixable.length\n }\n }\n totalErrors += peerResult.errors.length\n }\n\n logPublintSummary(workspaces.length, totalErrors, performance.now() - start)\n return totalErrors\n}\n","import type { Argv } from 'yargs'\n\nexport const packagePositionalParam = (yargs: Argv<unknown>) => {\n return yargs.positional('package', { describe: 'Specific package to target', type: 'string' })\n}\n","import type { CommandModule } from 'yargs'\n\nimport { publint } from '../../actions/index.ts'\nimport { packagePositionalParam } from '../param.ts'\n\nexport const publintCommand: CommandModule = {\n command: 'publint [package]',\n describe: 'Publint - Run Publint',\n builder: (yargs) => {\n return packagePositionalParam(yargs)\n .option('fix', {\n describe: 'Auto-fix issues (e.g. remove \"src\" from files, \"source\" from exports, root-level \"source\"/\"src\" fields)',\n type: 'boolean',\n default: false,\n })\n .option('exclude', {\n alias: 'e',\n description: 'Checks to skip (comma-separated): publint, files, source, rootSource, main, types, module, sideEffects, resolutions, peerDeps',\n type: 'string',\n })\n .option('include', {\n description: 'Only run these checks (comma-separated): publint, files, source, rootSource, main, types, module, sideEffects, resolutions, peerDeps',\n type: 'string',\n })\n .option('pack', {\n description: 'Run pack before publint to verify published files (default: true)',\n type: 'boolean',\n })\n },\n handler: async (argv) => {\n if (argv.verbose) console.log('Publint')\n const parseList = (raw: string | undefined) => raw\n ?.split(',')\n .map(v => v.trim())\n .filter(Boolean)\n process.exitCode = await publint({\n cliExclude: parseList(argv.exclude as string | undefined),\n cliInclude: parseList(argv.include as string | undefined),\n fix: !!argv.fix,\n jobs: argv.jobs as number,\n pack: argv.pack as boolean | undefined,\n pkg: argv.package as string,\n verbose: !!argv.verbose,\n })\n },\n}\n"],"mappings":"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","names":["chalk","chalk","chalk","expected","chalk","chalk","chalk","publint","chalk","chalk","chalk"]}
|
|
1
|
+
{"version":3,"sources":["../../../src/lib/concurrency.ts","../../../src/pm/detectPackageManager.ts","../../../src/pm/registry.ts","../../../src/lib/initCwd.ts","../../../src/lib/loadConfig.ts","../../../src/lib/runInstall.ts","../../../src/actions/package-lint-deps.ts","../../../src/actions/package/compile/XyConfig.ts","../../../src/actions/package/publint.ts","../../../src/actions/publint.ts","../../../src/xy/param.ts","../../../src/xy/lint/publintCommand.ts"],"sourcesContent":["import { AsyncLocalStorage } from 'node:async_hooks'\n\nexport const outputStorage = new AsyncLocalStorage<string[]>()\n\nlet captureInstalled = false\n\nexport function installOutputCapture(): void {\n if (captureInstalled) return\n captureInstalled = true\n\n const originalStdoutWrite = process.stdout.write.bind(process.stdout)\n const originalStderrWrite = process.stderr.write.bind(process.stderr)\n\n function intercept(\n original: typeof process.stdout.write,\n ): typeof process.stdout.write {\n return function (chunk: string | Uint8Array, ...args: unknown[]) {\n const buffer = outputStorage.getStore()\n if (buffer) {\n buffer.push(typeof chunk === 'string' ? chunk : new TextDecoder().decode(chunk))\n return true\n }\n return (original as (...params: unknown[]) => boolean)(chunk, ...args)\n } as typeof process.stdout.write\n }\n\n process.stdout.write = intercept(originalStdoutWrite)\n process.stderr.write = intercept(originalStderrWrite)\n}\n\nexport async function runWithConcurrency<T>(\n items: T[],\n concurrency: number,\n fn: (item: T) => Promise<void>,\n): Promise<void> {\n let next = 0\n async function worker(): Promise<void> {\n while (next < items.length) {\n const i = next++\n await fn(items[i])\n }\n }\n await Promise.all(Array.from({ length: Math.min(concurrency, items.length) }, () => worker()))\n}\n","import { existsSync } from 'node:fs'\n\nexport type PackageManagerName = 'pnpm' | 'yarn'\n\nexport function detectPackageManager(): PackageManagerName {\n if (existsSync('pnpm-lock.yaml') || existsSync('pnpm-workspace.yaml')) return 'pnpm'\n return 'yarn'\n}\n","import type { PackageManagerName } from './detectPackageManager.ts'\nimport { detectPackageManager } from './detectPackageManager.ts'\nimport type { PackageManager } from './PackageManager.ts'\n\nconst implementations = new Map<PackageManagerName, PackageManager>()\n\nexport function registerPackageManager(pm: PackageManager): void {\n implementations.set(pm.name, pm)\n}\n\nexport function getPackageManager(name?: PackageManagerName): PackageManager {\n const pmName = name ?? detectPackageManager()\n const pm = implementations.get(pmName)\n if (!pm) {\n throw new Error(\n `No package manager implementation registered for \"${pmName}\". `\n + 'Ensure registerPackageManager() has been called before getPackageManager().',\n )\n }\n return pm\n}\n","export function INIT_CWD(): string {\n return process.env.INIT_CWD ?? process.cwd()\n}\n","import chalk from 'chalk'\nimport { cosmiconfig } from 'cosmiconfig'\nimport { TypeScriptLoader } from 'cosmiconfig-typescript-loader'\nimport deepmerge from 'deepmerge'\n\nlet config: Record<string, unknown>\nlet rootConfigPath: string | undefined\n\nconst workspaceConfigCache = new Map<string, Record<string, unknown>>()\nconst deprecationWarned = new Set<string>()\n\nfunction createExplorer() {\n return cosmiconfig('xy', { cache: true, loaders: { '.ts': TypeScriptLoader() } })\n}\n\nexport const loadConfig = async <T extends object>(params?: T): Promise<T> => {\n if (config === undefined) {\n const cosmicConfigResult = await createExplorer().search()\n config = (cosmicConfigResult?.config ?? {}) as Record<string, unknown>\n rootConfigPath = cosmicConfigResult?.filepath\n const configFilePath = cosmicConfigResult?.filepath\n if (configFilePath !== undefined) {\n console.log(chalk.green(`Loaded config from ${configFilePath}`))\n if (config.verbose) {\n console.log(chalk.gray(`${JSON.stringify(config, null, 2)}`))\n }\n }\n }\n return deepmerge(config, params ?? {}) as T\n}\n\n/**\n * Loads the xy.config from a specific workspace directory.\n * Returns an empty object if the workspace has no config or if\n * the found config is the root config (avoids double-applying).\n */\nasync function loadWorkspaceConfig(workspaceDir: string): Promise<Record<string, unknown>> {\n const cached = workspaceConfigCache.get(workspaceDir)\n if (cached !== undefined) return cached\n\n const result = await createExplorer().search(workspaceDir)\n\n // If no config found or it's the root config, no workspace override\n if (!result || result.filepath === rootConfigPath) {\n workspaceConfigCache.set(workspaceDir, {})\n return {}\n }\n\n const wsConfig = (result.config ?? {}) as Record<string, unknown>\n workspaceConfigCache.set(workspaceDir, wsConfig)\n return wsConfig\n}\n\n/** Deprecated top-level fields that should be under `commands`. */\nconst DEPRECATED_COMMAND_FIELDS = new Set(['deplint', 'publint'])\n\n/**\n * Resolves a command's config field from a config object.\n * Prefers `commands.[name]` over top-level `[name]`.\n * Warns once per config file when a deprecated top-level field is used.\n */\nfunction resolveCommandField(\n cfg: Record<string, unknown>,\n commandName: string,\n configPath?: string,\n): Record<string, unknown> {\n const commands = cfg.commands as Record<string, unknown> | undefined\n const fromCommands = commands?.[commandName]\n const fromTopLevel = cfg[commandName]\n\n if (fromCommands !== undefined && typeof fromCommands === 'object') {\n return fromCommands as Record<string, unknown>\n }\n\n if (fromTopLevel !== undefined && typeof fromTopLevel === 'object'\n && DEPRECATED_COMMAND_FIELDS.has(commandName)) {\n const key = `${configPath ?? 'unknown'}:${commandName}`\n if (!deprecationWarned.has(key)) {\n deprecationWarned.add(key)\n console.warn(chalk.yellow(\n `[xy] Deprecated: top-level \"${commandName}\" in ${configPath ?? 'xy.config'} — move to \"commands.${commandName}\"`,\n ))\n }\n return fromTopLevel as Record<string, unknown>\n }\n\n return {}\n}\n\n/**\n * Loads a command-specific config merged from root and workspace levels.\n * The root config provides defaults; the workspace config extends/overrides.\n * Arrays (e.g. `exclude`) are unioned and maps (e.g. `packages`) are merged\n * via deepmerge, with workspace entries overriding root entries for the same key.\n */\nexport async function loadWorkspaceCommandConfig<C>(\n workspaceDir: string,\n commandName: string,\n): Promise<C> {\n // Ensure root config is loaded\n const root = await loadConfig()\n const rootCmd = resolveCommandField(root as Record<string, unknown>, commandName, rootConfigPath)\n\n const wsConfig = await loadWorkspaceConfig(workspaceDir)\n const wsConfigPath = workspaceConfigCache.has(workspaceDir) ? workspaceDir : undefined\n const wsCmd = resolveCommandField(wsConfig, commandName, wsConfigPath)\n\n return deepmerge(rootCmd, wsCmd) as C\n}\n","import { spawnSync } from 'node:child_process'\n\nimport chalk from 'chalk'\n\nimport { detectPackageManager } from '../pm/index.ts'\n\nexport function runInstall(cwd?: string): boolean {\n const pm = detectPackageManager()\n console.log(chalk.gray(`Running ${pm} install...`))\n const result = spawnSync(pm, ['install'], {\n cwd,\n stdio: 'inherit',\n })\n if (result.status !== 0) {\n console.warn(chalk.yellow(`${pm} install failed`))\n return false\n }\n console.log(chalk.green('Dependencies installed'))\n return true\n}\n","import { readFileSync, writeFileSync } from 'node:fs'\nimport PATH from 'node:path'\n\nimport chalk from 'chalk'\nimport semver from 'semver'\n\nimport { INIT_CWD } from '../lib/index.ts'\nimport { getPackageManager } from '../pm/index.ts'\nimport type { LintResult } from './package-lint.ts'\n\nfunction readWorkspacePackageJson(cwd: string, location: string): Record<string, unknown> | undefined {\n const pkgPath = PATH.resolve(cwd, location, 'package.json')\n try {\n return JSON.parse(readFileSync(pkgPath, 'utf8')) as Record<string, unknown>\n } catch {\n return undefined\n }\n}\n\nfunction writeWorkspacePackageJson(cwd: string, location: string, pkg: Record<string, unknown>) {\n const pkgPath = PATH.resolve(cwd, location, 'package.json')\n writeFileSync(pkgPath, `${JSON.stringify(pkg, null, 2)}\\n`, 'utf8')\n}\n\nfunction buildWorkspaceVersionMap(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): Map<string, string> {\n const map = new Map<string, string>()\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) map.set(name, version)\n }\n return map\n}\n\n/**\n * Derives the expected peerDep range from the workspace protocol used in\n * the matching devDependency and the current version of the target package.\n *\n * workspace:~ + version 7.6.21 → ~7.6\n * workspace:^ + version 7.6.21 → ^7\n *\n * Falls back to ~major.minor if no matching devDep is found.\n */\nfunction expectedPeerRange(devDepVersion: string | undefined, targetVersion: string): string {\n const parsed = semver.parse(targetVersion)\n if (!parsed) return `~${targetVersion}`\n\n if (devDepVersion === 'workspace:^') {\n return `^${parsed.major}`\n }\n return `~${parsed.major}.${parsed.minor}`\n}\n\n// --- Version consistency checks ---\n\nexport function checkVersionConsistency(\n cwd: string,\n rootPkg: Record<string, unknown>,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n\n if (rootPkg.version !== undefined) {\n result.fixable.push('Root package.json should not have a \"version\" field in a monorepo')\n }\n\n const versions = new Map<string, string>()\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) {\n versions.set(name, version)\n } else {\n result.errors.push(`${name} (${location}) is missing a \"version\" field`)\n }\n }\n\n const uniqueVersions = new Set(versions.values())\n if (uniqueVersions.size > 1) {\n const versionList = [...uniqueVersions].toSorted(semver.rcompare)\n for (const [name, version] of versions) {\n if (version !== versionList[0]) {\n result.fixable.push(`${name} has version ${version} (expected ${versionList[0]})`)\n }\n }\n }\n\n return result\n}\n\nexport function fixVersionConsistency(\n cwd: string,\n rootPkg: Record<string, unknown>,\n writeRootPackageJson: (cwd: string, pkg: Record<string, unknown>) => void,\n workspaces: { location: string; name: string }[],\n): void {\n if (rootPkg.version !== undefined) {\n delete rootPkg.version\n writeRootPackageJson(cwd, rootPkg)\n console.log(chalk.green(' ✔ Fixed: removed \"version\" from root package.json'))\n }\n\n const versions: string[] = []\n for (const { location } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version && semver.valid(version)) {\n versions.push(version)\n }\n }\n\n if (versions.length === 0) return\n\n const highest = versions.toSorted(semver.rcompare)[0]\n\n for (const { location, name } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n if (pkg.version !== highest) {\n pkg.version = highest\n writeWorkspacePackageJson(cwd, location, pkg)\n console.log(chalk.green(` ✔ Fixed: set version to ${highest} in ${name} (${location})`))\n }\n }\n}\n\n// --- Internal dependency version checks (dependencies and devDependencies only) ---\n\nfunction expectedDepVersion(targetVersion: string): string {\n const parsed = semver.parse(targetVersion)\n if (!parsed) return `~${targetVersion}`\n return `~${targetVersion}`\n}\n\nexport function checkInternalDepVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n const expected = expectedDepVersion(targetVersion)\n if (version.startsWith('workspace:')) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should be \"${expected}\" (not workspace: protocol)`,\n )\n } else if (version !== expected) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should be \"${expected}\"`,\n )\n }\n }\n }\n }\n\n return result\n}\n\nexport function fixInternalDepVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n let modified = false\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n const expected = expectedDepVersion(targetVersion)\n if (version !== expected) {\n deps[dep] = expected\n console.log(chalk.green(` ✔ Fixed: set ${depField}.${dep} to \"${expected}\" in ${name} (${location})`))\n modified = true\n }\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n// --- Workspace protocol checks (pnpm — dependencies and devDependencies only) ---\n\nexport function checkWorkspaceProtocol(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceNames = new Set(workspaces.map(w => w.name))\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n if (!workspaceNames.has(dep)) continue\n if (!version.startsWith('workspace:')) {\n result.fixable.push(\n `${name} (${location}) ${depField}.${dep} is \"${version}\" — should use workspace: protocol`,\n )\n }\n }\n }\n }\n\n return result\n}\n\nexport function fixWorkspaceProtocol(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceNames = new Set(workspaces.map(w => w.name))\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n let modified = false\n\n for (const depField of ['dependencies', 'devDependencies'] as const) {\n const deps = pkg[depField] as Record<string, string> | undefined\n if (!deps) continue\n for (const [dep, version] of Object.entries(deps)) {\n if (!workspaceNames.has(dep)) continue\n if (!version.startsWith('workspace:')) {\n deps[dep] = 'workspace:~'\n console.log(chalk.green(` ✔ Fixed: set ${depField}.${dep} to \"workspace:~\" in ${name} (${location})`))\n modified = true\n }\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n// --- Internal peerDependency version checks ---\n\nexport function checkInternalPeerVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): LintResult {\n const result: LintResult = {\n errors: [], fixable: [], warnings: [],\n }\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n if (version.startsWith('workspace:')) {\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n result.fixable.push(\n `${name} (${location}) peerDependencies.${dep} uses workspace: protocol — should be \"${expected}\"`,\n )\n continue\n }\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected && !semver.satisfies(targetVersion, version)) {\n result.fixable.push(\n `${name} (${location}) peerDependencies.${dep} is \"${version}\" — current version ${targetVersion} is not satisfied; expected \"${expected}\"`,\n )\n }\n }\n }\n\n return result\n}\n\nexport function fixInternalPeerVersions(\n cwd: string,\n workspaces: { location: string; name: string }[],\n): void {\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n let modified = false\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected) {\n peerDeps[dep] = expected\n console.log(chalk.green(` ✔ Fixed: set peerDependencies.${dep} to \"${expected}\" in ${name} (${location})`))\n modified = true\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n}\n\n/**\n * Syncs all internal peerDependency versions to match current workspace versions.\n * Called by xy publish to ensure peerDeps are correct before publishing.\n */\nexport function syncInternalPeerVersions(): number {\n const cwd = INIT_CWD()\n const workspaces = getPackageManager().listWorkspaces()\n const workspaceVersions = buildWorkspaceVersionMap(cwd, workspaces)\n let updated = 0\n\n for (const { location, name } of workspaces) {\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n\n const peerDeps = pkg.peerDependencies as Record<string, string> | undefined\n if (!peerDeps) continue\n const devDeps = pkg.devDependencies as Record<string, string> | undefined\n let modified = false\n\n for (const [dep, version] of Object.entries(peerDeps)) {\n const targetVersion = workspaceVersions.get(dep)\n if (!targetVersion) continue\n\n const expected = expectedPeerRange(devDeps?.[dep], targetVersion)\n if (version !== expected) {\n peerDeps[dep] = expected\n console.log(chalk.green(`Publish: updated ${name} peerDependencies.${dep} to \"${expected}\"`))\n modified = true\n updated++\n }\n }\n\n if (modified) {\n writeWorkspacePackageJson(cwd, location, pkg)\n }\n }\n\n return updated\n}\n\n/**\n * Reads the shared monorepo version from the first non-root workspace\n * and logs it. Call at the end of deploy to report the new version.\n */\nexport function logMonorepoVersion(): void {\n const cwd = INIT_CWD()\n const workspaces = getPackageManager().listWorkspaces()\n\n for (const { location } of workspaces) {\n if (location === '.') continue\n const pkg = readWorkspacePackageJson(cwd, location)\n if (!pkg) continue\n const version = pkg.version as string | undefined\n if (version) {\n console.log(chalk.green(`\\nDeployed version: ${chalk.bold(version)}`))\n return\n }\n }\n}\n","import type { Options } from 'tsup'\n\nexport type EntryMode = 'all' | 'single' | 'auto' | 'platform' | 'custom'\n\n/**\n * Configuration for specifying which paths are targeted.\n */\nexport interface PathConfig {\n /**\n * Glob patterns to exclude (takes precedence over include).\n */\n exclude?: string[]\n /**\n * Glob patterns to include.\n */\n include?: string[]\n}\n\n/**\n * Configuration for Dynamic Share.\n */\n\nexport interface DynamicShareConfig extends PathConfig {}\n\n/**\n * Configuration for Live Share.\n */\n\nexport interface LiveShareConfig extends PathConfig {}\n\nexport interface CompileConfig {\n bundleTypes?: boolean\n /** @param entryMode all, single, custom, platform, or auto */\n entryMode?: EntryMode\n /** @param when building types with tsc, should it use the outDir to write to? */\n outDirAsBuildDir?: boolean\n}\n\nexport type PackageCompileTsupConfig = CompileConfig & {\n browser?: Record<string, Options | boolean>\n neutral?: Record<string, Options | boolean>\n node?: Record<string, Options | boolean>\n tsup?: { options?: Options }\n verbose?: boolean\n}\n\nexport type PackageCompileTscConfig = CompileConfig & { mode: 'tsc' }\n\n/**\n * How deplint should classify a dependency.\n * - `dep`: must stay in `dependencies` (never promoted to peerDependencies)\n * - `peer`: should be treated as a peerDependency (overrides a parent `dep` setting)\n */\nexport type DeplintRefType = 'dep' | 'peer'\n\n/**\n * Per-package configuration within deplint.\n */\nexport interface DeplintPackageConfig {\n /** How this dependency should be classified. */\n refType: DeplintRefType\n}\n\n/**\n * Configuration for deplint (dependency linting).\n */\nexport interface DeplintConfig {\n /**\n * Package names to exclude from unused-dependency checks.\n * Packages listed here will never be reported as \"unused\" by deplint,\n * even if no import for them is detected in source or dist files.\n * Useful for packages that are used implicitly (e.g. runtime plugins,\n * CSS-in-JS themes, or polyfills that have side effects on import).\n */\n exclude?: string[]\n /**\n * Per-dependency configuration keyed by package name.\n * Cascades from root to package configs (maps are merged, with\n * package-level entries overriding root-level entries for the same key).\n */\n packages?: Record<string, DeplintPackageConfig>\n}\n\n/**\n * Canonical names for individually toggleable publint checks.\n */\nexport type PublintCheckName\n = | 'files'\n | 'importToDefault'\n | 'main'\n | 'module'\n | 'peerDeps'\n | 'publint'\n | 'resolutions'\n | 'rootSource'\n | 'rootTypes'\n | 'sideEffects'\n | 'source'\n | 'types'\n\nexport const ALL_PUBLINT_CHECKS: PublintCheckName[] = [\n 'files', 'importToDefault', 'main', 'module', 'peerDeps', 'publint', 'resolutions', 'rootSource', 'rootTypes', 'sideEffects', 'source', 'types',\n]\n\n/** Checks that only apply to published (non-private) packages */\nexport const PUBLISH_ONLY_CHECKS: PublintCheckName[] = [\n 'files', 'importToDefault', 'main', 'module', 'publint', 'rootSource', 'rootTypes', 'sideEffects', 'source', 'types',\n]\n\n/**\n * Configuration for publint (package publishing linting).\n */\nexport interface PublintConfig {\n /**\n * Check names to exclude from publint runs.\n * All checks run by default; listed names are skipped.\n * Cannot be used together with `include`.\n */\n exclude?: PublintCheckName[]\n /**\n * Check names to include (whitelist) in publint runs.\n * Only listed checks will run; all others are skipped.\n * Cannot be used together with `exclude`.\n */\n include?: PublintCheckName[]\n /**\n * Whether to run `pack` when invoking the publint library.\n * When true (default), the package manager is used to determine which\n * files would be published. Set to false to skip packing for faster runs.\n */\n pack?: boolean\n}\n\n/**\n * Configuration for readme generation.\n */\nexport interface ReadmeConfig {\n /**\n * URL that the logo links to when clicked.\n * Replaces the placeholder in the template's [![logo][]](url) link.\n */\n logoLinkUrl?: string\n /**\n * Public URL for the logo image displayed at the top of generated READMEs.\n * Replaces the placeholder in the template's [logo] reference link.\n */\n logoUrl?: string\n}\n\n/**\n * Configuration for packman lint (package manager config linting).\n */\nexport interface PackmanConfig {\n /**\n * Minimum age in minutes that a package must be published before pnpm will install it.\n * Only applies when pnpm is the detected package manager.\n * @default 4320 (3 days)\n */\n minimumReleaseAge?: number\n /**\n * Package patterns to exclude from the minimumReleaseAge requirement.\n * These packages can be installed immediately upon release.\n * Supports exact names and scoped wildcards (e.g. '@myorg/*').\n * @default [\"'@xylabs/*'\", \"'@xyo-network/*'\"]\n */\n minimumReleaseAgeExclude?: string[]\n}\n\n/**\n * Command-specific configuration that cascades from root to package.\n * Settings here override the legacy top-level equivalents.\n */\nexport interface CommandsConfig {\n deplint?: DeplintConfig\n packman?: PackmanConfig\n publint?: boolean | PublintConfig\n}\n\nexport interface XyConfigBase {\n /**\n * Command-specific settings grouped under `commands`.\n * These cascade from root xy.config down to per-package xy.config files.\n * Takes precedence over the legacy top-level `deplint`/`publint` fields.\n */\n commands?: CommandsConfig\n compile?: CompileConfig\n /** @deprecated Use `commands.deplint` instead. */\n deplint?: DeplintConfig\n dynamicShare?: DynamicShareConfig\n liveShare?: LiveShareConfig\n /** @deprecated Use `commands.publint` instead. */\n publint?: boolean | PublintConfig\n\n readme?: ReadmeConfig\n verbose?: boolean\n}\n\nexport interface XyTsupConfig extends XyConfigBase { compile?: PackageCompileTsupConfig }\n\nexport interface XyTscConfig extends XyConfigBase { compile?: PackageCompileTscConfig }\n\nexport type XyConfigLegacy = XyTsupConfig | XyTscConfig\n\nexport type XyConfig = XyConfigLegacy & {\n dev?: {\n build?: {\n clean?: boolean /* default: true */\n compile?: boolean /* default: true */\n deplint?: boolean /* default: true */\n gendocs?: boolean /* default: false */\n gitlint?: boolean /* default: true */\n knip?: boolean /* default: true */\n license?: boolean /* default: true */\n lint?: boolean /* default: true */\n publint?: boolean /* default: true */\n statics?: boolean /* default: true */\n verbose?: boolean\n }\n compile?: PackageCompileTsupConfig\n verbose?: boolean\n }\n verbose?: boolean\n}\n","import { promises as fs } from 'node:fs'\nimport path from 'node:path'\n\nimport chalk from 'chalk'\nimport { glob } from 'glob'\nimport sortPackageJson from 'sort-package-json'\n\nimport { INIT_CWD } from '../../lib/index.ts'\n// eslint-disable-next-line import-x/no-internal-modules\nimport type { PublintCheckName } from './compile/XyConfig.ts'\n// eslint-disable-next-line import-x/no-internal-modules\nimport { PUBLISH_ONLY_CHECKS } from './compile/XyConfig.ts'\n\nexport interface PackagePublintParams {\n exclude?: Set<PublintCheckName>\n fix?: boolean\n pack?: boolean\n pkgDir?: string\n strict?: boolean\n verbose?: boolean\n}\n\nconst removeSourceFromExports = (exports: Record<string, unknown>): boolean => {\n let removed = false\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'source') {\n delete exports[key]\n removed = true\n } else if (typeof value === 'object' && value !== null && removeSourceFromExports(value as Record<string, unknown>)) removed = true\n }\n return removed\n}\n\nconst hasSourceInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'source') return true\n if (typeof value === 'object' && value !== null && hasSourceInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nconst hasImportKeyInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'import' && typeof value === 'string' && value.endsWith('.mjs')) return true\n if (typeof value === 'object' && value !== null && hasImportKeyInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nconst replaceImportWithDefault = (exports: Record<string, unknown>): boolean => {\n let modified = false\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'import' && typeof value === 'string' && value.endsWith('.mjs')) {\n if (exports.default === undefined) {\n exports.default = value\n }\n delete exports.import\n if (exports.types === undefined) {\n exports.types = value.replace(/\\.mjs$/, '.d.ts')\n }\n modified = true\n } else if (typeof value === 'object' && value !== null && replaceImportWithDefault(value as Record<string, unknown>)) modified = true\n }\n return modified\n}\n\nconst hasTypesInExports = (exports: Record<string, unknown>): boolean => {\n for (const [key, value] of Object.entries(exports)) {\n if (key === 'types') return true\n if (typeof value === 'object' && value !== null && hasTypesInExports(value as Record<string, unknown>)) return true\n }\n return false\n}\n\nfunction ensureExportsPath(value: string): string {\n if (value.startsWith('./') || value.startsWith('../')) return value\n return `./${value}`\n}\n\ninterface CustomLintResult {\n errors: number\n modified: boolean\n warnings: number\n}\n\nfunction emptyCustomResult(): CustomLintResult {\n return {\n errors: 0, modified: false, warnings: 0,\n }\n}\n\nfunction mergeResults(target: CustomLintResult, source: CustomLintResult): void {\n target.errors += source.errors\n target.warnings += source.warnings\n target.modified = target.modified || source.modified\n}\n\nfunction checkFiles(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const files = pkg.files as string[] | undefined\n if (files === undefined) {\n console.warn(chalk.yellow('Publint [custom]: \"files\" field is missing'))\n result.warnings++\n }\n if (Array.isArray(files) && !files.includes('README.md')) {\n files.push('README.md')\n console.warn(chalk.yellow('Publint [custom]: added \"README.md\" to \"files\"'))\n result.modified = true\n result.warnings++\n }\n if (Array.isArray(files) && files.includes('src')) {\n if (fix) {\n pkg.files = files.filter((f: string) => f !== 'src')\n console.warn(chalk.yellow('Publint [custom]: removed \"src\" from \"files\"'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"src\" should not be in \"files\" (use --fix to remove)'))\n }\n result.warnings++\n }\n return result\n}\n\nfunction checkExportsSource(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (exports && typeof exports === 'object' && hasSourceInExports(exports)) {\n if (fix) {\n removeSourceFromExports(exports)\n console.warn(chalk.yellow('Publint [custom]: removed \"source\" entries from \"exports\"'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"source\" entries should not be in \"exports\" (use --fix to remove)'))\n }\n result.warnings++\n }\n return result\n}\n\nfunction migrateFieldToExports(\n pkg: Record<string, unknown>,\n field: string,\n exportKey: string,\n fix: boolean,\n): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg[field] === undefined) return result\n\n // Skip non-JS files (e.g. tsconfig packages use \"main\": \"./tsconfig.json\")\n const fieldValue = pkg[field] as string\n if (!fieldValue.endsWith('.js') && !fieldValue.endsWith('.mjs') && !fieldValue.endsWith('.cjs')) return result\n\n if (fix) {\n const exportValue = ensureExportsPath(fieldValue)\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (exports && typeof exports === 'object') {\n const dot = exports['.']\n if (dot && typeof dot === 'object' && !(dot as Record<string, unknown>)[exportKey]) {\n (dot as Record<string, unknown>)[exportKey] = exportValue\n console.warn(chalk.yellow(`Publint [custom]: migrated \"${field}\" to \"exports['.'].${exportKey}\" (${fieldValue})`))\n }\n } else if (!pkg.exports) {\n pkg.exports = { '.': { [exportKey]: exportValue } }\n console.warn(chalk.yellow(`Publint [custom]: migrated \"${field}\" to \"exports\" (.→${fieldValue})`))\n }\n delete pkg[field]\n console.warn(chalk.yellow(`Publint [custom]: removed deprecated \"${field}\" field`))\n result.modified = true\n } else {\n console.warn(chalk.yellow(`Publint [custom]: \"${field}\" field is deprecated, use \"exports\" instead (use --fix to remove)`))\n }\n result.warnings++\n return result\n}\n\nfunction checkSideEffects(pkg: Record<string, unknown>): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.sideEffects !== false) {\n console.warn(chalk.yellow('Publint [custom]: \"sideEffects\" field should be set to false'))\n result.warnings++\n }\n return result\n}\n\nfunction checkRootSource(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n for (const field of ['source', 'src']) {\n if (pkg[field] !== undefined) {\n if (fix) {\n delete pkg[field]\n console.warn(chalk.yellow(`Publint [custom]: removed root-level \"${field}\" field`))\n result.modified = true\n } else {\n console.warn(chalk.yellow(`Publint [custom]: root-level \"${field}\" field should not be in package.json (use --fix to remove)`))\n }\n result.warnings++\n }\n }\n return result\n}\n\nfunction checkResolutions(pkg: Record<string, unknown>): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.resolutions !== undefined) {\n console.warn(chalk.yellow('Publint [custom]: \"resolutions\" in use'))\n console.warn(chalk.gray(JSON.stringify(pkg.resolutions, null, 2)))\n result.warnings++\n }\n return result\n}\n\nfunction checkImportToDefault(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (!exports || typeof exports !== 'object') return result\n if (!hasImportKeyInExports(exports)) return result\n\n if (fix) {\n replaceImportWithDefault(exports)\n console.warn(chalk.yellow('Publint [custom]: renamed \"import\" to \"default\" in \"exports\" and ensured \"types\" siblings'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: \"import\" entries in \"exports\" should use \"default\" instead (use --fix to rename)'))\n }\n result.warnings++\n return result\n}\n\nfunction checkRootTypes(pkg: Record<string, unknown>, fix: boolean): CustomLintResult {\n const result = emptyCustomResult()\n if (pkg.types === undefined) return result\n const exports = pkg.exports as Record<string, unknown> | undefined\n if (!exports || typeof exports !== 'object' || !hasTypesInExports(exports)) return result\n\n if (fix) {\n delete pkg.types\n console.warn(chalk.yellow('Publint [custom]: removed redundant root \"types\" field (already defined in \"exports\")'))\n result.modified = true\n } else {\n console.warn(chalk.yellow('Publint [custom]: root \"types\" field is redundant when \"exports\" defines types (use --fix to remove)'))\n }\n result.warnings++\n return result\n}\n\nfunction customPubLint(\n pkg: Record<string, unknown>,\n fix = false,\n exclude = new Set<PublintCheckName>(),\n): [number, number, boolean] {\n const result = emptyCustomResult()\n if (!exclude.has('files')) mergeResults(result, checkFiles(pkg, fix))\n if (!exclude.has('source')) mergeResults(result, checkExportsSource(pkg, fix))\n if (!exclude.has('rootSource')) mergeResults(result, checkRootSource(pkg, fix))\n if (!exclude.has('main')) mergeResults(result, migrateFieldToExports(pkg, 'main', 'default', fix))\n if (!exclude.has('types')) mergeResults(result, migrateFieldToExports(pkg, 'types', 'types', fix))\n if (!exclude.has('module')) mergeResults(result, migrateFieldToExports(pkg, 'module', 'default', fix))\n if (!exclude.has('importToDefault')) mergeResults(result, checkImportToDefault(pkg, fix))\n if (!exclude.has('rootTypes')) mergeResults(result, checkRootTypes(pkg, fix))\n if (!exclude.has('sideEffects')) mergeResults(result, checkSideEffects(pkg))\n if (!exclude.has('resolutions')) mergeResults(result, checkResolutions(pkg))\n return [result.errors, result.warnings, result.modified]\n}\n\n// Always-included files that npm packs regardless of the \"files\" field\nconst ALWAYS_INCLUDED_PATTERNS = [\n 'package.json',\n 'README',\n 'README.*',\n 'LICENCE',\n 'LICENCE.*',\n 'LICENSE',\n 'LICENSE.*',\n 'CHANGELOG',\n 'CHANGELOG.*',\n]\n\ninterface PackFile {\n data: string\n name: string\n}\n\nasync function resolvePackFiles(pkgDir: string, filesField?: string[]): Promise<PackFile[]> {\n const patterns = [...ALWAYS_INCLUDED_PATTERNS]\n if (filesField) {\n for (const pattern of filesField) {\n // Negation patterns (e.g. \"!**/*.spec.*\") are exclusions, pass through as-is\n if (pattern.startsWith('!')) {\n patterns.push(pattern)\n } else {\n // Include pattern — glob both the pattern itself and its contents if it's a directory\n patterns.push(pattern, `${pattern}/**`)\n }\n }\n }\n\n const matched = await glob(patterns, {\n cwd: pkgDir,\n nodir: true,\n dot: false,\n })\n\n const files: PackFile[] = await Promise.all(\n matched.map(async (rel) => {\n const abs = path.join(pkgDir, rel)\n const data = await fs.readFile(abs, 'utf8').catch(() => '')\n // publint's tarball VFS looks up files by path.join(pkgDir, rel),\n // so names must be prefixed with pkgDir to match\n return { name: path.join(pkgDir, rel), data }\n }),\n )\n return files\n}\n\nasync function runPublintLibrary(pkgDir: string, pkg: Record<string, unknown>, strict: boolean, pack: boolean): Promise<{ errors: number; total: number }> {\n const { publint } = await import('publint')\n\n let packOption: { files: PackFile[] } | false = false\n if (pack) {\n const files = await resolvePackFiles(pkgDir, pkg.files as string[] | undefined)\n packOption = { files }\n }\n\n const { messages } = await publint({\n level: 'suggestion',\n pack: packOption,\n pkgDir,\n strict,\n })\n\n // eslint-disable-next-line import-x/no-internal-modules\n const { formatMessage } = await import('publint/utils')\n\n for (const message of messages) {\n switch (message.type) {\n case 'error': {\n console.error(chalk.red(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n case 'warning': {\n console.warn(chalk.yellow(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n default: {\n console.log(chalk.white(`[${message.code}] ${formatMessage(message, pkg)}`))\n break\n }\n }\n }\n\n return {\n errors: messages.filter(message => message.type === 'error').length,\n total: messages.length,\n }\n}\n\nexport const packagePublint = async ({\n exclude = new Set(), fix = false, pack = true, pkgDir: pkgDirParam, strict = true, verbose: _verbose = false,\n}: PackagePublintParams = {}): Promise<number> => {\n const pkgDir = pkgDirParam ?? INIT_CWD()\n\n const sortedPkg = sortPackageJson(await fs.readFile(`${pkgDir}/package.json`, 'utf8'))\n await fs.writeFile(`${pkgDir}/package.json`, sortedPkg)\n\n const pkg = JSON.parse(await fs.readFile(`${pkgDir}/package.json`, 'utf8')) as Record<string, unknown>\n\n const effectiveExclude = pkg.private\n ? new Set([...exclude, ...PUBLISH_ONLY_CHECKS])\n : exclude\n\n console.log(chalk.green(`Publint: ${String(pkg.name)}${pkg.private ? chalk.gray(' (private)') : ''}`))\n console.log(chalk.gray(pkgDir))\n\n let libraryErrors = 0\n if (!effectiveExclude.has('publint')) {\n const library = await runPublintLibrary(pkgDir, pkg, strict, pack)\n libraryErrors = library.errors\n }\n\n const [errorCount, _warningCount, modified] = customPubLint(pkg, fix, effectiveExclude)\n\n if (modified) {\n const sorted = sortPackageJson(JSON.stringify(pkg, null, 2))\n await fs.writeFile(`${pkgDir}/package.json`, sorted)\n }\n\n return libraryErrors + errorCount\n}\n","import chalk from 'chalk'\n\nimport {\n INIT_CWD,\n installOutputCapture,\n loadConfig,\n loadWorkspaceCommandConfig,\n outputStorage,\n runInstall,\n runWithConcurrency,\n} from '../lib/index.ts'\nimport { getPackageManager } from '../pm/index.ts'\nimport type {\n PublintCheckName, PublintConfig, XyConfig,\n} from './package/index.ts'\nimport { ALL_PUBLINT_CHECKS, packagePublint } from './package/index.ts'\nimport {\n checkInternalPeerVersions,\n fixInternalPeerVersions,\n} from './package-lint-deps.ts'\n\nexport interface PublintParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n jobs: number\n pack?: boolean\n pkg?: string\n verbose?: boolean\n}\n\nexport interface PublintPackageParams {\n exclude: Set<PublintCheckName>\n fix?: boolean\n pack?: boolean\n pkg: string\n verbose?: boolean\n}\n\nfunction resolveExclude(\n publintConfig: { exclude?: PublintCheckName[]; include?: PublintCheckName[] },\n cliExclude?: string[],\n cliInclude?: string[],\n): Set<PublintCheckName> | undefined {\n const hasExclude = (publintConfig.exclude?.length ?? 0) > 0 || (cliExclude?.length ?? 0) > 0\n const hasInclude = (publintConfig.include?.length ?? 0) > 0 || (cliInclude?.length ?? 0) > 0\n\n if (hasExclude && hasInclude) {\n console.error(chalk.red('Publint: --include and --exclude cannot be used together'))\n return undefined\n }\n\n if (hasInclude) {\n const include = new Set<PublintCheckName>([\n ...((publintConfig.include ?? [])),\n ...((cliInclude ?? []) as PublintCheckName[]),\n ])\n return new Set(ALL_PUBLINT_CHECKS.filter(c => !include.has(c)))\n }\n\n return new Set<PublintCheckName>([\n ...(publintConfig.exclude ?? []),\n ...((cliExclude ?? []) as PublintCheckName[]),\n ])\n}\n\nfunction normalizePublintConfig(value: boolean | PublintConfig | undefined): PublintConfig {\n if (typeof value === 'object') return value\n return {}\n}\n\nexport interface ResolvedPublintOptions {\n exclude: Set<PublintCheckName>\n pack: boolean\n}\n\nexport async function loadPublintOptions(): Promise<ResolvedPublintOptions> {\n const config = await loadConfig<XyConfig>()\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const publintConfig = normalizePublintConfig(config.commands?.publint ?? config.publint)\n const exclude = resolveExclude(publintConfig) ?? new Set<PublintCheckName>()\n return { exclude, pack: publintConfig.pack ?? true }\n}\n\nexport const publint = async ({\n cliExclude, cliInclude, fix, jobs, pack, verbose, pkg,\n}: PublintParams) => {\n return pkg === undefined\n ? await publintAll({\n cliExclude, cliInclude, fix, jobs, pack, verbose,\n })\n : await publintSingle({\n cliExclude, cliInclude, fix, pack, pkg, verbose,\n })\n}\n\nfunction logPublintSummary(packages: number, errors: number, ms: number): void {\n const color = errors > 0 ? chalk.red : chalk.blue\n console.log(color(`Checked ${packages} package(s) in ${ms.toFixed(0)}ms with ${errors} issue(s) found.`))\n}\n\ninterface PublintSingleParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n pack?: boolean\n pkg: string\n verbose?: boolean\n}\n\nexport const publintSingle = async ({\n cliExclude, cliInclude, fix, pack, pkg, verbose,\n}: PublintSingleParams) => {\n const start = performance.now()\n const pm = getPackageManager()\n const workspace = pm.findWorkspace(pkg)\n if (!workspace) {\n console.error(chalk.red(`Publint: workspace \"${pkg}\" not found`))\n return 1\n }\n const wsPublintConfig = normalizePublintConfig(\n await loadWorkspaceCommandConfig<boolean | PublintConfig>(workspace.location, 'publint'),\n )\n const exclude = resolveExclude(wsPublintConfig, cliExclude, cliInclude)\n if (!exclude) return 1\n const shouldPack = pack ?? wsPublintConfig.pack ?? true\n\n const errors = await packagePublint({\n exclude, fix, pack: shouldPack, pkgDir: workspace.location, verbose,\n })\n logPublintSummary(1, errors, performance.now() - start)\n return errors\n}\n\ninterface PublintAllParams {\n cliExclude?: string[]\n cliInclude?: string[]\n fix?: boolean\n jobs: number\n pack?: boolean\n verbose?: boolean\n}\n\ninterface CapturedResult {\n errors: number\n output: string[]\n}\n\nexport const publintAll = async ({\n cliExclude, cliInclude, fix, jobs, pack, verbose,\n}: PublintAllParams) => {\n const start = performance.now()\n const pm = getPackageManager()\n const workspaces = pm.listWorkspaces()\n const concurrency = jobs\n\n const results: CapturedResult[] = Array.from({ length: workspaces.length }, () => ({ errors: 0, output: [] }))\n\n installOutputCapture()\n\n await runWithConcurrency(\n workspaces.map((ws, i) => ({ i, ws })),\n concurrency,\n async ({ i, ws }) => {\n const output: string[] = []\n await outputStorage.run(output, async () => {\n try {\n const wsPublintConfig = normalizePublintConfig(\n await loadWorkspaceCommandConfig<boolean | PublintConfig>(ws.location, 'publint'),\n )\n const exclude = resolveExclude(wsPublintConfig, cliExclude, cliInclude)\n ?? new Set<PublintCheckName>()\n const shouldPack = pack ?? wsPublintConfig.pack ?? true\n\n const errors = await packagePublint({\n exclude, fix, pack: shouldPack, pkgDir: ws.location, verbose,\n })\n results[i] = { errors, output }\n } catch (ex) {\n output.push(chalk.red(`Publint failed for ${ws.name}: ${(ex as Error).message}\\n`))\n results[i] = { errors: 1, output }\n }\n })\n },\n )\n\n let totalErrors = 0\n for (const { errors, output } of results) {\n for (const line of output) {\n process.stdout.write(line)\n }\n totalErrors += errors\n }\n\n // Check internal peerDependencies use semver ranges (not workspace: protocol)\n const allExclude = resolveExclude({}, cliExclude, cliInclude) ?? new Set<PublintCheckName>()\n if (!allExclude.has('peerDeps')) {\n const cwd = INIT_CWD()\n const peerResult = checkInternalPeerVersions(cwd, workspaces)\n if (peerResult.fixable.length > 0) {\n if (fix) {\n fixInternalPeerVersions(cwd, workspaces)\n runInstall()\n } else {\n for (const msg of peerResult.fixable) {\n console.log(chalk.red(` ✗ ${msg} (fixable)`))\n }\n totalErrors += peerResult.fixable.length\n }\n }\n totalErrors += peerResult.errors.length\n }\n\n logPublintSummary(workspaces.length, totalErrors, performance.now() - start)\n return totalErrors\n}\n","import type { Argv } from 'yargs'\n\nexport const packagePositionalParam = (yargs: Argv<unknown>) => {\n return yargs.positional('package', { describe: 'Specific package to target', type: 'string' })\n}\n","import type { CommandModule } from 'yargs'\n\nimport { publint } from '../../actions/index.ts'\nimport { packagePositionalParam } from '../param.ts'\n\nexport const publintCommand: CommandModule = {\n command: 'publint [package]',\n describe: 'Publint - Run Publint',\n builder: (yargs) => {\n return packagePositionalParam(yargs)\n .option('fix', {\n describe: 'Auto-fix issues (e.g. remove \"src\" from files, \"source\" from exports, root-level \"source\"/\"src\" fields)',\n type: 'boolean',\n default: false,\n })\n .option('exclude', {\n alias: 'e',\n description: 'Checks to skip (comma-separated): publint, files, source, rootSource, main, types, module, sideEffects, resolutions, peerDeps',\n type: 'string',\n })\n .option('include', {\n description: 'Only run these checks (comma-separated): publint, files, source, rootSource, main, types, module, sideEffects, resolutions, peerDeps',\n type: 'string',\n })\n .option('pack', {\n description: 'Run pack before publint to verify published files (default: true)',\n type: 'boolean',\n })\n },\n handler: async (argv) => {\n if (argv.verbose) console.log('Publint')\n const parseList = (raw: string | undefined) => raw\n ?.split(',')\n .map(v => v.trim())\n .filter(Boolean)\n process.exitCode = await publint({\n cliExclude: parseList(argv.exclude as string | undefined),\n cliInclude: parseList(argv.include as string | undefined),\n fix: !!argv.fix,\n jobs: argv.jobs as number,\n pack: argv.pack as boolean | undefined,\n pkg: argv.package as string,\n verbose: !!argv.verbose,\n })\n },\n}\n"],"mappings":"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","names":["chalk","chalk","chalk","expected","chalk","chalk","chalk","publint","chalk","chalk","chalk"]}
|
package/dist/xy/xy.mjs
CHANGED
|
@@ -6244,7 +6244,7 @@ function packageLintMonorepo(fix2 = false) {
|
|
|
6244
6244
|
fix: () => fixInternalDepVersions(cwd, workspaces),
|
|
6245
6245
|
label: "Internal deps/devDeps use correct version ranges"
|
|
6246
6246
|
};
|
|
6247
|
-
const
|
|
6247
|
+
const checks = [
|
|
6248
6248
|
{
|
|
6249
6249
|
check: () => checkRootPrivate(pkg),
|
|
6250
6250
|
fix: fixRootPrivate,
|
|
@@ -6296,7 +6296,7 @@ function packageLintMonorepo(fix2 = false) {
|
|
|
6296
6296
|
label: "Internal peerDeps use semver ranges (not workspace: protocol)"
|
|
6297
6297
|
}
|
|
6298
6298
|
];
|
|
6299
|
-
const { errors, fixed } = runChecks(
|
|
6299
|
+
const { errors, fixed } = runChecks(checks, cwd, pkg, fix2);
|
|
6300
6300
|
logSummary(errors, fixed);
|
|
6301
6301
|
if (fix2 && fixed > 0) {
|
|
6302
6302
|
runInstall();
|
|
@@ -6919,6 +6919,41 @@ import {
|
|
|
6919
6919
|
} from "fs";
|
|
6920
6920
|
import PATH25 from "path";
|
|
6921
6921
|
import chalk53 from "chalk";
|
|
6922
|
+
var DEFAULT_MINIMUM_RELEASE_AGE = 4320;
|
|
6923
|
+
var DEFAULT_RELEASE_AGE_EXCLUDES = ["'@xylabs/*'", "'@xyo-network/*'"];
|
|
6924
|
+
function resolvePackmanConfig(cfg) {
|
|
6925
|
+
return {
|
|
6926
|
+
minimumReleaseAge: cfg?.minimumReleaseAge ?? DEFAULT_MINIMUM_RELEASE_AGE,
|
|
6927
|
+
minimumReleaseAgeExclude: cfg?.minimumReleaseAgeExclude ?? DEFAULT_RELEASE_AGE_EXCLUDES
|
|
6928
|
+
};
|
|
6929
|
+
}
|
|
6930
|
+
function readPnpmWorkspaceYaml(cwd) {
|
|
6931
|
+
const wsPath = PATH25.join(cwd, "pnpm-workspace.yaml");
|
|
6932
|
+
if (!existsSync20(wsPath)) return void 0;
|
|
6933
|
+
return readFileSync27(wsPath, "utf8");
|
|
6934
|
+
}
|
|
6935
|
+
function writePnpmWorkspaceYaml(cwd, content) {
|
|
6936
|
+
writeFileSync16(PATH25.join(cwd, "pnpm-workspace.yaml"), content, "utf8");
|
|
6937
|
+
}
|
|
6938
|
+
function parseYamlListSection(content, sectionName) {
|
|
6939
|
+
const items = [];
|
|
6940
|
+
let inSection = false;
|
|
6941
|
+
for (const line of content.split("\n")) {
|
|
6942
|
+
if (new RegExp(String.raw`^${sectionName}\s*:`).test(line)) {
|
|
6943
|
+
inSection = true;
|
|
6944
|
+
continue;
|
|
6945
|
+
}
|
|
6946
|
+
if (inSection) {
|
|
6947
|
+
const match = /^\s+-\s+(.+)$/.exec(line);
|
|
6948
|
+
if (match) {
|
|
6949
|
+
items.push(match[1].trim());
|
|
6950
|
+
} else if (line.trim() && !/^\s/.test(line)) {
|
|
6951
|
+
break;
|
|
6952
|
+
}
|
|
6953
|
+
}
|
|
6954
|
+
}
|
|
6955
|
+
return items;
|
|
6956
|
+
}
|
|
6922
6957
|
function checkEnableScripts(cwd, verbose, silent) {
|
|
6923
6958
|
const yarnrcPath = PATH25.join(cwd, ".yarnrc.yml");
|
|
6924
6959
|
if (!existsSync20(yarnrcPath)) {
|
|
@@ -6926,8 +6961,7 @@ function checkEnableScripts(cwd, verbose, silent) {
|
|
|
6926
6961
|
return true;
|
|
6927
6962
|
}
|
|
6928
6963
|
const content = readFileSync27(yarnrcPath, "utf8");
|
|
6929
|
-
const
|
|
6930
|
-
for (const line of lines) {
|
|
6964
|
+
for (const line of content.split("\n")) {
|
|
6931
6965
|
const trimmed = line.trim();
|
|
6932
6966
|
if (/^enableScripts\s*:/.test(trimmed)) {
|
|
6933
6967
|
const value = trimmed.replace(/^enableScripts\s*:\s*/, "").trim();
|
|
@@ -6942,12 +6976,9 @@ function checkEnableScripts(cwd, verbose, silent) {
|
|
|
6942
6976
|
if (!silent) console.log(chalk53.red(" enableScripts is not set in .yarnrc.yml (expected false)"));
|
|
6943
6977
|
return false;
|
|
6944
6978
|
}
|
|
6945
|
-
function fixEnableScripts(cwd
|
|
6979
|
+
function fixEnableScripts(cwd) {
|
|
6946
6980
|
const yarnrcPath = PATH25.join(cwd, ".yarnrc.yml");
|
|
6947
|
-
if (!existsSync20(yarnrcPath))
|
|
6948
|
-
if (verbose) console.log(chalk53.gray(" No .yarnrc.yml found, skipping enableScripts fix"));
|
|
6949
|
-
return true;
|
|
6950
|
-
}
|
|
6981
|
+
if (!existsSync20(yarnrcPath)) return true;
|
|
6951
6982
|
const content = readFileSync27(yarnrcPath, "utf8");
|
|
6952
6983
|
const lines = content.split("\n");
|
|
6953
6984
|
let found = false;
|
|
@@ -6981,28 +7012,129 @@ function fixEnableScripts(cwd, verbose) {
|
|
|
6981
7012
|
console.log(chalk53.green(" Fixed: enableScripts set to false"));
|
|
6982
7013
|
return true;
|
|
6983
7014
|
}
|
|
6984
|
-
|
|
6985
|
-
|
|
6986
|
-
|
|
6987
|
-
|
|
6988
|
-
|
|
7015
|
+
function checkMinimumReleaseAge(cwd, config2, verbose, silent) {
|
|
7016
|
+
if (detectPackageManager() !== "pnpm") return true;
|
|
7017
|
+
const content = readPnpmWorkspaceYaml(cwd);
|
|
7018
|
+
if (!content) {
|
|
7019
|
+
if (!silent) console.log(chalk53.red(" No pnpm-workspace.yaml found"));
|
|
7020
|
+
return false;
|
|
6989
7021
|
}
|
|
6990
|
-
|
|
6991
|
-
|
|
7022
|
+
const { minimumReleaseAge } = config2;
|
|
7023
|
+
for (const line of content.split("\n")) {
|
|
7024
|
+
const match = /^minimumReleaseAge\s*:\s*(\d+)/.exec(line.trim());
|
|
7025
|
+
if (match) {
|
|
7026
|
+
const value = Number.parseInt(match[1], 10);
|
|
7027
|
+
if (value >= minimumReleaseAge) {
|
|
7028
|
+
if (verbose) console.log(chalk53.green(` minimumReleaseAge is ${value} (>= ${minimumReleaseAge})`));
|
|
7029
|
+
return true;
|
|
7030
|
+
}
|
|
7031
|
+
if (!silent) console.log(chalk53.red(` minimumReleaseAge is ${value} (expected >= ${minimumReleaseAge})`));
|
|
7032
|
+
return false;
|
|
7033
|
+
}
|
|
7034
|
+
}
|
|
7035
|
+
if (!silent) console.log(chalk53.red(` minimumReleaseAge is not set in pnpm-workspace.yaml (expected >= ${minimumReleaseAge})`));
|
|
7036
|
+
return false;
|
|
7037
|
+
}
|
|
7038
|
+
function fixMinimumReleaseAge(cwd, config2) {
|
|
7039
|
+
if (detectPackageManager() !== "pnpm") return true;
|
|
7040
|
+
const content = readPnpmWorkspaceYaml(cwd);
|
|
7041
|
+
if (!content) return false;
|
|
7042
|
+
const { minimumReleaseAge } = config2;
|
|
7043
|
+
const lines = content.split("\n");
|
|
7044
|
+
let found = false;
|
|
7045
|
+
const newLines = lines.map((line) => {
|
|
7046
|
+
if (/^minimumReleaseAge\s*:/.test(line)) {
|
|
7047
|
+
found = true;
|
|
7048
|
+
return `minimumReleaseAge: ${minimumReleaseAge}`;
|
|
7049
|
+
}
|
|
7050
|
+
return line;
|
|
7051
|
+
});
|
|
7052
|
+
if (!found) {
|
|
7053
|
+
const lastLine = newLines.at(-1);
|
|
7054
|
+
if (lastLine === "") {
|
|
7055
|
+
newLines.splice(-1, 0, `minimumReleaseAge: ${minimumReleaseAge}`);
|
|
7056
|
+
} else {
|
|
7057
|
+
newLines.push(`minimumReleaseAge: ${minimumReleaseAge}`);
|
|
7058
|
+
}
|
|
7059
|
+
}
|
|
7060
|
+
writePnpmWorkspaceYaml(cwd, newLines.join("\n"));
|
|
7061
|
+
console.log(chalk53.green(` Fixed: minimumReleaseAge set to ${minimumReleaseAge}`));
|
|
7062
|
+
return true;
|
|
7063
|
+
}
|
|
7064
|
+
function checkMinimumReleaseAgeExclude(cwd, config2, verbose, silent) {
|
|
7065
|
+
if (detectPackageManager() !== "pnpm") return true;
|
|
7066
|
+
const content = readPnpmWorkspaceYaml(cwd);
|
|
7067
|
+
if (!content) {
|
|
7068
|
+
if (!silent) console.log(chalk53.red(" No pnpm-workspace.yaml found"));
|
|
7069
|
+
return false;
|
|
7070
|
+
}
|
|
7071
|
+
const excludes = parseYamlListSection(content, "minimumReleaseAgeExclude");
|
|
7072
|
+
const missing = config2.minimumReleaseAgeExclude.filter((scope) => !excludes.includes(scope));
|
|
7073
|
+
if (missing.length === 0) {
|
|
7074
|
+
if (verbose) console.log(chalk53.green(" minimumReleaseAgeExclude includes all required scopes"));
|
|
7075
|
+
return true;
|
|
7076
|
+
}
|
|
7077
|
+
if (!silent) console.log(chalk53.red(` minimumReleaseAgeExclude is missing: ${missing.join(", ")}`));
|
|
7078
|
+
return false;
|
|
7079
|
+
}
|
|
7080
|
+
function fixMinimumReleaseAgeExclude(cwd, config2) {
|
|
7081
|
+
if (detectPackageManager() !== "pnpm") return true;
|
|
7082
|
+
const content = readPnpmWorkspaceYaml(cwd);
|
|
7083
|
+
if (!content) return false;
|
|
7084
|
+
const existingExcludes = parseYamlListSection(content, "minimumReleaseAgeExclude");
|
|
7085
|
+
const toAdd = config2.minimumReleaseAgeExclude.filter((scope) => !existingExcludes.includes(scope));
|
|
7086
|
+
if (toAdd.length === 0) return true;
|
|
7087
|
+
const lines = content.split("\n");
|
|
7088
|
+
const sectionIndex = lines.findIndex((line) => /^minimumReleaseAgeExclude\s*:/.test(line));
|
|
7089
|
+
if (sectionIndex === -1) {
|
|
7090
|
+
const newSection = ["minimumReleaseAgeExclude:", ...config2.minimumReleaseAgeExclude.map((s) => ` - ${s}`)];
|
|
7091
|
+
const lastLine = lines.at(-1);
|
|
7092
|
+
if (lastLine === "") {
|
|
7093
|
+
lines.splice(-1, 0, ...newSection);
|
|
7094
|
+
} else {
|
|
7095
|
+
lines.push(...newSection);
|
|
7096
|
+
}
|
|
7097
|
+
} else {
|
|
7098
|
+
let insertAt = sectionIndex + 1;
|
|
7099
|
+
while (insertAt < lines.length && /^\s+-/.test(lines[insertAt])) {
|
|
7100
|
+
insertAt++;
|
|
7101
|
+
}
|
|
7102
|
+
for (const scope of toAdd) {
|
|
7103
|
+
lines.splice(insertAt, 0, ` - ${scope}`);
|
|
7104
|
+
insertAt++;
|
|
7105
|
+
}
|
|
7106
|
+
}
|
|
7107
|
+
writePnpmWorkspaceYaml(cwd, lines.join("\n"));
|
|
7108
|
+
console.log(chalk53.green(` Fixed: added ${toAdd.join(", ")} to minimumReleaseAgeExclude`));
|
|
7109
|
+
return true;
|
|
7110
|
+
}
|
|
7111
|
+
async function packmanLint({ fix: fix2, verbose } = {}) {
|
|
6992
7112
|
const cwd = process.cwd();
|
|
7113
|
+
const rootConfig = await loadConfig();
|
|
7114
|
+
const packmanConfig = resolvePackmanConfig(rootConfig.commands ? rootConfig.commands.packman : void 0);
|
|
6993
7115
|
let failures = 0;
|
|
6994
|
-
|
|
6995
|
-
|
|
6996
|
-
|
|
6997
|
-
|
|
6998
|
-
|
|
6999
|
-
|
|
7000
|
-
|
|
7001
|
-
|
|
7002
|
-
|
|
7003
|
-
|
|
7004
|
-
|
|
7005
|
-
|
|
7116
|
+
const enableScriptsPassed = checkEnableScripts(cwd, verbose, fix2);
|
|
7117
|
+
if (!enableScriptsPassed) {
|
|
7118
|
+
if (fix2) {
|
|
7119
|
+
if (!fixEnableScripts(cwd)) failures++;
|
|
7120
|
+
} else {
|
|
7121
|
+
failures++;
|
|
7122
|
+
}
|
|
7123
|
+
}
|
|
7124
|
+
const agePassed = checkMinimumReleaseAge(cwd, packmanConfig, verbose, fix2);
|
|
7125
|
+
if (!agePassed) {
|
|
7126
|
+
if (fix2) {
|
|
7127
|
+
if (!fixMinimumReleaseAge(cwd, packmanConfig)) failures++;
|
|
7128
|
+
} else {
|
|
7129
|
+
failures++;
|
|
7130
|
+
}
|
|
7131
|
+
}
|
|
7132
|
+
const excludePassed = checkMinimumReleaseAgeExclude(cwd, packmanConfig, verbose, fix2);
|
|
7133
|
+
if (!excludePassed) {
|
|
7134
|
+
if (fix2) {
|
|
7135
|
+
if (!fixMinimumReleaseAgeExclude(cwd, packmanConfig)) failures++;
|
|
7136
|
+
} else {
|
|
7137
|
+
failures++;
|
|
7006
7138
|
}
|
|
7007
7139
|
}
|
|
7008
7140
|
if (failures > 0) {
|
|
@@ -7274,14 +7406,14 @@ function lintPackages(cwd) {
|
|
|
7274
7406
|
function readmeLint({ config: config2, verbose }) {
|
|
7275
7407
|
const cwd = INIT_CWD();
|
|
7276
7408
|
console.log(chalk55.green("Readme Lint"));
|
|
7277
|
-
const
|
|
7409
|
+
const checks = [
|
|
7278
7410
|
lintTemplate(cwd),
|
|
7279
7411
|
lintLogoConfig(cwd, config2),
|
|
7280
7412
|
lintPackages(cwd)
|
|
7281
7413
|
];
|
|
7282
7414
|
let errorCount = 0;
|
|
7283
7415
|
let warningCount = 0;
|
|
7284
|
-
for (const { errors, warnings } of
|
|
7416
|
+
for (const { errors, warnings } of checks) {
|
|
7285
7417
|
for (const error of errors) {
|
|
7286
7418
|
console.log(chalk55.red(` \u2717 ${error}`));
|
|
7287
7419
|
errorCount++;
|
|
@@ -8106,8 +8238,8 @@ var lintCommand = {
|
|
|
8106
8238
|
type: "boolean"
|
|
8107
8239
|
});
|
|
8108
8240
|
},
|
|
8109
|
-
handler: (argv) => {
|
|
8110
|
-
process.exitCode = packmanLint({
|
|
8241
|
+
handler: async (argv) => {
|
|
8242
|
+
process.exitCode = await packmanLint({
|
|
8111
8243
|
fix: !!argv.fix,
|
|
8112
8244
|
verbose: !!argv.verbose
|
|
8113
8245
|
});
|