@standards-kit/conform 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +143 -0
  3. package/dist/{chunk-P7TIZJ4C.js → chunk-DXIYZR62.js} +2 -2
  4. package/dist/chunk-DXIYZR62.js.map +1 -0
  5. package/dist/{chunk-RXA4FO7L.js → chunk-NADY2H35.js} +12 -8
  6. package/dist/chunk-NADY2H35.js.map +1 -0
  7. package/dist/chunk-O745CMWG.js +29 -0
  8. package/dist/chunk-O745CMWG.js.map +1 -0
  9. package/dist/chunk-RHM53NLG.js +49 -0
  10. package/dist/chunk-RHM53NLG.js.map +1 -0
  11. package/dist/{chunk-KHO6NIAI.js → chunk-YGDEM6K5.js} +24 -10
  12. package/dist/chunk-YGDEM6K5.js.map +1 -0
  13. package/dist/cli.d.ts +2 -0
  14. package/dist/cli.js +49 -38
  15. package/dist/cli.js.map +1 -1
  16. package/dist/{cloudwatch-KSZ4A256.js → cloudwatch-3LTDYG6G.js} +6 -10
  17. package/dist/cloudwatch-3LTDYG6G.js.map +1 -0
  18. package/dist/code/index.d.ts +11 -0
  19. package/dist/code/tools/base.d.ts +51 -0
  20. package/dist/code/tools/comment-utils.d.ts +17 -0
  21. package/dist/code/tools/coverage-run.d.ts +37 -0
  22. package/dist/code/tools/disable-comments.d.ts +42 -0
  23. package/dist/code/tools/eslint.d.ts +99 -0
  24. package/dist/code/tools/gitleaks.d.ts +42 -0
  25. package/dist/code/tools/index.d.ts +13 -0
  26. package/dist/code/tools/knip.d.ts +20 -0
  27. package/dist/code/tools/naming.d.ts +64 -0
  28. package/dist/code/tools/pipaudit.d.ts +24 -0
  29. package/dist/code/tools/pnpmaudit.d.ts +36 -0
  30. package/dist/code/tools/ruff.d.ts +46 -0
  31. package/dist/code/tools/tsc.d.ts +57 -0
  32. package/dist/code/tools/ty.d.ts +34 -0
  33. package/dist/code/tools/vulture.d.ts +32 -0
  34. package/dist/constants.d.ts +69 -0
  35. package/dist/core/index.d.ts +7 -0
  36. package/dist/core/loader.d.ts +42 -0
  37. package/dist/core/registry.d.ts +17 -0
  38. package/dist/core/schema.d.ts +1857 -0
  39. package/dist/core/types.d.ts +95 -0
  40. package/dist/{src-KZRTG3EU.js → core-QRFGIQ42.js} +4 -3
  41. package/dist/dependencies/index.d.ts +13 -0
  42. package/dist/dependencies/mappings.d.ts +17 -0
  43. package/dist/dependencies/output.d.ts +12 -0
  44. package/dist/dependencies/types.d.ts +34 -0
  45. package/dist/{dynamodb-5KVESCVJ.js → dynamodb-HQH3IMAI.js} +6 -10
  46. package/dist/dynamodb-HQH3IMAI.js.map +1 -0
  47. package/dist/{ec2-HKPE6GZV.js → ec2-AEPT735A.js} +6 -10
  48. package/dist/ec2-AEPT735A.js.map +1 -0
  49. package/dist/{ecs-OS3NJZTA.js → ecs-UHKCH5A7.js} +6 -10
  50. package/dist/ecs-UHKCH5A7.js.map +1 -0
  51. package/dist/{elasticache-7TCRHYYM.js → elasticache-5Y6K7GKJ.js} +6 -10
  52. package/dist/elasticache-5Y6K7GKJ.js.map +1 -0
  53. package/dist/{elb-PEDLXW5R.js → elb-CN6ELVM5.js} +6 -10
  54. package/dist/elb-CN6ELVM5.js.map +1 -0
  55. package/dist/{iam-7H5HFWVQ.js → iam-YXMHK2MV.js} +6 -2
  56. package/dist/iam-YXMHK2MV.js.map +1 -0
  57. package/dist/index.d.ts +21 -0
  58. package/dist/index.js +99 -121
  59. package/dist/index.js.map +1 -1
  60. package/dist/infra/arn.d.ts +16 -0
  61. package/dist/infra/checkers/client-factory.d.ts +45 -0
  62. package/dist/infra/checkers/cloudwatch.d.ts +8 -0
  63. package/dist/infra/checkers/dynamodb.d.ts +8 -0
  64. package/dist/infra/checkers/ec2.d.ts +13 -0
  65. package/dist/infra/checkers/ecs.d.ts +13 -0
  66. package/dist/infra/checkers/elasticache.d.ts +13 -0
  67. package/dist/infra/checkers/elb.d.ts +13 -0
  68. package/dist/infra/checkers/gcp/artifactregistry.d.ts +5 -0
  69. package/dist/infra/checkers/gcp/cloudrun.d.ts +5 -0
  70. package/dist/infra/checkers/gcp/iam.d.ts +5 -0
  71. package/dist/infra/checkers/gcp/index.d.ts +17 -0
  72. package/dist/infra/checkers/gcp/secretmanager.d.ts +5 -0
  73. package/dist/infra/checkers/iam.d.ts +8 -0
  74. package/dist/infra/checkers/index.d.ts +26 -0
  75. package/dist/infra/checkers/lambda.d.ts +8 -0
  76. package/dist/infra/checkers/rds.d.ts +13 -0
  77. package/dist/infra/checkers/s3.d.ts +8 -0
  78. package/dist/infra/checkers/secretsmanager.d.ts +8 -0
  79. package/dist/infra/checkers/sns.d.ts +8 -0
  80. package/dist/infra/checkers/sqs.d.ts +8 -0
  81. package/dist/infra/checkers/types.d.ts +28 -0
  82. package/dist/infra/gcp.d.ts +18 -0
  83. package/dist/infra/generate.d.ts +74 -0
  84. package/dist/infra/index.d.ts +59 -0
  85. package/dist/infra/manifest.d.ts +58 -0
  86. package/dist/infra/output.d.ts +8 -0
  87. package/dist/infra/scan.d.ts +25 -0
  88. package/dist/infra/schemas.d.ts +806 -0
  89. package/dist/infra/types.d.ts +8 -0
  90. package/dist/{infra-UXM5XQX3.js → infra-TO54IUSC.js} +21 -19
  91. package/dist/infra-TO54IUSC.js.map +1 -0
  92. package/dist/{lambda-NFB5UILT.js → lambda-YTJOCYV5.js} +6 -10
  93. package/dist/lambda-YTJOCYV5.js.map +1 -0
  94. package/dist/mcp/index.d.ts +7 -0
  95. package/dist/mcp/server.d.ts +18 -0
  96. package/dist/mcp/standards/fetcher.d.ts +29 -0
  97. package/dist/mcp/standards/index.d.ts +4 -0
  98. package/dist/mcp/standards/matcher.d.ts +22 -0
  99. package/dist/mcp/standards/parser.d.ts +46 -0
  100. package/dist/mcp/standards/types.d.ts +32 -0
  101. package/dist/mcp/tools/get-guideline.d.ts +26 -0
  102. package/dist/mcp/tools/get-ruleset.d.ts +26 -0
  103. package/dist/mcp/tools/get-standards.d.ts +27 -0
  104. package/dist/mcp/tools/index.d.ts +4 -0
  105. package/dist/mcp/tools/list-guidelines.d.ts +25 -0
  106. package/dist/{mcp-O5O7XVFG.js → mcp-73FZXT3P.js} +5 -4
  107. package/dist/mcp-73FZXT3P.js.map +1 -0
  108. package/dist/output/index.d.ts +14 -0
  109. package/dist/process/commands/check-branch.d.ts +13 -0
  110. package/dist/process/commands/check-commit.d.ts +14 -0
  111. package/dist/process/commands/index.d.ts +2 -0
  112. package/dist/process/index.d.ts +11 -0
  113. package/dist/process/scan/index.d.ts +5 -0
  114. package/dist/process/scan/remote-fetcher.d.ts +18 -0
  115. package/dist/process/scan/scanner.d.ts +6 -0
  116. package/dist/process/scan/types.d.ts +57 -0
  117. package/dist/process/scan/validators.d.ts +37 -0
  118. package/dist/process/sync/applier.d.ts +10 -0
  119. package/dist/process/sync/differ.d.ts +7 -0
  120. package/dist/process/sync/fetcher.d.ts +14 -0
  121. package/dist/process/sync/index.d.ts +9 -0
  122. package/dist/process/sync/types.d.ts +131 -0
  123. package/dist/process/sync/validator.d.ts +22 -0
  124. package/dist/process/tools/backups.d.ts +32 -0
  125. package/dist/process/tools/base.d.ts +52 -0
  126. package/dist/process/tools/branches.d.ts +41 -0
  127. package/dist/process/tools/changesets.d.ts +53 -0
  128. package/dist/process/tools/ci.d.ts +57 -0
  129. package/dist/process/tools/codeowners.d.ts +68 -0
  130. package/dist/process/tools/commits.d.ts +39 -0
  131. package/dist/process/tools/coverage.d.ts +57 -0
  132. package/dist/process/tools/docs-helpers.d.ts +44 -0
  133. package/dist/process/tools/docs.d.ts +38 -0
  134. package/dist/process/tools/forbidden-files.d.ts +40 -0
  135. package/dist/process/tools/hooks.d.ts +39 -0
  136. package/dist/process/tools/index.d.ts +14 -0
  137. package/dist/process/tools/pr.d.ts +59 -0
  138. package/dist/process/tools/repo.d.ts +65 -0
  139. package/dist/process/tools/tickets.d.ts +42 -0
  140. package/dist/projects/detector.d.ts +16 -0
  141. package/dist/projects/index.d.ts +4 -0
  142. package/dist/projects/templates.d.ts +15 -0
  143. package/dist/projects/tier-loader.d.ts +21 -0
  144. package/dist/projects/types.d.ts +76 -0
  145. package/dist/{rds-KLG5O5SI.js → rds-GZ5RVPIU.js} +6 -10
  146. package/dist/rds-GZ5RVPIU.js.map +1 -0
  147. package/dist/{registry-V65CC7IN.js → registry-JRCQAIHR.js} +3 -2
  148. package/dist/{s3-2DH7PRVR.js → s3-53UELUWT.js} +16 -12
  149. package/dist/s3-53UELUWT.js.map +1 -0
  150. package/dist/s3-S4GXNR7H.js +53 -0
  151. package/dist/s3-S4GXNR7H.js.map +1 -0
  152. package/dist/{scan-EELS42BP.js → scan-RHQWHASY.js} +5 -4
  153. package/dist/{scan-EELS42BP.js.map → scan-RHQWHASY.js.map} +1 -1
  154. package/dist/{secretsmanager-MOOIHLAO.js → secretsmanager-FJKTPIXI.js} +6 -10
  155. package/dist/secretsmanager-FJKTPIXI.js.map +1 -0
  156. package/dist/{sns-Y36LVTWA.js → sns-RV64OMK2.js} +6 -10
  157. package/dist/sns-RV64OMK2.js.map +1 -0
  158. package/dist/{sqs-RRS3GRHK.js → sqs-MHBW6UFC.js} +6 -10
  159. package/dist/sqs-MHBW6UFC.js.map +1 -0
  160. package/dist/{standards-RXK5G4IG.js → standards-XAZKTKYJ.js} +3 -2
  161. package/dist/{sync-RLYBGYNY.js → sync-P3UZECLW.js} +4 -3
  162. package/dist/{sync-RLYBGYNY.js.map → sync-P3UZECLW.js.map} +1 -1
  163. package/dist/validate/guidelines.d.ts +18 -0
  164. package/dist/validate/index.d.ts +5 -0
  165. package/dist/validate/tier.d.ts +17 -0
  166. package/dist/validate/types.d.ts +50 -0
  167. package/dist/{validate-AABLVQJS.js → validate-J5E336GX.js} +53 -84
  168. package/dist/validate-J5E336GX.js.map +1 -0
  169. package/package.json +22 -25
  170. package/dist/chunk-KHO6NIAI.js.map +0 -1
  171. package/dist/chunk-P7TIZJ4C.js.map +0 -1
  172. package/dist/chunk-RXA4FO7L.js.map +0 -1
  173. package/dist/cloudwatch-KSZ4A256.js.map +0 -1
  174. package/dist/dynamodb-5KVESCVJ.js.map +0 -1
  175. package/dist/ec2-HKPE6GZV.js.map +0 -1
  176. package/dist/ecs-OS3NJZTA.js.map +0 -1
  177. package/dist/elasticache-7TCRHYYM.js.map +0 -1
  178. package/dist/elb-PEDLXW5R.js.map +0 -1
  179. package/dist/iam-7H5HFWVQ.js.map +0 -1
  180. package/dist/infra-UXM5XQX3.js.map +0 -1
  181. package/dist/lambda-NFB5UILT.js.map +0 -1
  182. package/dist/mcp-O5O7XVFG.js.map +0 -1
  183. package/dist/rds-KLG5O5SI.js.map +0 -1
  184. package/dist/s3-2DH7PRVR.js.map +0 -1
  185. package/dist/secretsmanager-MOOIHLAO.js.map +0 -1
  186. package/dist/sns-Y36LVTWA.js.map +0 -1
  187. package/dist/sqs-RRS3GRHK.js.map +0 -1
  188. package/dist/validate-AABLVQJS.js.map +0 -1
  189. /package/dist/{registry-V65CC7IN.js.map → core-QRFGIQ42.js.map} +0 -0
  190. /package/dist/{src-KZRTG3EU.js.map → registry-JRCQAIHR.js.map} +0 -0
  191. /package/dist/{standards-RXK5G4IG.js.map → standards-XAZKTKYJ.js.map} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/registry.ts","../src/core/loader.ts","../src/core/schema.ts"],"sourcesContent":["/* eslint-disable max-lines -- registry config merging requires many type-safe merge functions */\nimport * as fs from \"node:fs\";\nimport * as os from \"node:os\";\nimport * as path from \"node:path\";\n\nimport * as toml from \"@iarna/toml\";\nimport { execa } from \"execa\";\n\nimport { CACHE, TIMEOUTS } from \"../constants.js\";\nimport { ConfigError } from \"./loader.js\";\nimport { type Config, configSchema } from \"./schema.js\";\n\n/** Authentication method for private registries */\ntype AuthMethod = \"token\" | \"ssh\" | \"none\";\n\ninterface RegistryLocation {\n type: \"github\" | \"local\";\n owner?: string;\n repo?: string;\n ref?: string;\n path: string;\n auth?: AuthMethod;\n}\n\n/**\n * Detect authentication method based on environment variables.\n * Priority: CONFORM_REGISTRY_TOKEN > GITHUB_TOKEN > SSH key detection > none\n */\nfunction detectAuthMethod(): AuthMethod {\n if (process.env.CONFORM_REGISTRY_TOKEN || process.env.GITHUB_TOKEN) {\n return \"token\";\n }\n // Check for SSH key - if SSH_AUTH_SOCK is set, SSH agent is available\n if (process.env.SSH_AUTH_SOCK) {\n return \"ssh\";\n }\n return \"none\";\n}\n\n/**\n * Get the authentication token from environment variables.\n */\nfunction getAuthToken(): string | undefined {\n return process.env.CONFORM_REGISTRY_TOKEN ?? process.env.GITHUB_TOKEN;\n}\n\n/**\n * Build the git URL for a GitHub repository based on auth method.\n */\nfunction buildGitHubUrl(owner: string, repo: string, auth: AuthMethod): string {\n switch (auth) {\n case \"ssh\":\n return `git@github.com:${owner}/${repo}.git`;\n case \"token\": {\n const token = getAuthToken();\n if (token) {\n return `https://x-access-token:${token}@github.com/${owner}/${repo}.git`;\n }\n // Fall back to regular HTTPS if no token found\n return `https://github.com/${owner}/${repo}.git`;\n }\n case \"none\":\n default:\n return `https://github.com/${owner}/${repo}.git`;\n }\n}\n\n/**\n * Parse explicit auth method from URL prefix.\n * Supports: github+ssh:, github+token:, github: (auto-detect)\n */\nfunction parseAuthFromUrl(url: string): { auth: AuthMethod | \"auto\"; rest: string } {\n if (url.startsWith(\"github+ssh:\")) {\n return { auth: \"ssh\", rest: url.slice(11) };\n }\n if (url.startsWith(\"github+token:\")) {\n return { auth: \"token\", rest: url.slice(13) };\n }\n if (url.startsWith(\"github:\")) {\n return { auth: \"auto\", rest: url.slice(7) };\n }\n throw new ConfigError(`Invalid GitHub registry URL: ${url}`);\n}\n\nfunction parseGitHubUrl(url: string): RegistryLocation {\n const { auth: explicitAuth, rest } = parseAuthFromUrl(url);\n const [repoPath, ref] = rest.split(\"@\");\n const [owner, repo] = repoPath.split(\"/\");\n\n if (!owner || !repo) {\n throw new ConfigError(\n `Invalid GitHub registry URL: ${url}. Expected format: github:owner/repo or github+ssh:owner/repo`\n );\n }\n\n const auth = explicitAuth === \"auto\" ? detectAuthMethod() : explicitAuth;\n\n return {\n type: \"github\",\n owner,\n repo,\n ref: ref || undefined,\n path: buildGitHubUrl(owner, repo, auth),\n auth,\n };\n}\n\nexport function parseRegistryUrl(url: string, configDir?: string): RegistryLocation {\n if (url.startsWith(\"github:\") || url.startsWith(\"github+\")) {\n return parseGitHubUrl(url);\n }\n\n const localPath = !path.isAbsolute(url) && configDir ? path.resolve(configDir, url) : url;\n return { type: \"local\", path: localPath };\n}\n\nasync function updateExistingRepo(repoDir: string, ref?: string): Promise<boolean> {\n try {\n if (ref) {\n await execa(\"git\", [\"fetch\", \"--all\"], { cwd: repoDir });\n await execa(\"git\", [\"checkout\", ref], { cwd: repoDir });\n } else {\n await execa(\"git\", [\"pull\", \"--ff-only\"], { cwd: repoDir });\n }\n return true;\n } catch {\n fs.rmSync(repoDir, { recursive: true, force: true });\n return false;\n }\n}\n\nasync function cloneRepo(location: RegistryLocation, repoDir: string): Promise<void> {\n const cacheDir = path.dirname(repoDir);\n fs.mkdirSync(cacheDir, { recursive: true });\n\n const cloneArgs = [\"clone\", \"--depth\", \"1\"];\n if (location.ref) {\n cloneArgs.push(\"--branch\", location.ref);\n }\n cloneArgs.push(location.path, repoDir);\n\n try {\n await execa(\"git\", cloneArgs, { timeout: TIMEOUTS.git });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (message.includes(\"timed out\")) {\n throw new ConfigError(`Registry clone timed out after ${TIMEOUTS.git / 1000} seconds: ${location.path}`);\n }\n throw new ConfigError(`Failed to clone registry: ${message}`);\n }\n}\n\nexport async function fetchRegistry(location: RegistryLocation): Promise<string> {\n if (location.type === \"local\") {\n if (!fs.existsSync(location.path)) {\n throw new ConfigError(`Registry not found: ${location.path}`);\n }\n return location.path;\n }\n\n const cacheDir = path.join(os.tmpdir(), CACHE.registryCacheDir);\n const repoDir = path.join(cacheDir, `${location.owner}-${location.repo}`);\n\n if (fs.existsSync(repoDir)) {\n await updateExistingRepo(repoDir, location.ref);\n }\n\n if (!fs.existsSync(repoDir)) {\n await cloneRepo(location, repoDir);\n }\n\n return repoDir;\n}\n\nexport function loadRuleset(registryDir: string, rulesetName: string): Config {\n const rulesetPath = path.join(registryDir, \"rulesets\", `${rulesetName}.toml`);\n\n if (!fs.existsSync(rulesetPath)) {\n throw new ConfigError(`Ruleset not found: ${rulesetName} (expected at ${rulesetPath})`);\n }\n\n const content = fs.readFileSync(rulesetPath, \"utf-8\");\n\n let parsed: unknown;\n try {\n parsed = toml.parse(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n throw new ConfigError(`Failed to parse ruleset ${rulesetName}: ${message}`);\n }\n\n const result = configSchema.safeParse(parsed);\n if (!result.success) {\n const errors = result.error.errors.map((e) => `${e.path.join(\".\")}: ${e.message}`).join(\", \");\n throw new ConfigError(`Invalid ruleset ${rulesetName}: ${errors}`);\n }\n\n return result.data;\n}\n\ntype CodeConfig = NonNullable<Config[\"code\"]>;\n\nfunction mergeToolConfig<T extends object>(base?: T, override?: T): T | undefined {\n if (!override) {\n return base;\n }\n return { ...base, ...override };\n}\n\nfunction mergeLinting(\n base: CodeConfig[\"linting\"],\n override: CodeConfig[\"linting\"]\n): CodeConfig[\"linting\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n eslint: mergeToolConfig(base?.eslint, override.eslint),\n ruff: mergeToolConfig(base?.ruff, override.ruff),\n };\n}\n\nfunction mergeTypes(base: CodeConfig[\"types\"], override: CodeConfig[\"types\"]): CodeConfig[\"types\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n tsc: mergeToolConfig(base?.tsc, override.tsc),\n ty: mergeToolConfig(base?.ty, override.ty),\n };\n}\n\nfunction mergeUnused(\n base: CodeConfig[\"unused\"],\n override: CodeConfig[\"unused\"]\n): CodeConfig[\"unused\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n knip: mergeToolConfig(base?.knip, override.knip),\n vulture: mergeToolConfig(base?.vulture, override.vulture),\n };\n}\n\nfunction mergeSecurity(\n base: CodeConfig[\"security\"],\n override: CodeConfig[\"security\"]\n): CodeConfig[\"security\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n secrets: mergeToolConfig(base?.secrets, override.secrets),\n pnpmaudit: mergeToolConfig(base?.pnpmaudit, override.pnpmaudit),\n pipaudit: mergeToolConfig(base?.pipaudit, override.pipaudit),\n };\n}\n\nfunction mergeNaming(\n base: CodeConfig[\"naming\"],\n override: CodeConfig[\"naming\"]\n): CodeConfig[\"naming\"] {\n if (!override) {\n return base;\n }\n // enabled has a default value from schema, so it's always defined after parsing\n return {\n enabled: override.enabled,\n rules: override.rules ?? base?.rules,\n };\n}\n\nfunction mergeQuality(\n base: CodeConfig[\"quality\"],\n override: CodeConfig[\"quality\"]\n): CodeConfig[\"quality\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n \"disable-comments\": mergeToolConfig(base?.[\"disable-comments\"], override[\"disable-comments\"]),\n };\n}\n\nfunction mergeCodeSection(base: CodeConfig | undefined, override: CodeConfig): CodeConfig {\n return {\n linting: mergeLinting(base?.linting, override.linting),\n types: mergeTypes(base?.types, override.types),\n unused: mergeUnused(base?.unused, override.unused),\n coverage_run: mergeToolConfig(base?.coverage_run, override.coverage_run),\n security: mergeSecurity(base?.security, override.security),\n naming: mergeNaming(base?.naming, override.naming),\n quality: mergeQuality(base?.quality, override.quality),\n };\n}\n\ntype ProcessConfig = NonNullable<Config[\"process\"]>;\n\nfunction mergeHooksConfig(\n base: ProcessConfig[\"hooks\"],\n override: ProcessConfig[\"hooks\"]\n): ProcessConfig[\"hooks\"] {\n if (!override) {\n return base;\n }\n // enabled and require_husky have schema defaults, so they're always defined\n return {\n enabled: override.enabled,\n require_husky: override.require_husky,\n require_hooks: override.require_hooks ?? base?.require_hooks,\n commands: override.commands ?? base?.commands,\n };\n}\n\nfunction mergeCiConfig(\n base: ProcessConfig[\"ci\"],\n override: ProcessConfig[\"ci\"]\n): ProcessConfig[\"ci\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_workflows: override.require_workflows ?? base?.require_workflows,\n jobs: override.jobs ?? base?.jobs,\n actions: override.actions ?? base?.actions,\n };\n}\n\nfunction mergeBranchesConfig(\n base: ProcessConfig[\"branches\"],\n override: ProcessConfig[\"branches\"]\n): ProcessConfig[\"branches\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_issue: override.require_issue,\n pattern: override.pattern ?? base?.pattern,\n exclude: override.exclude ?? base?.exclude,\n issue_pattern: override.issue_pattern ?? base?.issue_pattern,\n };\n}\n\nfunction mergePrConfig(\n base: ProcessConfig[\"pr\"],\n override: ProcessConfig[\"pr\"]\n): ProcessConfig[\"pr\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_issue: override.require_issue,\n max_files: override.max_files ?? base?.max_files,\n max_lines: override.max_lines ?? base?.max_lines,\n issue_keywords: override.issue_keywords ?? base?.issue_keywords,\n };\n}\n\nfunction mergeTicketsConfig(\n base: ProcessConfig[\"tickets\"],\n override: ProcessConfig[\"tickets\"]\n): ProcessConfig[\"tickets\"] {\n if (!override) {\n return base;\n }\n // require_in_commits and require_in_branch have schema defaults, so they're always defined after parsing\n return {\n enabled: override.enabled,\n pattern: override.pattern ?? base?.pattern,\n require_in_commits: override.require_in_commits,\n require_in_branch: override.require_in_branch,\n };\n}\n\nfunction mergeCoverageConfig(\n base: ProcessConfig[\"coverage\"],\n override: ProcessConfig[\"coverage\"]\n): ProcessConfig[\"coverage\"] {\n if (!override) {\n return base;\n }\n // enforce_in has schema default, so it's always defined after parsing\n return {\n enabled: override.enabled,\n min_threshold: override.min_threshold ?? base?.min_threshold,\n enforce_in: override.enforce_in,\n ci_workflow: override.ci_workflow ?? base?.ci_workflow,\n ci_job: override.ci_job ?? base?.ci_job,\n };\n}\n\nfunction mergeCommitsConfig(\n base: ProcessConfig[\"commits\"],\n override: ProcessConfig[\"commits\"]\n): ProcessConfig[\"commits\"] {\n if (!override) {\n return base;\n }\n // require_scope has schema default, so it's always defined after parsing\n return {\n enabled: override.enabled,\n pattern: override.pattern ?? base?.pattern,\n types: override.types ?? base?.types,\n require_scope: override.require_scope,\n max_subject_length: override.max_subject_length ?? base?.max_subject_length,\n };\n}\n\nfunction mergeChangesetsConfig(\n base: ProcessConfig[\"changesets\"],\n override: ProcessConfig[\"changesets\"]\n): ProcessConfig[\"changesets\"] {\n if (!override) {\n return base;\n }\n // validate_format and require_description have schema defaults, so they're always defined after parsing\n return {\n enabled: override.enabled,\n require_for_paths: override.require_for_paths ?? base?.require_for_paths,\n exclude_paths: override.exclude_paths ?? base?.exclude_paths,\n validate_format: override.validate_format,\n allowed_bump_types: override.allowed_bump_types ?? base?.allowed_bump_types,\n require_description: override.require_description,\n min_description_length: override.min_description_length ?? base?.min_description_length,\n };\n}\n\nfunction mergeRepoConfig(\n base: ProcessConfig[\"repo\"],\n override: ProcessConfig[\"repo\"]\n): ProcessConfig[\"repo\"] {\n if (!override) {\n return base;\n }\n // require_branch_protection and require_codeowners have schema defaults\n return {\n enabled: override.enabled,\n require_branch_protection: override.require_branch_protection,\n require_codeowners: override.require_codeowners,\n ruleset: override.ruleset ?? base?.ruleset,\n tag_protection: override.tag_protection ?? base?.tag_protection,\n };\n}\n\nfunction mergeBackupsConfig(\n base: ProcessConfig[\"backups\"],\n override: ProcessConfig[\"backups\"]\n): ProcessConfig[\"backups\"] {\n if (!override) {\n return base;\n }\n // max_age_hours has schema default\n return {\n enabled: override.enabled,\n bucket: override.bucket ?? base?.bucket,\n prefix: override.prefix ?? base?.prefix,\n max_age_hours: override.max_age_hours,\n region: override.region ?? base?.region,\n };\n}\n\nfunction mergeCodeownersConfig(\n base: ProcessConfig[\"codeowners\"],\n override: ProcessConfig[\"codeowners\"]\n): ProcessConfig[\"codeowners\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n rules: override.rules ?? base?.rules,\n };\n}\n\n// eslint-disable-next-line complexity -- docs config has many optional fields requiring individual merge\nfunction mergeDocsConfig(\n base: ProcessConfig[\"docs\"],\n override: ProcessConfig[\"docs\"]\n): ProcessConfig[\"docs\"] {\n if (!override) {\n return base;\n }\n // Fields with schema defaults: enabled, path, enforcement, staleness_days\n return {\n enabled: override.enabled,\n path: override.path,\n enforcement: override.enforcement,\n allowlist: override.allowlist ?? base?.allowlist,\n max_files: override.max_files ?? base?.max_files,\n max_file_lines: override.max_file_lines ?? base?.max_file_lines,\n max_total_kb: override.max_total_kb ?? base?.max_total_kb,\n staleness_days: override.staleness_days,\n stale_mappings: override.stale_mappings ?? base?.stale_mappings,\n min_coverage: override.min_coverage ?? base?.min_coverage,\n coverage_paths: override.coverage_paths ?? base?.coverage_paths,\n exclude_patterns: override.exclude_patterns ?? base?.exclude_patterns,\n types: override.types ?? base?.types,\n };\n}\n\n// eslint-disable-next-line complexity -- merging all process config sections requires multiple calls\nfunction mergeProcessSection(\n base: ProcessConfig | undefined,\n override: ProcessConfig\n): ProcessConfig {\n return {\n hooks: mergeHooksConfig(base?.hooks, override.hooks),\n ci: mergeCiConfig(base?.ci, override.ci),\n branches: mergeBranchesConfig(base?.branches, override.branches),\n commits: mergeCommitsConfig(base?.commits, override.commits),\n changesets: mergeChangesetsConfig(base?.changesets, override.changesets),\n pr: mergePrConfig(base?.pr, override.pr),\n tickets: mergeTicketsConfig(base?.tickets, override.tickets),\n coverage: mergeCoverageConfig(base?.coverage, override.coverage),\n repo: mergeRepoConfig(base?.repo, override.repo),\n backups: mergeBackupsConfig(base?.backups, override.backups),\n codeowners: mergeCodeownersConfig(base?.codeowners, override.codeowners),\n docs: mergeDocsConfig(base?.docs, override.docs),\n };\n}\n\nexport function mergeConfigs(base: Config, override: Config): Config {\n const merged: Config = { ...base };\n\n if (override.code) {\n merged.code = mergeCodeSection(base.code, override.code);\n }\n\n if (override.process) {\n merged.process = mergeProcessSection(base.process, override.process);\n }\n\n if (override.infra) {\n merged.infra = override.infra;\n }\n\n if (override.monorepo) {\n merged.monorepo = override.monorepo;\n }\n\n return merged;\n}\n\nexport async function resolveExtends(config: Config, configDir: string): Promise<Config> {\n if (!config.extends) {\n return config;\n }\n\n const { registry, rulesets } = config.extends;\n const location = parseRegistryUrl(registry, configDir);\n const registryDir = await fetchRegistry(location);\n\n let mergedConfig: Config = {};\n for (const rulesetName of rulesets) {\n const ruleset = loadRuleset(registryDir, rulesetName);\n mergedConfig = mergeConfigs(mergedConfig, ruleset);\n }\n\n // Local config overrides registry config (include all domains)\n const localConfig: Config = {\n code: config.code,\n process: config.process,\n infra: config.infra,\n monorepo: config.monorepo,\n };\n return mergeConfigs(mergedConfig, localConfig);\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\n\nimport TOML from \"@iarna/toml\";\n\nimport { resolveExtends } from \"./registry.js\";\nimport { type Config, configSchema, defaultConfig } from \"./schema.js\";\n\n/** Config file name */\nexport const CONFIG_FILE_NAME = \"standards.toml\";\n\ninterface LoadConfigResult {\n config: Config;\n configPath: string;\n}\n\nexport class ConfigError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ConfigError\";\n }\n}\n\n/**\n * Check if a path is a broken symlink\n */\nfunction isBrokenSymlink(filePath: string): boolean {\n try {\n const stats = fs.lstatSync(filePath);\n if (stats.isSymbolicLink()) {\n // It's a symlink - check if target exists\n try {\n fs.statSync(filePath);\n return false; // Target exists, not broken\n } catch {\n return true; // Target doesn't exist, broken symlink\n }\n }\n return false; // Not a symlink\n } catch {\n return false; // Path doesn't exist at all\n }\n}\n\n/**\n * Find standards.toml by walking up the directory tree\n */\nexport function findConfigFile(startDir: string = process.cwd()): string | null {\n let currentDir = path.resolve(startDir);\n const root = path.parse(currentDir).root;\n\n while (currentDir !== root) {\n const configPath = path.join(currentDir, CONFIG_FILE_NAME);\n if (isBrokenSymlink(configPath)) {\n throw new ConfigError(`${CONFIG_FILE_NAME} exists but is a broken symlink: ${configPath}`);\n }\n if (fs.existsSync(configPath)) {\n return configPath;\n }\n currentDir = path.dirname(currentDir);\n }\n\n // Check root directory too\n const rootConfig = path.join(root, CONFIG_FILE_NAME);\n if (isBrokenSymlink(rootConfig)) {\n throw new ConfigError(`${CONFIG_FILE_NAME} exists but is a broken symlink: ${rootConfig}`);\n }\n return fs.existsSync(rootConfig) ? rootConfig : null;\n}\n\n/**\n * Resolve and validate config file path\n * Always returns an absolute path to ensure consistent behavior\n */\nfunction resolveConfigPath(configPath?: string): string {\n const resolved = configPath ?? findConfigFile();\n if (!resolved) {\n throw new ConfigError(`No ${CONFIG_FILE_NAME} found. Create one or specify --config path.`);\n }\n // Convert to absolute path for consistent behavior across tools\n const absolutePath = path.resolve(resolved);\n if (!fs.existsSync(absolutePath)) {\n throw new ConfigError(`Config file not found: ${resolved}`);\n }\n return absolutePath;\n}\n\n/**\n * Parse TOML file content\n */\nfunction parseTomlFile(filePath: string): unknown {\n try {\n const content = fs.readFileSync(filePath, \"utf-8\");\n return TOML.parse(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n throw new ConfigError(`Failed to parse ${CONFIG_FILE_NAME}: ${message}`);\n }\n}\n\n/**\n * Validate config against schema\n */\nfunction validateConfig(rawConfig: unknown): Config {\n const result = configSchema.safeParse(rawConfig);\n if (!result.success) {\n const errors = result.error.errors\n .map((e) => ` - ${e.path.join(\".\")}: ${e.message}`)\n .join(\"\\n\");\n throw new ConfigError(`Invalid ${CONFIG_FILE_NAME} configuration:\\n${errors}`);\n }\n return result.data;\n}\n\n/**\n * Load and parse standards.toml configuration (sync version without extends resolution)\n * Use loadConfigAsync for full extends support\n */\nexport function loadConfig(configPath?: string): LoadConfigResult {\n const resolvedPath = resolveConfigPath(configPath);\n const rawConfig = parseTomlFile(resolvedPath);\n const validatedConfig = validateConfig(rawConfig);\n const config = mergeWithDefaults(validatedConfig);\n return { config, configPath: resolvedPath };\n}\n\n/**\n * Load and parse standards.toml configuration with extends resolution\n */\nexport async function loadConfigAsync(configPath?: string): Promise<LoadConfigResult> {\n const resolvedPath = resolveConfigPath(configPath);\n const rawConfig = parseTomlFile(resolvedPath);\n const validatedConfig = validateConfig(rawConfig);\n\n // Resolve extends if present\n const configDir = path.dirname(resolvedPath);\n const resolvedConfig = await resolveExtends(validatedConfig, configDir);\n\n const config = mergeWithDefaults(resolvedConfig);\n return { config, configPath: resolvedPath };\n}\n\n/** Merge two optional objects, with right side taking precedence */\nfunction merge<T extends object>(a: T | undefined, b: T | undefined): T {\n return { ...a, ...b } as T;\n}\n\ntype CodeConfig = NonNullable<Config[\"code\"]>;\n\nfunction mergeLinting(c: Config, dc: Config): CodeConfig[\"linting\"] {\n const cl = c.code?.linting;\n const dl = dc.code?.linting;\n return { eslint: merge(dl?.eslint, cl?.eslint), ruff: merge(dl?.ruff, cl?.ruff) };\n}\n\nfunction mergeSecurity(c: Config, dc: Config): CodeConfig[\"security\"] {\n const cs = c.code?.security;\n const ds = dc.code?.security;\n return {\n secrets: merge(ds?.secrets, cs?.secrets),\n pnpmaudit: merge(ds?.pnpmaudit, cs?.pnpmaudit),\n pipaudit: merge(ds?.pipaudit, cs?.pipaudit),\n };\n}\n\nfunction mergeTypes(c: Config, dc: Config): CodeConfig[\"types\"] {\n return {\n tsc: merge(dc.code?.types?.tsc, c.code?.types?.tsc),\n ty: merge(dc.code?.types?.ty, c.code?.types?.ty),\n };\n}\n\nfunction mergeUnused(c: Config, dc: Config): CodeConfig[\"unused\"] {\n return {\n knip: merge(dc.code?.unused?.knip, c.code?.unused?.knip),\n vulture: merge(dc.code?.unused?.vulture, c.code?.unused?.vulture),\n };\n}\n\nfunction mergeCoverageRun(c: Config, dc: Config): CodeConfig[\"coverage_run\"] {\n return merge(dc.code?.coverage_run, c.code?.coverage_run);\n}\n\nfunction mergeNaming(c: Config, dc: Config): CodeConfig[\"naming\"] {\n const cn = c.code?.naming;\n const dn = dc.code?.naming;\n // For naming, we want to preserve the rules array from user config\n return {\n enabled: cn?.enabled ?? dn?.enabled ?? false,\n rules: cn?.rules ?? dn?.rules,\n };\n}\n\nfunction mergeQuality(c: Config, dc: Config): CodeConfig[\"quality\"] {\n const cq = c.code?.quality;\n const dq = dc.code?.quality;\n return {\n \"disable-comments\": merge(dq?.[\"disable-comments\"], cq?.[\"disable-comments\"]),\n };\n}\n\nfunction mergeCode(c: Config, dc: Config): CodeConfig {\n return {\n linting: mergeLinting(c, dc),\n types: mergeTypes(c, dc),\n unused: mergeUnused(c, dc),\n coverage_run: mergeCoverageRun(c, dc),\n security: mergeSecurity(c, dc),\n naming: mergeNaming(c, dc),\n quality: mergeQuality(c, dc),\n };\n}\n\ntype ProcessConfig = NonNullable<Config[\"process\"]>;\ntype HooksConfig = NonNullable<ProcessConfig[\"hooks\"]>;\ntype CiConfig = NonNullable<ProcessConfig[\"ci\"]>;\ntype BranchesConfig = NonNullable<ProcessConfig[\"branches\"]>;\ntype CommitsConfig = NonNullable<ProcessConfig[\"commits\"]>;\ntype ChangesetsConfig = NonNullable<ProcessConfig[\"changesets\"]>;\ntype PrConfig = NonNullable<ProcessConfig[\"pr\"]>;\ntype TicketsConfig = NonNullable<ProcessConfig[\"tickets\"]>;\ntype CoverageConfig = NonNullable<ProcessConfig[\"coverage\"]>;\ntype RepoConfig = NonNullable<ProcessConfig[\"repo\"]>;\ntype BackupsConfig = NonNullable<ProcessConfig[\"backups\"]>;\ntype CodeownersConfig = NonNullable<ProcessConfig[\"codeowners\"]>;\ntype DocsConfig = NonNullable<ProcessConfig[\"docs\"]>;\ntype ForbiddenFilesConfig = NonNullable<ProcessConfig[\"forbidden_files\"]>;\n\nconst defaultHooks: HooksConfig = { enabled: false, require_husky: true };\nconst defaultCi: CiConfig = { enabled: false };\nconst defaultBranches: BranchesConfig = { enabled: false, require_issue: false };\nconst defaultCommits: CommitsConfig = { enabled: false, require_scope: false };\nconst defaultChangesets: ChangesetsConfig = {\n enabled: false,\n validate_format: true,\n require_description: true,\n};\nconst defaultPr: PrConfig = { enabled: false, require_issue: false };\nconst defaultTickets: TicketsConfig = {\n enabled: false,\n require_in_commits: true,\n require_in_branch: false,\n};\nconst defaultCoverage: CoverageConfig = { enabled: false, enforce_in: \"config\" };\nconst defaultRepo: RepoConfig = {\n enabled: false,\n require_branch_protection: false,\n require_codeowners: false,\n};\nconst defaultBackups: BackupsConfig = { enabled: false, max_age_hours: 24 };\nconst defaultCodeowners: CodeownersConfig = { enabled: false };\nconst defaultDocs: DocsConfig = {\n enabled: false,\n path: \"docs/\",\n enforcement: \"warn\",\n staleness_days: 30,\n};\nconst defaultForbiddenFiles: ForbiddenFilesConfig = { enabled: false };\n\n/** Merge a single process config section with defaults */\nfunction mergeProcessSection<T>(defaultVal: T, dcVal: T | undefined, cVal: T | undefined): T {\n return { ...defaultVal, ...dcVal, ...cVal };\n}\n\nfunction mergeProcessHooks(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): HooksConfig {\n return mergeProcessSection(defaultHooks, dcp?.hooks, cp?.hooks);\n}\n\nfunction mergeProcessCi(cp: ProcessConfig | undefined, dcp: ProcessConfig | undefined): CiConfig {\n return mergeProcessSection(defaultCi, dcp?.ci, cp?.ci);\n}\n\nfunction mergeProcessBranches(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): BranchesConfig {\n return mergeProcessSection(defaultBranches, dcp?.branches, cp?.branches);\n}\n\nfunction mergeProcessCommits(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CommitsConfig {\n return mergeProcessSection(defaultCommits, dcp?.commits, cp?.commits);\n}\n\nfunction mergeProcessChangesets(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): ChangesetsConfig {\n return mergeProcessSection(defaultChangesets, dcp?.changesets, cp?.changesets);\n}\n\nfunction mergeProcessPr(cp: ProcessConfig | undefined, dcp: ProcessConfig | undefined): PrConfig {\n return mergeProcessSection(defaultPr, dcp?.pr, cp?.pr);\n}\n\nfunction mergeProcessTickets(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): TicketsConfig {\n return mergeProcessSection(defaultTickets, dcp?.tickets, cp?.tickets);\n}\n\nfunction mergeProcessCoverage(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CoverageConfig {\n return mergeProcessSection(defaultCoverage, dcp?.coverage, cp?.coverage);\n}\n\nfunction mergeProcessRepo(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): RepoConfig {\n return mergeProcessSection(defaultRepo, dcp?.repo, cp?.repo);\n}\n\nfunction mergeProcessBackups(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): BackupsConfig {\n return mergeProcessSection(defaultBackups, dcp?.backups, cp?.backups);\n}\n\nfunction mergeProcessCodeowners(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CodeownersConfig {\n const cco = cp?.codeowners;\n const dco = dcp?.codeowners;\n // Merge rules arrays: registry rules + project rules (deduplicated by pattern)\n const registryRules = dco?.rules ?? [];\n const projectRules = cco?.rules ?? [];\n // Project rules can override registry rules for the same pattern\n const ruleMap = new Map<string, { pattern: string; owners: string[] }>();\n for (const rule of registryRules) {\n ruleMap.set(rule.pattern, rule);\n }\n for (const rule of projectRules) {\n ruleMap.set(rule.pattern, rule);\n }\n const mergedRules = Array.from(ruleMap.values());\n return {\n ...defaultCodeowners,\n ...dco,\n ...cco,\n rules: mergedRules.length > 0 ? mergedRules : undefined,\n };\n}\n\nfunction mergeProcessDocs(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): DocsConfig {\n return mergeProcessSection(defaultDocs, dcp?.docs, cp?.docs);\n}\n\nfunction mergeProcessForbiddenFiles(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): ForbiddenFilesConfig {\n return mergeProcessSection(defaultForbiddenFiles, dcp?.forbidden_files, cp?.forbidden_files);\n}\n\nfunction mergeProcess(c: Config, dc: Config): ProcessConfig {\n return {\n hooks: mergeProcessHooks(c.process, dc.process),\n ci: mergeProcessCi(c.process, dc.process),\n branches: mergeProcessBranches(c.process, dc.process),\n commits: mergeProcessCommits(c.process, dc.process),\n changesets: mergeProcessChangesets(c.process, dc.process),\n pr: mergeProcessPr(c.process, dc.process),\n tickets: mergeProcessTickets(c.process, dc.process),\n coverage: mergeProcessCoverage(c.process, dc.process),\n repo: mergeProcessRepo(c.process, dc.process),\n backups: mergeProcessBackups(c.process, dc.process),\n codeowners: mergeProcessCodeowners(c.process, dc.process),\n docs: mergeProcessDocs(c.process, dc.process),\n forbidden_files: mergeProcessForbiddenFiles(c.process, dc.process),\n };\n}\n\n/**\n * Deep merge config with defaults\n */\nfunction mergeWithDefaults(config: Config): Config {\n return {\n code: mergeCode(config, defaultConfig),\n process: mergeProcess(config, defaultConfig),\n infra: {\n enabled: config.infra?.enabled ?? defaultConfig.infra?.enabled ?? false,\n manifest: config.infra?.manifest ?? defaultConfig.infra?.manifest ?? \"infra-manifest.json\",\n },\n monorepo: config.monorepo,\n };\n}\n\n/**\n * Get the project root directory (where standards.toml is located)\n */\nexport function getProjectRoot(configPath: string): string {\n return path.dirname(configPath);\n}\n\n/** Information about a config override */\nexport interface ConfigOverride {\n section: string;\n key: string;\n registryValue: string;\n projectValue: string;\n}\n\n/** Check if a project rule overrides a registry rule */\nfunction checkRuleOverride(\n projectRule: { pattern: string; owners: string[] },\n registryOwners: string[] | undefined\n): ConfigOverride | null {\n if (!registryOwners) {\n return null;\n }\n const registryStr = registryOwners.join(\" \");\n const projectStr = projectRule.owners.join(\" \");\n if (registryStr === projectStr) {\n return null;\n }\n return {\n section: \"process.codeowners.rules\",\n key: projectRule.pattern,\n registryValue: registryStr,\n projectValue: projectStr,\n };\n}\n\n/** Detect CODEOWNERS rule overrides between registry and project config */\nfunction detectCodeownersOverrides(\n registryConfig: Config | undefined,\n projectConfig: Config | undefined\n): ConfigOverride[] {\n const registryRules = registryConfig?.process?.codeowners?.rules ?? [];\n const projectRules = projectConfig?.process?.codeowners?.rules ?? [];\n const registryMap = new Map(registryRules.map((r) => [r.pattern, r.owners]));\n\n return projectRules\n .map((rule) => checkRuleOverride(rule, registryMap.get(rule.pattern)))\n .filter((o): o is ConfigOverride => o !== null);\n}\n\n/** Load registry config from extends */\nasync function loadRegistryConfig(\n extendsConfig: NonNullable<Config[\"extends\"]>,\n configDir: string\n): Promise<Config> {\n const registryModule = await import(\"./registry.js\");\n const loc = registryModule.parseRegistryUrl(extendsConfig.registry, configDir);\n const registryDir = await registryModule.fetchRegistry(loc);\n\n let config: Config = {};\n for (const name of extendsConfig.rulesets) {\n config = registryModule.mergeConfigs(config, registryModule.loadRuleset(registryDir, name));\n }\n return config;\n}\n\n/**\n * Load config and detect any overrides from registry\n * Returns both the merged config and information about overrides\n */\nexport async function loadConfigWithOverrides(\n configPath?: string\n): Promise<LoadConfigResult & { overrides: ConfigOverride[] }> {\n const resolvedPath = resolveConfigPath(configPath);\n const validatedConfig = validateConfig(parseTomlFile(resolvedPath));\n\n let overrides: ConfigOverride[] = [];\n if (validatedConfig.extends) {\n const registryConfig = await loadRegistryConfig(\n validatedConfig.extends,\n path.dirname(resolvedPath)\n );\n overrides = detectCodeownersOverrides(registryConfig, validatedConfig);\n }\n\n const { config, configPath: finalPath } = await loadConfigAsync(configPath);\n return { config, configPath: finalPath, overrides };\n}\n","/* eslint-disable max-lines -- schema file contains all domain schemas and grows with features */\nimport { minimatch } from \"minimatch\";\nimport { z } from \"zod\";\n\n/**\n * Count unclosed brackets and braces in a pattern, respecting escapes.\n */\nfunction countUnclosedDelimiters(pattern: string): { brackets: number; braces: number } {\n let brackets = 0;\n let braces = 0;\n for (let i = 0; i < pattern.length; i++) {\n if (pattern[i] === \"\\\\\" && i + 1 < pattern.length) {\n i++; // Skip escaped character\n continue;\n }\n switch (pattern[i]) {\n case \"[\":\n brackets++;\n break;\n case \"]\":\n if (brackets > 0) {\n brackets--;\n }\n break;\n case \"{\":\n braces++;\n break;\n case \"}\":\n if (braces > 0) {\n braces--;\n }\n break;\n }\n }\n return { brackets, braces };\n}\n\n/**\n * Validate that a string is a valid glob pattern.\n * Checks for balanced brackets/braces since minimatch is too lenient.\n */\nfunction isValidGlobPattern(pattern: string): { valid: boolean; error?: string } {\n if (pattern.length === 0) {\n return { valid: false, error: \"empty pattern\" };\n }\n\n const unclosed = countUnclosedDelimiters(pattern);\n if (unclosed.brackets > 0) {\n return { valid: false, error: \"unclosed bracket '['\" };\n }\n if (unclosed.braces > 0) {\n return { valid: false, error: \"unclosed brace '{'\" };\n }\n\n try {\n const result = minimatch.makeRe(pattern);\n return result === false ? { valid: false, error: \"invalid pattern syntax\" } : { valid: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Invalid glob pattern\";\n return { valid: false, error: message };\n }\n}\n\n/**\n * Zod schema for a valid glob pattern string\n */\nconst globPatternSchema = z.string().refine(\n (pattern) => isValidGlobPattern(pattern).valid,\n (pattern) => ({\n message: `Invalid glob pattern: \"${pattern}\" - ${isValidGlobPattern(pattern).error}`,\n })\n);\n\n/**\n * Zod schema for standards.toml configuration\n */\n\n// =============================================================================\n// ESLint Configuration\n// =============================================================================\n\n/** ESLint rule severity */\nconst eslintRuleSeverity = z.enum([\"off\", \"warn\", \"error\"]);\n\n/**\n * ESLint rule with options in TOML-friendly object format.\n * Example: { severity = \"error\", max = 10 }\n * The 'severity' key is required, all other keys are rule-specific options.\n */\nconst eslintRuleWithOptions = z\n .object({\n severity: eslintRuleSeverity,\n })\n .catchall(z.unknown()); // Allow any additional options (max, skipBlankLines, etc.)\n\n/**\n * ESLint rule value - can be:\n * - severity string: \"error\"\n * - object with severity and options: { severity: \"error\", max: 10 }\n */\nconst eslintRuleValue = z.union([eslintRuleSeverity, eslintRuleWithOptions]);\n\n/** ESLint rules configuration */\nconst eslintRulesSchema = z.record(z.string(), eslintRuleValue).optional();\n\n/** ESLint configuration */\nconst eslintConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(true),\n files: z.array(z.string()).optional(), // Glob patterns for files to lint\n ignore: z.array(z.string()).optional(), // Glob patterns to ignore\n \"max-warnings\": z.number().int().nonnegative().optional(), // Max warnings before failure\n rules: eslintRulesSchema, // Required rules for audit (verifies eslint.config.js)\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Ruff Configuration\n// =============================================================================\n\n/** Ruff lint configuration */\nconst ruffLintSchema = z\n .object({\n select: z.array(z.string()).optional(),\n ignore: z.array(z.string()).optional(),\n })\n .strict()\n .optional();\n\n/** Ruff configuration */\nconst ruffConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(true),\n \"line-length\": z.number().int().positive().optional(),\n lint: ruffLintSchema,\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// TypeScript Configuration\n// =============================================================================\n\n/** TypeScript compiler options that can be required via audit */\nconst tscCompilerOptionsSchema = z\n .object({\n strict: z.boolean().optional(),\n noImplicitAny: z.boolean().optional(),\n strictNullChecks: z.boolean().optional(),\n noUnusedLocals: z.boolean().optional(),\n noUnusedParameters: z.boolean().optional(),\n noImplicitReturns: z.boolean().optional(),\n noFallthroughCasesInSwitch: z.boolean().optional(),\n esModuleInterop: z.boolean().optional(),\n skipLibCheck: z.boolean().optional(),\n forceConsistentCasingInFileNames: z.boolean().optional(),\n })\n .strict()\n .optional();\n\n/** TypeScript compiler configuration */\nconst tscConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require: tscCompilerOptionsSchema, // Required compiler options for audit\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// ty Configuration (Python Type Checking)\n// =============================================================================\n\n/** ty Python type checker configuration */\nconst tyConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Knip Configuration (Unused Code Detection)\n// =============================================================================\n\n/** Knip configuration */\nconst knipConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Vulture Configuration (Python Dead Code Detection)\n// =============================================================================\n\n/** Vulture configuration */\nconst vultureConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Coverage Run Configuration\n// =============================================================================\n\n/** Coverage run test runner type */\nconst coverageRunnerSchema = z.enum([\"vitest\", \"jest\", \"pytest\", \"auto\"]);\n\n/** Coverage run configuration - runs tests and verifies coverage threshold */\nconst coverageRunConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n min_threshold: z.number().int().min(0).max(100).optional().default(80), // Minimum coverage percentage\n runner: coverageRunnerSchema.optional().default(\"auto\"), // Test runner to use\n command: z.string().optional(), // Custom command to run tests with coverage\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Security Configuration\n// =============================================================================\n\n/** Secrets (Gitleaks) configuration */\nconst secretsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n scan_mode: z\n .enum([\"branch\", \"files\", \"staged\", \"full\"])\n .optional()\n .default(\"branch\"), // branch: scan current branch commits, files: scan filesystem, staged: staged files only, full: entire git history\n base_branch: z.string().optional().default(\"main\"), // Branch to compare against for \"branch\" mode\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** pnpm audit configuration */\nconst pnpmauditConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n exclude_dev: z.boolean().optional().default(true),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** pip-audit configuration */\nconst pipauditConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** Code security configuration */\nconst codeSecuritySchema = z\n .object({\n secrets: secretsConfigSchema,\n pnpmaudit: pnpmauditConfigSchema,\n pipaudit: pipauditConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Naming Conventions Configuration\n// =============================================================================\n\n/** Supported case types for naming conventions */\nconst caseTypeSchema = z.enum([\"kebab-case\", \"snake_case\", \"camelCase\", \"PascalCase\"]);\n\n/** Helper to validate no duplicate values in array */\nconst uniqueArraySchema = <T extends z.ZodTypeAny>(schema: T): z.ZodEffects<z.ZodArray<T>> =>\n z.array(schema).refine((arr) => new Set(arr).size === arr.length, {\n message: \"Duplicate values not allowed\",\n });\n\n/** Helper to validate no duplicate values in array with minimum length */\nconst uniqueArraySchemaMin1 = <T extends z.ZodTypeAny>(schema: T): z.ZodEffects<z.ZodArray<T>> =>\n z\n .array(schema)\n .min(1, \"At least one value is required\")\n .refine((arr) => new Set(arr).size === arr.length, {\n message: \"Duplicate values not allowed\",\n });\n\n/** Single naming rule */\nconst namingRuleSchema = z\n .object({\n extensions: uniqueArraySchemaMin1(z.string()), // e.g., [\"ts\", \"tsx\"] - no duplicates allowed, at least one required\n file_case: caseTypeSchema,\n folder_case: caseTypeSchema,\n exclude: z.array(z.string()).optional(), // Glob patterns to exclude, e.g., [\"tests/**\"]\n allow_dynamic_routes: z.boolean().optional(), // Allow Next.js/Remix dynamic route folders: [id], [...slug], (group)\n })\n .strict();\n\n/** Naming conventions configuration */\nconst namingConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n rules: z.array(namingRuleSchema).optional(),\n })\n .strict()\n .superRefine((data, ctx) => {\n if (!data.rules || data.rules.length <= 1) {\n return;\n }\n\n const extensionToRuleIndex = new Map<string, number>();\n for (let i = 0; i < data.rules.length; i++) {\n for (const ext of data.rules[i].extensions) {\n const existing = extensionToRuleIndex.get(ext);\n if (existing !== undefined) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Extension \"${ext}\" appears in multiple naming rules (rules ${existing + 1} and ${i + 1}). Each extension can only appear in one rule.`,\n path: [\"rules\", i, \"extensions\"],\n });\n } else {\n extensionToRuleIndex.set(ext, i);\n }\n }\n }\n })\n .optional();\n\n// =============================================================================\n// Quality Configuration (Disable Comments Detection)\n// =============================================================================\n\n/** Disable comments configuration */\nconst disableCommentsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n patterns: z.array(z.string()).optional(), // Override default patterns\n extensions: uniqueArraySchema(z.string()).optional(), // File extensions to scan - no duplicates allowed\n exclude: z.array(z.string()).optional(), // Glob patterns to exclude\n })\n .strict()\n .optional();\n\n/** Code quality configuration */\nconst codeQualitySchema = z\n .object({\n \"disable-comments\": disableCommentsConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Code Domain Configuration\n// =============================================================================\n\n/** Code linting configuration */\nconst codeLintingSchema = z\n .object({\n eslint: eslintConfigSchema,\n ruff: ruffConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code type checking configuration */\nconst codeTypesSchema = z\n .object({\n tsc: tscConfigSchema,\n ty: tyConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code unused detection configuration */\nconst codeUnusedSchema = z\n .object({\n knip: knipConfigSchema,\n vulture: vultureConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code domain configuration */\nconst codeSchema = z\n .object({\n linting: codeLintingSchema,\n types: codeTypesSchema,\n unused: codeUnusedSchema,\n coverage_run: coverageRunConfigSchema,\n security: codeSecuritySchema,\n naming: namingConfigSchema,\n quality: codeQualitySchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Process Domain Configuration\n// =============================================================================\n\n/** Hook commands configuration - maps hook name to required commands */\nconst hookCommandsSchema = z.record(z.string(), z.array(z.string())).optional();\n\n/** Git hooks (husky) configuration */\nconst hooksConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_husky: z.boolean().optional().default(true), // Require .husky/ directory\n require_hooks: z.array(z.string()).optional(), // e.g., [\"pre-commit\", \"pre-push\"]\n commands: hookCommandsSchema, // e.g., { \"pre-commit\": [\"lint-staged\"] }\n protected_branches: z.array(z.string()).optional(), // e.g., [\"main\", \"master\"] - verify pre-push prevents direct pushes\n })\n .strict()\n .optional();\n\n/**\n * CI commands configuration value - can be:\n * - Array of strings: commands required anywhere in workflow\n * - Record mapping job names to arrays: commands required in specific jobs\n */\nconst ciCommandsValueSchema = z.union([\n z.array(z.string()), // Workflow-level: [\"cmd1\", \"cmd2\"]\n z.record(z.string(), z.array(z.string())), // Job-level: { jobName: [\"cmd1\"] }\n]);\n\n/** CI commands schema - maps workflow file to required commands */\nconst ciCommandsSchema = z.record(z.string(), ciCommandsValueSchema).optional();\n\n/** CI/CD workflows configuration */\nconst ciConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_workflows: z.array(z.string()).optional(), // e.g., [\"ci.yml\", \"release.yml\"]\n jobs: z.record(z.string(), z.array(z.string())).optional(), // e.g., { \"ci.yml\": [\"test\", \"lint\"] }\n actions: z.record(z.string(), z.array(z.string())).optional(), // e.g., { \"ci.yml\": [\"actions/checkout\"] }\n commands: ciCommandsSchema, // e.g., { \"ci.yml\": [\"conform code check\"] } or { \"ci.yml\": { \"test\": [\"npm test\"] } }\n })\n .strict()\n .optional();\n\n/** Branch naming configuration */\nconst branchesConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for branch names\n exclude: z.array(z.string()).optional(), // Branches to skip (e.g., [\"main\", \"master\"])\n require_issue: z.boolean().optional().default(false), // Require issue number in branch name\n issue_pattern: z.string().optional(), // Regex to extract issue number (default: captures number after type/)\n })\n .strict()\n .optional();\n\n/** Commit message format configuration */\nconst commitsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for commit messages (e.g., conventional commits)\n types: z.array(z.string()).optional(), // Allowed commit types (e.g., [\"feat\", \"fix\", \"chore\"])\n require_scope: z.boolean().optional().default(false), // Require scope like feat(api): ...\n max_subject_length: z.number().int().positive().optional(), // Max length of subject line\n })\n .strict()\n .optional();\n\n/** Changeset bump type */\nconst changesetBumpTypeSchema = z.enum([\"patch\", \"minor\", \"major\"]);\n\n/** Changeset validation configuration */\nconst changesetsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_for_paths: z.array(z.string()).optional(), // Glob patterns that require changesets (e.g., [\"src/**\"])\n exclude_paths: z.array(z.string()).optional(), // Paths that don't require changesets (e.g., [\"**/*.test.ts\"])\n validate_format: z.boolean().optional().default(true), // Validate changeset file format (frontmatter, description)\n allowed_bump_types: z.array(changesetBumpTypeSchema).optional(), // Restrict allowed bump types (e.g., [\"patch\", \"minor\"])\n require_description: z.boolean().optional().default(true), // Require non-empty description\n min_description_length: z.number().int().positive().optional(), // Minimum description length\n })\n .strict()\n .optional();\n\n/** PR configuration */\nconst prConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n max_files: z.number().int().positive().optional(), // Max files changed in PR\n max_lines: z.number().int().positive().optional(), // Max lines changed (additions + deletions)\n require_issue: z.boolean().optional().default(false), // Require issue reference in PR description\n issue_keywords: z.array(z.string()).optional(), // Keywords that link to issues (e.g., [\"Closes\", \"Fixes\", \"Resolves\"])\n exclude: z.array(globPatternSchema).optional(), // Glob patterns to exclude from size calculation (e.g., [\"*.lock\", \"**/*.snap\"])\n })\n .strict()\n .optional();\n\n/** Ticket reference validation configuration */\nconst ticketsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for ticket IDs (e.g., \"^(ABC|XYZ)-[0-9]+\")\n require_in_commits: z.boolean().optional().default(true), // Require ticket in commit messages\n require_in_branch: z.boolean().optional().default(false), // Require ticket in branch name\n })\n .strict()\n .optional();\n\n/** Coverage enforcement mode */\nconst coverageEnforceInSchema = z.enum([\"ci\", \"config\", \"both\"]);\n\n/** Coverage enforcement configuration */\nconst coverageConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n min_threshold: z.number().int().min(0).max(100).optional(), // Minimum coverage percentage\n enforce_in: coverageEnforceInSchema.optional().default(\"config\"), // Where to verify coverage\n ci_workflow: z.string().optional(), // Workflow file to check (e.g., \"ci.yml\")\n ci_job: z.string().optional(), // Job name to check (e.g., \"test\")\n })\n .strict()\n .optional();\n\n/** Bypass actor type for GitHub Rulesets */\nconst bypassActorTypeSchema = z.enum([\n \"Integration\", // GitHub App\n \"OrganizationAdmin\", // Org admin role\n \"RepositoryRole\", // Repository role (1=read, 2=triage, 3=write, 4=maintain, 5=admin)\n \"Team\", // GitHub team\n \"DeployKey\", // Deploy key\n]);\n\n/** Bypass mode - when the actor can bypass */\nconst bypassModeSchema = z.enum([\n \"always\", // Can always bypass\n \"pull_request\", // Can bypass only via pull request\n]);\n\n/** Single bypass actor configuration */\nconst bypassActorSchema = z\n .object({\n actor_type: bypassActorTypeSchema,\n actor_id: z.number().int().positive().optional(), // Actor ID (required except for DeployKey)\n bypass_mode: bypassModeSchema.optional().default(\"always\"),\n })\n .strict();\n\n/** Ruleset configuration (uses GitHub Rulesets API) */\nconst rulesetConfigSchema = z\n .object({\n name: z.string().optional().default(\"Branch Protection\"), // Ruleset name in GitHub\n branch: z.string().optional().default(\"main\"), // Branch to check (default: main)\n enforcement: z.enum([\"active\", \"evaluate\", \"disabled\"]).optional().default(\"active\"), // Ruleset enforcement\n required_reviews: z.number().int().min(0).optional(), // Minimum required reviews\n dismiss_stale_reviews: z.boolean().optional(), // Dismiss stale reviews on new commits\n require_code_owner_reviews: z.boolean().optional(), // Require CODEOWNER review\n require_status_checks: z.array(z.string()).optional(), // Required status checks\n require_branches_up_to_date: z.boolean().optional(), // Require branch to be up to date\n require_signed_commits: z.boolean().optional(), // Require signed commits\n enforce_admins: z.boolean().optional(), // Enforce rules for admins (no bypass actors when true)\n bypass_actors: z.array(bypassActorSchema).optional(), // Actors that can bypass rules\n })\n .strict()\n .optional();\n\n/** Tag protection ruleset configuration */\nconst tagProtectionConfigSchema = z\n .object({\n patterns: z.array(z.string()).optional(), // Tag patterns to protect (e.g., [\"v*\"])\n prevent_deletion: z.boolean().optional().default(true), // Prevent tag deletion\n prevent_update: z.boolean().optional().default(true), // Prevent tag updates (force-push)\n })\n .strict()\n .optional();\n\n/** Repository settings configuration */\nconst repoConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_branch_protection: z.boolean().optional().default(false), // Check branch protection exists\n require_codeowners: z.boolean().optional().default(false), // Check CODEOWNERS file exists\n ruleset: rulesetConfigSchema, // GitHub Ruleset configuration\n tag_protection: tagProtectionConfigSchema, // Tag protection via GitHub rulesets\n })\n .strict()\n .optional();\n\n/** S3 backup verification configuration */\nconst backupsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n bucket: z.string().optional(), // S3 bucket name\n prefix: z.string().optional(), // S3 key prefix\n max_age_hours: z.number().int().positive().optional().default(24), // Max age of most recent backup\n region: z.string().optional(), // AWS region (defaults to AWS_REGION env)\n })\n .strict()\n .optional();\n\n/** Single CODEOWNERS rule */\nconst codeownersRuleSchema = z\n .object({\n pattern: z.string(), // File pattern (e.g., \"/standards.toml\", \"*.js\", \"/src/api/*\")\n owners: z.array(z.string()), // Owner handles (e.g., [\"@user\", \"@org/team\"])\n })\n .strict();\n\n/** CODEOWNERS validation configuration */\nconst codeownersConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n rules: z.array(codeownersRuleSchema).optional(), // Required rules in CODEOWNERS\n })\n .strict()\n .optional();\n\n/** Doc type configuration - defines required sections and frontmatter per doc type */\nconst docsTypeConfigSchema = z\n .object({\n required_sections: z.array(z.string()).optional(), // e.g., [\"Overview\", \"Parameters\", \"Returns\", \"Examples\"]\n frontmatter: z.array(z.string()).optional(), // e.g., [\"title\", \"tracks\"]\n })\n .strict();\n\n/** Documentation enforcement mode */\nconst docsEnforcementSchema = z.enum([\"block\", \"warn\"]);\n\n/** Documentation governance configuration */\nconst docsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n path: z.string().optional().default(\"docs/\"), // Documentation directory\n enforcement: docsEnforcementSchema.optional().default(\"warn\"), // \"block\" or \"warn\"\n allowlist: z.array(z.string()).optional(), // Markdown files allowed outside docs/, e.g., [\"README.md\", \"CLAUDE.md\"]\n max_files: z.number().int().positive().optional(), // Max markdown files in docs/\n max_file_lines: z.number().int().positive().optional(), // Max lines per markdown file\n max_total_kb: z.number().int().positive().optional(), // Max total size of docs/\n staleness_days: z.number().int().positive().optional().default(30), // Days before doc is considered stale\n stale_mappings: z.record(z.string(), z.string()).optional(), // Override doc-to-source mappings\n min_coverage: z.number().int().min(0).max(100).optional(), // Minimum API coverage percentage\n coverage_paths: z.array(z.string()).optional(), // Glob patterns for source files, e.g., [\"src/**/*.ts\"]\n exclude_patterns: z.array(z.string()).optional(), // Exclude from coverage, e.g., [\"**/*.test.ts\"]\n types: z.record(z.string(), docsTypeConfigSchema).optional(), // Per-type config, e.g., { api: {...}, guide: {...} }\n })\n .strict()\n .optional();\n\n// =============================================================================\n// MCP Configuration\n// =============================================================================\n\n/** MCP standards source configuration */\nconst mcpStandardsSchema = z\n .object({\n source: z\n .string()\n .optional()\n .describe(\n 'Standards repository source: \"github:owner/repo\", \"github:owner/repo@ref\", or local path'\n ),\n })\n .strict()\n .optional();\n\n/** MCP configuration */\nconst mcpSchema = z\n .object({\n standards: mcpStandardsSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Infra Domain Configuration\n// =============================================================================\n\n/** Infra domain configuration for AWS resource verification */\nconst infraSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n manifest: z.string().optional().default(\"infra-manifest.json\"), // Path to manifest file\n })\n .strict()\n .optional();\n\n/** Default ignore patterns for forbidden files scan */\nconst DEFAULT_FORBIDDEN_FILES_IGNORE = [\"**/node_modules/**\", \"**/.git/**\"];\n\n/** Forbidden files configuration - files that must NOT exist */\nconst forbiddenFilesConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n files: z.array(globPatternSchema).optional(), // Glob patterns for files that must not exist (validated)\n ignore: z.array(globPatternSchema).optional(), // Glob patterns to ignore (validated, overrides defaults if provided)\n message: z.string().optional(), // Custom message explaining why these files are forbidden\n })\n .strict()\n .optional();\n\nexport { DEFAULT_FORBIDDEN_FILES_IGNORE };\n\n/** Process domain configuration */\nconst processSchema = z\n .object({\n hooks: hooksConfigSchema,\n ci: ciConfigSchema,\n branches: branchesConfigSchema,\n commits: commitsConfigSchema,\n changesets: changesetsConfigSchema,\n pr: prConfigSchema,\n tickets: ticketsConfigSchema,\n coverage: coverageConfigSchema,\n repo: repoConfigSchema,\n backups: backupsConfigSchema,\n codeowners: codeownersConfigSchema,\n docs: docsConfigSchema,\n forbidden_files: forbiddenFilesConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Metadata Configuration\n// =============================================================================\n\n/** Repository tier for standards enforcement level */\nconst tierSchema = z.enum([\"production\", \"internal\", \"prototype\"]);\n\n/** Repository status indicating lifecycle phase */\nconst statusSchema = z.enum([\"active\", \"pre-release\", \"deprecated\"]);\n\n/** Metadata configuration for repository tier, project, organisation, and status */\nconst metadataSchema = z\n .object({\n tier: tierSchema,\n project: z.string().optional(),\n organisation: z.string().optional(),\n status: statusSchema.optional().default(\"active\"),\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Extends Configuration\n// =============================================================================\n\n/** Extends configuration for inheriting from registries */\nconst extendsSchema = z\n .object({\n registry: z.string(), // e.g., \"github:myorg/standards\" or local path\n rulesets: z.array(z.string()), // e.g., [\"base\", \"typescript\"]\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Monorepo Configuration\n// =============================================================================\n\n/** Monorepo project detection configuration */\nconst monorepoSchema = z\n .object({\n exclude: z.array(globPatternSchema).optional(), // Glob patterns to exclude from project detection\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Full Configuration\n// =============================================================================\n\n/** Full standards.toml schema */\nexport const configSchema = z\n .object({\n metadata: metadataSchema,\n extends: extendsSchema,\n code: codeSchema,\n process: processSchema,\n infra: infraSchema,\n mcp: mcpSchema,\n monorepo: monorepoSchema,\n })\n .strict();\n\n/** Inferred TypeScript type from schema */\nexport type Config = z.infer<typeof configSchema>;\n\n/** Default configuration */\nexport const defaultConfig: Config = {\n code: {\n linting: {\n eslint: { enabled: false },\n ruff: { enabled: false },\n },\n types: {\n tsc: { enabled: false },\n ty: { enabled: false },\n },\n unused: {\n knip: { enabled: false },\n vulture: { enabled: false },\n },\n coverage_run: {\n enabled: false,\n min_threshold: 80,\n runner: \"auto\",\n },\n security: {\n secrets: { enabled: false, scan_mode: \"branch\", base_branch: \"main\" },\n pnpmaudit: { enabled: false, exclude_dev: true },\n pipaudit: { enabled: false },\n },\n naming: {\n enabled: false,\n },\n quality: {\n \"disable-comments\": { enabled: false },\n },\n },\n monorepo: {},\n process: {\n hooks: {\n enabled: false,\n require_husky: true,\n },\n ci: {\n enabled: false,\n },\n branches: {\n enabled: false,\n require_issue: false,\n },\n commits: {\n enabled: false,\n require_scope: false,\n },\n changesets: {\n enabled: false,\n validate_format: true,\n require_description: true,\n },\n pr: {\n enabled: false,\n require_issue: false,\n },\n tickets: {\n enabled: false,\n require_in_commits: true,\n require_in_branch: false,\n },\n coverage: {\n enabled: false,\n enforce_in: \"config\",\n },\n repo: {\n enabled: false,\n require_branch_protection: false,\n require_codeowners: false,\n },\n backups: {\n enabled: false,\n max_age_hours: 24,\n },\n codeowners: {\n enabled: false,\n },\n docs: {\n enabled: false,\n path: \"docs/\",\n enforcement: \"warn\",\n staleness_days: 30,\n },\n forbidden_files: {\n enabled: false,\n },\n },\n infra: {\n enabled: false,\n manifest: \"infra-manifest.json\",\n },\n mcp: {\n standards: {\n source: undefined,\n },\n },\n};\n"],"mappings":";;;;;;AACA,YAAYA,SAAQ;AACpB,YAAY,QAAQ;AACpB,YAAYC,WAAU;AAEtB,YAAY,UAAU;AACtB,SAAS,aAAa;;;ACNtB,YAAY,QAAQ;AACpB,YAAY,UAAU;AAEtB,OAAO,UAAU;;;ACFjB,SAAS,iBAAiB;AAC1B,SAAS,SAAS;AAKlB,SAAS,wBAAwB,SAAuD;AACtF,MAAI,WAAW;AACf,MAAI,SAAS;AACb,WAAS,IAAI,GAAG,IAAI,QAAQ,QAAQ,KAAK;AACvC,QAAI,QAAQ,CAAC,MAAM,QAAQ,IAAI,IAAI,QAAQ,QAAQ;AACjD;AACA;AAAA,IACF;AACA,YAAQ,QAAQ,CAAC,GAAG;AAAA,MAClB,KAAK;AACH;AACA;AAAA,MACF,KAAK;AACH,YAAI,WAAW,GAAG;AAChB;AAAA,QACF;AACA;AAAA,MACF,KAAK;AACH;AACA;AAAA,MACF,KAAK;AACH,YAAI,SAAS,GAAG;AACd;AAAA,QACF;AACA;AAAA,IACJ;AAAA,EACF;AACA,SAAO,EAAE,UAAU,OAAO;AAC5B;AAMA,SAAS,mBAAmB,SAAqD;AAC/E,MAAI,QAAQ,WAAW,GAAG;AACxB,WAAO,EAAE,OAAO,OAAO,OAAO,gBAAgB;AAAA,EAChD;AAEA,QAAM,WAAW,wBAAwB,OAAO;AAChD,MAAI,SAAS,WAAW,GAAG;AACzB,WAAO,EAAE,OAAO,OAAO,OAAO,uBAAuB;AAAA,EACvD;AACA,MAAI,SAAS,SAAS,GAAG;AACvB,WAAO,EAAE,OAAO,OAAO,OAAO,qBAAqB;AAAA,EACrD;AAEA,MAAI;AACF,UAAM,SAAS,UAAU,OAAO,OAAO;AACvC,WAAO,WAAW,QAAQ,EAAE,OAAO,OAAO,OAAO,yBAAyB,IAAI,EAAE,OAAO,KAAK;AAAA,EAC9F,SAAS,OAAO;AACd,UAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU;AACzD,WAAO,EAAE,OAAO,OAAO,OAAO,QAAQ;AAAA,EACxC;AACF;AAKA,IAAM,oBAAoB,EAAE,OAAO,EAAE;AAAA,EACnC,CAAC,YAAY,mBAAmB,OAAO,EAAE;AAAA,EACzC,CAAC,aAAa;AAAA,IACZ,SAAS,0BAA0B,OAAO,OAAO,mBAAmB,OAAO,EAAE,KAAK;AAAA,EACpF;AACF;AAWA,IAAM,qBAAqB,EAAE,KAAK,CAAC,OAAO,QAAQ,OAAO,CAAC;AAO1D,IAAM,wBAAwB,EAC3B,OAAO;AAAA,EACN,UAAU;AACZ,CAAC,EACA,SAAS,EAAE,QAAQ,CAAC;AAOvB,IAAM,kBAAkB,EAAE,MAAM,CAAC,oBAAoB,qBAAqB,CAAC;AAG3E,IAAM,oBAAoB,EAAE,OAAO,EAAE,OAAO,GAAG,eAAe,EAAE,SAAS;AAGzE,IAAM,qBAAqB,EACxB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA,EAC5C,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACpC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACrC,gBAAgB,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,SAAS;AAAA;AAAA,EACxD,OAAO;AAAA;AAAA,EACP,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA,EACrC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AACvC,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA,EAC5C,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA,EACpD,MAAM;AAAA,EACN,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,2BAA2B,EAC9B,OAAO;AAAA,EACN,QAAQ,EAAE,QAAQ,EAAE,SAAS;AAAA,EAC7B,eAAe,EAAE,QAAQ,EAAE,SAAS;AAAA,EACpC,kBAAkB,EAAE,QAAQ,EAAE,SAAS;AAAA,EACvC,gBAAgB,EAAE,QAAQ,EAAE,SAAS;AAAA,EACrC,oBAAoB,EAAE,QAAQ,EAAE,SAAS;AAAA,EACzC,mBAAmB,EAAE,QAAQ,EAAE,SAAS;AAAA,EACxC,4BAA4B,EAAE,QAAQ,EAAE,SAAS;AAAA,EACjD,iBAAiB,EAAE,QAAQ,EAAE,SAAS;AAAA,EACtC,cAAc,EAAE,QAAQ,EAAE,SAAS;AAAA,EACnC,kCAAkC,EAAE,QAAQ,EAAE,SAAS;AACzD,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,kBAAkB,EACrB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,SAAS;AAAA;AAAA,EACT,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,uBAAuB,EAAE,KAAK,CAAC,UAAU,QAAQ,UAAU,MAAM,CAAC;AAGxE,IAAM,0BAA0B,EAC7B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE;AAAA;AAAA,EACrE,QAAQ,qBAAqB,SAAS,EAAE,QAAQ,MAAM;AAAA;AAAA,EACtD,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC7B,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,WAAW,EACR,KAAK,CAAC,UAAU,SAAS,UAAU,MAAM,CAAC,EAC1C,SAAS,EACT,QAAQ,QAAQ;AAAA;AAAA,EACnB,aAAa,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,MAAM;AAAA;AAAA,EACjD,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,wBAAwB,EAC3B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA,EAChD,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,uBAAuB,EAC1B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,cAAc,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,qBAAqB,EACxB,OAAO;AAAA,EACN,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AACZ,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,iBAAiB,EAAE,KAAK,CAAC,cAAc,cAAc,aAAa,YAAY,CAAC;AAGrF,IAAM,oBAAoB,CAAyB,WACjD,EAAE,MAAM,MAAM,EAAE,OAAO,CAAC,QAAQ,IAAI,IAAI,GAAG,EAAE,SAAS,IAAI,QAAQ;AAAA,EAChE,SAAS;AACX,CAAC;AAGH,IAAM,wBAAwB,CAAyB,WACrD,EACG,MAAM,MAAM,EACZ,IAAI,GAAG,gCAAgC,EACvC,OAAO,CAAC,QAAQ,IAAI,IAAI,GAAG,EAAE,SAAS,IAAI,QAAQ;AAAA,EACjD,SAAS;AACX,CAAC;AAGL,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,YAAY,sBAAsB,EAAE,OAAO,CAAC;AAAA;AAAA,EAC5C,WAAW;AAAA,EACX,aAAa;AAAA,EACb,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACtC,sBAAsB,EAAE,QAAQ,EAAE,SAAS;AAAA;AAC7C,CAAC,EACA,OAAO;AAGV,IAAM,qBAAqB,EACxB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,OAAO,EAAE,MAAM,gBAAgB,EAAE,SAAS;AAC5C,CAAC,EACA,OAAO,EACP,YAAY,CAAC,MAAM,QAAQ;AAC1B,MAAI,CAAC,KAAK,SAAS,KAAK,MAAM,UAAU,GAAG;AACzC;AAAA,EACF;AAEA,QAAM,uBAAuB,oBAAI,IAAoB;AACrD,WAAS,IAAI,GAAG,IAAI,KAAK,MAAM,QAAQ,KAAK;AAC1C,eAAW,OAAO,KAAK,MAAM,CAAC,EAAE,YAAY;AAC1C,YAAM,WAAW,qBAAqB,IAAI,GAAG;AAC7C,UAAI,aAAa,QAAW;AAC1B,YAAI,SAAS;AAAA,UACX,MAAM,EAAE,aAAa;AAAA,UACrB,SAAS,cAAc,GAAG,6CAA6C,WAAW,CAAC,QAAQ,IAAI,CAAC;AAAA,UAChG,MAAM,CAAC,SAAS,GAAG,YAAY;AAAA,QACjC,CAAC;AAAA,MACH,OAAO;AACL,6BAAqB,IAAI,KAAK,CAAC;AAAA,MACjC;AAAA,IACF;AAAA,EACF;AACF,CAAC,EACA,SAAS;AAOZ,IAAM,8BAA8B,EACjC,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACvC,YAAY,kBAAkB,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACnD,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AACxC,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,oBAAoB,EACvB,OAAO;AAAA,EACN,oBAAoB;AACtB,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,oBAAoB,EACvB,OAAO;AAAA,EACN,QAAQ;AAAA,EACR,MAAM;AACR,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,kBAAkB,EACrB,OAAO;AAAA,EACN,KAAK;AAAA,EACL,IAAI;AACN,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,MAAM;AAAA,EACN,SAAS;AACX,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,aAAa,EAChB,OAAO;AAAA,EACN,SAAS;AAAA,EACT,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,cAAc;AAAA,EACd,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,SAAS;AACX,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,qBAAqB,EAAE,OAAO,EAAE,OAAO,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,SAAS;AAG9E,IAAM,oBAAoB,EACvB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,eAAe,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AAAA,EAClD,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC5C,UAAU;AAAA;AAAA,EACV,oBAAoB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AACnD,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,wBAAwB,EAAE,MAAM;AAAA,EACpC,EAAE,MAAM,EAAE,OAAO,CAAC;AAAA;AAAA,EAClB,EAAE,OAAO,EAAE,OAAO,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;AAAA;AAC1C,CAAC;AAGD,IAAM,mBAAmB,EAAE,OAAO,EAAE,OAAO,GAAG,qBAAqB,EAAE,SAAS;AAG9E,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,mBAAmB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAChD,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,SAAS;AAAA;AAAA,EACzD,SAAS,EAAE,OAAO,EAAE,OAAO,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,SAAS;AAAA;AAAA,EAC5D,UAAU;AAAA;AACZ,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,uBAAuB,EAC1B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC7B,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACtC,eAAe,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AAAA,EACnD,eAAe,EAAE,OAAO,EAAE,SAAS;AAAA;AACrC,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC7B,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACpC,eAAe,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AAAA,EACnD,oBAAoB,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAC3D,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,0BAA0B,EAAE,KAAK,CAAC,SAAS,SAAS,OAAO,CAAC;AAGlE,IAAM,yBAAyB,EAC5B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,mBAAmB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAChD,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC5C,iBAAiB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AAAA,EACpD,oBAAoB,EAAE,MAAM,uBAAuB,EAAE,SAAS;AAAA;AAAA,EAC9D,qBAAqB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AAAA,EACxD,wBAAwB,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAC/D,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,WAAW,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EAChD,WAAW,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EAChD,eAAe,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AAAA,EACnD,gBAAgB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC7C,SAAS,EAAE,MAAM,iBAAiB,EAAE,SAAS;AAAA;AAC/C,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC7B,oBAAoB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AAAA,EACvD,mBAAmB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AACzD,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,0BAA0B,EAAE,KAAK,CAAC,MAAM,UAAU,MAAM,CAAC;AAG/D,IAAM,uBAAuB,EAC1B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,SAAS;AAAA;AAAA,EACzD,YAAY,wBAAwB,SAAS,EAAE,QAAQ,QAAQ;AAAA;AAAA,EAC/D,aAAa,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EACjC,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA;AAC9B,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,wBAAwB,EAAE,KAAK;AAAA,EACnC;AAAA;AAAA,EACA;AAAA;AAAA,EACA;AAAA;AAAA,EACA;AAAA;AAAA,EACA;AAAA;AACF,CAAC;AAGD,IAAM,mBAAmB,EAAE,KAAK;AAAA,EAC9B;AAAA;AAAA,EACA;AAAA;AACF,CAAC;AAGD,IAAM,oBAAoB,EACvB,OAAO;AAAA,EACN,YAAY;AAAA,EACZ,UAAU,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EAC/C,aAAa,iBAAiB,SAAS,EAAE,QAAQ,QAAQ;AAC3D,CAAC,EACA,OAAO;AAGV,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,mBAAmB;AAAA;AAAA,EACvD,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,MAAM;AAAA;AAAA,EAC5C,aAAa,EAAE,KAAK,CAAC,UAAU,YAAY,UAAU,CAAC,EAAE,SAAS,EAAE,QAAQ,QAAQ;AAAA;AAAA,EACnF,kBAAkB,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,SAAS;AAAA;AAAA,EACnD,uBAAuB,EAAE,QAAQ,EAAE,SAAS;AAAA;AAAA,EAC5C,4BAA4B,EAAE,QAAQ,EAAE,SAAS;AAAA;AAAA,EACjD,uBAAuB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACpD,6BAA6B,EAAE,QAAQ,EAAE,SAAS;AAAA;AAAA,EAClD,wBAAwB,EAAE,QAAQ,EAAE,SAAS;AAAA;AAAA,EAC7C,gBAAgB,EAAE,QAAQ,EAAE,SAAS;AAAA;AAAA,EACrC,eAAe,EAAE,MAAM,iBAAiB,EAAE,SAAS;AAAA;AACrD,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,4BAA4B,EAC/B,OAAO;AAAA,EACN,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACvC,kBAAkB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AAAA,EACrD,gBAAgB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,IAAI;AAAA;AACrD,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,2BAA2B,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AAAA,EAC/D,oBAAoB,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA;AAAA,EACxD,SAAS;AAAA;AAAA,EACT,gBAAgB;AAAA;AAClB,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,sBAAsB,EACzB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC5B,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA;AAAA,EAC5B,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE;AAAA;AAAA,EAChE,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA;AAC9B,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,uBAAuB,EAC1B,OAAO;AAAA,EACN,SAAS,EAAE,OAAO;AAAA;AAAA,EAClB,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC;AAAA;AAC5B,CAAC,EACA,OAAO;AAGV,IAAM,yBAAyB,EAC5B,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,OAAO,EAAE,MAAM,oBAAoB,EAAE,SAAS;AAAA;AAChD,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,uBAAuB,EAC1B,OAAO;AAAA,EACN,mBAAmB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAChD,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAC5C,CAAC,EACA,OAAO;AAGV,IAAM,wBAAwB,EAAE,KAAK,CAAC,SAAS,MAAM,CAAC;AAGtD,IAAM,mBAAmB,EACtB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,OAAO;AAAA;AAAA,EAC3C,aAAa,sBAAsB,SAAS,EAAE,QAAQ,MAAM;AAAA;AAAA,EAC5D,WAAW,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EACxC,WAAW,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EAChD,gBAAgB,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EACrD,cAAc,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS;AAAA;AAAA,EACnD,gBAAgB,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE;AAAA;AAAA,EACjE,gBAAgB,EAAE,OAAO,EAAE,OAAO,GAAG,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC1D,cAAc,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,SAAS;AAAA;AAAA,EACxD,gBAAgB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC7C,kBAAkB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA;AAAA,EAC/C,OAAO,EAAE,OAAO,EAAE,OAAO,GAAG,oBAAoB,EAAE,SAAS;AAAA;AAC7D,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,qBAAqB,EACxB,OAAO;AAAA,EACN,QAAQ,EACL,OAAO,EACP,SAAS,EACT;AAAA,IACC;AAAA,EACF;AACJ,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,YAAY,EACf,OAAO;AAAA,EACN,WAAW;AACb,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,cAAc,EACjB,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,qBAAqB;AAAA;AAC/D,CAAC,EACA,OAAO,EACP,SAAS;AAGZ,IAAM,iCAAiC,CAAC,sBAAsB,YAAY;AAG1E,IAAM,6BAA6B,EAChC,OAAO;AAAA,EACN,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,KAAK;AAAA,EAC7C,OAAO,EAAE,MAAM,iBAAiB,EAAE,SAAS;AAAA;AAAA,EAC3C,QAAQ,EAAE,MAAM,iBAAiB,EAAE,SAAS;AAAA;AAAA,EAC5C,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA;AAC/B,CAAC,EACA,OAAO,EACP,SAAS;AAKZ,IAAM,gBAAgB,EACnB,OAAO;AAAA,EACN,OAAO;AAAA,EACP,IAAI;AAAA,EACJ,UAAU;AAAA,EACV,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,IAAI;AAAA,EACJ,SAAS;AAAA,EACT,UAAU;AAAA,EACV,MAAM;AAAA,EACN,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,MAAM;AAAA,EACN,iBAAiB;AACnB,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,aAAa,EAAE,KAAK,CAAC,cAAc,YAAY,WAAW,CAAC;AAGjE,IAAM,eAAe,EAAE,KAAK,CAAC,UAAU,eAAe,YAAY,CAAC;AAGnE,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,MAAM;AAAA,EACN,SAAS,EAAE,OAAO,EAAE,SAAS;AAAA,EAC7B,cAAc,EAAE,OAAO,EAAE,SAAS;AAAA,EAClC,QAAQ,aAAa,SAAS,EAAE,QAAQ,QAAQ;AAClD,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,gBAAgB,EACnB,OAAO;AAAA,EACN,UAAU,EAAE,OAAO;AAAA;AAAA,EACnB,UAAU,EAAE,MAAM,EAAE,OAAO,CAAC;AAAA;AAC9B,CAAC,EACA,OAAO,EACP,SAAS;AAOZ,IAAM,iBAAiB,EACpB,OAAO;AAAA,EACN,SAAS,EAAE,MAAM,iBAAiB,EAAE,SAAS;AAAA;AAC/C,CAAC,EACA,OAAO,EACP,SAAS;AAOL,IAAM,eAAe,EACzB,OAAO;AAAA,EACN,UAAU;AAAA,EACV,SAAS;AAAA,EACT,MAAM;AAAA,EACN,SAAS;AAAA,EACT,OAAO;AAAA,EACP,KAAK;AAAA,EACL,UAAU;AACZ,CAAC,EACA,OAAO;AAMH,IAAM,gBAAwB;AAAA,EACnC,MAAM;AAAA,IACJ,SAAS;AAAA,MACP,QAAQ,EAAE,SAAS,MAAM;AAAA,MACzB,MAAM,EAAE,SAAS,MAAM;AAAA,IACzB;AAAA,IACA,OAAO;AAAA,MACL,KAAK,EAAE,SAAS,MAAM;AAAA,MACtB,IAAI,EAAE,SAAS,MAAM;AAAA,IACvB;AAAA,IACA,QAAQ;AAAA,MACN,MAAM,EAAE,SAAS,MAAM;AAAA,MACvB,SAAS,EAAE,SAAS,MAAM;AAAA,IAC5B;AAAA,IACA,cAAc;AAAA,MACZ,SAAS;AAAA,MACT,eAAe;AAAA,MACf,QAAQ;AAAA,IACV;AAAA,IACA,UAAU;AAAA,MACR,SAAS,EAAE,SAAS,OAAO,WAAW,UAAU,aAAa,OAAO;AAAA,MACpE,WAAW,EAAE,SAAS,OAAO,aAAa,KAAK;AAAA,MAC/C,UAAU,EAAE,SAAS,MAAM;AAAA,IAC7B;AAAA,IACA,QAAQ;AAAA,MACN,SAAS;AAAA,IACX;AAAA,IACA,SAAS;AAAA,MACP,oBAAoB,EAAE,SAAS,MAAM;AAAA,IACvC;AAAA,EACF;AAAA,EACA,UAAU,CAAC;AAAA,EACX,SAAS;AAAA,IACP,OAAO;AAAA,MACL,SAAS;AAAA,MACT,eAAe;AAAA,IACjB;AAAA,IACA,IAAI;AAAA,MACF,SAAS;AAAA,IACX;AAAA,IACA,UAAU;AAAA,MACR,SAAS;AAAA,MACT,eAAe;AAAA,IACjB;AAAA,IACA,SAAS;AAAA,MACP,SAAS;AAAA,MACT,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,SAAS;AAAA,MACT,iBAAiB;AAAA,MACjB,qBAAqB;AAAA,IACvB;AAAA,IACA,IAAI;AAAA,MACF,SAAS;AAAA,MACT,eAAe;AAAA,IACjB;AAAA,IACA,SAAS;AAAA,MACP,SAAS;AAAA,MACT,oBAAoB;AAAA,MACpB,mBAAmB;AAAA,IACrB;AAAA,IACA,UAAU;AAAA,MACR,SAAS;AAAA,MACT,YAAY;AAAA,IACd;AAAA,IACA,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,2BAA2B;AAAA,MAC3B,oBAAoB;AAAA,IACtB;AAAA,IACA,SAAS;AAAA,MACP,SAAS;AAAA,MACT,eAAe;AAAA,IACjB;AAAA,IACA,YAAY;AAAA,MACV,SAAS;AAAA,IACX;AAAA,IACA,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,MAAM;AAAA,MACN,aAAa;AAAA,MACb,gBAAgB;AAAA,IAClB;AAAA,IACA,iBAAiB;AAAA,MACf,SAAS;AAAA,IACX;AAAA,EACF;AAAA,EACA,OAAO;AAAA,IACL,SAAS;AAAA,IACT,UAAU;AAAA,EACZ;AAAA,EACA,KAAK;AAAA,IACH,WAAW;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,EACF;AACF;;;ADt3BO,IAAM,mBAAmB;AAOzB,IAAM,cAAN,cAA0B,MAAM;AAAA,EACrC,YAAY,SAAiB;AAC3B,UAAM,OAAO;AACb,SAAK,OAAO;AAAA,EACd;AACF;AAKA,SAAS,gBAAgB,UAA2B;AAClD,MAAI;AACF,UAAM,QAAW,aAAU,QAAQ;AACnC,QAAI,MAAM,eAAe,GAAG;AAE1B,UAAI;AACF,QAAG,YAAS,QAAQ;AACpB,eAAO;AAAA,MACT,QAAQ;AACN,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,EACT,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAKO,SAAS,eAAe,WAAmB,QAAQ,IAAI,GAAkB;AAC9E,MAAI,aAAkB,aAAQ,QAAQ;AACtC,QAAM,OAAY,WAAM,UAAU,EAAE;AAEpC,SAAO,eAAe,MAAM;AAC1B,UAAM,aAAkB,UAAK,YAAY,gBAAgB;AACzD,QAAI,gBAAgB,UAAU,GAAG;AAC/B,YAAM,IAAI,YAAY,GAAG,gBAAgB,oCAAoC,UAAU,EAAE;AAAA,IAC3F;AACA,QAAO,cAAW,UAAU,GAAG;AAC7B,aAAO;AAAA,IACT;AACA,iBAAkB,aAAQ,UAAU;AAAA,EACtC;AAGA,QAAM,aAAkB,UAAK,MAAM,gBAAgB;AACnD,MAAI,gBAAgB,UAAU,GAAG;AAC/B,UAAM,IAAI,YAAY,GAAG,gBAAgB,oCAAoC,UAAU,EAAE;AAAA,EAC3F;AACA,SAAU,cAAW,UAAU,IAAI,aAAa;AAClD;AAMA,SAAS,kBAAkB,YAA6B;AACtD,QAAM,WAAW,cAAc,eAAe;AAC9C,MAAI,CAAC,UAAU;AACb,UAAM,IAAI,YAAY,MAAM,gBAAgB,8CAA8C;AAAA,EAC5F;AAEA,QAAM,eAAoB,aAAQ,QAAQ;AAC1C,MAAI,CAAI,cAAW,YAAY,GAAG;AAChC,UAAM,IAAI,YAAY,0BAA0B,QAAQ,EAAE;AAAA,EAC5D;AACA,SAAO;AACT;AAKA,SAAS,cAAc,UAA2B;AAChD,MAAI;AACF,UAAM,UAAa,gBAAa,UAAU,OAAO;AACjD,WAAO,KAAK,MAAM,OAAO;AAAA,EAC3B,SAAS,OAAO;AACd,UAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU;AACzD,UAAM,IAAI,YAAY,mBAAmB,gBAAgB,KAAK,OAAO,EAAE;AAAA,EACzE;AACF;AAKA,SAAS,eAAe,WAA4B;AAClD,QAAM,SAAS,aAAa,UAAU,SAAS;AAC/C,MAAI,CAAC,OAAO,SAAS;AACnB,UAAM,SAAS,OAAO,MAAM,OACzB,IAAI,CAAC,MAAM,OAAO,EAAE,KAAK,KAAK,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,EAClD,KAAK,IAAI;AACZ,UAAM,IAAI,YAAY,WAAW,gBAAgB;AAAA,EAAoB,MAAM,EAAE;AAAA,EAC/E;AACA,SAAO,OAAO;AAChB;AAMO,SAAS,WAAW,YAAuC;AAChE,QAAM,eAAe,kBAAkB,UAAU;AACjD,QAAM,YAAY,cAAc,YAAY;AAC5C,QAAM,kBAAkB,eAAe,SAAS;AAChD,QAAM,SAAS,kBAAkB,eAAe;AAChD,SAAO,EAAE,QAAQ,YAAY,aAAa;AAC5C;AAKA,eAAsB,gBAAgB,YAAgD;AACpF,QAAM,eAAe,kBAAkB,UAAU;AACjD,QAAM,YAAY,cAAc,YAAY;AAC5C,QAAM,kBAAkB,eAAe,SAAS;AAGhD,QAAM,YAAiB,aAAQ,YAAY;AAC3C,QAAM,iBAAiB,MAAM,eAAe,iBAAiB,SAAS;AAEtE,QAAM,SAAS,kBAAkB,cAAc;AAC/C,SAAO,EAAE,QAAQ,YAAY,aAAa;AAC5C;AAGA,SAAS,MAAwB,GAAkB,GAAqB;AACtE,SAAO,EAAE,GAAG,GAAG,GAAG,EAAE;AACtB;AAIA,SAAS,aAAa,GAAW,IAAmC;AAClE,QAAM,KAAK,EAAE,MAAM;AACnB,QAAM,KAAK,GAAG,MAAM;AACpB,SAAO,EAAE,QAAQ,MAAM,IAAI,QAAQ,IAAI,MAAM,GAAG,MAAM,MAAM,IAAI,MAAM,IAAI,IAAI,EAAE;AAClF;AAEA,SAAS,cAAc,GAAW,IAAoC;AACpE,QAAM,KAAK,EAAE,MAAM;AACnB,QAAM,KAAK,GAAG,MAAM;AACpB,SAAO;AAAA,IACL,SAAS,MAAM,IAAI,SAAS,IAAI,OAAO;AAAA,IACvC,WAAW,MAAM,IAAI,WAAW,IAAI,SAAS;AAAA,IAC7C,UAAU,MAAM,IAAI,UAAU,IAAI,QAAQ;AAAA,EAC5C;AACF;AAEA,SAAS,WAAW,GAAW,IAAiC;AAC9D,SAAO;AAAA,IACL,KAAK,MAAM,GAAG,MAAM,OAAO,KAAK,EAAE,MAAM,OAAO,GAAG;AAAA,IAClD,IAAI,MAAM,GAAG,MAAM,OAAO,IAAI,EAAE,MAAM,OAAO,EAAE;AAAA,EACjD;AACF;AAEA,SAAS,YAAY,GAAW,IAAkC;AAChE,SAAO;AAAA,IACL,MAAM,MAAM,GAAG,MAAM,QAAQ,MAAM,EAAE,MAAM,QAAQ,IAAI;AAAA,IACvD,SAAS,MAAM,GAAG,MAAM,QAAQ,SAAS,EAAE,MAAM,QAAQ,OAAO;AAAA,EAClE;AACF;AAEA,SAAS,iBAAiB,GAAW,IAAwC;AAC3E,SAAO,MAAM,GAAG,MAAM,cAAc,EAAE,MAAM,YAAY;AAC1D;AAEA,SAAS,YAAY,GAAW,IAAkC;AAChE,QAAM,KAAK,EAAE,MAAM;AACnB,QAAM,KAAK,GAAG,MAAM;AAEpB,SAAO;AAAA,IACL,SAAS,IAAI,WAAW,IAAI,WAAW;AAAA,IACvC,OAAO,IAAI,SAAS,IAAI;AAAA,EAC1B;AACF;AAEA,SAAS,aAAa,GAAW,IAAmC;AAClE,QAAM,KAAK,EAAE,MAAM;AACnB,QAAM,KAAK,GAAG,MAAM;AACpB,SAAO;AAAA,IACL,oBAAoB,MAAM,KAAK,kBAAkB,GAAG,KAAK,kBAAkB,CAAC;AAAA,EAC9E;AACF;AAEA,SAAS,UAAU,GAAW,IAAwB;AACpD,SAAO;AAAA,IACL,SAAS,aAAa,GAAG,EAAE;AAAA,IAC3B,OAAO,WAAW,GAAG,EAAE;AAAA,IACvB,QAAQ,YAAY,GAAG,EAAE;AAAA,IACzB,cAAc,iBAAiB,GAAG,EAAE;AAAA,IACpC,UAAU,cAAc,GAAG,EAAE;AAAA,IAC7B,QAAQ,YAAY,GAAG,EAAE;AAAA,IACzB,SAAS,aAAa,GAAG,EAAE;AAAA,EAC7B;AACF;AAiBA,IAAM,eAA4B,EAAE,SAAS,OAAO,eAAe,KAAK;AACxE,IAAM,YAAsB,EAAE,SAAS,MAAM;AAC7C,IAAM,kBAAkC,EAAE,SAAS,OAAO,eAAe,MAAM;AAC/E,IAAM,iBAAgC,EAAE,SAAS,OAAO,eAAe,MAAM;AAC7E,IAAM,oBAAsC;AAAA,EAC1C,SAAS;AAAA,EACT,iBAAiB;AAAA,EACjB,qBAAqB;AACvB;AACA,IAAM,YAAsB,EAAE,SAAS,OAAO,eAAe,MAAM;AACnE,IAAM,iBAAgC;AAAA,EACpC,SAAS;AAAA,EACT,oBAAoB;AAAA,EACpB,mBAAmB;AACrB;AACA,IAAM,kBAAkC,EAAE,SAAS,OAAO,YAAY,SAAS;AAC/E,IAAM,cAA0B;AAAA,EAC9B,SAAS;AAAA,EACT,2BAA2B;AAAA,EAC3B,oBAAoB;AACtB;AACA,IAAM,iBAAgC,EAAE,SAAS,OAAO,eAAe,GAAG;AAC1E,IAAM,oBAAsC,EAAE,SAAS,MAAM;AAC7D,IAAM,cAA0B;AAAA,EAC9B,SAAS;AAAA,EACT,MAAM;AAAA,EACN,aAAa;AAAA,EACb,gBAAgB;AAClB;AACA,IAAM,wBAA8C,EAAE,SAAS,MAAM;AAGrE,SAAS,oBAAuB,YAAe,OAAsB,MAAwB;AAC3F,SAAO,EAAE,GAAG,YAAY,GAAG,OAAO,GAAG,KAAK;AAC5C;AAEA,SAAS,kBACP,IACA,KACa;AACb,SAAO,oBAAoB,cAAc,KAAK,OAAO,IAAI,KAAK;AAChE;AAEA,SAAS,eAAe,IAA+B,KAA0C;AAC/F,SAAO,oBAAoB,WAAW,KAAK,IAAI,IAAI,EAAE;AACvD;AAEA,SAAS,qBACP,IACA,KACgB;AAChB,SAAO,oBAAoB,iBAAiB,KAAK,UAAU,IAAI,QAAQ;AACzE;AAEA,SAAS,oBACP,IACA,KACe;AACf,SAAO,oBAAoB,gBAAgB,KAAK,SAAS,IAAI,OAAO;AACtE;AAEA,SAAS,uBACP,IACA,KACkB;AAClB,SAAO,oBAAoB,mBAAmB,KAAK,YAAY,IAAI,UAAU;AAC/E;AAEA,SAAS,eAAe,IAA+B,KAA0C;AAC/F,SAAO,oBAAoB,WAAW,KAAK,IAAI,IAAI,EAAE;AACvD;AAEA,SAAS,oBACP,IACA,KACe;AACf,SAAO,oBAAoB,gBAAgB,KAAK,SAAS,IAAI,OAAO;AACtE;AAEA,SAAS,qBACP,IACA,KACgB;AAChB,SAAO,oBAAoB,iBAAiB,KAAK,UAAU,IAAI,QAAQ;AACzE;AAEA,SAAS,iBACP,IACA,KACY;AACZ,SAAO,oBAAoB,aAAa,KAAK,MAAM,IAAI,IAAI;AAC7D;AAEA,SAAS,oBACP,IACA,KACe;AACf,SAAO,oBAAoB,gBAAgB,KAAK,SAAS,IAAI,OAAO;AACtE;AAEA,SAAS,uBACP,IACA,KACkB;AAClB,QAAM,MAAM,IAAI;AAChB,QAAM,MAAM,KAAK;AAEjB,QAAM,gBAAgB,KAAK,SAAS,CAAC;AACrC,QAAM,eAAe,KAAK,SAAS,CAAC;AAEpC,QAAM,UAAU,oBAAI,IAAmD;AACvE,aAAW,QAAQ,eAAe;AAChC,YAAQ,IAAI,KAAK,SAAS,IAAI;AAAA,EAChC;AACA,aAAW,QAAQ,cAAc;AAC/B,YAAQ,IAAI,KAAK,SAAS,IAAI;AAAA,EAChC;AACA,QAAM,cAAc,MAAM,KAAK,QAAQ,OAAO,CAAC;AAC/C,SAAO;AAAA,IACL,GAAG;AAAA,IACH,GAAG;AAAA,IACH,GAAG;AAAA,IACH,OAAO,YAAY,SAAS,IAAI,cAAc;AAAA,EAChD;AACF;AAEA,SAAS,iBACP,IACA,KACY;AACZ,SAAO,oBAAoB,aAAa,KAAK,MAAM,IAAI,IAAI;AAC7D;AAEA,SAAS,2BACP,IACA,KACsB;AACtB,SAAO,oBAAoB,uBAAuB,KAAK,iBAAiB,IAAI,eAAe;AAC7F;AAEA,SAAS,aAAa,GAAW,IAA2B;AAC1D,SAAO;AAAA,IACL,OAAO,kBAAkB,EAAE,SAAS,GAAG,OAAO;AAAA,IAC9C,IAAI,eAAe,EAAE,SAAS,GAAG,OAAO;AAAA,IACxC,UAAU,qBAAqB,EAAE,SAAS,GAAG,OAAO;AAAA,IACpD,SAAS,oBAAoB,EAAE,SAAS,GAAG,OAAO;AAAA,IAClD,YAAY,uBAAuB,EAAE,SAAS,GAAG,OAAO;AAAA,IACxD,IAAI,eAAe,EAAE,SAAS,GAAG,OAAO;AAAA,IACxC,SAAS,oBAAoB,EAAE,SAAS,GAAG,OAAO;AAAA,IAClD,UAAU,qBAAqB,EAAE,SAAS,GAAG,OAAO;AAAA,IACpD,MAAM,iBAAiB,EAAE,SAAS,GAAG,OAAO;AAAA,IAC5C,SAAS,oBAAoB,EAAE,SAAS,GAAG,OAAO;AAAA,IAClD,YAAY,uBAAuB,EAAE,SAAS,GAAG,OAAO;AAAA,IACxD,MAAM,iBAAiB,EAAE,SAAS,GAAG,OAAO;AAAA,IAC5C,iBAAiB,2BAA2B,EAAE,SAAS,GAAG,OAAO;AAAA,EACnE;AACF;AAKA,SAAS,kBAAkB,QAAwB;AACjD,SAAO;AAAA,IACL,MAAM,UAAU,QAAQ,aAAa;AAAA,IACrC,SAAS,aAAa,QAAQ,aAAa;AAAA,IAC3C,OAAO;AAAA,MACL,SAAS,OAAO,OAAO,WAAW,cAAc,OAAO,WAAW;AAAA,MAClE,UAAU,OAAO,OAAO,YAAY,cAAc,OAAO,YAAY;AAAA,IACvE;AAAA,IACA,UAAU,OAAO;AAAA,EACnB;AACF;AAKO,SAAS,eAAe,YAA4B;AACzD,SAAY,aAAQ,UAAU;AAChC;AAWA,SAAS,kBACP,aACA,gBACuB;AACvB,MAAI,CAAC,gBAAgB;AACnB,WAAO;AAAA,EACT;AACA,QAAM,cAAc,eAAe,KAAK,GAAG;AAC3C,QAAM,aAAa,YAAY,OAAO,KAAK,GAAG;AAC9C,MAAI,gBAAgB,YAAY;AAC9B,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,SAAS;AAAA,IACT,KAAK,YAAY;AAAA,IACjB,eAAe;AAAA,IACf,cAAc;AAAA,EAChB;AACF;AAGA,SAAS,0BACP,gBACA,eACkB;AAClB,QAAM,gBAAgB,gBAAgB,SAAS,YAAY,SAAS,CAAC;AACrE,QAAM,eAAe,eAAe,SAAS,YAAY,SAAS,CAAC;AACnE,QAAM,cAAc,IAAI,IAAI,cAAc,IAAI,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;AAE3E,SAAO,aACJ,IAAI,CAAC,SAAS,kBAAkB,MAAM,YAAY,IAAI,KAAK,OAAO,CAAC,CAAC,EACpE,OAAO,CAAC,MAA2B,MAAM,IAAI;AAClD;AAGA,eAAe,mBACb,eACA,WACiB;AACjB,QAAM,iBAAiB,MAAM,OAAO,wBAAe;AACnD,QAAM,MAAM,eAAe,iBAAiB,cAAc,UAAU,SAAS;AAC7E,QAAM,cAAc,MAAM,eAAe,cAAc,GAAG;AAE1D,MAAI,SAAiB,CAAC;AACtB,aAAW,QAAQ,cAAc,UAAU;AACzC,aAAS,eAAe,aAAa,QAAQ,eAAe,YAAY,aAAa,IAAI,CAAC;AAAA,EAC5F;AACA,SAAO;AACT;AAMA,eAAsB,wBACpB,YAC6D;AAC7D,QAAM,eAAe,kBAAkB,UAAU;AACjD,QAAM,kBAAkB,eAAe,cAAc,YAAY,CAAC;AAElE,MAAI,YAA8B,CAAC;AACnC,MAAI,gBAAgB,SAAS;AAC3B,UAAM,iBAAiB,MAAM;AAAA,MAC3B,gBAAgB;AAAA,MACX,aAAQ,YAAY;AAAA,IAC3B;AACA,gBAAY,0BAA0B,gBAAgB,eAAe;AAAA,EACvE;AAEA,QAAM,EAAE,QAAQ,YAAY,UAAU,IAAI,MAAM,gBAAgB,UAAU;AAC1E,SAAO,EAAE,QAAQ,YAAY,WAAW,UAAU;AACpD;;;AD5cA,SAAS,mBAA+B;AACtC,MAAI,QAAQ,IAAI,0BAA0B,QAAQ,IAAI,cAAc;AAClE,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,IAAI,eAAe;AAC7B,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAKA,SAAS,eAAmC;AAC1C,SAAO,QAAQ,IAAI,0BAA0B,QAAQ,IAAI;AAC3D;AAKA,SAAS,eAAe,OAAe,MAAc,MAA0B;AAC7E,UAAQ,MAAM;AAAA,IACZ,KAAK;AACH,aAAO,kBAAkB,KAAK,IAAI,IAAI;AAAA,IACxC,KAAK,SAAS;AACZ,YAAM,QAAQ,aAAa;AAC3B,UAAI,OAAO;AACT,eAAO,0BAA0B,KAAK,eAAe,KAAK,IAAI,IAAI;AAAA,MACpE;AAEA,aAAO,sBAAsB,KAAK,IAAI,IAAI;AAAA,IAC5C;AAAA,IACA,KAAK;AAAA,IACL;AACE,aAAO,sBAAsB,KAAK,IAAI,IAAI;AAAA,EAC9C;AACF;AAMA,SAAS,iBAAiB,KAA0D;AAClF,MAAI,IAAI,WAAW,aAAa,GAAG;AACjC,WAAO,EAAE,MAAM,OAAO,MAAM,IAAI,MAAM,EAAE,EAAE;AAAA,EAC5C;AACA,MAAI,IAAI,WAAW,eAAe,GAAG;AACnC,WAAO,EAAE,MAAM,SAAS,MAAM,IAAI,MAAM,EAAE,EAAE;AAAA,EAC9C;AACA,MAAI,IAAI,WAAW,SAAS,GAAG;AAC7B,WAAO,EAAE,MAAM,QAAQ,MAAM,IAAI,MAAM,CAAC,EAAE;AAAA,EAC5C;AACA,QAAM,IAAI,YAAY,gCAAgC,GAAG,EAAE;AAC7D;AAEA,SAAS,eAAe,KAA+B;AACrD,QAAM,EAAE,MAAM,cAAc,KAAK,IAAI,iBAAiB,GAAG;AACzD,QAAM,CAAC,UAAU,GAAG,IAAI,KAAK,MAAM,GAAG;AACtC,QAAM,CAAC,OAAO,IAAI,IAAI,SAAS,MAAM,GAAG;AAExC,MAAI,CAAC,SAAS,CAAC,MAAM;AACnB,UAAM,IAAI;AAAA,MACR,gCAAgC,GAAG;AAAA,IACrC;AAAA,EACF;AAEA,QAAM,OAAO,iBAAiB,SAAS,iBAAiB,IAAI;AAE5D,SAAO;AAAA,IACL,MAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA,KAAK,OAAO;AAAA,IACZ,MAAM,eAAe,OAAO,MAAM,IAAI;AAAA,IACtC;AAAA,EACF;AACF;AAEO,SAAS,iBAAiB,KAAa,WAAsC;AAClF,MAAI,IAAI,WAAW,SAAS,KAAK,IAAI,WAAW,SAAS,GAAG;AAC1D,WAAO,eAAe,GAAG;AAAA,EAC3B;AAEA,QAAM,YAAY,CAAM,iBAAW,GAAG,KAAK,YAAiB,cAAQ,WAAW,GAAG,IAAI;AACtF,SAAO,EAAE,MAAM,SAAS,MAAM,UAAU;AAC1C;AAEA,eAAe,mBAAmB,SAAiB,KAAgC;AACjF,MAAI;AACF,QAAI,KAAK;AACP,YAAM,MAAM,OAAO,CAAC,SAAS,OAAO,GAAG,EAAE,KAAK,QAAQ,CAAC;AACvD,YAAM,MAAM,OAAO,CAAC,YAAY,GAAG,GAAG,EAAE,KAAK,QAAQ,CAAC;AAAA,IACxD,OAAO;AACL,YAAM,MAAM,OAAO,CAAC,QAAQ,WAAW,GAAG,EAAE,KAAK,QAAQ,CAAC;AAAA,IAC5D;AACA,WAAO;AAAA,EACT,QAAQ;AACN,IAAG,WAAO,SAAS,EAAE,WAAW,MAAM,OAAO,KAAK,CAAC;AACnD,WAAO;AAAA,EACT;AACF;AAEA,eAAe,UAAU,UAA4B,SAAgC;AACnF,QAAM,WAAgB,cAAQ,OAAO;AACrC,EAAG,cAAU,UAAU,EAAE,WAAW,KAAK,CAAC;AAE1C,QAAM,YAAY,CAAC,SAAS,WAAW,GAAG;AAC1C,MAAI,SAAS,KAAK;AAChB,cAAU,KAAK,YAAY,SAAS,GAAG;AAAA,EACzC;AACA,YAAU,KAAK,SAAS,MAAM,OAAO;AAErC,MAAI;AACF,UAAM,MAAM,OAAO,WAAW,EAAE,SAAS,SAAS,IAAI,CAAC;AAAA,EACzD,SAAS,OAAO;AACd,UAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AACrE,QAAI,QAAQ,SAAS,WAAW,GAAG;AACjC,YAAM,IAAI,YAAY,kCAAkC,SAAS,MAAM,GAAI,aAAa,SAAS,IAAI,EAAE;AAAA,IACzG;AACA,UAAM,IAAI,YAAY,6BAA6B,OAAO,EAAE;AAAA,EAC9D;AACF;AAEA,eAAsB,cAAc,UAA6C;AAC/E,MAAI,SAAS,SAAS,SAAS;AAC7B,QAAI,CAAI,eAAW,SAAS,IAAI,GAAG;AACjC,YAAM,IAAI,YAAY,uBAAuB,SAAS,IAAI,EAAE;AAAA,IAC9D;AACA,WAAO,SAAS;AAAA,EAClB;AAEA,QAAM,WAAgB,WAAQ,UAAO,GAAG,MAAM,gBAAgB;AAC9D,QAAM,UAAe,WAAK,UAAU,GAAG,SAAS,KAAK,IAAI,SAAS,IAAI,EAAE;AAExE,MAAO,eAAW,OAAO,GAAG;AAC1B,UAAM,mBAAmB,SAAS,SAAS,GAAG;AAAA,EAChD;AAEA,MAAI,CAAI,eAAW,OAAO,GAAG;AAC3B,UAAM,UAAU,UAAU,OAAO;AAAA,EACnC;AAEA,SAAO;AACT;AAEO,SAAS,YAAY,aAAqB,aAA6B;AAC5E,QAAM,cAAmB,WAAK,aAAa,YAAY,GAAG,WAAW,OAAO;AAE5E,MAAI,CAAI,eAAW,WAAW,GAAG;AAC/B,UAAM,IAAI,YAAY,sBAAsB,WAAW,iBAAiB,WAAW,GAAG;AAAA,EACxF;AAEA,QAAM,UAAa,iBAAa,aAAa,OAAO;AAEpD,MAAI;AACJ,MAAI;AACF,aAAc,WAAM,OAAO;AAAA,EAC7B,SAAS,OAAO;AACd,UAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AACrE,UAAM,IAAI,YAAY,2BAA2B,WAAW,KAAK,OAAO,EAAE;AAAA,EAC5E;AAEA,QAAM,SAAS,aAAa,UAAU,MAAM;AAC5C,MAAI,CAAC,OAAO,SAAS;AACnB,UAAM,SAAS,OAAO,MAAM,OAAO,IAAI,CAAC,MAAM,GAAG,EAAE,KAAK,KAAK,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,KAAK,IAAI;AAC5F,UAAM,IAAI,YAAY,mBAAmB,WAAW,KAAK,MAAM,EAAE;AAAA,EACnE;AAEA,SAAO,OAAO;AAChB;AAIA,SAAS,gBAAkC,MAAU,UAA6B;AAChF,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO,EAAE,GAAG,MAAM,GAAG,SAAS;AAChC;AAEA,SAASC,cACP,MACA,UACuB;AACvB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,QAAQ,gBAAgB,MAAM,QAAQ,SAAS,MAAM;AAAA,IACrD,MAAM,gBAAgB,MAAM,MAAM,SAAS,IAAI;AAAA,EACjD;AACF;AAEA,SAASC,YAAW,MAA2B,UAAoD;AACjG,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,KAAK,gBAAgB,MAAM,KAAK,SAAS,GAAG;AAAA,IAC5C,IAAI,gBAAgB,MAAM,IAAI,SAAS,EAAE;AAAA,EAC3C;AACF;AAEA,SAASC,aACP,MACA,UACsB;AACtB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,MAAM,gBAAgB,MAAM,MAAM,SAAS,IAAI;AAAA,IAC/C,SAAS,gBAAgB,MAAM,SAAS,SAAS,OAAO;AAAA,EAC1D;AACF;AAEA,SAASC,eACP,MACA,UACwB;AACxB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,SAAS,gBAAgB,MAAM,SAAS,SAAS,OAAO;AAAA,IACxD,WAAW,gBAAgB,MAAM,WAAW,SAAS,SAAS;AAAA,IAC9D,UAAU,gBAAgB,MAAM,UAAU,SAAS,QAAQ;AAAA,EAC7D;AACF;AAEA,SAASC,aACP,MACA,UACsB;AACtB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,OAAO,SAAS,SAAS,MAAM;AAAA,EACjC;AACF;AAEA,SAASC,cACP,MACA,UACuB;AACvB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,GAAG;AAAA,IACH,oBAAoB,gBAAgB,OAAO,kBAAkB,GAAG,SAAS,kBAAkB,CAAC;AAAA,EAC9F;AACF;AAEA,SAAS,iBAAiB,MAA8B,UAAkC;AACxF,SAAO;AAAA,IACL,SAASL,cAAa,MAAM,SAAS,SAAS,OAAO;AAAA,IACrD,OAAOC,YAAW,MAAM,OAAO,SAAS,KAAK;AAAA,IAC7C,QAAQC,aAAY,MAAM,QAAQ,SAAS,MAAM;AAAA,IACjD,cAAc,gBAAgB,MAAM,cAAc,SAAS,YAAY;AAAA,IACvE,UAAUC,eAAc,MAAM,UAAU,SAAS,QAAQ;AAAA,IACzD,QAAQC,aAAY,MAAM,QAAQ,SAAS,MAAM;AAAA,IACjD,SAASC,cAAa,MAAM,SAAS,SAAS,OAAO;AAAA,EACvD;AACF;AAIA,SAAS,iBACP,MACA,UACwB;AACxB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,eAAe,SAAS;AAAA,IACxB,eAAe,SAAS,iBAAiB,MAAM;AAAA,IAC/C,UAAU,SAAS,YAAY,MAAM;AAAA,EACvC;AACF;AAEA,SAAS,cACP,MACA,UACqB;AACrB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,mBAAmB,SAAS,qBAAqB,MAAM;AAAA,IACvD,MAAM,SAAS,QAAQ,MAAM;AAAA,IAC7B,SAAS,SAAS,WAAW,MAAM;AAAA,EACrC;AACF;AAEA,SAAS,oBACP,MACA,UAC2B;AAC3B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,eAAe,SAAS;AAAA,IACxB,SAAS,SAAS,WAAW,MAAM;AAAA,IACnC,SAAS,SAAS,WAAW,MAAM;AAAA,IACnC,eAAe,SAAS,iBAAiB,MAAM;AAAA,EACjD;AACF;AAEA,SAAS,cACP,MACA,UACqB;AACrB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,eAAe,SAAS;AAAA,IACxB,WAAW,SAAS,aAAa,MAAM;AAAA,IACvC,WAAW,SAAS,aAAa,MAAM;AAAA,IACvC,gBAAgB,SAAS,kBAAkB,MAAM;AAAA,EACnD;AACF;AAEA,SAAS,mBACP,MACA,UAC0B;AAC1B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,SAAS,SAAS,WAAW,MAAM;AAAA,IACnC,oBAAoB,SAAS;AAAA,IAC7B,mBAAmB,SAAS;AAAA,EAC9B;AACF;AAEA,SAAS,oBACP,MACA,UAC2B;AAC3B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,eAAe,SAAS,iBAAiB,MAAM;AAAA,IAC/C,YAAY,SAAS;AAAA,IACrB,aAAa,SAAS,eAAe,MAAM;AAAA,IAC3C,QAAQ,SAAS,UAAU,MAAM;AAAA,EACnC;AACF;AAEA,SAAS,mBACP,MACA,UAC0B;AAC1B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,SAAS,SAAS,WAAW,MAAM;AAAA,IACnC,OAAO,SAAS,SAAS,MAAM;AAAA,IAC/B,eAAe,SAAS;AAAA,IACxB,oBAAoB,SAAS,sBAAsB,MAAM;AAAA,EAC3D;AACF;AAEA,SAAS,sBACP,MACA,UAC6B;AAC7B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,mBAAmB,SAAS,qBAAqB,MAAM;AAAA,IACvD,eAAe,SAAS,iBAAiB,MAAM;AAAA,IAC/C,iBAAiB,SAAS;AAAA,IAC1B,oBAAoB,SAAS,sBAAsB,MAAM;AAAA,IACzD,qBAAqB,SAAS;AAAA,IAC9B,wBAAwB,SAAS,0BAA0B,MAAM;AAAA,EACnE;AACF;AAEA,SAAS,gBACP,MACA,UACuB;AACvB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,2BAA2B,SAAS;AAAA,IACpC,oBAAoB,SAAS;AAAA,IAC7B,SAAS,SAAS,WAAW,MAAM;AAAA,IACnC,gBAAgB,SAAS,kBAAkB,MAAM;AAAA,EACnD;AACF;AAEA,SAAS,mBACP,MACA,UAC0B;AAC1B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,QAAQ,SAAS,UAAU,MAAM;AAAA,IACjC,QAAQ,SAAS,UAAU,MAAM;AAAA,IACjC,eAAe,SAAS;AAAA,IACxB,QAAQ,SAAS,UAAU,MAAM;AAAA,EACnC;AACF;AAEA,SAAS,sBACP,MACA,UAC6B;AAC7B,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,OAAO,SAAS,SAAS,MAAM;AAAA,EACjC;AACF;AAGA,SAAS,gBACP,MACA,UACuB;AACvB,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,SAAS,SAAS;AAAA,IAClB,MAAM,SAAS;AAAA,IACf,aAAa,SAAS;AAAA,IACtB,WAAW,SAAS,aAAa,MAAM;AAAA,IACvC,WAAW,SAAS,aAAa,MAAM;AAAA,IACvC,gBAAgB,SAAS,kBAAkB,MAAM;AAAA,IACjD,cAAc,SAAS,gBAAgB,MAAM;AAAA,IAC7C,gBAAgB,SAAS;AAAA,IACzB,gBAAgB,SAAS,kBAAkB,MAAM;AAAA,IACjD,cAAc,SAAS,gBAAgB,MAAM;AAAA,IAC7C,gBAAgB,SAAS,kBAAkB,MAAM;AAAA,IACjD,kBAAkB,SAAS,oBAAoB,MAAM;AAAA,IACrD,OAAO,SAAS,SAAS,MAAM;AAAA,EACjC;AACF;AAGA,SAASC,qBACP,MACA,UACe;AACf,SAAO;AAAA,IACL,OAAO,iBAAiB,MAAM,OAAO,SAAS,KAAK;AAAA,IACnD,IAAI,cAAc,MAAM,IAAI,SAAS,EAAE;AAAA,IACvC,UAAU,oBAAoB,MAAM,UAAU,SAAS,QAAQ;AAAA,IAC/D,SAAS,mBAAmB,MAAM,SAAS,SAAS,OAAO;AAAA,IAC3D,YAAY,sBAAsB,MAAM,YAAY,SAAS,UAAU;AAAA,IACvE,IAAI,cAAc,MAAM,IAAI,SAAS,EAAE;AAAA,IACvC,SAAS,mBAAmB,MAAM,SAAS,SAAS,OAAO;AAAA,IAC3D,UAAU,oBAAoB,MAAM,UAAU,SAAS,QAAQ;AAAA,IAC/D,MAAM,gBAAgB,MAAM,MAAM,SAAS,IAAI;AAAA,IAC/C,SAAS,mBAAmB,MAAM,SAAS,SAAS,OAAO;AAAA,IAC3D,YAAY,sBAAsB,MAAM,YAAY,SAAS,UAAU;AAAA,IACvE,MAAM,gBAAgB,MAAM,MAAM,SAAS,IAAI;AAAA,EACjD;AACF;AAEO,SAAS,aAAa,MAAc,UAA0B;AACnE,QAAM,SAAiB,EAAE,GAAG,KAAK;AAEjC,MAAI,SAAS,MAAM;AACjB,WAAO,OAAO,iBAAiB,KAAK,MAAM,SAAS,IAAI;AAAA,EACzD;AAEA,MAAI,SAAS,SAAS;AACpB,WAAO,UAAUA,qBAAoB,KAAK,SAAS,SAAS,OAAO;AAAA,EACrE;AAEA,MAAI,SAAS,OAAO;AAClB,WAAO,QAAQ,SAAS;AAAA,EAC1B;AAEA,MAAI,SAAS,UAAU;AACrB,WAAO,WAAW,SAAS;AAAA,EAC7B;AAEA,SAAO;AACT;AAEA,eAAsB,eAAe,QAAgB,WAAoC;AACvF,MAAI,CAAC,OAAO,SAAS;AACnB,WAAO;AAAA,EACT;AAEA,QAAM,EAAE,UAAU,SAAS,IAAI,OAAO;AACtC,QAAM,WAAW,iBAAiB,UAAU,SAAS;AACrD,QAAM,cAAc,MAAM,cAAc,QAAQ;AAEhD,MAAI,eAAuB,CAAC;AAC5B,aAAW,eAAe,UAAU;AAClC,UAAM,UAAU,YAAY,aAAa,WAAW;AACpD,mBAAe,aAAa,cAAc,OAAO;AAAA,EACnD;AAGA,QAAM,cAAsB;AAAA,IAC1B,MAAM,OAAO;AAAA,IACb,SAAS,OAAO;AAAA,IAChB,OAAO,OAAO;AAAA,IACd,UAAU,OAAO;AAAA,EACnB;AACA,SAAO,aAAa,cAAc,WAAW;AAC/C;","names":["fs","path","mergeLinting","mergeTypes","mergeUnused","mergeSecurity","mergeNaming","mergeQuality","mergeProcessSection"]}
package/dist/cli.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ export {};
package/dist/cli.js CHANGED
@@ -3,7 +3,7 @@ import {
3
3
  CheckResultBuilder,
4
4
  DomainResultBuilder,
5
5
  ExitCode
6
- } from "./chunk-P7TIZJ4C.js";
6
+ } from "./chunk-DXIYZR62.js";
7
7
  import {
8
8
  ConfigError,
9
9
  DEFAULT_FORBIDDEN_FILES_IGNORE,
@@ -11,7 +11,12 @@ import {
11
11
  getProjectRoot,
12
12
  loadConfig,
13
13
  loadConfigAsync
14
- } from "./chunk-KHO6NIAI.js";
14
+ } from "./chunk-YGDEM6K5.js";
15
+ import {
16
+ AWS_DEFAULTS,
17
+ GITHUB_API,
18
+ TIMEOUTS
19
+ } from "./chunk-RHM53NLG.js";
15
20
 
16
21
  // src/cli.ts
17
22
  import * as fs22 from "fs";
@@ -351,7 +356,7 @@ var CoverageRunRunner = class extends BaseToolRunner {
351
356
  const result = await execa(testCommand.cmd, testCommand.args, {
352
357
  cwd: projectRoot,
353
358
  reject: false,
354
- timeout: 10 * 60 * 1e3,
359
+ timeout: TIMEOUTS.codeToolExtended,
355
360
  env: { ...process.env, CI: "true" }
356
361
  });
357
362
  return { exitCode: result.exitCode, stderr: result.stderr, stdout: result.stdout };
@@ -852,7 +857,7 @@ var ESLintRunner = class extends BaseToolRunner {
852
857
  const result = await execa2("npx", ["eslint", ...args], {
853
858
  cwd: projectRoot,
854
859
  reject: false,
855
- timeout: 5 * 60 * 1e3
860
+ timeout: TIMEOUTS.codeTool
856
861
  });
857
862
  const violations = this.parseOutput(result.stdout, projectRoot);
858
863
  if (violations === null && result.exitCode !== 0 && result.stderr) {
@@ -936,7 +941,7 @@ var ESLintRunner = class extends BaseToolRunner {
936
941
  const result = await execa2("npx", ["eslint", "--print-config", sampleFile], {
937
942
  cwd: projectRoot,
938
943
  reject: false,
939
- timeout: 30 * 1e3
944
+ timeout: TIMEOUTS.quick
940
945
  });
941
946
  if (result.exitCode !== 0) {
942
947
  return { error: `Failed to read ESLint config: ${result.stderr || "Unknown error"}` };
@@ -1260,7 +1265,7 @@ var GitleaksRunner = class extends BaseToolRunner {
1260
1265
  const result = await execa3("gitleaks", args, {
1261
1266
  cwd: projectRoot,
1262
1267
  reject: false,
1263
- timeout: 5 * 60 * 1e3
1268
+ timeout: TIMEOUTS.codeTool
1264
1269
  });
1265
1270
  return this.processResult(result, elapsed);
1266
1271
  } catch (error) {
@@ -1340,7 +1345,7 @@ var GitleaksRunner = class extends BaseToolRunner {
1340
1345
  await execa3("gitleaks", ["version"], {
1341
1346
  cwd: projectRoot,
1342
1347
  reject: true,
1343
- timeout: 10 * 1e3
1348
+ timeout: TIMEOUTS.versionCheck
1344
1349
  });
1345
1350
  return this.pass(Date.now() - startTime);
1346
1351
  } catch (error) {
@@ -1377,7 +1382,7 @@ var KnipRunner = class extends BaseToolRunner {
1377
1382
  const result = await execa4("npx", ["knip", "--reporter", "json"], {
1378
1383
  cwd: projectRoot,
1379
1384
  reject: false,
1380
- timeout: 5 * 60 * 1e3
1385
+ timeout: TIMEOUTS.codeTool
1381
1386
  });
1382
1387
  const output = result.stdout || result.stderr;
1383
1388
  const violations = this.parseOutput(output, projectRoot);
@@ -1839,13 +1844,13 @@ var PipAuditRunner = class extends BaseToolRunner {
1839
1844
  return await execa5("uvx", args, {
1840
1845
  cwd: projectRoot,
1841
1846
  reject: false,
1842
- timeout: 5 * 60 * 1e3
1847
+ timeout: TIMEOUTS.codeTool
1843
1848
  });
1844
1849
  } catch {
1845
1850
  return await execa5("pip-audit", args.slice(1), {
1846
1851
  cwd: projectRoot,
1847
1852
  reject: false,
1848
- timeout: 5 * 60 * 1e3
1853
+ timeout: TIMEOUTS.codeTool
1849
1854
  });
1850
1855
  }
1851
1856
  }
@@ -1962,7 +1967,7 @@ var PnpmAuditRunner = class extends BaseToolRunner {
1962
1967
  const result = await execa6("pnpm", args, {
1963
1968
  cwd: projectRoot,
1964
1969
  reject: false,
1965
- timeout: 5 * 60 * 1e3
1970
+ timeout: TIMEOUTS.codeTool
1966
1971
  });
1967
1972
  return this.processAuditResult(result, elapsed);
1968
1973
  } catch (error) {
@@ -2140,7 +2145,7 @@ var RuffRunner = class extends BaseToolRunner {
2140
2145
  const result = await execa7("ruff", this.buildCliArgs(), {
2141
2146
  cwd: projectRoot,
2142
2147
  reject: false,
2143
- timeout: 5 * 60 * 1e3
2148
+ timeout: TIMEOUTS.codeTool
2144
2149
  });
2145
2150
  if (this.isBinaryNotFound(result)) {
2146
2151
  return this.skipNotInstalled(Date.now() - startTime);
@@ -2306,7 +2311,7 @@ var TscRunner = class extends BaseToolRunner {
2306
2311
  return execa8("npx", ["tsc", "--noEmit"], {
2307
2312
  cwd: projectRoot,
2308
2313
  reject: false,
2309
- timeout: 5 * 60 * 1e3
2314
+ timeout: TIMEOUTS.codeTool
2310
2315
  });
2311
2316
  }
2312
2317
  processRunResult(result, projectRoot, elapsed) {
@@ -2537,7 +2542,7 @@ var TyRunner = class extends BaseToolRunner {
2537
2542
  const result = await execa9("uvx", ["ty", "check", "--output-format", "concise", "."], {
2538
2543
  cwd: projectRoot,
2539
2544
  reject: false,
2540
- timeout: 5 * 60 * 1e3
2545
+ timeout: TIMEOUTS.codeTool
2541
2546
  });
2542
2547
  return this.handleExitCode(result, projectRoot, elapsed);
2543
2548
  } catch (error) {
@@ -2686,7 +2691,7 @@ var VultureRunner = class _VultureRunner extends BaseToolRunner {
2686
2691
  const result = await execa10("vulture", [".", "--exclude", excludePatterns], {
2687
2692
  cwd: projectRoot,
2688
2693
  reject: false,
2689
- timeout: 5 * 60 * 1e3
2694
+ timeout: TIMEOUTS.codeTool
2690
2695
  });
2691
2696
  if (this.isBinaryNotFound(result)) {
2692
2697
  return this.skipNotInstalled(Date.now() - startTime);
@@ -3200,7 +3205,7 @@ function formatJson(result) {
3200
3205
  }
3201
3206
  function formatText(result) {
3202
3207
  const lines = [];
3203
- lines.push(`check-my-toolkit v${result.version}`);
3208
+ lines.push(`conform v${result.version}`);
3204
3209
  lines.push(`Config: ${result.configPath}`);
3205
3210
  lines.push("");
3206
3211
  for (const [domainName, domain] of Object.entries(result.domains)) {
@@ -3759,7 +3764,7 @@ var BackupsRunner = class extends BaseProcessToolRunner {
3759
3764
  }
3760
3765
  getS3Client() {
3761
3766
  return this.s3Client ?? new S3Client({
3762
- region: this.config.region ?? process.env.AWS_REGION ?? "us-east-1"
3767
+ region: this.config.region ?? process.env.AWS_REGION ?? AWS_DEFAULTS.globalRegion
3763
3768
  });
3764
3769
  }
3765
3770
  createExistsViolation() {
@@ -5727,7 +5732,7 @@ var PrRunner = class extends BaseProcessToolRunner {
5727
5732
  /** Fetch a single page of PR files from GitHub API */
5728
5733
  async fetchPrFilesPage(repo, prNumber, page, token) {
5729
5734
  const response = await fetch(
5730
- `https://api.github.com/repos/${repo}/pulls/${prNumber}/files?per_page=100&page=${page}`,
5735
+ `${GITHUB_API.baseUrl}/repos/${repo}/pulls/${prNumber}/files?per_page=${GITHUB_API.perPage}&page=${page}`,
5731
5736
  {
5732
5737
  headers: {
5733
5738
  Authorization: `Bearer ${token}`,
@@ -6820,24 +6825,30 @@ function createRegistry(registryPath, projectTypes, dryRun) {
6820
6825
  // src/projects/tier-loader.ts
6821
6826
  import * as fs21 from "fs";
6822
6827
  import * as path19 from "path";
6823
- import * as yaml3 from "js-yaml";
6828
+ import TOML from "@iarna/toml";
6824
6829
  var DEFAULT_TIER = "internal";
6825
6830
  var VALID_TIERS = ["production", "internal", "prototype"];
6826
6831
  function loadProjectTier(projectDir) {
6827
- const metadataPath = path19.join(projectDir, "repo-metadata.yaml");
6828
- if (!fs21.existsSync(metadataPath)) {
6832
+ const tomlPath = path19.join(projectDir, "standards.toml");
6833
+ if (!fs21.existsSync(tomlPath)) {
6829
6834
  return { tier: void 0, source: null };
6830
6835
  }
6831
6836
  try {
6832
- const content = fs21.readFileSync(metadataPath, "utf-8");
6833
- const metadata = yaml3.load(content);
6834
- if (!metadata?.tier) {
6837
+ const content = fs21.readFileSync(tomlPath, "utf-8");
6838
+ const parsed = TOML.parse(content);
6839
+ if (!parsed.metadata?.tier) {
6835
6840
  return { tier: DEFAULT_TIER, source: "default" };
6836
6841
  }
6837
- if (!VALID_TIERS.includes(metadata.tier)) {
6842
+ if (!VALID_TIERS.includes(parsed.metadata.tier)) {
6838
6843
  return { tier: DEFAULT_TIER, source: "default" };
6839
6844
  }
6840
- return { tier: metadata.tier, source: "repo-metadata.yaml" };
6845
+ return {
6846
+ tier: parsed.metadata.tier,
6847
+ source: "standards.toml",
6848
+ project: parsed.metadata.project,
6849
+ organisation: parsed.metadata.organisation,
6850
+ status: parsed.metadata.status
6851
+ };
6841
6852
  } catch {
6842
6853
  return { tier: void 0, source: null };
6843
6854
  }
@@ -7135,7 +7146,7 @@ validateCommand.command("config").description("Validate standards.toml configura
7135
7146
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7136
7147
  ).action(async (options) => {
7137
7148
  try {
7138
- const { loadConfigWithOverrides } = await import("./src-KZRTG3EU.js");
7149
+ const { loadConfigWithOverrides } = await import("./core-QRFGIQ42.js");
7139
7150
  const { configPath, overrides } = await loadConfigWithOverrides(options.config);
7140
7151
  outputValidateResult(configPath, overrides, options);
7141
7152
  process.exit(ExitCode.SUCCESS);
@@ -7228,7 +7239,7 @@ validateCommand.command("tier").description("Validate tier-ruleset alignment (re
7228
7239
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7229
7240
  ).action(async (options) => {
7230
7241
  try {
7231
- const { validateTierRuleset, formatTierResultText, formatTierResultJson } = await import("./validate-AABLVQJS.js");
7242
+ const { validateTierRuleset, formatTierResultText, formatTierResultJson } = await import("./validate-J5E336GX.js");
7232
7243
  const result = validateTierRuleset({ config: options.config });
7233
7244
  const output = options.format === "json" ? formatTierResultJson(result) : formatTierResultText(result);
7234
7245
  process.stdout.write(`${output}
@@ -7255,7 +7266,7 @@ validateCommand.command("guidelines <path>").description("Validate guideline mar
7255
7266
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7256
7267
  ).action(async (dirPath, options) => {
7257
7268
  try {
7258
- const { runValidateGuidelines } = await import("./validate-AABLVQJS.js");
7269
+ const { runValidateGuidelines } = await import("./validate-J5E336GX.js");
7259
7270
  await runValidateGuidelines(dirPath, options);
7260
7271
  } catch (error) {
7261
7272
  handleError(error);
@@ -7274,7 +7285,7 @@ schemaCommand.command("config").description("Output JSON schema for standards.to
7274
7285
  `);
7275
7286
  });
7276
7287
  schemaCommand.command("guidelines").description("Output JSON schema for guideline frontmatter").action(async () => {
7277
- const { frontmatterSchema } = await import("./standards-RXK5G4IG.js");
7288
+ const { frontmatterSchema } = await import("./standards-XAZKTKYJ.js");
7278
7289
  const jsonSchema = zodToJsonSchema(frontmatterSchema, {
7279
7290
  name: "GuidelineFrontmatter",
7280
7291
  $refStrategy: "none"
@@ -7303,14 +7314,14 @@ processCommand.command("audit").description("Verify workflow configs exist").opt
7303
7314
  processCommand.command("diff").description("Show repository setting differences (current vs. config)").option("-c, --config <path>", "Path to standards.toml config file").addOption(
7304
7315
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7305
7316
  ).action(async (options) => {
7306
- const { runDiff } = await import("./sync-RLYBGYNY.js");
7317
+ const { runDiff } = await import("./sync-P3UZECLW.js");
7307
7318
  await runDiff({ config: options.config, format: options.format });
7308
7319
  });
7309
7320
  processCommand.command("sync").description("Synchronize repository settings to match config").option("-c, --config <path>", "Path to standards.toml config file").option("--apply", "Actually apply changes (required for safety)").option("--validate-actors", "Validate bypass actor IDs against GitHub API before applying").addOption(
7310
7321
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7311
7322
  ).action(
7312
7323
  async (options) => {
7313
- const { runSync } = await import("./sync-RLYBGYNY.js");
7324
+ const { runSync } = await import("./sync-P3UZECLW.js");
7314
7325
  await runSync({
7315
7326
  config: options.config,
7316
7327
  format: options.format,
@@ -7322,13 +7333,13 @@ processCommand.command("sync").description("Synchronize repository settings to m
7322
7333
  processCommand.command("diff-tags").description("Show tag protection differences (current vs. config)").option("-c, --config <path>", "Path to standards.toml config file").addOption(
7323
7334
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7324
7335
  ).action(async (options) => {
7325
- const { runTagDiff } = await import("./sync-RLYBGYNY.js");
7336
+ const { runTagDiff } = await import("./sync-P3UZECLW.js");
7326
7337
  await runTagDiff({ config: options.config, format: options.format });
7327
7338
  });
7328
7339
  processCommand.command("sync-tags").description("Synchronize tag protection ruleset to match config").option("-c, --config <path>", "Path to standards.toml config file").option("--apply", "Actually apply changes (required for safety)").addOption(
7329
7340
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7330
7341
  ).action(async (options) => {
7331
- const { runTagSync } = await import("./sync-RLYBGYNY.js");
7342
+ const { runTagSync } = await import("./sync-P3UZECLW.js");
7332
7343
  await runTagSync({
7333
7344
  config: options.config,
7334
7345
  format: options.format,
@@ -7359,7 +7370,7 @@ processCommand.command("scan").description("Scan remote repository settings via
7359
7370
  ).option("-c, --config <path>", "Path to standards.toml config file").addOption(
7360
7371
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7361
7372
  ).action(async (options) => {
7362
- const { runScan } = await import("./scan-EELS42BP.js");
7373
+ const { runScan } = await import("./scan-RHQWHASY.js");
7363
7374
  await runScan({
7364
7375
  repo: options.repo,
7365
7376
  config: options.config,
@@ -7399,7 +7410,7 @@ var infraCommand = configureExitOverride(
7399
7410
  infraCommand.command("scan").description("Verify AWS resources declared in manifest exist").option("-c, --config <path>", "Path to standards.toml config file").option("-m, --manifest <path>", "Path to manifest file (overrides config)").option("-a, --account <name>", "Filter to specific account (by alias or account key like 'aws:123')").addOption(
7400
7411
  new Option("-f, --format <format>", "Output format").choices(["text", "json"]).default("text")
7401
7412
  ).action(async (options) => {
7402
- const { runInfraScan } = await import("./infra-UXM5XQX3.js");
7413
+ const { runInfraScan } = await import("./infra-TO54IUSC.js");
7403
7414
  await runInfraScan({
7404
7415
  configPath: options.config,
7405
7416
  manifestPath: options.manifest,
@@ -7409,7 +7420,7 @@ infraCommand.command("scan").description("Verify AWS resources declared in manif
7409
7420
  });
7410
7421
  infraCommand.command("generate").description("Generate infra-manifest.json from Pulumi stack export").option("-i, --input <path>", "Input file (reads from stdin if not provided)").option("-o, --output <path>", "Output file path (default: infra-manifest.json)").option("-p, --project <name>", "Project name (extracted from stack if not provided)").option("-a, --account <alias>", "Account alias (e.g., 'prod-aws')").option("--account-id <id>", "Explicit account ID (e.g., 'aws:111111111111')").option("--merge", "Merge into existing manifest instead of overwriting").option("--stdout", "Output to stdout instead of file").action(
7411
7422
  async (options) => {
7412
- const { runInfraGenerate } = await import("./infra-UXM5XQX3.js");
7423
+ const { runInfraGenerate } = await import("./infra-TO54IUSC.js");
7413
7424
  await runInfraGenerate(options);
7414
7425
  }
7415
7426
  );
@@ -7422,7 +7433,7 @@ program.command("audit").description("Verify all configs exist (code + process)"
7422
7433
  ).action((options) => runAudit(options));
7423
7434
  program.command("mcp").description("Start MCP server for coding standards (for Claude Desktop integration)").action(async () => {
7424
7435
  try {
7425
- const { startServer } = await import("./mcp-O5O7XVFG.js");
7436
+ const { startServer } = await import("./mcp-73FZXT3P.js");
7426
7437
  await startServer();
7427
7438
  } catch (error) {
7428
7439
  handleError(error);