@polymorphism-tech/morph-spec 4.6.0 → 4.7.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 (239) hide show
  1. package/README.md +414 -700
  2. package/docs/ARCHITECTURE.md +331 -0
  3. package/docs/CHEATSHEET.md +221 -0
  4. package/docs/COMMAND-FLOWS.md +368 -0
  5. package/docs/QUICKSTART.md +212 -0
  6. package/docs/examples/order-management/contracts.cs +84 -0
  7. package/docs/examples/order-management/proposal.md +24 -0
  8. package/docs/examples/order-management/spec.md +162 -0
  9. package/docs/plans/2026-02-23-ddd-architecture-refactor.md +1153 -0
  10. package/docs/plans/2026-02-23-ddd-nextsteps.md +682 -0
  11. package/docs/plans/2026-02-23-infra-architect-refactor.md +437 -0
  12. package/docs/plans/2026-02-23-nextjs-code-review-design.md +156 -0
  13. package/docs/plans/2026-02-23-nextjs-code-review-impl.md +1254 -0
  14. package/docs/plans/2026-02-23-nextjs-standards-design.md +149 -0
  15. package/docs/plans/2026-02-23-nextjs-standards-impl.md +1846 -0
  16. package/framework/agents/README.md +14 -14
  17. package/framework/agents/architecture/standards-architect.md +159 -159
  18. package/framework/agents/frontend/nextjs-expert.md +87 -127
  19. package/framework/agents/infrastructure/azure-architect.md +147 -147
  20. package/framework/agents/infrastructure/infra-architect.md +45 -0
  21. package/framework/agents.json +1145 -278
  22. package/framework/rules/frontend-standards.md +0 -3
  23. package/framework/rules/nextjs-standards.md +17 -0
  24. package/framework/skills/level-0-meta/code-review-nextjs/SKILL.md +147 -0
  25. package/framework/skills/level-0-meta/code-review-nextjs/references/review-example-nextjs.md +254 -0
  26. package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +3 -3
  27. package/framework/skills/level-1-workflows/phase-design/SKILL.md +45 -9
  28. package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +38 -0
  29. package/framework/standards/STANDARDS.json +121 -0
  30. package/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
  31. package/framework/standards/architecture/ddd/complexity-levels.md +108 -0
  32. package/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
  33. package/framework/standards/frontend/nextjs/app-router.md +123 -0
  34. package/framework/standards/frontend/nextjs/components.md +132 -0
  35. package/framework/standards/frontend/nextjs/data-fetching.md +126 -0
  36. package/framework/standards/frontend/nextjs/forms.md +128 -0
  37. package/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
  38. package/framework/standards/frontend/nextjs/project-structure.md +102 -0
  39. package/framework/standards/frontend/nextjs/state-management.md +72 -0
  40. package/framework/standards/frontend/nextjs/testing.md +111 -0
  41. package/framework/templates/REGISTRY.json +538 -142
  42. package/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
  43. package/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
  44. package/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
  45. package/framework/templates/docs/spec.md +49 -0
  46. package/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
  47. package/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
  48. package/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
  49. package/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
  50. package/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
  51. package/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
  52. package/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
  53. package/framework/templates/project-structure/dotnet-ddd.md +70 -0
  54. package/framework/workflows/docs/enforcement-pipeline.md +2 -1
  55. package/package.json +1 -1
  56. package/scripts/scan-nextjs.mjs +169 -0
  57. package/src/commands/project/doctor.js +52 -1
  58. package/src/commands/project/init.js +15 -1
  59. package/src/commands/project/update.js +6 -1
  60. package/src/lib/standards/standards-context-injector.js +5 -0
  61. package/src/lib/validators/nextjs/index.js +6 -0
  62. package/src/lib/validators/nextjs/next-component-validator.js +181 -0
  63. package/src/lib/validators/validation-runner.js +5 -0
  64. package/src/utils/agents-installer.js +14 -2
  65. package/.morph/.morphversion +0 -5
  66. package/.morph/analytics/threads-log.jsonl +0 -6
  67. package/.morph/config/config.json +0 -8
  68. package/.morph/framework/agents.json +0 -948
  69. package/.morph/framework/standards/STANDARDS.json +0 -812
  70. package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
  71. package/.morph/framework/standards/ai-agents/production.md +0 -415
  72. package/.morph/framework/standards/ai-agents/setup.md +0 -418
  73. package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
  74. package/.morph/framework/standards/ai-agents/workflows.md +0 -354
  75. package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
  76. package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
  77. package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
  78. package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
  79. package/.morph/framework/standards/backend/api/rest.md +0 -492
  80. package/.morph/framework/standards/backend/api/validation.md +0 -88
  81. package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
  82. package/.morph/framework/standards/backend/database/ef-core.md +0 -199
  83. package/.morph/framework/standards/backend/database/migrations.md +0 -393
  84. package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
  85. package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
  86. package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
  87. package/.morph/framework/standards/backend/dotnet/async.md +0 -366
  88. package/.morph/framework/standards/backend/dotnet/core.md +0 -117
  89. package/.morph/framework/standards/backend/dotnet/di.md +0 -439
  90. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
  91. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
  92. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
  93. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
  94. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
  95. package/.morph/framework/standards/context/analytics.md +0 -96
  96. package/.morph/framework/standards/context/bundles.md +0 -110
  97. package/.morph/framework/standards/context/priming.md +0 -78
  98. package/.morph/framework/standards/core/architecture.md +0 -185
  99. package/.morph/framework/standards/core/coding.md +0 -214
  100. package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
  101. package/.morph/framework/standards/core/git.md +0 -185
  102. package/.morph/framework/standards/core/testing.md +0 -295
  103. package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
  104. package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
  105. package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
  106. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
  107. package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
  108. package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
  109. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
  110. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
  111. package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
  112. package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
  113. package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
  114. package/.morph/framework/standards/frontend/blazor/state.md +0 -191
  115. package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
  116. package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
  117. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -215
  118. package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
  119. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
  120. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
  121. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
  122. package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
  123. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
  124. package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
  125. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
  126. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
  127. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
  128. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
  129. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
  130. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
  131. package/.morph/framework/standards/integration/api/graphql.md +0 -91
  132. package/.morph/framework/standards/integration/api/grpc.md +0 -114
  133. package/.morph/framework/standards/integration/api/rest-design.md +0 -95
  134. package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
  135. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
  136. package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
  137. package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
  138. package/.morph/framework/standards/observability/logging.md +0 -131
  139. package/.morph/framework/standards/observability/metrics.md +0 -121
  140. package/.morph/framework/standards/observability/monitoring.md +0 -114
  141. package/.morph/framework/standards/observability/tracing.md +0 -132
  142. package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
  143. package/.morph/framework/standards/workflows/thread-management.md +0 -113
  144. package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
  145. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
  146. package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
  147. package/.morph/framework/templates/README.md +0 -814
  148. package/.morph/framework/templates/REGISTRY.json +0 -1492
  149. package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
  150. package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
  151. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
  152. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
  153. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
  154. package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
  155. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
  156. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  157. package/.morph/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
  158. package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
  159. package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
  160. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
  161. package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
  162. package/.morph/framework/templates/code/dotnet/test.cs +0 -239
  163. package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
  164. package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
  165. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
  166. package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
  167. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
  168. package/.morph/framework/templates/context/CONTEXT.md +0 -181
  169. package/.morph/framework/templates/docs/clarifications.md +0 -253
  170. package/.morph/framework/templates/docs/onboarding.md +0 -123
  171. package/.morph/framework/templates/docs/proposal.md +0 -182
  172. package/.morph/framework/templates/docs/schema-analysis.md +0 -119
  173. package/.morph/framework/templates/docs/spec.md +0 -149
  174. package/.morph/framework/templates/docs/ui-components.md +0 -124
  175. package/.morph/framework/templates/docs/ui-design-system.md +0 -76
  176. package/.morph/framework/templates/docs/ui-flows.md +0 -167
  177. package/.morph/framework/templates/docs/ui-mockups.md +0 -98
  178. package/.morph/framework/templates/docs/user-stories.md +0 -34
  179. package/.morph/framework/templates/examples/design-system-examples.md +0 -357
  180. package/.morph/framework/templates/examples/spec-examples.md +0 -90
  181. package/.morph/framework/templates/feature/decisions.md +0 -187
  182. package/.morph/framework/templates/feature/recap.md +0 -146
  183. package/.morph/framework/templates/feature/tasks.md +0 -199
  184. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
  185. package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
  186. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
  187. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
  188. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
  189. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
  190. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
  191. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
  192. package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
  193. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
  194. package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
  195. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
  196. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
  197. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
  198. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
  199. package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
  200. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
  201. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
  202. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
  203. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
  204. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
  205. package/.morph/framework/templates/infrastructure/github/README.md +0 -593
  206. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
  207. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
  208. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
  209. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
  210. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
  211. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
  212. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
  213. package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
  214. package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
  215. package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
  216. package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
  217. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
  218. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
  219. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
  220. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
  221. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
  222. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
  223. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
  224. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
  225. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
  226. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
  227. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
  228. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
  229. package/.morph/framework/templates/saas/subscription.cs +0 -347
  230. package/.morph/framework/templates/saas/tenant.cs +0 -338
  231. package/.morph/framework/templates/state.template.json +0 -17
  232. package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
  233. package/.morph/framework/templates/ui/MudTheme.cs +0 -281
  234. package/.morph/framework/templates/ui/design-system.css +0 -226
  235. package/.morph/logs/tool-failures.log +0 -7
  236. package/.morph/memory/pre-compact-2026-02-23T15-43-03-521Z.json +0 -16
  237. package/.morph/state.json +0 -48
  238. package/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
  239. package/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
@@ -1,96 +0,0 @@
1
- # Context Standard: Context Analytics
2
-
3
- ## Overview
4
- Context analytics tracks token usage, identifies optimization opportunities, and monitors session efficiency.
5
-
6
- ## Metrics Collected
7
-
8
- ### Session Metrics
9
- - Session ID, start time, feature, agent
10
- - Token usage at session start vs end
11
- - Optimization actions taken
12
- - Files read (and token cost per file)
13
-
14
- ### Context Efficiency Score
15
- ```
16
- Efficiency = 1 - (contextTokens / totalContextCapacity)
17
- Target: > 0.6 (60% of context available for work)
18
- Warning: < 0.4 (less than 40% available)
19
- Critical: < 0.2 (less than 20% available)
20
- ```
21
-
22
- ## Viewing Analytics
23
-
24
- ### Feature Analytics
25
- ```bash
26
- morph-spec analytics feature morph-next-gen
27
-
28
- # Context Usage — morph-next-gen
29
- # ─────────────────────────────────────
30
- # Sessions: 12
31
- # Avg session tokens: 45,200
32
- # Total tokens used: 542,400
33
- #
34
- # Efficiency distribution:
35
- # Excellent (>0.8) ████████░░ 8/12 (67%)
36
- # Good (0.6-0.8) ██░░░░░░░░ 2/12 (17%)
37
- # Poor (<0.6) ██░░░░░░░░ 2/12 (17%)
38
- #
39
- # Top token consumers:
40
- # CLAUDE.md 23,000 tokens (42%)
41
- # standards/coding.md 2,100 tokens (4%)
42
- # spec.md 1,800 tokens (3%)
43
- #
44
- # Optimizations recommended:
45
- # → Replace CLAUDE.md with priming file (save ~22,500 tokens)
46
- # → Use context bundle for resume sessions
47
- ```
48
-
49
- ### Context Dashboard
50
- ```bash
51
- morph-spec analytics context
52
-
53
- # Core Four Status
54
- # ─────────────────────────────────────
55
- # Context: [████████░░░░░░░░░░░░] 41% (82,000/200,000 tokens)
56
- # Model: claude-sonnet-4-6
57
- # Prompt: 3,200 tokens (current turn)
58
- # Tools: 12 tools active
59
- ```
60
-
61
- ## Optimization Triggers
62
-
63
- | Condition | Trigger | Action |
64
- |-----------|---------|--------|
65
- | Context > 75% | Warning | Suggest bundle creation |
66
- | Context > 90% | Critical | Auto-suggest micro-agent split |
67
- | CLAUDE.md loaded | Info | Suggest priming file |
68
- | > 5 standards loaded | Info | Suggest standards subset |
69
- | Unused MCP servers | Warning | Suggest MCP hygiene |
70
-
71
- ## Analytics Storage
72
- Events stored in JSONL format at `.morph/analytics/`:
73
- - `threads-log.jsonl` — thread lifecycle events
74
- - `context-log.jsonl` — context optimization events
75
- - `trust-log.jsonl` — trust/approval events
76
-
77
- Each event:
78
- ```json
79
- {
80
- "timestamp": "2026-02-19T00:00:00Z",
81
- "type": "context_warning",
82
- "feature": "morph-next-gen",
83
- "data": {
84
- "contextPercent": 82,
85
- "tokensUsed": 164000,
86
- "totalCapacity": 200000,
87
- "recommendation": "CREATE_BUNDLE"
88
- }
89
- }
90
- ```
91
-
92
- ## Pruning
93
- Analytics auto-prune after 90 days. Manual prune:
94
- ```bash
95
- morph-spec analytics project --prune 30
96
- ```
@@ -1,110 +0,0 @@
1
- # Context Standard: Context Bundles
2
-
3
- ## Overview
4
- Context bundles are compressed snapshots of feature state for resuming long-running sessions without re-reading all files.
5
-
6
- ## What a Bundle Contains
7
-
8
- ```json
9
- {
10
- "bundleId": "morph-next-gen-20260219-001",
11
- "feature": "morph-next-gen",
12
- "createdAt": "2026-02-19T00:00:00Z",
13
- "tokensEstimated": 14800,
14
- "compressionRatio": 0.12,
15
-
16
- "spec": {
17
- "problem": "1-2 sentence problem statement",
18
- "solution": "1-2 sentence solution approach",
19
- "keyRequirements": ["REQ1", "REQ2", "REQ3"],
20
- "dataModel": ["Entity1 (fields)", "Entity2 (fields)"]
21
- },
22
-
23
- "decisions": [
24
- { "id": "ADR-001", "summary": "Chose X over Y because Z", "fullPath": "decisions.md#adr-001" }
25
- ],
26
-
27
- "tasks": {
28
- "completed": ["T001", "T002", "T003"],
29
- "inProgress": "T004",
30
- "pending": ["T005", "T006"],
31
- "total": 10,
32
- "progress": "30%"
33
- },
34
-
35
- "checkpoints": [
36
- { "num": 1, "passed": true, "validatorsRun": ["architecture", "security"] }
37
- ],
38
-
39
- "agents": ["dotnet-senior", "ef-modeler"],
40
-
41
- "resumeHints": [
42
- "Currently implementing: T004 - Create UserService",
43
- "Last file modified: Services/UserService.cs",
44
- "Pending issue: DbContext injection pattern needs review"
45
- ]
46
- }
47
- ```
48
-
49
- ## Creating and Using Bundles
50
-
51
- ### Create a Bundle (auto or manual)
52
- ```bash
53
- # Auto-created on task completion (configured in llm-interaction.json)
54
- # Manual creation:
55
- morph-spec bundle create morph-next-gen
56
-
57
- # Output:
58
- # ✅ Bundle created: .morph/bundles/morph-next-gen-20260219-001.json
59
- # Original context: ~180,000 tokens
60
- # Bundle: ~15,000 tokens (compression: 92%)
61
- ```
62
-
63
- ### Load Bundle for Resume
64
- ```bash
65
- # Load latest bundle for feature
66
- morph-spec bundle load morph-next-gen
67
-
68
- # Generates resume context to stdout:
69
- # "You are resuming the morph-next-gen feature. Current phase: implement.
70
- # Last completed: T003. Next task: T004 (Create UserService)..."
71
- ```
72
-
73
- ### List Bundles
74
- ```bash
75
- morph-spec bundle list morph-next-gen
76
-
77
- # ID Created Tokens Compression
78
- # morph-next-gen-20260219-001 2026-02-19 14,800 92%
79
- # morph-next-gen-20260218-001 2026-02-18 12,400 94%
80
- ```
81
-
82
- ## Bundle vs Full Context
83
-
84
- | Scenario | Use |
85
- |----------|-----|
86
- | Starting fresh implementation | Full spec + tasks + standards |
87
- | Resuming mid-session | Bundle (loads in seconds) |
88
- | Micro-agent handoff | Bundle with agent-specific slice |
89
- | Cross-day resume | Bundle + load specific changed files |
90
-
91
- ## Auto-Bundle Configuration
92
- ```json
93
- // .morph/config/llm-interaction.json
94
- {
95
- "contextOptimization": {
96
- "bundles": {
97
- "enabled": true,
98
- "directory": ".morph/bundles/",
99
- "createOnTaskDone": true,
100
- "maxBundles": 10
101
- }
102
- }
103
- }
104
- ```
105
-
106
- ## Bundle Lifecycle
107
- - Created: on task completion (if auto-enabled)
108
- - Retained: last 10 bundles per feature
109
- - Invalidated: when spec.md is modified (decisions changed)
110
- - Deleted: when feature is archived
@@ -1,78 +0,0 @@
1
- # Context Standard: Priming Files
2
-
3
- ## Overview
4
- Priming files are ~500-token summaries replacing the full CLAUDE.md (23K tokens) for focused work sessions.
5
-
6
- ## When to Use Priming Files
7
- - Starting a new task where full CLAUDE.md is unnecessary
8
- - Micro-agent sessions with narrow scope
9
- - Parallel workers that only need domain-specific context
10
-
11
- ## Available Priming Files
12
-
13
- | File | Focus | When to Use |
14
- |------|-------|-------------|
15
- | `.morph/context/feature-prime.md` | Feature implementation | Implementing a new feature |
16
- | `.morph/context/bug-prime.md` | Bug fixing | Fixing a reported bug |
17
- | `.morph/context/refactor-prime.md` | Refactoring | Code improvement without behavior change |
18
- | `.morph/context/design-prime.md` | Design phase | Creating spec.md, decisions.md |
19
- | `.morph/context/infra-prime.md` | Infrastructure | Bicep, Docker, deployment |
20
-
21
- ## Loading a Priming File
22
- ```bash
23
- # Load priming file into context
24
- morph-spec prime feature
25
-
26
- # Output: contents of feature-prime.md to stdout
27
- # AI should read this instead of full CLAUDE.md
28
-
29
- # For micro-agents:
30
- morph-spec micro-agent create bug-fixer \
31
- --prime bug \
32
- --standards "core/coding.md"
33
- ```
34
-
35
- ## Creating Custom Priming Files
36
-
37
- Keep priming files under 600 tokens (≈3000 characters):
38
- ```markdown
39
- # {Context Name} — Quick Reference
40
-
41
- ## Stack
42
- - Backend: .NET 10 Blazor Server
43
- - DB: Azure SQL (EF Core)
44
- - Deploy: Azure Container Apps
45
-
46
- ## Key Patterns
47
- - Use IDbContextFactory<> (not DbContext directly)
48
- - Async/await throughout
49
- - DI order: DbContext → Services → Controllers
50
-
51
- ## Current Feature
52
- {Feature summary in 2-3 sentences}
53
-
54
- ## Critical Files
55
- - spec.md: [path]
56
- - contracts.cs: [path]
57
- - tasks.json: [path]
58
-
59
- ## Do Not Touch
60
- - [files to avoid]
61
- ```
62
-
63
- ## Token Budget Guidelines
64
-
65
- | Context Type | Tokens | Use Case |
66
- |--------------|--------|----------|
67
- | Full CLAUDE.md | ~23,000 | Full orchestrator session |
68
- | Priming file | ~500 | Focused task session |
69
- | Context bundle | ~15,000 | Feature resume (compressed) |
70
- | Standards subset | ~2,000/file | Domain specialist |
71
- | Agent prompt | ~1,000 | Micro-agent task |
72
-
73
- ## Optimization Flow
74
- 1. Start with priming file (500 tokens)
75
- 2. Load relevant standards (2,000 tokens/file, max 3 files)
76
- 3. Load spec summary from metadata.json (not full spec.md)
77
- 4. Load tasks.json for current phase only
78
- 5. Total budget: target < 8,000 tokens for routine tasks
@@ -1,185 +0,0 @@
1
- # Architecture Standards
2
-
3
- > **Scope:** universal
4
- > **Layer:** 0 (always load)
5
- > **Keywords:** architecture, clean, solid, layers, di, separation of concerns
6
- > **Load When:** always
7
-
8
- Architecture patterns, layer responsibilities, and structural rules.
9
-
10
- ---
11
-
12
- ## Clean Architecture Layers
13
-
14
- ```
15
- ┌───────────────────────────────────────┐
16
- │ Web (Blazor/NextJS, API) │ ← Entry, UI, controllers
17
- │ ┌─────────────────────────────────┐ │
18
- │ │ Infrastructure (EF, External) │ │ ← Data, services
19
- │ │ ┌───────────────────────────┐ │ │
20
- │ │ │ Application (Services) │ │ │ ← Business logic
21
- │ │ │ ┌───────────────────┐ │ │ │
22
- │ │ │ │ Domain (Entities) │ │ │ │ ← Core
23
- │ │ │ └───────────────────┘ │ │ │
24
- │ │ └───────────────────────────┘ │ │
25
- │ └─────────────────────────────────┘ │
26
- └───────────────────────────────────────┘
27
- ```
28
-
29
- **Dependency Rule:** Inner layers NEVER reference outer layers.
30
-
31
- ---
32
-
33
- ## Layer Responsibilities
34
-
35
- | Layer | Contains | References | Key Packages |
36
- |-------|----------|------------|--------------|
37
- | **Domain** | Entities, Value Objects, Enums, Interfaces | None | None (pure C#) |
38
- | **Application** | Services, DTOs, Validators | Domain | FluentValidation, MediatR |
39
- | **Infrastructure** | DbContext, Repositories, External clients | Domain, Application | EF Core, HttpClient |
40
- | **Web** | Pages, Components, Controllers, Program.cs | All | Blazor, Fluent UI |
41
-
42
- ---
43
-
44
- ## Project Structure
45
-
46
- ```
47
- src/{App}.Domain/
48
- Entities/ Order.cs, Customer.cs
49
- ValueObjects/ Money.cs, Address.cs
50
- Enums/ OrderStatus.cs
51
- Interfaces/ IOrderRepository.cs
52
-
53
- src/{App}.Application/
54
- Services/ OrderService.cs
55
- DTOs/ OrderResponse.cs
56
- Validators/ CreateOrderValidator.cs
57
-
58
- src/{App}.Infrastructure/
59
- Data/
60
- AppDbContext.cs
61
- Configurations/ OrderConfiguration.cs
62
- Repositories/ OrderRepository.cs
63
- Services/ AsaasPaymentService.cs
64
-
65
- src/{App}.Web/
66
- Components/
67
- Layout/ MainLayout.razor
68
- Pages/ Orders.razor
69
- wwwroot/
70
- Program.cs
71
- ```
72
-
73
- ---
74
-
75
- ## File Organization
76
-
77
- | Rule | Description |
78
- |------|-------------|
79
- | One class per file | `OrderService.cs` for `OrderService` |
80
- | Folder = namespace | `Entities/Order.cs` → `MyApp.Domain.Entities` |
81
- | No nested classes | Except private helpers |
82
- | Extensions per layer | `ServiceCollectionExtensions.cs` in each project |
83
-
84
- ---
85
-
86
- ## SOLID Quick Reference
87
-
88
- | Principle | Rule | Signal |
89
- |-----------|------|--------|
90
- | **S** Single Responsibility | One reason to change | Class > 300 lines? Mix DB + email + validation? Split. |
91
- | **O** Open/Closed | Extend via new classes | `switch` on type? Use polymorphism. |
92
- | **L** Liskov Substitution | Subtypes substitutable | Override throws `NotSupportedException`? Violation. |
93
- | **I** Interface Segregation | Small interfaces | Interface with 10+ methods? Split. |
94
- | **D** Dependency Inversion | Depend on abstractions | Concrete class in constructor? Use interface. |
95
-
96
- ---
97
-
98
- ## Service Patterns
99
-
100
- | Pattern | When | Complexity |
101
- |---------|------|-----------|
102
- | Direct DbContext | Simple CRUD, < 3 entities | Low |
103
- | Repository | Data abstraction, testability | Medium |
104
- | Repository Factory | Background ops, Hangfire | Medium |
105
- | CQRS | Read/write models differ | Medium-High |
106
- | MediatR | Decouple handlers, pipelines | Medium |
107
-
108
- ```csharp
109
- public sealed class OrderService(IOrderRepository repository, ILogger<OrderService> logger) : IOrderService
110
- {
111
- public async Task<Result<OrderResponse>> CreateAsync(CreateOrderRequest request, CancellationToken ct = default)
112
- {
113
- logger.LogInformation("Creating order for {CustomerId}", request.CustomerId);
114
- if (request.Items.Count == 0)
115
- return Result.Failure<OrderResponse>("Order must have items");
116
-
117
- var order = Order.Create(request.CustomerId, request.Items);
118
- await repository.AddAsync(order, ct);
119
- await repository.SaveChangesAsync(ct);
120
- return Result.Success(order.ToResponse());
121
- }
122
- }
123
- ```
124
-
125
- ---
126
-
127
- ## DI Registration Pattern
128
-
129
- ```csharp
130
- // Program.cs
131
- builder.Services
132
- .AddApplication()
133
- .AddInfrastructure(builder.Configuration)
134
- .AddWeb();
135
-
136
- // Application/Extensions/ServiceCollectionExtensions.cs
137
- public static IServiceCollection AddApplication(this IServiceCollection services)
138
- {
139
- services.AddScoped<IOrderService, OrderService>();
140
- services.AddValidatorsFromAssemblyContaining<CreateOrderValidator>();
141
- return services;
142
- }
143
-
144
- // Infrastructure/Extensions/ServiceCollectionExtensions.cs
145
- public static IServiceCollection AddInfrastructure(this IServiceCollection services, IConfiguration config)
146
- {
147
- var conn = config.GetConnectionString("Default");
148
- services.AddDbContext<AppDbContext>(o => o.UseSqlServer(conn));
149
- services.AddDbContextFactory<AppDbContext>(o => o.UseSqlServer(conn));
150
- services.AddScoped<IOrderRepository, OrderRepository>();
151
- return services;
152
- }
153
- ```
154
-
155
- ---
156
-
157
- ## Architecture Smells
158
-
159
- | Smell | Signal | Fix |
160
- |-------|--------|-----|
161
- | Circular dependency | A refs B, B refs A | Extract shared interface to lower layer |
162
- | Fat controller/page | Page > 50 lines logic | Extract to service |
163
- | Anemic domain | Entities data-only | Move behavior into entities |
164
- | God class | > 500 lines, 10+ deps | Split by responsibility |
165
- | Service locator | `IServiceProvider.GetService<T>()` | Constructor injection |
166
- | Over-abstraction | Interface, one impl, never mocked | Use concrete class |
167
- | Under-abstraction | External service called directly | Extract interface |
168
- | Leaking infrastructure | `DbContext` in Web layer | Route through Application |
169
-
170
- ---
171
-
172
- ## Checklist
173
-
174
- - [ ] No circular references (`dotnet build` clean)
175
- - [ ] Domain has zero NuGet packages
176
- - [ ] No unused project references
177
- - [ ] Every interface has consumer (no "just in case")
178
- - [ ] External services through interfaces
179
- - [ ] Configuration via Options pattern
180
- - [ ] No hardcoded secrets in code
181
- - [ ] All secrets in Key Vault or user-secrets
182
-
183
- ---
184
-
185
- *MORPH-SPEC by Polymorphism Tech*
@@ -1,214 +0,0 @@
1
- # C# Coding Standards
2
-
3
- > **Scope:** universal
4
- > **Layer:** 0 (always load)
5
- > **Keywords:** coding, naming, async, style, conventions, csharp
6
- > **Load When:** always
7
-
8
- Single source of truth for C# naming conventions, code style, and enforcement.
9
- Based on [Microsoft C# Coding Conventions](https://learn.microsoft.com/en-us/dotnet/csharp/fundamentals/coding-style/coding-conventions) and [.NET Naming Guidelines](https://learn.microsoft.com/en-us/dotnet/standard/design-guidelines/naming-guidelines).
10
-
11
- ---
12
-
13
- ## Naming Conventions
14
-
15
- | Element | Convention | Example |
16
- |---------|-----------|---------|
17
- | Classes | PascalCase | `OrderService` |
18
- | Interfaces | `I` + PascalCase | `IOrderService` |
19
- | Methods | PascalCase | `GetOrderAsync` |
20
- | Async methods | + `Async` suffix | `ProcessPaymentAsync` |
21
- | Properties | PascalCase | `OrderTotal` |
22
- | Constants | PascalCase | `DefaultPageSize` **NOT** `DEFAULT_PAGE_SIZE` |
23
- | Enums / Members | PascalCase | `OrderStatus.PendingPayment` **NOT** `PENDING_PAYMENT` |
24
- | Namespaces | PascalCase | `MyApp.Domain` |
25
- | Type parameters | `T` + PascalCase | `TEntity`, `TResult` |
26
- | Private fields | `_camelCase` | `_orderRepository` |
27
- | Static private | `s_camelCase` | `s_instance` |
28
- | Thread-static | `t_camelCase` | `t_contextId` |
29
- | Locals / Params | camelCase | `orderId`, `orderTotal` |
30
-
31
- ### Acronyms
32
-
33
- | Length | Rule | Example |
34
- |--------|------|---------|
35
- | 2 chars | Both uppercase | `IO`, `UI` |
36
- | 3+ chars | PascalCase | `Html`, `Xml`, `Http` |
37
-
38
- ### DON'T
39
-
40
- | Wrong | Right |
41
- |-------|-------|
42
- | `strName`, `iCount` | `name`, `count` |
43
- | `MAX_RETRY_COUNT` | `MaxRetryCount` |
44
- | `btnSubmit`, `lblName` | `submitButton`, `nameLabel` |
45
- | `order_total`, `get_order` | `orderTotal`, `GetOrder` |
46
- | `repo`, `ctx`, `mgr`, `svc` | `repository`, `context`, `manager`, `service` |
47
- | `Int32 count`, `String name` | `int count`, `string name` |
48
-
49
- ---
50
-
51
- ## Code Style
52
-
53
- ### Modern C# (10+)
54
-
55
- ```csharp
56
- namespace MyApp.Application.Services; // File-scoped
57
-
58
- public sealed class OrderService(IOrderRepository repository) : IOrderService
59
- {
60
- public async Task<Result<Order>> GetByIdAsync(int id, CancellationToken ct = default)
61
- {
62
- var order = await repository.GetByIdAsync(id, ct);
63
- return order is null
64
- ? Result.Failure<Order>("Not found")
65
- : Result.Success(order);
66
- }
67
- }
68
- ```
69
-
70
- ### Style Rules
71
-
72
- | Rule | Wrong | Right |
73
- |------|-------|-------|
74
- | `var` when obvious | `OrderDto order = new OrderDto()` | `var order = new OrderDto()` |
75
- | Target-typed `new` | `OrderDto order = new OrderDto()` | `OrderDto order = new()` |
76
- | Null checks | `== null`, `!= null` | `is null`, `is not null` |
77
- | Collections | `new List<int> { 1, 2 }` | `List<int> items = [1, 2]` |
78
- | Expression body | `{ return _name; }` | `=> _name;` |
79
- | Nullable refs | Disabled | `<Nullable>enable</Nullable>` |
80
- | Pattern matching | `if (x is int)` then cast | `if (x is int value)` |
81
- | Default `sealed` | Unsealed classes | `sealed` unless inheritance needed |
82
-
83
- ### Complexity Thresholds
84
-
85
- | Metric | Limit |
86
- |--------|-------|
87
- | Method length | < 30 lines (prefer < 20) |
88
- | Method parameters | ≤ 4 (use record for more) |
89
- | Class length | < 300 lines |
90
- | Nesting depth | ≤ 3 levels |
91
- | Cyclomatic complexity | < 10 per method |
92
-
93
- ---
94
-
95
- ## Async Conventions
96
-
97
- ```csharp
98
- // ALWAYS: Async suffix + CancellationToken
99
- public async Task<Order> GetOrderAsync(int id, CancellationToken ct = default)
100
-
101
- // NEVER: .Result or .Wait() (deadlock risk in Blazor Server)
102
- var order = await service.GetOrderAsync(id, ct); // Correct
103
- var order = service.GetOrderAsync(id).Result; // DEADLOCK
104
-
105
- // NEVER: async void (except event handlers)
106
- public async Task HandleClickAsync() { } // Correct
107
- public async void HandleClick() { } // exceptions lost
108
- ```
109
-
110
- ---
111
-
112
- ## Dependency Injection
113
-
114
- | Lifetime | When | Example |
115
- |----------|------|---------|
116
- | **Scoped** | DbContext, per-request | `AddScoped<IOrderService, OrderService>()` |
117
- | **Singleton** | Factories, caches | `AddSingleton<IRepositoryFactory>()` |
118
- | **Transient** | Lightweight, stateless | `AddTransient<IValidator<Order>>()` |
119
-
120
- ```csharp
121
- // Constructor injection with interfaces
122
- public sealed class OrderService(IOrderRepository repository, ILogger<OrderService> logger)
123
-
124
- // Service Locator anti-pattern
125
- var service = serviceProvider.GetService<IOrderService>();
126
- ```
127
-
128
- ---
129
-
130
- ## Logging
131
-
132
- ```csharp
133
- // Structured logging with message templates
134
- logger.LogInformation("Processing order {OrderId} for {CustomerId}", orderId, customerId);
135
-
136
- // String interpolation defeats structured logging
137
- logger.LogInformation($"Processing order {orderId}"); // WRONG
138
-
139
- // Include correlation IDs
140
- logger.LogError(ex, "Failed to process order {OrderId}", orderId);
141
- ```
142
-
143
- | Level | When |
144
- |-------|------|
145
- | `Trace` | Fine-grained diagnostic (dev only) |
146
- | `Debug` | Internal state, troubleshooting |
147
- | `Information` | Normal operations (start, complete, key decisions) |
148
- | `Warning` | Unexpected but recoverable (retry, fallback) |
149
- | `Error` | Failure requiring attention |
150
- | `Critical` | System-level failure (app crash, data corruption) |
151
-
152
- ---
153
-
154
- ## Error Handling
155
-
156
- ```csharp
157
- // Result pattern for business errors
158
- public async Task<Result<Order>> ProcessAsync(Guid id, CancellationToken ct)
159
- {
160
- var order = await _repository.GetByIdAsync(id, ct);
161
- if (order is null) return Result.Failure<Order>("Not found");
162
- if (order.Status >= OrderStatus.Completed)
163
- return Result.Failure<Order>("Already completed");
164
- return Result.Success(order);
165
- }
166
-
167
- // Exceptions for infrastructure errors only
168
- // NEVER: empty catch or swallowed exceptions
169
- try { await _client.SendAsync(request, ct); }
170
- catch (Exception) { } // WRONG
171
-
172
- // ALWAYS: preserve inner exception
173
- catch (HttpRequestException ex)
174
- {
175
- throw new PaymentGatewayException("Payment failed", ex);
176
- }
177
-
178
- // ALWAYS: specific exception types
179
- catch (DbUpdateConcurrencyException ex) { /* handle */ }
180
- catch (Exception ex) { /* log and rethrow */ throw; }
181
- ```
182
-
183
- ---
184
-
185
- ## .editorconfig Template
186
-
187
- Minimal `.editorconfig` for enforcement:
188
-
189
- ```ini
190
- [*.cs]
191
- # Naming
192
- dotnet_naming_rule.interfaces.severity = error
193
- dotnet_naming_rule.interfaces.symbols = interface
194
- dotnet_naming_rule.interfaces.style = begins_with_i
195
-
196
- # File-scoped namespaces
197
- csharp_style_namespace_declarations = file_scoped:warning
198
-
199
- # var preferences
200
- csharp_style_var_when_type_is_apparent = true:suggestion
201
-
202
- # Null checks
203
- dotnet_style_prefer_is_null_check_over_reference_equality_method = true:warning
204
-
205
- # Async suffix
206
- dotnet_naming_rule.async_methods.severity = warning
207
- dotnet_naming_rule.async_methods.required_suffix = Async
208
- ```
209
-
210
- Full template: `.editorconfig` in project root.
211
-
212
- ---
213
-
214
- *MORPH-SPEC by Polymorphism Tech*