@polymorphism-tech/morph-spec 4.3.1 → 4.3.3

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 (194) hide show
  1. package/bin/morph-spec.js +1 -1
  2. package/package.json +2 -1
  3. package/src/commands/project/doctor.js +24 -18
  4. package/src/commands/project/init.js +15 -5
  5. package/src/commands/project/update.js +7 -3
  6. package/src/commands/state/state.js +24 -2
  7. package/src/core/templates/template-registry.js +1 -1
  8. package/src/core/workflows/workflow-detector.js +2 -2
  9. package/stacks/blazor-azure/.claude/commands/morph-apply.md +221 -0
  10. package/stacks/blazor-azure/.claude/commands/morph-archive.md +79 -0
  11. package/stacks/blazor-azure/.claude/commands/morph-deploy.md +529 -0
  12. package/stacks/blazor-azure/.claude/commands/morph-infra.md +209 -0
  13. package/stacks/blazor-azure/.claude/commands/morph-preflight.md +227 -0
  14. package/stacks/blazor-azure/.claude/commands/morph-proposal.md +122 -0
  15. package/stacks/blazor-azure/.claude/commands/morph-status.md +86 -0
  16. package/stacks/blazor-azure/.claude/commands/morph-troubleshoot.md +122 -0
  17. package/stacks/blazor-azure/.morph/.morphversion +5 -5
  18. package/stacks/blazor-azure/.morph/config/config.json +9 -0
  19. package/stacks/blazor-azure/.morph/project/context/README.md +17 -0
  20. package/stacks/blazor-azure/.morph/standards/ai-agents/blazor-ui.md +364 -0
  21. package/stacks/blazor-azure/.morph/standards/ai-agents/production.md +415 -0
  22. package/stacks/blazor-azure/.morph/standards/ai-agents/setup.md +418 -0
  23. package/stacks/blazor-azure/.morph/standards/ai-agents/team-orchestration.md +479 -0
  24. package/stacks/blazor-azure/.morph/standards/ai-agents/workflows.md +354 -0
  25. package/stacks/blazor-azure/.morph/standards/architecture/ddd/aggregates.md +120 -0
  26. package/stacks/blazor-azure/.morph/standards/architecture/ddd/entities.md +99 -0
  27. package/stacks/blazor-azure/.morph/standards/architecture/ddd/value-objects.md +124 -0
  28. package/stacks/blazor-azure/.morph/standards/backend/api/minimal-api.md +494 -0
  29. package/stacks/blazor-azure/.morph/standards/backend/api/rest.md +492 -0
  30. package/stacks/blazor-azure/.morph/standards/backend/api/validation.md +88 -0
  31. package/stacks/blazor-azure/.morph/standards/backend/authentication/passkeys.md +428 -0
  32. package/stacks/blazor-azure/.morph/standards/backend/database/ef-core.md +199 -0
  33. package/stacks/blazor-azure/.morph/standards/backend/database/migrations.md +393 -0
  34. package/stacks/blazor-azure/.morph/standards/backend/database/postgresql/database.md +352 -0
  35. package/stacks/blazor-azure/.morph/standards/backend/database/repository-patterns.md +528 -0
  36. package/stacks/blazor-azure/.morph/standards/backend/database/vector-search-rag.md +541 -0
  37. package/stacks/blazor-azure/.morph/standards/backend/dotnet/async.md +366 -0
  38. package/stacks/blazor-azure/.morph/standards/backend/dotnet/core.md +117 -0
  39. package/stacks/blazor-azure/.morph/standards/backend/dotnet/di.md +439 -0
  40. package/stacks/blazor-azure/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
  41. package/stacks/blazor-azure/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
  42. package/stacks/blazor-azure/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
  43. package/stacks/blazor-azure/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
  44. package/stacks/blazor-azure/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
  45. package/stacks/blazor-azure/.morph/standards/context/analytics.md +96 -0
  46. package/stacks/blazor-azure/.morph/standards/context/bundles.md +110 -0
  47. package/stacks/blazor-azure/.morph/standards/context/priming.md +78 -0
  48. package/stacks/blazor-azure/.morph/standards/core/architecture.md +185 -0
  49. package/stacks/blazor-azure/.morph/standards/core/coding.md +214 -0
  50. package/stacks/blazor-azure/.morph/standards/core/git-branching-strategy.md +403 -0
  51. package/stacks/blazor-azure/.morph/standards/core/git.md +185 -0
  52. package/stacks/blazor-azure/.morph/standards/core/testing.md +295 -0
  53. package/stacks/blazor-azure/.morph/standards/data/nosql/blob-storage.md +102 -0
  54. package/stacks/blazor-azure/.morph/standards/data/nosql/cache/redis.md +97 -0
  55. package/stacks/blazor-azure/.morph/standards/data/nosql/cosmos-db.md +118 -0
  56. package/stacks/blazor-azure/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
  57. package/stacks/blazor-azure/.morph/standards/data/vector-search/rag-chunking.md +104 -0
  58. package/stacks/blazor-azure/.morph/standards/frontend/blazor/design-checklist.md +222 -0
  59. package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
  60. package/stacks/blazor-azure/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
  61. package/stacks/blazor-azure/.morph/standards/frontend/blazor/html-conversion.md +184 -0
  62. package/stacks/blazor-azure/.morph/standards/frontend/blazor/lifecycle.md +195 -0
  63. package/stacks/blazor-azure/.morph/standards/frontend/blazor/pitfalls.md +198 -0
  64. package/stacks/blazor-azure/.morph/standards/frontend/blazor/state.md +191 -0
  65. package/stacks/blazor-azure/.morph/standards/frontend/design-system/animations.md +151 -0
  66. package/stacks/blazor-azure/.morph/standards/frontend/design-system/naming.md +64 -0
  67. package/stacks/blazor-azure/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
  68. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/azure.md +624 -0
  69. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
  70. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
  71. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
  72. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/functions.md +486 -0
  73. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
  74. package/stacks/blazor-azure/.morph/standards/infrastructure/azure/services/storage.md +407 -0
  75. package/stacks/blazor-azure/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
  76. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
  77. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
  78. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
  79. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
  80. package/stacks/blazor-azure/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
  81. package/stacks/blazor-azure/.morph/standards/integration/api/graphql.md +91 -0
  82. package/stacks/blazor-azure/.morph/standards/integration/api/grpc.md +114 -0
  83. package/stacks/blazor-azure/.morph/standards/integration/api/rest-design.md +95 -0
  84. package/stacks/blazor-azure/.morph/standards/integration/event-driven/cqrs.md +101 -0
  85. package/stacks/blazor-azure/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
  86. package/stacks/blazor-azure/.morph/standards/integration/event-driven/service-bus.md +95 -0
  87. package/stacks/blazor-azure/.morph/standards/observability/logging.md +131 -0
  88. package/stacks/blazor-azure/.morph/standards/observability/metrics.md +121 -0
  89. package/stacks/blazor-azure/.morph/standards/observability/monitoring.md +114 -0
  90. package/stacks/blazor-azure/.morph/standards/observability/tracing.md +132 -0
  91. package/stacks/blazor-azure/.morph/standards/workflows/parallel-execution.md +112 -0
  92. package/stacks/blazor-azure/.morph/standards/workflows/thread-management.md +113 -0
  93. package/stacks/blazor-azure/CLAUDE.md +106 -101
  94. package/stacks/nextjs-supabase/.claude/commands/morph-apply.md +221 -0
  95. package/stacks/nextjs-supabase/.claude/commands/morph-archive.md +79 -0
  96. package/stacks/nextjs-supabase/.claude/commands/morph-deploy.md +529 -0
  97. package/stacks/nextjs-supabase/.claude/commands/morph-infra.md +209 -0
  98. package/stacks/nextjs-supabase/.claude/commands/morph-preflight.md +227 -0
  99. package/stacks/nextjs-supabase/.claude/commands/morph-proposal.md +122 -0
  100. package/stacks/nextjs-supabase/.claude/commands/morph-status.md +86 -0
  101. package/stacks/nextjs-supabase/.claude/commands/morph-troubleshoot.md +122 -0
  102. package/stacks/nextjs-supabase/.morph/.morphversion +5 -0
  103. package/stacks/nextjs-supabase/.morph/config/agents.json +345 -345
  104. package/stacks/nextjs-supabase/.morph/config/config.json +9 -0
  105. package/stacks/nextjs-supabase/.morph/project/context/README.md +17 -0
  106. package/stacks/nextjs-supabase/.morph/standards/ai-agents/blazor-ui.md +364 -0
  107. package/stacks/nextjs-supabase/.morph/standards/ai-agents/production.md +415 -0
  108. package/stacks/nextjs-supabase/.morph/standards/ai-agents/setup.md +418 -0
  109. package/stacks/nextjs-supabase/.morph/standards/ai-agents/team-orchestration.md +479 -0
  110. package/stacks/nextjs-supabase/.morph/standards/ai-agents/workflows.md +354 -0
  111. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/aggregates.md +120 -0
  112. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/entities.md +99 -0
  113. package/stacks/nextjs-supabase/.morph/standards/architecture/ddd/value-objects.md +124 -0
  114. package/stacks/nextjs-supabase/.morph/standards/backend/api/minimal-api.md +494 -0
  115. package/stacks/nextjs-supabase/.morph/standards/backend/api/rest.md +492 -0
  116. package/stacks/nextjs-supabase/.morph/standards/backend/api/validation.md +88 -0
  117. package/stacks/nextjs-supabase/.morph/standards/backend/authentication/passkeys.md +428 -0
  118. package/stacks/nextjs-supabase/.morph/standards/backend/database/ef-core.md +199 -0
  119. package/stacks/nextjs-supabase/.morph/standards/backend/database/migrations.md +393 -0
  120. package/stacks/nextjs-supabase/.morph/standards/backend/database/postgresql/database.md +352 -0
  121. package/stacks/nextjs-supabase/.morph/standards/backend/database/repository-patterns.md +528 -0
  122. package/stacks/nextjs-supabase/.morph/standards/backend/database/vector-search-rag.md +541 -0
  123. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/async.md +366 -0
  124. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/core.md +117 -0
  125. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/di.md +439 -0
  126. package/stacks/nextjs-supabase/.morph/standards/backend/dotnet/program-cs-checklist.md +92 -0
  127. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/asaas/asaas-api.md +216 -0
  128. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/clerk/clerk-auth.md +290 -0
  129. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
  130. package/stacks/nextjs-supabase/.morph/standards/backend/integrations/resend/resend-email.md +385 -0
  131. package/stacks/nextjs-supabase/.morph/standards/context/analytics.md +96 -0
  132. package/stacks/nextjs-supabase/.morph/standards/context/bundles.md +110 -0
  133. package/stacks/nextjs-supabase/.morph/standards/context/priming.md +78 -0
  134. package/stacks/nextjs-supabase/.morph/standards/core/architecture.md +185 -0
  135. package/stacks/nextjs-supabase/.morph/standards/core/coding.md +214 -0
  136. package/stacks/nextjs-supabase/.morph/standards/core/git-branching-strategy.md +403 -0
  137. package/stacks/nextjs-supabase/.morph/standards/core/git.md +185 -0
  138. package/stacks/nextjs-supabase/.morph/standards/core/testing.md +295 -0
  139. package/stacks/nextjs-supabase/.morph/standards/data/nosql/blob-storage.md +102 -0
  140. package/stacks/nextjs-supabase/.morph/standards/data/nosql/cache/redis.md +97 -0
  141. package/stacks/nextjs-supabase/.morph/standards/data/nosql/cosmos-db.md +118 -0
  142. package/stacks/nextjs-supabase/.morph/standards/data/vector-search/azure-ai-search.md +121 -0
  143. package/stacks/nextjs-supabase/.morph/standards/data/vector-search/rag-chunking.md +104 -0
  144. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/design-checklist.md +222 -0
  145. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui-setup.md +595 -0
  146. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/fluent-ui.md +137 -0
  147. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/html-conversion.md +184 -0
  148. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/lifecycle.md +195 -0
  149. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/pitfalls.md +198 -0
  150. package/stacks/nextjs-supabase/.morph/standards/frontend/blazor/state.md +191 -0
  151. package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/animations.md +151 -0
  152. package/stacks/nextjs-supabase/.morph/standards/frontend/design-system/naming.md +64 -0
  153. package/stacks/nextjs-supabase/.morph/standards/frontend/nextjs/nextjs-patterns.md +198 -0
  154. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/azure.md +624 -0
  155. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
  156. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
  157. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/devops/local-development.md +520 -0
  158. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/functions.md +486 -0
  159. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/service-bus.md +459 -0
  160. package/stacks/nextjs-supabase/.morph/standards/infrastructure/azure/services/storage.md +407 -0
  161. package/stacks/nextjs-supabase/.morph/standards/infrastructure/docker/easypanel-deploy.md +196 -0
  162. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/mcp-setup.md +252 -0
  163. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-auth.md +176 -0
  164. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
  165. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-rls.md +184 -0
  166. package/stacks/nextjs-supabase/.morph/standards/infrastructure/supabase/supabase-storage.md +153 -0
  167. package/stacks/nextjs-supabase/.morph/standards/integration/api/graphql.md +91 -0
  168. package/stacks/nextjs-supabase/.morph/standards/integration/api/grpc.md +114 -0
  169. package/stacks/nextjs-supabase/.morph/standards/integration/api/rest-design.md +95 -0
  170. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/cqrs.md +101 -0
  171. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/event-sourcing.md +124 -0
  172. package/stacks/nextjs-supabase/.morph/standards/integration/event-driven/service-bus.md +95 -0
  173. package/stacks/nextjs-supabase/.morph/standards/observability/logging.md +131 -0
  174. package/stacks/nextjs-supabase/.morph/standards/observability/metrics.md +121 -0
  175. package/stacks/nextjs-supabase/.morph/standards/observability/monitoring.md +114 -0
  176. package/stacks/nextjs-supabase/.morph/standards/observability/tracing.md +132 -0
  177. package/stacks/nextjs-supabase/.morph/standards/workflows/parallel-execution.md +112 -0
  178. package/stacks/nextjs-supabase/.morph/standards/workflows/thread-management.md +113 -0
  179. package/stacks/nextjs-supabase/CLAUDE.md +69 -63
  180. package/stacks/blazor-azure/.morph/config/config.template.json +0 -122
  181. package/stacks/blazor-azure/.morph/hooks/pre-commit/tests-csharp.sh +0 -61
  182. package/stacks/blazor-azure/.morph/project.md +0 -160
  183. package/stacks/blazor-azure/.morph/state.json +0 -18
  184. package/stacks/blazor-azure/.morph/templates/.gitkeep +0 -0
  185. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -41
  186. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -24
  187. package/stacks/blazor-azure/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -23
  188. package/stacks/nextjs-supabase/.morph/config/config.template.json +0 -92
  189. package/stacks/nextjs-supabase/.morph/hooks/pre-commit/tests-typescript.sh +0 -61
  190. package/stacks/nextjs-supabase/.morph/project.md +0 -168
  191. package/stacks/nextjs-supabase/.morph/templates/.gitkeep +0 -0
  192. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-prod.yml.hbs +0 -22
  193. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/cd-staging.yml.hbs +0 -22
  194. package/stacks/nextjs-supabase/.morph/templates/infrastructure/github/workflows/ci-build.yml.hbs +0 -35
@@ -0,0 +1,96 @@
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
+ ```
@@ -0,0 +1,110 @@
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
@@ -0,0 +1,78 @@
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
@@ -0,0 +1,185 @@
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*
@@ -0,0 +1,214 @@
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*