@polymorphism-tech/morph-spec 3.0.0 → 3.1.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 (240) hide show
  1. package/CLAUDE.md +68 -400
  2. package/README.md +198 -76
  3. package/bin/detect-agents.js +227 -225
  4. package/bin/morph-spec.js +10 -0
  5. package/bin/render-template.js +303 -302
  6. package/bin/semantic-detect-agents.js +247 -246
  7. package/bin/{task-manager.js → task-manager.cjs} +12 -1
  8. package/bin/validate-agents-skills.js +257 -251
  9. package/bin/validate-agents.js +70 -69
  10. package/bin/validate-phase.js +263 -263
  11. package/docs/getting-started.md +3 -3
  12. package/package.json +3 -4
  13. package/scripts/reorganize-skills.cjs +175 -0
  14. package/scripts/validate-agents-structure.cjs +52 -0
  15. package/scripts/validate-skills.cjs +180 -0
  16. package/src/commands/create-story.js +354 -351
  17. package/src/commands/detect-agents.js +13 -2
  18. package/src/commands/detect.js +104 -104
  19. package/src/commands/state.js +334 -333
  20. package/src/commands/sync.js +167 -167
  21. package/src/commands/task.js +1 -1
  22. package/src/commands/update.js +13 -1
  23. package/src/lib/context-generator.js +7 -4
  24. package/{detectors → src/lib/detectors}/config-detector.js +223 -223
  25. package/{detectors → src/lib/detectors}/conversation-analyzer.js +163 -163
  26. package/{detectors → src/lib/detectors}/index.js +84 -84
  27. package/{detectors → src/lib/detectors}/standards-generator.js +275 -275
  28. package/src/lib/hook-executor.js +2 -1
  29. package/src/lib/stack-resolver.js +148 -0
  30. package/src/lib/standards-context-injector.js +4 -3
  31. package/src/lib/state-manager.js +21 -4
  32. package/src/lib/team-orchestrator.js +2 -1
  33. package/src/lib/troubleshoot-grep.js +13 -3
  34. package/src/lib/validation-runner.js +2 -1
  35. package/src/utils/file-copier.js +3 -1
  36. package/{content → stacks/blazor-azure}/.azure/README.md +293 -293
  37. package/{content → stacks/blazor-azure}/.azure/docs/azure-devops-setup.md +454 -454
  38. package/{content → stacks/blazor-azure}/.azure/docs/branch-strategy.md +398 -398
  39. package/{content → stacks/blazor-azure}/.azure/docs/local-development.md +515 -515
  40. package/{content → stacks/blazor-azure}/.azure/pipelines/pipeline-variables.yml +34 -34
  41. package/{content → stacks/blazor-azure}/.azure/pipelines/prod-pipeline.yml +319 -319
  42. package/{content → stacks/blazor-azure}/.azure/pipelines/staging-pipeline.yml +234 -234
  43. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/build-dotnet.yml +75 -75
  44. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-app-service.yml +94 -94
  45. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/deploy-container-app.yml +120 -120
  46. package/{content → stacks/blazor-azure}/.azure/pipelines/templates/infra-deploy.yml +90 -90
  47. package/{content → stacks/blazor-azure}/.claude/commands/morph-archive.md +79 -79
  48. package/{content → stacks/blazor-azure}/.claude/commands/morph-deploy.md +529 -529
  49. package/{content → stacks/blazor-azure}/.claude/commands/morph-infra.md +209 -209
  50. package/{content → stacks/blazor-azure}/.claude/commands/morph-troubleshoot.md +1 -1
  51. package/{content → stacks/blazor-azure}/.claude/settings.local.json +15 -15
  52. package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-setup.md +1 -1
  53. package/{content/.claude/skills/specialists → stacks/blazor-azure/.claude/skills/level-2-domains/architecture}/prompt-engineer.md +189 -189
  54. package/{content/.claude/skills/specialists → stacks/blazor-azure/.claude/skills/level-2-domains/architecture}/seo-growth-hacker.md +320 -320
  55. package/{content/.claude/skills/infra → stacks/blazor-azure/.claude/skills/level-2-domains/infrastructure}/azure-deploy-specialist.md +699 -699
  56. package/{content → stacks/blazor-azure}/.morph/.morphversion +5 -5
  57. package/{content → stacks/blazor-azure}/.morph/archive/.gitkeep +25 -25
  58. package/{content → stacks/blazor-azure}/.morph/config/agents.json +7 -5
  59. package/{content → stacks/blazor-azure}/.morph/docs/STORY-DRIVEN-DEVELOPMENT.md +392 -392
  60. package/{content → stacks/blazor-azure}/.morph/docs/workflows/enforcement-pipeline.md +3 -3
  61. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/README.md +241 -241
  62. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/contracts.ts +307 -307
  63. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/spec.md +399 -399
  64. package/{content → stacks/blazor-azure}/.morph/examples/api-nextjs/tasks.md +168 -168
  65. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/README.md +125 -125
  66. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/contracts.cs +358 -358
  67. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/decisions.md +246 -246
  68. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/spec.md +236 -236
  69. package/{content → stacks/blazor-azure}/.morph/examples/micro-saas/tasks.md +150 -150
  70. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/README.md +309 -309
  71. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/contracts.cs +433 -433
  72. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/spec.md +479 -479
  73. package/{content → stacks/blazor-azure}/.morph/examples/multi-agent/tasks.md +185 -185
  74. package/{content → stacks/blazor-azure}/.morph/examples/state-v3.json +188 -188
  75. package/{content → stacks/blazor-azure}/.morph/features/.gitkeep +25 -25
  76. package/{content → stacks/blazor-azure}/.morph/hooks/README.md +12 -12
  77. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-all.sh +48 -48
  78. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-specs.sh +49 -49
  79. package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-tests.sh +60 -60
  80. package/{content → stacks/blazor-azure}/.morph/project.md +160 -160
  81. package/{content → stacks/blazor-azure}/.morph/schemas/agent.schema.json +296 -296
  82. package/{content → stacks/blazor-azure}/.morph/specs/.gitkeep +20 -20
  83. package/{content → stacks/blazor-azure}/.morph/standards/agent-teams-workflow.md +2 -2
  84. package/{content → stacks/blazor-azure}/.morph/standards/coding.md +377 -377
  85. package/{content → stacks/blazor-azure}/.morph/standards/fluent-ui-setup.md +590 -590
  86. package/{content → stacks/blazor-azure}/.morph/standards/migration-guide.md +514 -514
  87. package/{content → stacks/blazor-azure}/.morph/standards/passkeys-auth.md +423 -423
  88. package/{content → stacks/blazor-azure}/.morph/standards/vector-search-rag.md +536 -536
  89. package/{content → stacks/blazor-azure}/.morph/state.json +17 -17
  90. package/{content → stacks/blazor-azure}/.morph/templates/FluentDesignTheme.cs +149 -149
  91. package/{content → stacks/blazor-azure}/.morph/templates/MudTheme.cs +281 -281
  92. package/{content → stacks/blazor-azure}/.morph/templates/component.razor +239 -239
  93. package/{content → stacks/blazor-azure}/.morph/templates/contracts.cs +217 -217
  94. package/{content → stacks/blazor-azure}/.morph/templates/design-system.css +226 -226
  95. package/{content → stacks/blazor-azure}/.morph/templates/infra/.dockerignore.example +89 -89
  96. package/{content → stacks/blazor-azure}/.morph/templates/infra/Dockerfile.example +82 -82
  97. package/{content → stacks/blazor-azure}/.morph/templates/infra/README.md +286 -286
  98. package/{content → stacks/blazor-azure}/.morph/templates/infra/app-insights.bicep +63 -63
  99. package/{content → stacks/blazor-azure}/.morph/templates/infra/app-service.bicep +164 -164
  100. package/{content → stacks/blazor-azure}/.morph/templates/infra/azure-pipelines-deploy.yml +480 -480
  101. package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app-env.bicep +49 -49
  102. package/{content → stacks/blazor-azure}/.morph/templates/infra/container-app.bicep +156 -156
  103. package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.ps1 +229 -229
  104. package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy.sh +208 -208
  105. package/{content → stacks/blazor-azure}/.morph/templates/infra/key-vault.bicep +91 -91
  106. package/{content → stacks/blazor-azure}/.morph/templates/infra/main.bicep +189 -189
  107. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.dev.json +29 -29
  108. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.prod.json +29 -29
  109. package/{content → stacks/blazor-azure}/.morph/templates/infra/parameters.staging.json +29 -29
  110. package/{content → stacks/blazor-azure}/.morph/templates/infra/sql-database.bicep +103 -103
  111. package/{content → stacks/blazor-azure}/.morph/templates/infra/storage.bicep +106 -106
  112. package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-client.cs +387 -387
  113. package/{content → stacks/blazor-azure}/.morph/templates/integrations/asaas-webhook.cs +351 -351
  114. package/{content → stacks/blazor-azure}/.morph/templates/integrations/azure-identity-config.cs +288 -288
  115. package/{content → stacks/blazor-azure}/.morph/templates/integrations/clerk-config.cs +258 -258
  116. package/{content → stacks/blazor-azure}/.morph/templates/job.cs +171 -171
  117. package/{content → stacks/blazor-azure}/.morph/templates/migration.cs +83 -83
  118. package/{content → stacks/blazor-azure}/.morph/templates/repository.cs +141 -141
  119. package/{content → stacks/blazor-azure}/.morph/templates/saas/subscription.cs +347 -347
  120. package/{content → stacks/blazor-azure}/.morph/templates/saas/tenant.cs +338 -338
  121. package/{content → stacks/blazor-azure}/.morph/templates/service.cs +139 -139
  122. package/{content → stacks/blazor-azure}/.morph/templates/sprint-status.yaml +68 -68
  123. package/{content → stacks/blazor-azure}/.morph/templates/story.md +143 -143
  124. package/{content → stacks/blazor-azure}/.morph/templates/test.cs +239 -239
  125. package/{content → stacks/blazor-azure}/.morph/templates/ui-design-system.md +286 -286
  126. package/{content → stacks/blazor-azure}/.morph/templates/ui-flows.md +336 -336
  127. package/{content → stacks/blazor-azure}/.morph/templates/ui-mockups.md +133 -133
  128. package/{content → stacks/blazor-azure}/.morph/test-infra/example.bicep +59 -59
  129. package/{content → stacks/blazor-azure}/README.md +79 -79
  130. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/backend/dotnet-supabase.md +244 -0
  131. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/frontend/nextjs-supabase.md +335 -0
  132. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/infrastructure/easypanel-deployer.md +189 -0
  133. package/stacks/nextjs-supabase/.claude/skills/level-2-domains/integrations/supabase-expert.md +170 -0
  134. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -0
  135. package/stacks/nextjs-supabase/.morph/config/config.template.json +92 -0
  136. package/stacks/nextjs-supabase/.morph/docs/easypanel-setup.md +169 -0
  137. package/stacks/nextjs-supabase/.morph/docs/supabase-mcp-setup.md +247 -0
  138. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/README.md +697 -0
  139. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/spec.md +85 -0
  140. package/stacks/nextjs-supabase/.morph/examples/crud-nextjs-supabase/tasks.md +86 -0
  141. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/README.md +498 -0
  142. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/decisions.md +121 -0
  143. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/spec.md +138 -0
  144. package/stacks/nextjs-supabase/.morph/examples/saas-nextjs-supabase/tasks.md +162 -0
  145. package/stacks/nextjs-supabase/.morph/project.md +168 -0
  146. package/stacks/nextjs-supabase/.morph/standards/easypanel-deploy.md +191 -0
  147. package/stacks/nextjs-supabase/.morph/standards/nextjs-patterns.md +193 -0
  148. package/stacks/nextjs-supabase/.morph/standards/supabase-auth.md +171 -0
  149. package/stacks/nextjs-supabase/.morph/standards/supabase-pgvector.md +164 -0
  150. package/stacks/nextjs-supabase/.morph/standards/supabase-rls.md +179 -0
  151. package/stacks/nextjs-supabase/.morph/standards/supabase-storage.md +148 -0
  152. package/stacks/nextjs-supabase/.morph/templates/contracts.cs +173 -0
  153. package/stacks/nextjs-supabase/.morph/templates/contracts.ts +168 -0
  154. package/stacks/nextjs-supabase/.morph/templates/decisions.md +115 -0
  155. package/stacks/nextjs-supabase/.morph/templates/dockerfile-api.dockerfile +38 -0
  156. package/stacks/nextjs-supabase/.morph/templates/dockerfile-web.dockerfile +48 -0
  157. package/stacks/nextjs-supabase/.morph/templates/proposal.md +145 -0
  158. package/stacks/nextjs-supabase/.morph/templates/recap.md +134 -0
  159. package/stacks/nextjs-supabase/.morph/templates/rls-policy.sql +57 -0
  160. package/stacks/nextjs-supabase/.morph/templates/spec.md +231 -0
  161. package/stacks/nextjs-supabase/.morph/templates/supabase-migration.sql +100 -0
  162. package/stacks/nextjs-supabase/.morph/templates/tasks.md +257 -0
  163. package/stacks/nextjs-supabase/CLAUDE.md +149 -0
  164. package/stacks/nextjs-supabase/README.md +112 -0
  165. /package/{detectors → src/lib/detectors}/structure-detector.js +0 -0
  166. /package/{content → stacks/blazor-azure}/.claude/commands/morph-apply.md +0 -0
  167. /package/{content → stacks/blazor-azure}/.claude/commands/morph-preflight.md +0 -0
  168. /package/{content → stacks/blazor-azure}/.claude/commands/morph-proposal.md +0 -0
  169. /package/{content → stacks/blazor-azure}/.claude/commands/morph-status.md +0 -0
  170. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/README.md +0 -0
  171. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/code-review.md +0 -0
  172. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/morph-checklist.md +0 -0
  173. /package/{content → stacks/blazor-azure}/.claude/skills/level-0-meta/simulation-checklist.md +0 -0
  174. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/README.md +0 -0
  175. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/morph-replicate.md +0 -0
  176. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-clarify.md +0 -0
  177. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-design.md +0 -0
  178. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-tasks.md +0 -0
  179. /package/{content → stacks/blazor-azure}/.claude/skills/level-1-workflows/phase-uiux.md +0 -0
  180. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/README.md +0 -0
  181. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/ai-agents/ai-system-architect.md +0 -0
  182. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/po-pm-advisor.md +0 -0
  183. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/architecture/standards-architect.md +0 -0
  184. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/dotnet-senior.md +0 -0
  185. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ef-modeler.md +0 -0
  186. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/hangfire-orchestrator.md +0 -0
  187. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/backend/ms-agent-expert.md +0 -0
  188. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/blazor-builder.md +0 -0
  189. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/nextjs-expert.md +0 -0
  190. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/frontend/ui-ux-designer.md +0 -0
  191. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/azure-architect.md +0 -0
  192. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/bicep-architect.md +0 -0
  193. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/container-specialist.md +0 -0
  194. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/infrastructure/devops-engineer.md +0 -0
  195. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/asaas-financial.md +0 -0
  196. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/azure-identity.md +0 -0
  197. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/clerk-auth.md +0 -0
  198. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/integrations/resend-email.md +0 -0
  199. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/code-analyzer.md +0 -0
  200. /package/{content → stacks/blazor-azure}/.claude/skills/level-2-domains/quality/testing-specialist.md +0 -0
  201. /package/{content → stacks/blazor-azure}/.claude/skills/level-3-technologies/README.md +0 -0
  202. /package/{content → stacks/blazor-azure}/.claude/skills/level-4-patterns/README.md +0 -0
  203. /package/{content → stacks/blazor-azure}/.morph/config/config.template.json +0 -0
  204. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/design-impl.md +0 -0
  205. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/fast-track.md +0 -0
  206. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/full-morph.md +0 -0
  207. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/standard.md +0 -0
  208. /package/{content → stacks/blazor-azure}/.morph/docs/workflows/ui-refresh.md +0 -0
  209. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/decisions.md +0 -0
  210. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/proposal.md +0 -0
  211. /package/{content → stacks/blazor-azure}/.morph/examples/scheduled-reports/spec.md +0 -0
  212. /package/{content → stacks/blazor-azure}/.morph/hooks/pre-commit-agents.sh +0 -0
  213. /package/{content → stacks/blazor-azure}/.morph/hooks/task-completed.js +0 -0
  214. /package/{content → stacks/blazor-azure}/.morph/hooks/teammate-idle.js +0 -0
  215. /package/{content → stacks/blazor-azure}/.morph/schemas/tasks.schema.json +0 -0
  216. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-blazor-ui.md +0 -0
  217. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-production.md +0 -0
  218. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-setup.md +0 -0
  219. /package/{content → stacks/blazor-azure}/.morph/standards/agent-framework-workflows.md +0 -0
  220. /package/{content → stacks/blazor-azure}/.morph/standards/architecture.md +0 -0
  221. /package/{content → stacks/blazor-azure}/.morph/standards/azure.md +0 -0
  222. /package/{content → stacks/blazor-azure}/.morph/standards/dotnet10-migration.md +0 -0
  223. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT-FEATURE.md +0 -0
  224. /package/{content → stacks/blazor-azure}/.morph/templates/CONTEXT.md +0 -0
  225. /package/{content → stacks/blazor-azure}/.morph/templates/agent.cs +0 -0
  226. /package/{content → stacks/blazor-azure}/.morph/templates/clarify-questions.md +0 -0
  227. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Commands.cs +0 -0
  228. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Entities.cs +0 -0
  229. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/Queries.cs +0 -0
  230. /package/{content → stacks/blazor-azure}/.morph/templates/contracts/README.md +0 -0
  231. /package/{content → stacks/blazor-azure}/.morph/templates/decisions.md +0 -0
  232. /package/{content → stacks/blazor-azure}/.morph/templates/infra/deploy-checklist.md +0 -0
  233. /package/{content → stacks/blazor-azure}/.morph/templates/proposal.md +0 -0
  234. /package/{content → stacks/blazor-azure}/.morph/templates/recap.md +0 -0
  235. /package/{content → stacks/blazor-azure}/.morph/templates/simulation.md +0 -0
  236. /package/{content → stacks/blazor-azure}/.morph/templates/spec.md +0 -0
  237. /package/{content → stacks/blazor-azure}/.morph/templates/state.template.json +0 -0
  238. /package/{content → stacks/blazor-azure}/.morph/templates/tasks.md +0 -0
  239. /package/{content → stacks/blazor-azure}/.morph/templates/ui-components.md +0 -0
  240. /package/{content → stacks/blazor-azure}/CLAUDE.md +0 -0
@@ -1,275 +1,275 @@
1
- /**
2
- * Standards Generator - Generates inferred-standards.md from detection results
3
- */
4
-
5
- /**
6
- * Generate inferred standards
7
- * @param {Object} detectionResults - Results from all detectors
8
- * @returns {Promise<Object>} Generated standards
9
- */
10
- export async function generateStandards(detectionResults) {
11
- const { structure, config, conversation } = detectionResults;
12
-
13
- const standards = {
14
- markdown: generateMarkdown(structure, config, conversation),
15
- recommendations: generateRecommendations(structure, config, conversation),
16
- gaps: identifyGaps(structure, config)
17
- };
18
-
19
- return standards;
20
- }
21
-
22
- /**
23
- * Generate markdown content for inferred-standards.md
24
- */
25
- function generateMarkdown(structure, config, conversation) {
26
- const sections = [];
27
-
28
- // Header
29
- sections.push(`# Inferred Standards (Auto-generated)`);
30
- sections.push(``);
31
- sections.push(`> ⚠️ This file is auto-generated by MORPH-SPEC detection system.`);
32
- sections.push(`> Manual edits will be overwritten. Create custom standards in \`overrides.md\`.`);
33
- sections.push(``);
34
- sections.push(`**Generated:** ${new Date().toISOString()}`);
35
- sections.push(``);
36
- sections.push(`---`);
37
- sections.push(``);
38
-
39
- // Stack Summary
40
- sections.push(`## 🎯 Project Stack`);
41
- sections.push(``);
42
- sections.push(`- **Type**: ${structure?.stack || 'unknown'}`);
43
- sections.push(`- **Language**: ${config?.language || 'unknown'}`);
44
- sections.push(`- **Version**: ${config?.version || 'unknown'}`);
45
- sections.push(`- **Architecture**: ${structure?.architecture || 'unknown'}`);
46
- if (structure?.uiLibrary) {
47
- sections.push(`- **UI Library**: ${structure.uiLibrary}`);
48
- }
49
- sections.push(``);
50
-
51
- // Technologies
52
- if (config?.technologies?.length > 0) {
53
- sections.push(`## 🛠️ Technologies Detected`);
54
- sections.push(``);
55
- config.technologies.forEach(tech => {
56
- sections.push(`- ${tech}`);
57
- });
58
- sections.push(``);
59
- }
60
-
61
- // Patterns
62
- if (structure?.patterns?.length > 0) {
63
- sections.push(`## 📐 Patterns in Use`);
64
- sections.push(``);
65
- structure.patterns.forEach(pattern => {
66
- sections.push(`- ${pattern}`);
67
- });
68
- sections.push(``);
69
- }
70
-
71
- // Coding Standards (inferred)
72
- sections.push(`## 💻 Inferred Coding Standards`);
73
- sections.push(``);
74
- sections.push(generateCodingStandards(structure, config));
75
- sections.push(``);
76
-
77
- // Architecture Patterns
78
- if (structure?.architecture !== 'unknown') {
79
- sections.push(`## 🏗️ Architecture Pattern`);
80
- sections.push(``);
81
- sections.push(generateArchitectureSection(structure));
82
- sections.push(``);
83
- }
84
-
85
- // Dependencies
86
- if (config?.dependencies?.length > 0) {
87
- sections.push(`## 📦 Key Dependencies`);
88
- sections.push(``);
89
- const importantDeps = filterImportantDependencies(config.dependencies);
90
- importantDeps.slice(0, 10).forEach(dep => {
91
- sections.push(`- ${dep}`);
92
- });
93
- if (config.dependencies.length > 10) {
94
- sections.push(`- ... and ${config.dependencies.length - 10} more`);
95
- }
96
- sections.push(``);
97
- }
98
-
99
- // User Preferences (from conversation)
100
- if (conversation?.preferences && Object.keys(conversation.preferences).some(k => conversation.preferences[k])) {
101
- sections.push(`## 🎨 User Preferences (from past decisions)`);
102
- sections.push(``);
103
- Object.entries(conversation.preferences).forEach(([key, value]) => {
104
- if (value) {
105
- sections.push(`- **${formatKey(key)}**: ${value}`);
106
- }
107
- });
108
- sections.push(``);
109
- }
110
-
111
- return sections.join('\n');
112
- }
113
-
114
- /**
115
- * Generate coding standards section
116
- */
117
- function generateCodingStandards(structure, config) {
118
- if (config?.language === 'csharp') {
119
- return `### C# / .NET Conventions
120
-
121
- Based on detected patterns in your codebase:
122
-
123
- - **Naming**: PascalCase for classes, camelCase for variables
124
- - **Async**: Methods with \`Async\` suffix
125
- - **DI**: Constructor injection (${structure.patterns.includes('Dependency Injection') ? '✅ detected' : '⚠️ not detected'})
126
- - **Tests**: ${structure.patterns.includes('Unit Tests') ? '✅ Present' : '⚠️ Not detected'}
127
-
128
- **Recommendation**: Refer to \`.morph/standards/coding.md\` for complete .NET standards.`;
129
- }
130
-
131
- if (config?.language === 'javascript') {
132
- return `### JavaScript / TypeScript Conventions
133
-
134
- Based on detected patterns in your codebase:
135
-
136
- - **Package Manager**: ${config.packageManager}
137
- - **Framework**: ${config.technologies.join(', ')}
138
-
139
- **Recommendation**: Refer to framework standards for JavaScript best practices.`;
140
- }
141
-
142
- return 'No specific coding standards inferred. Check framework standards for guidance.';
143
- }
144
-
145
- /**
146
- * Generate architecture section
147
- */
148
- function generateArchitectureSection(structure) {
149
- const { architecture } = structure;
150
-
151
- const descriptions = {
152
- 'clean-architecture': `### Clean Architecture
153
-
154
- Your project follows Clean Architecture pattern:
155
-
156
- - ✅ **Domain** layer detected (core business logic)
157
- - ✅ **Application** layer detected (use cases)
158
- - ✅ **Infrastructure** layer detected (implementations)
159
-
160
- **Key principles**:
161
- - Domain has no dependencies
162
- - Application depends on Domain
163
- - Infrastructure implements Application interfaces`,
164
-
165
- 'cqrs': `### CQRS Pattern
166
-
167
- Your project uses Command Query Responsibility Segregation:
168
-
169
- - ✅ **Commands** detected (write operations)
170
- - ✅ **Queries** detected (read operations)
171
-
172
- **Key principles**:
173
- - Separate read and write models
174
- - Commands return void or Task
175
- - Queries return data`,
176
-
177
- 'mvc': `### MVC Pattern
178
-
179
- Your project uses Model-View-Controller pattern:
180
-
181
- - ✅ **Controllers** detected
182
- - ✅ **Models** detected
183
- - ✅ **Views** detected`
184
- };
185
-
186
- return descriptions[architecture] || `Architecture: ${architecture}`;
187
- }
188
-
189
- /**
190
- * Generate recommendations
191
- */
192
- function generateRecommendations(structure, config, conversation) {
193
- const recommendations = [];
194
-
195
- // Recommend based on stack
196
- if (structure?.stack === 'blazor') {
197
- if (!structure.uiLibrary) {
198
- recommendations.push('Consider adding Fluent UI Blazor or MudBlazor for consistent UI components');
199
- }
200
-
201
- if (!structure.patterns.includes('AI Agents') && config?.technologies?.includes('Microsoft Agent Framework')) {
202
- recommendations.push('Setup detected Agent Framework but no agents found - check .morph/standards/agent-framework-setup.md');
203
- }
204
- }
205
-
206
- // Recommend tests
207
- if (!structure?.patterns?.includes('Unit Tests')) {
208
- recommendations.push('No unit tests detected - consider adding test project');
209
- }
210
-
211
- // Recommend DI
212
- if (!structure?.patterns?.includes('Dependency Injection')) {
213
- recommendations.push('Consider implementing Dependency Injection pattern');
214
- }
215
-
216
- // Architecture recommendations
217
- if (structure?.architecture === 'unknown' && structure?.folders?.hasServices) {
218
- recommendations.push('Service layer detected but no clear architecture - consider Clean Architecture or CQRS');
219
- }
220
-
221
- return recommendations;
222
- }
223
-
224
- /**
225
- * Identify gaps between framework and project
226
- */
227
- function identifyGaps(structure, config) {
228
- const gaps = [];
229
-
230
- // Check for missing patterns
231
- const expectedPatterns = {
232
- blazor: ['Service Layer', 'Repository Pattern', 'Dependency Injection'],
233
- nextjs: ['API Routes', 'Components'],
234
- };
235
-
236
- const expected = expectedPatterns[structure?.stack];
237
- if (expected) {
238
- expected.forEach(pattern => {
239
- if (!structure?.patterns?.includes(pattern)) {
240
- gaps.push(`Missing: ${pattern}`);
241
- }
242
- });
243
- }
244
-
245
- return gaps;
246
- }
247
-
248
- /**
249
- * Filter important dependencies
250
- */
251
- function filterImportantDependencies(deps) {
252
- const important = deps.filter(dep => {
253
- // Framework packages
254
- if (dep.includes('Microsoft.') || dep.includes('System.')) return true;
255
- // UI libraries
256
- if (dep.includes('Blazor') || dep.includes('FluentUI') || dep.includes('Mud')) return true;
257
- // Common tools
258
- if (dep.includes('Hangfire') || dep.includes('Serilog') || dep.includes('AutoMapper')) return true;
259
- // AI/ML
260
- if (dep.includes('Agents') || dep.includes('AI') || dep.includes('OpenAI')) return true;
261
- return false;
262
- });
263
-
264
- return important.length > 0 ? important : deps;
265
- }
266
-
267
- /**
268
- * Format key for display
269
- */
270
- function formatKey(key) {
271
- return key
272
- .replace(/([A-Z])/g, ' $1')
273
- .replace(/^./, str => str.toUpperCase())
274
- .trim();
275
- }
1
+ /**
2
+ * Standards Generator - Generates inferred-standards.md from detection results
3
+ */
4
+
5
+ /**
6
+ * Generate inferred standards
7
+ * @param {Object} detectionResults - Results from all detectors
8
+ * @returns {Promise<Object>} Generated standards
9
+ */
10
+ export async function generateStandards(detectionResults) {
11
+ const { structure, config, conversation } = detectionResults;
12
+
13
+ const standards = {
14
+ markdown: generateMarkdown(structure, config, conversation),
15
+ recommendations: generateRecommendations(structure, config, conversation),
16
+ gaps: identifyGaps(structure, config)
17
+ };
18
+
19
+ return standards;
20
+ }
21
+
22
+ /**
23
+ * Generate markdown content for inferred-standards.md
24
+ */
25
+ function generateMarkdown(structure, config, conversation) {
26
+ const sections = [];
27
+
28
+ // Header
29
+ sections.push(`# Inferred Standards (Auto-generated)`);
30
+ sections.push(``);
31
+ sections.push(`> ⚠️ This file is auto-generated by MORPH-SPEC detection system.`);
32
+ sections.push(`> Manual edits will be overwritten. Create custom standards in \`overrides.md\`.`);
33
+ sections.push(``);
34
+ sections.push(`**Generated:** ${new Date().toISOString()}`);
35
+ sections.push(``);
36
+ sections.push(`---`);
37
+ sections.push(``);
38
+
39
+ // Stack Summary
40
+ sections.push(`## 🎯 Project Stack`);
41
+ sections.push(``);
42
+ sections.push(`- **Type**: ${structure?.stack || 'unknown'}`);
43
+ sections.push(`- **Language**: ${config?.language || 'unknown'}`);
44
+ sections.push(`- **Version**: ${config?.version || 'unknown'}`);
45
+ sections.push(`- **Architecture**: ${structure?.architecture || 'unknown'}`);
46
+ if (structure?.uiLibrary) {
47
+ sections.push(`- **UI Library**: ${structure.uiLibrary}`);
48
+ }
49
+ sections.push(``);
50
+
51
+ // Technologies
52
+ if (config?.technologies?.length > 0) {
53
+ sections.push(`## 🛠️ Technologies Detected`);
54
+ sections.push(``);
55
+ config.technologies.forEach(tech => {
56
+ sections.push(`- ${tech}`);
57
+ });
58
+ sections.push(``);
59
+ }
60
+
61
+ // Patterns
62
+ if (structure?.patterns?.length > 0) {
63
+ sections.push(`## 📐 Patterns in Use`);
64
+ sections.push(``);
65
+ structure.patterns.forEach(pattern => {
66
+ sections.push(`- ${pattern}`);
67
+ });
68
+ sections.push(``);
69
+ }
70
+
71
+ // Coding Standards (inferred)
72
+ sections.push(`## 💻 Inferred Coding Standards`);
73
+ sections.push(``);
74
+ sections.push(generateCodingStandards(structure, config));
75
+ sections.push(``);
76
+
77
+ // Architecture Patterns
78
+ if (structure?.architecture !== 'unknown') {
79
+ sections.push(`## 🏗️ Architecture Pattern`);
80
+ sections.push(``);
81
+ sections.push(generateArchitectureSection(structure));
82
+ sections.push(``);
83
+ }
84
+
85
+ // Dependencies
86
+ if (config?.dependencies?.length > 0) {
87
+ sections.push(`## 📦 Key Dependencies`);
88
+ sections.push(``);
89
+ const importantDeps = filterImportantDependencies(config.dependencies);
90
+ importantDeps.slice(0, 10).forEach(dep => {
91
+ sections.push(`- ${dep}`);
92
+ });
93
+ if (config.dependencies.length > 10) {
94
+ sections.push(`- ... and ${config.dependencies.length - 10} more`);
95
+ }
96
+ sections.push(``);
97
+ }
98
+
99
+ // User Preferences (from conversation)
100
+ if (conversation?.preferences && Object.keys(conversation.preferences).some(k => conversation.preferences[k])) {
101
+ sections.push(`## 🎨 User Preferences (from past decisions)`);
102
+ sections.push(``);
103
+ Object.entries(conversation.preferences).forEach(([key, value]) => {
104
+ if (value) {
105
+ sections.push(`- **${formatKey(key)}**: ${value}`);
106
+ }
107
+ });
108
+ sections.push(``);
109
+ }
110
+
111
+ return sections.join('\n');
112
+ }
113
+
114
+ /**
115
+ * Generate coding standards section
116
+ */
117
+ function generateCodingStandards(structure, config) {
118
+ if (config?.language === 'csharp') {
119
+ return `### C# / .NET Conventions
120
+
121
+ Based on detected patterns in your codebase:
122
+
123
+ - **Naming**: PascalCase for classes, camelCase for variables
124
+ - **Async**: Methods with \`Async\` suffix
125
+ - **DI**: Constructor injection (${structure.patterns.includes('Dependency Injection') ? '✅ detected' : '⚠️ not detected'})
126
+ - **Tests**: ${structure.patterns.includes('Unit Tests') ? '✅ Present' : '⚠️ Not detected'}
127
+
128
+ **Recommendation**: Refer to \`.morph/standards/coding.md\` for complete .NET standards.`;
129
+ }
130
+
131
+ if (config?.language === 'javascript') {
132
+ return `### JavaScript / TypeScript Conventions
133
+
134
+ Based on detected patterns in your codebase:
135
+
136
+ - **Package Manager**: ${config.packageManager}
137
+ - **Framework**: ${config.technologies.join(', ')}
138
+
139
+ **Recommendation**: Refer to framework standards for JavaScript best practices.`;
140
+ }
141
+
142
+ return 'No specific coding standards inferred. Check framework standards for guidance.';
143
+ }
144
+
145
+ /**
146
+ * Generate architecture section
147
+ */
148
+ function generateArchitectureSection(structure) {
149
+ const { architecture } = structure;
150
+
151
+ const descriptions = {
152
+ 'clean-architecture': `### Clean Architecture
153
+
154
+ Your project follows Clean Architecture pattern:
155
+
156
+ - ✅ **Domain** layer detected (core business logic)
157
+ - ✅ **Application** layer detected (use cases)
158
+ - ✅ **Infrastructure** layer detected (implementations)
159
+
160
+ **Key principles**:
161
+ - Domain has no dependencies
162
+ - Application depends on Domain
163
+ - Infrastructure implements Application interfaces`,
164
+
165
+ 'cqrs': `### CQRS Pattern
166
+
167
+ Your project uses Command Query Responsibility Segregation:
168
+
169
+ - ✅ **Commands** detected (write operations)
170
+ - ✅ **Queries** detected (read operations)
171
+
172
+ **Key principles**:
173
+ - Separate read and write models
174
+ - Commands return void or Task
175
+ - Queries return data`,
176
+
177
+ 'mvc': `### MVC Pattern
178
+
179
+ Your project uses Model-View-Controller pattern:
180
+
181
+ - ✅ **Controllers** detected
182
+ - ✅ **Models** detected
183
+ - ✅ **Views** detected`
184
+ };
185
+
186
+ return descriptions[architecture] || `Architecture: ${architecture}`;
187
+ }
188
+
189
+ /**
190
+ * Generate recommendations
191
+ */
192
+ function generateRecommendations(structure, config, conversation) {
193
+ const recommendations = [];
194
+
195
+ // Recommend based on stack
196
+ if (structure?.stack === 'blazor') {
197
+ if (!structure.uiLibrary) {
198
+ recommendations.push('Consider adding Fluent UI Blazor or MudBlazor for consistent UI components');
199
+ }
200
+
201
+ if (!structure.patterns.includes('AI Agents') && config?.technologies?.includes('Microsoft Agent Framework')) {
202
+ recommendations.push('Setup detected Agent Framework but no agents found - check .morph/standards/agent-framework-setup.md');
203
+ }
204
+ }
205
+
206
+ // Recommend tests
207
+ if (!structure?.patterns?.includes('Unit Tests')) {
208
+ recommendations.push('No unit tests detected - consider adding test project');
209
+ }
210
+
211
+ // Recommend DI
212
+ if (!structure?.patterns?.includes('Dependency Injection')) {
213
+ recommendations.push('Consider implementing Dependency Injection pattern');
214
+ }
215
+
216
+ // Architecture recommendations
217
+ if (structure?.architecture === 'unknown' && structure?.folders?.hasServices) {
218
+ recommendations.push('Service layer detected but no clear architecture - consider Clean Architecture or CQRS');
219
+ }
220
+
221
+ return recommendations;
222
+ }
223
+
224
+ /**
225
+ * Identify gaps between framework and project
226
+ */
227
+ function identifyGaps(structure, config) {
228
+ const gaps = [];
229
+
230
+ // Check for missing patterns
231
+ const expectedPatterns = {
232
+ blazor: ['Service Layer', 'Repository Pattern', 'Dependency Injection'],
233
+ nextjs: ['API Routes', 'Components'],
234
+ };
235
+
236
+ const expected = expectedPatterns[structure?.stack];
237
+ if (expected) {
238
+ expected.forEach(pattern => {
239
+ if (!structure?.patterns?.includes(pattern)) {
240
+ gaps.push(`Missing: ${pattern}`);
241
+ }
242
+ });
243
+ }
244
+
245
+ return gaps;
246
+ }
247
+
248
+ /**
249
+ * Filter important dependencies
250
+ */
251
+ function filterImportantDependencies(deps) {
252
+ const important = deps.filter(dep => {
253
+ // Framework packages
254
+ if (dep.includes('Microsoft.') || dep.includes('System.')) return true;
255
+ // UI libraries
256
+ if (dep.includes('Blazor') || dep.includes('FluentUI') || dep.includes('Mud')) return true;
257
+ // Common tools
258
+ if (dep.includes('Hangfire') || dep.includes('Serilog') || dep.includes('AutoMapper')) return true;
259
+ // AI/ML
260
+ if (dep.includes('Agents') || dep.includes('AI') || dep.includes('OpenAI')) return true;
261
+ return false;
262
+ });
263
+
264
+ return important.length > 0 ? important : deps;
265
+ }
266
+
267
+ /**
268
+ * Format key for display
269
+ */
270
+ function formatKey(key) {
271
+ return key
272
+ .replace(/([A-Z])/g, ' $1')
273
+ .replace(/^./, str => str.toUpperCase())
274
+ .trim();
275
+ }
@@ -14,6 +14,7 @@
14
14
  import fs from 'fs/promises';
15
15
  import path from 'path';
16
16
  import { runValidation } from './validation-runner.js';
17
+ import { resolveAgentsConfigPath } from './stack-resolver.js';
17
18
 
18
19
  /**
19
20
  * Load agents.json to get hook configuration
@@ -21,7 +22,7 @@ import { runValidation } from './validation-runner.js';
21
22
  * @returns {Promise<Object>} Parsed agents configuration
22
23
  */
23
24
  async function loadAgentsConfig(projectPath) {
24
- const agentsPath = path.join(projectPath, 'content/.morph/config/agents.json');
25
+ const agentsPath = resolveAgentsConfigPath(projectPath);
25
26
  const content = await fs.readFile(agentsPath, 'utf8');
26
27
  return JSON.parse(content);
27
28
  }