@polymorphism-tech/morph-spec 4.7.2 → 4.8.1

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 (346) hide show
  1. package/.morph/analytics/threads-log.jsonl +54 -5
  2. package/.morph/state.json +152 -2
  3. package/LICENSE +1 -2
  4. package/README.md +379 -414
  5. package/bin/morph-spec.js +57 -394
  6. package/bin/validate.js +2 -26
  7. package/claude-plugin.json +2 -2
  8. package/docs/ARCHITECTURE.md +43 -46
  9. package/docs/CHEATSHEET.md +203 -221
  10. package/docs/COMMAND-FLOWS.md +319 -289
  11. package/docs/QUICKSTART.md +2 -8
  12. package/docs/plans/2026-02-22-claude-docs-morph-alignment-analysis.md +2 -0
  13. package/docs/plans/2026-02-22-claude-settings.md +2 -0
  14. package/docs/plans/2026-02-22-morph-cc-alignment-impl.md +2 -0
  15. package/docs/plans/2026-02-22-morph-spec-next.md +2 -0
  16. package/docs/plans/2026-02-22-native-alignment-design.md +2 -0
  17. package/docs/plans/2026-02-22-native-alignment-impl.md +2 -0
  18. package/docs/plans/2026-02-22-native-enrichment-design.md +2 -0
  19. package/docs/plans/2026-02-22-native-enrichment.md +2 -0
  20. package/docs/plans/2026-02-23-ddd-architecture-refactor.md +2 -0
  21. package/docs/plans/2026-02-23-ddd-nextsteps.md +2 -0
  22. package/docs/plans/2026-02-23-infra-architect-refactor.md +2 -0
  23. package/docs/plans/2026-02-23-nextjs-code-review-design.md +2 -1
  24. package/docs/plans/2026-02-23-nextjs-code-review-impl.md +2 -0
  25. package/docs/plans/2026-02-23-nextjs-standards-design.md +2 -1
  26. package/docs/plans/2026-02-23-nextjs-standards-impl.md +2 -0
  27. package/docs/plans/2026-02-24-cli-radical-simplification.md +592 -0
  28. package/docs/plans/2026-02-24-framework-failure-points.md +125 -0
  29. package/docs/plans/2026-02-24-morph-init-design.md +337 -0
  30. package/docs/plans/2026-02-24-morph-init-impl.md +1269 -0
  31. package/docs/plans/2026-02-24-tutorial-command-design.md +71 -0
  32. package/docs/plans/2026-02-24-tutorial-command.md +298 -0
  33. package/framework/CLAUDE.md +1 -1
  34. package/framework/commands/morph-proposal.md +3 -3
  35. package/framework/hooks/README.md +2 -5
  36. package/framework/hooks/claude-code/pre-tool-use/protect-readonly-files.js +4 -55
  37. package/framework/hooks/claude-code/session-start/inject-morph-context.js +20 -5
  38. package/framework/hooks/claude-code/statusline.py +6 -1
  39. package/framework/hooks/dev/check-sync-health.js +117 -0
  40. package/framework/hooks/dev/guard-version-numbers.js +57 -0
  41. package/framework/hooks/dev/sync-standards-registry.js +60 -0
  42. package/framework/hooks/dev/sync-template-registry.js +60 -0
  43. package/framework/hooks/dev/validate-skill-format.js +70 -0
  44. package/framework/hooks/dev/validate-standard-format.js +73 -0
  45. package/framework/hooks/shared/payload-utils.js +39 -0
  46. package/framework/hooks/shared/state-reader.js +25 -1
  47. package/framework/rules/morph-workflow.md +1 -1
  48. package/framework/skills/level-0-meta/morph-init/SKILL.md +216 -0
  49. package/framework/skills/level-0-meta/morph-replicate/SKILL.md +4 -4
  50. package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +4 -4
  51. package/framework/skills/level-0-meta/verification-before-completion/SKILL.md +1 -1
  52. package/framework/skills/level-1-workflows/phase-clarify/SKILL.md +192 -191
  53. package/framework/skills/level-1-workflows/phase-codebase-analysis/SKILL.md +181 -180
  54. package/framework/skills/level-1-workflows/phase-design/SKILL.md +339 -338
  55. package/framework/skills/level-1-workflows/phase-implement/SKILL.md +254 -253
  56. package/framework/skills/level-1-workflows/phase-setup/SKILL.md +168 -170
  57. package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +284 -283
  58. package/framework/skills/level-1-workflows/phase-uiux/SKILL.md +246 -245
  59. package/framework/templates/examples/design-system-examples.md +1 -1
  60. package/framework/templates/ui/FluentDesignTheme.cs +1 -1
  61. package/framework/templates/ui/MudTheme.cs +1 -1
  62. package/framework/templates/ui/design-system.css +1 -1
  63. package/package.json +4 -2
  64. package/scripts/bump-version.js +248 -0
  65. package/scripts/install-dev-hooks.js +138 -0
  66. package/src/commands/agents/index.js +1 -2
  67. package/src/commands/index.js +13 -16
  68. package/src/commands/project/doctor.js +100 -14
  69. package/src/commands/project/index.js +7 -10
  70. package/src/commands/project/init.js +398 -528
  71. package/src/commands/project/install-plugin-cmd.js +28 -0
  72. package/src/commands/project/setup-infra-cmd.js +12 -0
  73. package/src/commands/project/tutorial.js +115 -0
  74. package/src/commands/state/approve.js +213 -221
  75. package/src/commands/state/index.js +0 -1
  76. package/src/commands/state/state.js +337 -365
  77. package/src/commands/templates/index.js +0 -4
  78. package/src/commands/trust/trust.js +1 -93
  79. package/src/commands/utils/index.js +1 -5
  80. package/src/commands/validation/index.js +1 -5
  81. package/src/core/registry/command-registry.js +11 -285
  82. package/src/core/state/state-manager.js +5 -2
  83. package/src/lib/detectors/index.js +81 -87
  84. package/src/lib/detectors/structure-detector.js +275 -273
  85. package/src/lib/generators/recap-generator.js +232 -225
  86. package/src/scripts/global-install.js +34 -0
  87. package/src/scripts/install-plugin.js +126 -0
  88. package/src/scripts/setup-infra.js +203 -0
  89. package/src/utils/agents-installer.js +10 -1
  90. package/src/utils/hooks-installer.js +66 -3
  91. package/.morph/.morphversion +0 -5
  92. package/.morph/config/config.json +0 -8
  93. package/.morph/framework/agents.json +0 -1815
  94. package/.morph/framework/hooks/README.md +0 -205
  95. package/.morph/framework/hooks/claude-code/notification/approval-reminder.js +0 -54
  96. package/.morph/framework/hooks/claude-code/post-tool-use/dispatch.js +0 -83
  97. package/.morph/framework/hooks/claude-code/post-tool-use/handle-tool-failure.js +0 -42
  98. package/.morph/framework/hooks/claude-code/pre-compact/save-morph-context.js +0 -61
  99. package/.morph/framework/hooks/claude-code/pre-tool-use/enforce-phase-writes.js +0 -71
  100. package/.morph/framework/hooks/claude-code/pre-tool-use/protect-readonly-files.js +0 -58
  101. package/.morph/framework/hooks/claude-code/pre-tool-use/protect-spec-files.js +0 -64
  102. package/.morph/framework/hooks/claude-code/session-start/inject-morph-context.js +0 -94
  103. package/.morph/framework/hooks/claude-code/statusline.py +0 -538
  104. package/.morph/framework/hooks/claude-code/statusline.sh +0 -7
  105. package/.morph/framework/hooks/claude-code/stop/validate-completion.js +0 -88
  106. package/.morph/framework/hooks/claude-code/user-prompt/enrich-prompt.js +0 -91
  107. package/.morph/framework/hooks/git/commit-msg/conventional-commits.sh +0 -33
  108. package/.morph/framework/hooks/git/pre-commit/agents.sh +0 -25
  109. package/.morph/framework/hooks/git/pre-commit/orchestrator.sh +0 -64
  110. package/.morph/framework/hooks/git/pre-commit/specs.sh +0 -50
  111. package/.morph/framework/hooks/git/pre-push/run-tests.sh +0 -44
  112. package/.morph/framework/hooks/shared/hook-response.js +0 -45
  113. package/.morph/framework/hooks/shared/phase-utils.js +0 -129
  114. package/.morph/framework/hooks/shared/state-reader.js +0 -138
  115. package/.morph/framework/hooks/shared/stdin-reader.js +0 -26
  116. package/.morph/framework/standards/STANDARDS.json +0 -933
  117. package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
  118. package/.morph/framework/standards/ai-agents/production.md +0 -415
  119. package/.morph/framework/standards/ai-agents/setup.md +0 -418
  120. package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
  121. package/.morph/framework/standards/ai-agents/workflows.md +0 -354
  122. package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
  123. package/.morph/framework/standards/architecture/ddd/bounded-contexts.md +0 -105
  124. package/.morph/framework/standards/architecture/ddd/complexity-levels.md +0 -108
  125. package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
  126. package/.morph/framework/standards/architecture/ddd/ubiquitous-language.md +0 -58
  127. package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
  128. package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
  129. package/.morph/framework/standards/backend/api/rest.md +0 -492
  130. package/.morph/framework/standards/backend/api/validation.md +0 -88
  131. package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
  132. package/.morph/framework/standards/backend/database/ef-core.md +0 -199
  133. package/.morph/framework/standards/backend/database/migrations.md +0 -393
  134. package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
  135. package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
  136. package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
  137. package/.morph/framework/standards/backend/dotnet/async.md +0 -366
  138. package/.morph/framework/standards/backend/dotnet/core.md +0 -117
  139. package/.morph/framework/standards/backend/dotnet/di.md +0 -439
  140. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
  141. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
  142. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
  143. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
  144. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
  145. package/.morph/framework/standards/context/analytics.md +0 -96
  146. package/.morph/framework/standards/context/bundles.md +0 -110
  147. package/.morph/framework/standards/context/priming.md +0 -78
  148. package/.morph/framework/standards/core/architecture.md +0 -185
  149. package/.morph/framework/standards/core/coding.md +0 -214
  150. package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
  151. package/.morph/framework/standards/core/git.md +0 -185
  152. package/.morph/framework/standards/core/testing.md +0 -295
  153. package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
  154. package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
  155. package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
  156. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
  157. package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
  158. package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
  159. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
  160. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
  161. package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
  162. package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
  163. package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
  164. package/.morph/framework/standards/frontend/blazor/state.md +0 -191
  165. package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
  166. package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
  167. package/.morph/framework/standards/frontend/nextjs/app-router.md +0 -123
  168. package/.morph/framework/standards/frontend/nextjs/components.md +0 -132
  169. package/.morph/framework/standards/frontend/nextjs/data-fetching.md +0 -126
  170. package/.morph/framework/standards/frontend/nextjs/forms.md +0 -128
  171. package/.morph/framework/standards/frontend/nextjs/naming-conventions.md +0 -67
  172. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -215
  173. package/.morph/framework/standards/frontend/nextjs/project-structure.md +0 -102
  174. package/.morph/framework/standards/frontend/nextjs/state-management.md +0 -72
  175. package/.morph/framework/standards/frontend/nextjs/testing.md +0 -111
  176. package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
  177. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
  178. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
  179. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
  180. package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
  181. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
  182. package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
  183. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
  184. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
  185. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
  186. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
  187. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
  188. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
  189. package/.morph/framework/standards/integration/api/graphql.md +0 -91
  190. package/.morph/framework/standards/integration/api/grpc.md +0 -114
  191. package/.morph/framework/standards/integration/api/rest-design.md +0 -95
  192. package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
  193. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
  194. package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
  195. package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
  196. package/.morph/framework/standards/observability/logging.md +0 -131
  197. package/.morph/framework/standards/observability/metrics.md +0 -121
  198. package/.morph/framework/standards/observability/monitoring.md +0 -114
  199. package/.morph/framework/standards/observability/tracing.md +0 -132
  200. package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
  201. package/.morph/framework/standards/workflows/thread-management.md +0 -113
  202. package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
  203. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
  204. package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
  205. package/.morph/framework/templates/README.md +0 -814
  206. package/.morph/framework/templates/REGISTRY.json +0 -1888
  207. package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
  208. package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
  209. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
  210. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
  211. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
  212. package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
  213. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
  214. package/.morph/framework/templates/code/dotnet/contracts/contracts-level1.cs +0 -69
  215. package/.morph/framework/templates/code/dotnet/contracts/contracts-level2.cs +0 -86
  216. package/.morph/framework/templates/code/dotnet/contracts/contracts-level3.cs +0 -41
  217. package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
  218. package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
  219. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
  220. package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
  221. package/.morph/framework/templates/code/dotnet/test.cs +0 -239
  222. package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
  223. package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
  224. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
  225. package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
  226. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
  227. package/.morph/framework/templates/context/CONTEXT.md +0 -181
  228. package/.morph/framework/templates/docs/clarifications.md +0 -253
  229. package/.morph/framework/templates/docs/onboarding.md +0 -123
  230. package/.morph/framework/templates/docs/proposal.md +0 -182
  231. package/.morph/framework/templates/docs/schema-analysis.md +0 -119
  232. package/.morph/framework/templates/docs/spec.md +0 -198
  233. package/.morph/framework/templates/docs/ui-components.md +0 -124
  234. package/.morph/framework/templates/docs/ui-design-system.md +0 -76
  235. package/.morph/framework/templates/docs/ui-flows.md +0 -167
  236. package/.morph/framework/templates/docs/ui-mockups.md +0 -98
  237. package/.morph/framework/templates/docs/user-stories.md +0 -34
  238. package/.morph/framework/templates/examples/design-system-examples.md +0 -357
  239. package/.morph/framework/templates/examples/spec-examples.md +0 -90
  240. package/.morph/framework/templates/feature/decisions.md +0 -187
  241. package/.morph/framework/templates/feature/recap.md +0 -146
  242. package/.morph/framework/templates/feature/tasks.md +0 -199
  243. package/.morph/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +0 -43
  244. package/.morph/framework/templates/frontend/nextjs/client-component.tsx.hbs +0 -26
  245. package/.morph/framework/templates/frontend/nextjs/env.mjs.hbs +0 -32
  246. package/.morph/framework/templates/frontend/nextjs/feature-form.tsx.hbs +0 -56
  247. package/.morph/framework/templates/frontend/nextjs/page.tsx.hbs +0 -22
  248. package/.morph/framework/templates/frontend/nextjs/tsconfig.json.hbs +0 -26
  249. package/.morph/framework/templates/frontend/nextjs/use-feature.ts.hbs +0 -54
  250. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
  251. package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
  252. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
  253. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
  254. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
  255. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
  256. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
  257. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
  258. package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
  259. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
  260. package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
  261. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
  262. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
  263. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
  264. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
  265. package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
  266. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
  267. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
  268. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
  269. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
  270. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
  271. package/.morph/framework/templates/infrastructure/github/README.md +0 -593
  272. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
  273. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
  274. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
  275. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
  276. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
  277. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
  278. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
  279. package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
  280. package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
  281. package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
  282. package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
  283. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
  284. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
  285. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
  286. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
  287. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
  288. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
  289. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
  290. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
  291. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
  292. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
  293. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
  294. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
  295. package/.morph/framework/templates/project-structure/dotnet-ddd.md +0 -70
  296. package/.morph/framework/templates/saas/subscription.cs +0 -347
  297. package/.morph/framework/templates/saas/tenant.cs +0 -338
  298. package/.morph/framework/templates/state.template.json +0 -17
  299. package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
  300. package/.morph/framework/templates/ui/MudTheme.cs +0 -281
  301. package/.morph/framework/templates/ui/design-system.css +0 -226
  302. package/.morph/logs/tool-failures.log +0 -17
  303. package/.morph/memory/pre-compact-2026-02-24T17-43-30-049Z.json +0 -16
  304. package/.morph/plans/eager-watching-bunny.md +0 -105
  305. package/.morph/plans/temporal-seeking-nebula.md +0 -45
  306. package/CLAUDE.md +0 -77
  307. package/docs/claude-alignment-report.md +0 -137
  308. package/docs/examples/order-management/contracts.cs +0 -84
  309. package/docs/examples/order-management/proposal.md +0 -24
  310. package/docs/examples/order-management/spec.md +0 -162
  311. package/src/commands/feature/create-story.js +0 -362
  312. package/src/commands/feature/index.js +0 -6
  313. package/src/commands/feature/shard-spec.js +0 -225
  314. package/src/commands/feature/sprint-status.js +0 -250
  315. package/src/commands/generation/generate-onboarding.js +0 -169
  316. package/src/commands/generation/generate.js +0 -276
  317. package/src/commands/generation/index.js +0 -5
  318. package/src/commands/learning/capture-pattern.js +0 -121
  319. package/src/commands/learning/index.js +0 -5
  320. package/src/commands/learning/search-patterns.js +0 -126
  321. package/src/commands/mcp/mcp.js +0 -102
  322. package/src/commands/project/changes.js +0 -66
  323. package/src/commands/project/cost.js +0 -179
  324. package/src/commands/project/diff.js +0 -278
  325. package/src/commands/project/revert.js +0 -173
  326. package/src/commands/project/standards.js +0 -80
  327. package/src/commands/project/sync.js +0 -167
  328. package/src/commands/project/update-agents.js +0 -23
  329. package/src/commands/state/rollback-phase.js +0 -185
  330. package/src/commands/templates/template-customize.js +0 -87
  331. package/src/commands/templates/template-list.js +0 -114
  332. package/src/commands/templates/template-show.js +0 -129
  333. package/src/commands/templates/template-validate.js +0 -91
  334. package/src/commands/utils/troubleshoot.js +0 -222
  335. package/src/commands/validation/analyze-blazor-concurrency.js +0 -193
  336. package/src/commands/validation/lint-fluent.js +0 -352
  337. package/src/commands/validation/validate-blazor-state.js +0 -210
  338. package/src/commands/validation/validate-blazor.js +0 -156
  339. package/src/commands/validation/validate-css.js +0 -84
  340. package/src/lib/detectors/conversation-analyzer.js +0 -163
  341. package/src/lib/learning/index.js +0 -7
  342. package/src/lib/learning/learning-system.js +0 -520
  343. package/src/lib/troubleshooting/index.js +0 -8
  344. package/src/lib/troubleshooting/troubleshoot-grep.js +0 -198
  345. package/src/lib/troubleshooting/troubleshoot-index.js +0 -144
  346. package/src/llm/environment-detector.js +0 -43
@@ -0,0 +1,125 @@
1
+ # Framework Failure Points — Implementation Plan
2
+
3
+ **Status:** COMPLETE
4
+
5
+ > Created: 2026-02-24
6
+ > Status: In progress (detect-agents fix already merged)
7
+
8
+ ---
9
+
10
+ ## Already Done
11
+
12
+ - **#1 detect-agents ghost command** — Fixed in commit `9a90f31`. All 5 skill files updated to use `Read agents.json + morph-spec state add-agent` flow.
13
+ - **#2 validate-css in morph-replicate** — Fixed in same commit.
14
+
15
+ ---
16
+
17
+ ## Remaining Issues — Prioritized
18
+
19
+ ### Task 1 — Fix ARCHITECTURE.md hooks table (documentation, low risk)
20
+
21
+ The hooks table in `docs/ARCHITECTURE.md` has wrong hook names. Verified against actual files in `framework/hooks/claude-code/`:
22
+
23
+ | What doc says | What actually exists |
24
+ |---|---|
25
+ | UserPromptSubmit: `protect-spec-files.js` | UserPromptSubmit: `enrich-prompt.js` |
26
+ | PreToolUse: `validate-feature-phase.js` | PreToolUse: `enforce-phase-writes.js` + `protect-readonly-files.js` + `protect-spec-files.js` (3 hooks) |
27
+
28
+ **Fix:** Rewrite hooks table in `ARCHITECTURE.md` with correct names and descriptions. Also fix COMMAND-FLOWS.md Section 9 hook chain (same error — hook names partially wrong).
29
+
30
+ Files: `docs/ARCHITECTURE.md`, `docs/COMMAND-FLOWS.md`
31
+
32
+ ---
33
+
34
+ ### Task 2 — Add `morph-spec unapprove` command (gate revocation)
35
+
36
+ `approve` was kept in the CLI, but `reject` was removed in the simplification. Users who approve a gate and then realize the spec needs rework are blocked — no supported path to undo an approval.
37
+
38
+ **Fix:** Add `unapprove` command that sets `approvals[gate] = false` and removes the approval from history.
39
+
40
+ Files:
41
+ - `src/commands/state/approve.js` — add `unapproveCommand()`
42
+ - `bin/morph-spec.js` — register `morph-spec unapprove <feature> <gate>`
43
+ - `test/commands/approve.test.js` — add tests
44
+
45
+ ---
46
+
47
+ ### Task 3 — Make spec injection limit configurable
48
+
49
+ `inject-morph-context.js` hardcodes `3000` chars. Real specs exceed this; Claude starts sessions with truncated context and makes decisions based on partial information.
50
+
51
+ **Fix:** Read limit from `.morph/config/config.json` → `hooks.specInjectionLimit` (default: 3000). Add `specInjectionLimit` to the config schema.
52
+
53
+ Files:
54
+ - `framework/hooks/claude-code/session-start/inject-morph-context.js`
55
+ - `src/lib/config/config-schema.js` (or wherever defaults live)
56
+ - `test/hooks/hooks-e2e.test.js` — add test for custom limit
57
+
58
+ ---
59
+
60
+ ### Task 4 — Add hook health summary to `morph-spec doctor`
61
+
62
+ `doctor` checks for the existence of `.claude/skills/`, `.claude/agents/`, `.claude/rules/` but doesn't validate hook configuration. A broken hook (wrong path, deleted file) passes doctor with no warning.
63
+
64
+ **Fix:** Add a `hooks` health check section to `doctorCommand()`:
65
+ 1. Read `.claude/settings.local.json`
66
+ 2. For each configured hook, verify the hook script file exists at the referenced path
67
+ 3. Report any missing or misconfigured hooks
68
+
69
+ Files:
70
+ - `src/commands/project/doctor.js`
71
+ - `test/commands/doctor.test.js`
72
+
73
+ ---
74
+
75
+ ### Task 5 — Skills-CLI compatibility: add `cliVersion` to SKILL.md frontmatter + doctor check
76
+
77
+ After the radical simplification, skill files drifted from the CLI. There's no mechanism to detect this drift.
78
+
79
+ **Fix:**
80
+ 1. Add `cliVersion: "4.7.2"` to the frontmatter of all workflow skill files (`level-1-workflows/**`)
81
+ 2. `morph-spec doctor` reads each installed `.claude/skills/*/SKILL.md`, extracts `cliVersion`, and warns if it doesn't match the running CLI version
82
+
83
+ This gives future maintainers a clear signal when a skill update is needed.
84
+
85
+ Files:
86
+ - `framework/skills/level-1-workflows/*/SKILL.md` (8 files) — add `cliVersion: "4.7.2"` to frontmatter
87
+ - `src/commands/project/doctor.js` — add skills version check
88
+ - `test/commands/doctor.test.js` — add tests
89
+
90
+ ---
91
+
92
+ ### Task 6 — Atomic state.json writes (prevent corruption on concurrent hook + CLI)
93
+
94
+ `state-manager.js` does direct `writeFileSync`. If `track-output-creation.js` hook fires while a CLI command is mid-write, the state file can be corrupted or half-written.
95
+
96
+ **Fix:** Use write-then-rename pattern in `saveState()`:
97
+ 1. Write to `state.json.tmp`
98
+ 2. `fs.renameSync('state.json.tmp', 'state.json')`
99
+
100
+ `renameSync` is atomic on the same filesystem (POSIX guarantee; on Windows, Node ≥ 14 uses `MoveFileExW` which is also atomic for same-volume).
101
+
102
+ Files:
103
+ - `src/core/state/state-manager.js` — update `saveState()`
104
+ - `test/core/state-manager.test.js` — add concurrent write test
105
+
106
+ ---
107
+
108
+ ## Intentionally Deferred
109
+
110
+ **Phase numbering refactor** (issue #11): Renaming phase IDs and output directories (0-proposal → proposal/, 1-design → design/, etc.) is a breaking change that affects state.json migration, all skill files, all hook paths, and user documentation simultaneously. High value, high risk — scope for a dedicated major version bump.
111
+
112
+ ---
113
+
114
+ ## Execution Order
115
+
116
+ ```
117
+ Task 1 (docs fix) → low risk, do first, no tests needed
118
+ Task 2 (unapprove) → small new command, fully testable
119
+ Task 3 (spec limit) → single hook + config schema
120
+ Task 4 (doctor) → extends existing doctor checks
121
+ Task 5 (cliVersion) → frontmatter + doctor extension
122
+ Task 6 (atomic) → state-manager internals
123
+ ```
124
+
125
+ Tasks 1–3 are independent and can be done in any order. Tasks 4–5 both extend doctor.js; do sequentially. Task 6 is self-contained.
@@ -0,0 +1,337 @@
1
+ # morph-init: LLM-Powered Project Initialization
2
+
3
+ **Status:** COMPLETE (see implementation plan)
4
+
5
+ **Date:** 2026-02-24
6
+ **Replaces:** `morph-spec init` as user-facing entry point
7
+
8
+ ---
9
+
10
+ ## Problem
11
+
12
+ `morph-spec init` relies on deterministic file-based detection that fails in three common scenarios:
13
+
14
+ 1. **Monorepos** — Next.js in `src/frontend/`, .NET in `src/backend/`; patterns look for config at project root only
15
+ 2. **Empty/new projects** — no files yet to detect
16
+ 3. **Non-standard layouts** — any structure outside expected conventions
17
+
18
+ When detection fails, it writes `architecture: "unknown"`, `stack: "dotnet"` (false positive), and a placeholder `context/README.md` with `(To be detected)`. MCP recommendations are also wrong because they depend on the detected stack.
19
+
20
+ Additionally, skills throughout the framework reference `superpowers:brainstorming`, `superpowers:writing-plans`, etc. — but nothing in init ensures those plugins are installed.
21
+
22
+ ---
23
+
24
+ ## Decision
25
+
26
+ Split init into two layers with clear responsibilities:
27
+
28
+ | Layer | Entry Point | Mechanism | Responsibility |
29
+ |-------|-------------|-----------|----------------|
30
+ | Infrastructure | `morph-spec setup-infra` (internal) | CLI, deterministic | Dirs, framework files, hooks, agents, rules, skills |
31
+ | Context + Config | `/morph-init` (skill) | LLM-powered | Stack detection, README.md, config.json, MCPs, plugins |
32
+
33
+ **User-facing flow:**
34
+ ```
35
+ npm install -g @polymorphism-tech/morph-spec
36
+ ↓ (postinstall copies morph-init.md → ~/.claude/skills/)
37
+
38
+ Open project in Claude Code
39
+ /morph-init ← single entry point for all users
40
+ ```
41
+
42
+ `morph-spec init` CLI remains for CI/CD and non-Claude-Code environments but is no longer the documented primary path.
43
+
44
+ ---
45
+
46
+ ## Architecture
47
+
48
+ ```
49
+ npm package (@polymorphism-tech/morph-spec)
50
+ ├── bin/morph-spec.js CLI — retains: status, update, doctor, mcp, etc.
51
+ │ init kept for headless/CI use only
52
+ ├── src/scripts/
53
+ │ ├── setup-infra.js NEW — headless infrastructure setup (no prompts)
54
+ │ ├── install-plugin.js NEW — auto-installs Claude Code plugins
55
+ │ └── global-install.js NEW — postinstall: copies morph-init.md globally
56
+ └── framework/skills/
57
+ └── level-0-meta/morph-init/
58
+ └── SKILL.md NEW — primary user entry point
59
+ ```
60
+
61
+ ---
62
+
63
+ ## Skill Design: `/morph-init`
64
+
65
+ ### Frontmatter
66
+
67
+ ```yaml
68
+ ---
69
+ name: morph-init
70
+ description: >
71
+ LLM-powered project initialization. Installs morph-spec infrastructure,
72
+ analyzes any project structure intelligently, generates rich context/README.md
73
+ and config.json, and configures MCPs. Use once per project after installing
74
+ @polymorphism-tech/morph-spec. Re-run with /morph-init refresh to update
75
+ context as project evolves.
76
+ argument-hint: "[refresh]"
77
+ user-invocable: true
78
+ allowed-tools: Read, Write, Edit, Bash, Glob, Grep
79
+ ---
80
+ ```
81
+
82
+ ---
83
+
84
+ ### Step 0 — Plugin Prerequisites
85
+
86
+ Check and auto-install `superpowers` and `context7` Claude Code plugins.
87
+
88
+ **Detection:**
89
+ ```bash
90
+ # Read ~/.claude/plugins/installed_plugins.json
91
+ # Check for keys: "superpowers@claude-plugins-official", "context7@claude-plugins-official"
92
+ ```
93
+
94
+ **Auto-install flow (for each missing plugin):**
95
+ ```
96
+ [Bash] node {morphSpecRoot}/scripts/install-plugin.js {plugin}
97
+ 1. GET github.com/anthropics/claude-plugins-official — resolve latest SHA/version
98
+ 2. Download plugin files recursively to:
99
+ ~/.claude/plugins/cache/claude-plugins-official/{plugin}/{version}/
100
+ 3. Register in installed_plugins.json:
101
+ { scope: "user", installPath: "...", version: "...",
102
+ installedAt: now, lastUpdated: now, gitCommitSha: "..." }
103
+ 4. SUCCESS → "✓ {plugin} installed."
104
+ 5. FAIL → show manual guide (see below) → STOP
105
+ ```
106
+
107
+ **Manual fallback (on auto-install failure):**
108
+ ```
109
+ ┌─────────────────────────────────────────────────────────────┐
110
+ │ Plugin {plugin} requires manual installation: │
111
+ │ │
112
+ │ 1. Claude Code → Settings (Cmd/Ctrl+,) → Extensions │
113
+ │ 2. Browse → search "{plugin}" → Install │
114
+ │ 3. Restart Claude Code │
115
+ │ 4. Re-run /morph-init │
116
+ └─────────────────────────────────────────────────────────────┘
117
+ → STOP — do not continue without required plugins
118
+ ```
119
+
120
+ Both `superpowers` and `context7` are required. Execution halts if either cannot be installed.
121
+
122
+ ---
123
+
124
+ ### Step 1 — Infrastructure
125
+
126
+ ```
127
+ Check if .morph/ exists:
128
+
129
+ MISSING → [Bash] npx morph-spec setup-infra
130
+ Creates: .morph/{config,framework,context,features,checkpoints,memory,archive}
131
+ Copies: framework files (templates, standards, rules, agents, skills, hooks)
132
+ Installs: .claude/agents/, .claude/rules/, .claude/skills/
133
+ Creates: config.json (minimal), context/README.md (placeholder)
134
+ Updates: .gitignore
135
+ → "✓ Infrastructure installed"
136
+
137
+ EXISTS + argument "refresh" → continue (will overwrite context/config)
138
+
139
+ EXISTS + no argument →
140
+ "MORPH already initialized. Refresh context and config? (y/n)"
141
+ n → STOP
142
+ ```
143
+
144
+ ---
145
+
146
+ ### Step 2 — LLM Project Analysis
147
+
148
+ Run in parallel to build an evidence map:
149
+
150
+ | Tool | Pattern | Signal |
151
+ |------|---------|--------|
152
+ | Glob | `**/package.json` | All package.json — detect next, supabase, clerk, stripe, etc. |
153
+ | Glob | `**/*.csproj` | .NET projects (any depth) |
154
+ | Glob | `**/next.config.{js,ts,mjs}` | Next.js in any subdirectory |
155
+ | Glob | `**/components.json` | shadcn/ui |
156
+ | Glob | `**/docker-compose*.yml` | Services in use |
157
+ | Glob | `database/migrations/**` | Supabase local dev |
158
+ | Glob | `supabase/**` | Supabase project config |
159
+ | Glob | `**/*.razor` | Blazor |
160
+ | Read | `.env.example` | Env vars reveal integrations |
161
+ | Read | `README.md` | Existing developer context |
162
+ | Grep | `@supabase/supabase-js` | Supabase dep in any package.json |
163
+ | Grep | `clerk\|auth0\|nextauth` | Authentication provider |
164
+ | Grep | `stripe\|asaas` | Payment provider |
165
+
166
+ **Output: evidence map**
167
+ ```json
168
+ {
169
+ "stack": ["nextjs", "dotnet"],
170
+ "integrations": ["supabase", "docker", "clerk"],
171
+ "uiLibrary": "shadcn",
172
+ "monorepo": true,
173
+ "frontendPath": "src/frontend",
174
+ "backendPath": "src/backend",
175
+ "confidence": { "stack": 0.98, "integrations": 0.91 }
176
+ }
177
+ ```
178
+
179
+ ---
180
+
181
+ ### Step 3 — Targeted Questions (max 3)
182
+
183
+ **Rule: only ask what cannot be inferred with ≥90% confidence.**
184
+
185
+ | Question | Condition | Purpose |
186
+ |----------|-----------|---------|
187
+ | "Em uma frase: qual é o objetivo principal do [ProjectName]?" | Always | Generate Overview in README.md |
188
+ | "Confirmo: frontend em `{frontendPath}`, backend em `{backendPath}`. Correto?" | Monorepo detected | Validate before persisting paths |
189
+ | "Supabase Cloud (managed) ou self-hosted?" | Supabase detected | Determines MCP URL configuration |
190
+
191
+ Do not ask about technology already confirmed by file evidence.
192
+
193
+ ---
194
+
195
+ ### Step 4 — Generate `context/README.md`
196
+
197
+ ```markdown
198
+ # [ProjectName] — Project Context
199
+
200
+ ## Overview
201
+ [Answer from question 1]
202
+
203
+ ## Tech Stack
204
+ | Layer | Technology | Location |
205
+ |------------|-------------------------|------------------|
206
+ | Frontend | Next.js 14 (App Router) | src/frontend/ |
207
+ | Backend | .NET 8 (Clean Arch.) | src/backend/ |
208
+ | Database | Supabase (PostgreSQL) | database/ |
209
+ | UI Library | shadcn/ui + Tailwind | components.json |
210
+ | Auth | Clerk | — |
211
+
212
+ ## Architecture
213
+ [Inferred + confirmed: monorepo / single-stack / etc.]
214
+ [Description of layers and responsibilities]
215
+
216
+ ## Key Integrations
217
+ [Per integration: service → purpose → detection evidence]
218
+
219
+ ## Agent Notes
220
+ [Conventions detected from eslint/tsconfig/.editorconfig,
221
+ important paths, project-specific patterns for MORPH agents]
222
+ ```
223
+
224
+ ---
225
+
226
+ ### Step 5 — Update `config.json`
227
+
228
+ ```json
229
+ {
230
+ "framework": "global",
231
+ "frameworkVersion": "4.x.x",
232
+ "project": {
233
+ "name": "ProspectPRO",
234
+ "description": "One-sentence objective from question 1",
235
+ "stack": "nextjs+dotnet",
236
+ "architecture": "monorepo",
237
+ "uiLibrary": "shadcn",
238
+ "integrations": ["supabase", "docker", "clerk"],
239
+ "frontendPath": "src/frontend",
240
+ "backendPath": "src/backend"
241
+ }
242
+ }
243
+ ```
244
+
245
+ ---
246
+
247
+ ### Step 6 — Configure MCPs
248
+
249
+ For each detected integration with an available MCP:
250
+
251
+ ```
252
+ supabase detected:
253
+ "Configure Supabase MCP now? (needs SUPABASE_URL + SERVICE_ROLE_KEY)"
254
+ YES → collect credentials → Write .claude/settings.local.json
255
+ NO → show config snippet + "morph-spec mcp setup supabase"
256
+
257
+ github:
258
+ "Configure GitHub MCP? (needs GITHUB_PERSONAL_ACCESS_TOKEN)"
259
+ YES/NO → same pattern
260
+
261
+ Others (Figma, Docker, Azure): only if explicitly detected in .env.example or mentioned
262
+ ```
263
+
264
+ ---
265
+
266
+ ### Step 7 — Final Output
267
+
268
+ ```
269
+ ✓ Plugins: superpowers v4.3.1 ✓ context7 ✓
270
+ ✓ Infrastructure: .morph/ structure, hooks, agents, rules, skills
271
+ ✓ context/README.md generated
272
+ ✓ config.json updated
273
+ Stack: nextjs+dotnet | Architecture: monorepo
274
+ Integrations: supabase, docker, clerk
275
+ ✓ MCPs: supabase configured
276
+ ○ Restart Claude Code to activate newly installed plugins
277
+
278
+ Next: /morph-proposal [feature-name]
279
+ ```
280
+
281
+ ---
282
+
283
+ ## CLI Changes
284
+
285
+ ### `morph-spec setup-infra` (new command)
286
+
287
+ Headless infrastructure-only setup. Called internally by the skill.
288
+ Same logic as current `morph-spec init` but:
289
+ - No interactive prompts
290
+ - No stack detection (that's the skill's job)
291
+ - No MCP setup (that's the skill's job)
292
+ - Writes minimal `config.json` (name + version only)
293
+ - Writes placeholder `context/README.md`
294
+
295
+ ### `morph-spec init` (modified)
296
+
297
+ Remains for CI/CD and non-Claude-Code environments.
298
+ Internally delegates to `setup-infra.js` for infrastructure,
299
+ then runs a best-effort detection pass.
300
+ No longer documented as primary user path.
301
+
302
+ ### `morph-spec doctor` (modified)
303
+
304
+ Add plugin checks:
305
+ ```
306
+ ✓ superpowers@claude-plugins-official installed?
307
+ ✓ context7@claude-plugins-official installed?
308
+ ```
309
+
310
+ ---
311
+
312
+ ## New Files
313
+
314
+ | File | Description |
315
+ |------|-------------|
316
+ | `framework/skills/level-0-meta/morph-init/SKILL.md` | Primary skill |
317
+ | `src/scripts/setup-infra.js` | Headless infrastructure setup |
318
+ | `src/scripts/install-plugin.js` | Auto-install CC plugins from GitHub |
319
+ | `src/scripts/global-install.js` | postinstall: copy skill to ~/.claude/skills/ |
320
+
321
+ ## Modified Files
322
+
323
+ | File | Change |
324
+ |------|--------|
325
+ | `package.json` | Add `"postinstall": "node scripts/global-install.js"` |
326
+ | `src/commands/project/init.js` | Delegate to setup-infra.js; remove context/MCP logic |
327
+ | `src/commands/project/doctor.js` | Add plugin presence checks |
328
+ | `src/lib/detectors/structure-detector.js` | Fix nextjs patterns for subdirectories (best-effort) |
329
+
330
+ ---
331
+
332
+ ## Out of Scope
333
+
334
+ - Removing `morph-spec init` entirely (kept for CI/CD)
335
+ - Plugin auto-update (only install if missing)
336
+ - Interactive stack selector fallback in CLI (skill handles this)
337
+ - shadcn MCP (no official MCP available)