@polymorphism-tech/morph-spec 4.7.1 → 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 (138) hide show
  1. package/.morph/analytics/threads-log.jsonl +54 -0
  2. package/.morph/state.json +198 -0
  3. package/LICENSE +1 -2
  4. package/README.md +379 -414
  5. package/bin/morph-spec.js +57 -403
  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 +2 -2
  34. package/framework/commands/morph-proposal.md +3 -3
  35. package/framework/hooks/README.md +11 -10
  36. package/framework/hooks/claude-code/notification/approval-reminder.js +2 -0
  37. package/framework/hooks/claude-code/post-tool-use/dispatch.js +1 -1
  38. package/framework/hooks/claude-code/pre-tool-use/protect-readonly-files.js +4 -55
  39. package/framework/hooks/claude-code/session-start/inject-morph-context.js +20 -5
  40. package/framework/hooks/claude-code/statusline.py +6 -1
  41. package/framework/hooks/claude-code/stop/validate-completion.js +1 -1
  42. package/framework/hooks/claude-code/user-prompt/enrich-prompt.js +1 -1
  43. package/framework/hooks/dev/check-sync-health.js +117 -0
  44. package/framework/hooks/dev/guard-version-numbers.js +57 -0
  45. package/framework/hooks/dev/sync-standards-registry.js +60 -0
  46. package/framework/hooks/dev/sync-template-registry.js +60 -0
  47. package/framework/hooks/dev/validate-skill-format.js +70 -0
  48. package/framework/hooks/dev/validate-standard-format.js +73 -0
  49. package/framework/hooks/shared/payload-utils.js +39 -0
  50. package/framework/hooks/shared/state-reader.js +25 -1
  51. package/framework/rules/morph-workflow.md +1 -1
  52. package/framework/skills/level-0-meta/morph-init/SKILL.md +216 -0
  53. package/framework/skills/level-0-meta/morph-replicate/SKILL.md +4 -4
  54. package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +4 -4
  55. package/framework/skills/level-0-meta/verification-before-completion/SKILL.md +1 -1
  56. package/framework/skills/level-1-workflows/phase-clarify/SKILL.md +192 -191
  57. package/framework/skills/level-1-workflows/phase-codebase-analysis/SKILL.md +181 -180
  58. package/framework/skills/level-1-workflows/phase-design/SKILL.md +339 -338
  59. package/framework/skills/level-1-workflows/phase-implement/SKILL.md +254 -253
  60. package/framework/skills/level-1-workflows/phase-setup/SKILL.md +168 -170
  61. package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +284 -283
  62. package/framework/skills/level-1-workflows/phase-uiux/SKILL.md +246 -245
  63. package/framework/templates/examples/design-system-examples.md +1 -1
  64. package/framework/templates/ui/FluentDesignTheme.cs +1 -1
  65. package/framework/templates/ui/MudTheme.cs +1 -1
  66. package/framework/templates/ui/design-system.css +1 -1
  67. package/package.json +4 -2
  68. package/scripts/bump-version.js +248 -0
  69. package/scripts/install-dev-hooks.js +138 -0
  70. package/src/commands/agents/index.js +1 -2
  71. package/src/commands/index.js +13 -16
  72. package/src/commands/project/doctor.js +100 -14
  73. package/src/commands/project/index.js +7 -10
  74. package/src/commands/project/init.js +398 -555
  75. package/src/commands/project/install-plugin-cmd.js +28 -0
  76. package/src/commands/project/setup-infra-cmd.js +12 -0
  77. package/src/commands/project/tutorial.js +115 -0
  78. package/src/commands/project/update.js +22 -37
  79. package/src/commands/state/approve.js +213 -221
  80. package/src/commands/state/index.js +0 -1
  81. package/src/commands/state/state.js +337 -365
  82. package/src/commands/templates/index.js +0 -4
  83. package/src/commands/trust/trust.js +1 -93
  84. package/src/commands/utils/index.js +1 -5
  85. package/src/commands/validation/index.js +1 -5
  86. package/src/core/registry/command-registry.js +11 -285
  87. package/src/core/state/state-manager.js +5 -2
  88. package/src/lib/detectors/index.js +81 -87
  89. package/src/lib/detectors/structure-detector.js +275 -273
  90. package/src/lib/generators/recap-generator.js +232 -225
  91. package/src/lib/installers/mcp-installer.js +18 -3
  92. package/src/scripts/global-install.js +34 -0
  93. package/src/scripts/install-plugin.js +126 -0
  94. package/src/scripts/setup-infra.js +203 -0
  95. package/src/utils/agents-installer.js +10 -1
  96. package/src/utils/hooks-installer.js +70 -17
  97. package/CLAUDE.md +0 -77
  98. package/docs/claude-alignment-report.md +0 -137
  99. package/docs/examples/order-management/contracts.cs +0 -84
  100. package/docs/examples/order-management/proposal.md +0 -24
  101. package/docs/examples/order-management/spec.md +0 -162
  102. package/src/commands/feature/create-story.js +0 -362
  103. package/src/commands/feature/index.js +0 -6
  104. package/src/commands/feature/shard-spec.js +0 -225
  105. package/src/commands/feature/sprint-status.js +0 -250
  106. package/src/commands/generation/generate-onboarding.js +0 -169
  107. package/src/commands/generation/generate.js +0 -276
  108. package/src/commands/generation/index.js +0 -5
  109. package/src/commands/learning/capture-pattern.js +0 -121
  110. package/src/commands/learning/index.js +0 -5
  111. package/src/commands/learning/search-patterns.js +0 -126
  112. package/src/commands/mcp/mcp.js +0 -102
  113. package/src/commands/project/changes.js +0 -66
  114. package/src/commands/project/cost.js +0 -179
  115. package/src/commands/project/detect.js +0 -114
  116. package/src/commands/project/diff.js +0 -278
  117. package/src/commands/project/revert.js +0 -173
  118. package/src/commands/project/standards.js +0 -80
  119. package/src/commands/project/sync.js +0 -167
  120. package/src/commands/project/update-agents.js +0 -23
  121. package/src/commands/state/rollback-phase.js +0 -185
  122. package/src/commands/templates/template-customize.js +0 -87
  123. package/src/commands/templates/template-list.js +0 -114
  124. package/src/commands/templates/template-show.js +0 -129
  125. package/src/commands/templates/template-validate.js +0 -91
  126. package/src/commands/utils/troubleshoot.js +0 -222
  127. package/src/commands/validation/analyze-blazor-concurrency.js +0 -193
  128. package/src/commands/validation/lint-fluent.js +0 -352
  129. package/src/commands/validation/validate-blazor-state.js +0 -210
  130. package/src/commands/validation/validate-blazor.js +0 -156
  131. package/src/commands/validation/validate-css.js +0 -84
  132. package/src/lib/detectors/conversation-analyzer.js +0 -163
  133. package/src/lib/learning/index.js +0 -7
  134. package/src/lib/learning/learning-system.js +0 -520
  135. package/src/lib/troubleshooting/index.js +0 -8
  136. package/src/lib/troubleshooting/troubleshoot-grep.js +0 -198
  137. package/src/lib/troubleshooting/troubleshoot-index.js +0 -144
  138. package/src/llm/environment-detector.js +0 -43
@@ -1,181 +1,182 @@
1
- ---
2
- name: phase-codebase-analysis
3
- description: MORPH-SPEC Design sub-phase that analyzes existing codebase and database schema, producing schema-analysis.md with real column names, types, relationships, and field mismatches. Use at the start of Design phase before generating contracts.cs to prevent incorrect field names or types.
4
- user-invocable: false
5
- allowed-tools: Read, Write, Edit, Bash, Glob, Grep
6
- ---
7
-
8
- # MORPH Codebase Analysis - Sub-fase de DESIGN
9
-
10
- > INTERNAL: Automation skill for schema analysis step within Phase 2 (Design).
11
- > Called by `phase-design.md` Passo 2. Not a standalone user command.
12
-
13
- Automatiza a análise de código existente para gerar `schema-analysis.md` com dados reais do banco/código.
14
-
15
- ## Pré-requisitos
16
-
17
- - [ ] FASE 1 (Setup) concluída
18
- - [ ] Feature tem `proposal.md` aprovado
19
- - [ ] Contexto do projeto carregado (stack, agentes)
20
-
21
- ## Ferramentas Recomendadas
22
-
23
- > **Ref:** `framework/skills/level-0-meta/tool-usage-guide/SKILL.md` para guia completo.
24
- > **Ref:** `framework/standards/integration/mcp/mcp-tools.md` para referência MCP.
25
-
26
- | Ação | Ferramenta | Alternativa |
27
- |------|------------|-------------|
28
- | Listar tabelas do banco | **Supabase MCP** `list_tables()` | **Grep** `.from(` no código |
29
- | Obter schema de tabela | **Supabase MCP** `get_table_schema()` | **Read** type definitions |
30
- | Obter relacionamentos FK | **Supabase MCP** `get_relationships()` | **Grep** JOIN/FK patterns |
31
- | Obter políticas RLS | **Supabase MCP** `query()` | **Read** policy files |
32
- | Encontrar queries no código | **Grep** `\.from\(` em `*.ts,*.tsx,*.js,*.cs` | |
33
- | Encontrar type definitions | **Glob** `src/**/types/**/*.ts` ou `**/Entities/**/*.cs` | — |
34
- | Ler arquivos encontrados | **Read** cada arquivo | — |
35
- | Análise multi-arquivo complexa | **Task** (subagent Explore) | Read individual |
36
- | Gerar schema-analysis.md | **Write** usando template | **Bash** template render |
37
-
38
- **MCPs desta fase:** Supabase (schema — **PRIORITÁRIO**), Database MCPs genéricos.
39
-
40
- ---
41
-
42
- ## Workflow Automatizado
43
-
44
- ### Passo 1: Detectar Método de Análise
45
-
46
- ```
47
- SE MCP Supabase disponível:
48
- Usar Método A (MCP direto)
49
- SE MCP Database disponível:
50
- Usar Método A adaptado
51
- SENÃO:
52
- → Usar Método B (análise estática de código)
53
- ```
54
-
55
- ### Passo 2A: Método MCP (Preferencial)
56
-
57
- **Ferramentas:** Supabase MCP
58
-
59
- ```javascript
60
- // 1. Listar todas as tabelas
61
- const tables = await mcp__supabase__list_tables();
62
-
63
- // 2. Para cada tabela relevante à feature:
64
- for (const table of relevantTables) {
65
- // 2a. Schema completo
66
- const schema = await mcp__supabase__get_table_schema({ table: table.name });
67
- // column_name, data_type, is_nullable, column_default
68
-
69
- // 2b. Relacionamentos
70
- const rels = await mcp__supabase__get_relationships({ table: table.name });
71
- // foreign_table, foreign_column, constraint_type
72
-
73
- // 2c. Indexes
74
- const indexes = await mcp__supabase__query({
75
- query: `SELECT indexname, indexdef FROM pg_indexes WHERE tablename = '${table.name}'`
76
- });
77
-
78
- // 2d. RLS policies (segurança)
79
- const policies = await mcp__supabase__query({
80
- query: `SELECT policyname, cmd, qual FROM pg_policies WHERE tablename = '${table.name}'`
81
- });
82
- }
83
- ```
84
-
85
- ### Passo 2B: Método Análise Estática (Fallback)
86
-
87
- **Ferramentas:** Grep, Glob, Read, Task (subagent para projetos grandes)
88
-
89
- **Fase B1: Encontrar Queries**
90
-
91
- ```
92
- Grep: "\.from\(|\.select\(|SELECT |supabase\.|context\.|dbContext\.|DbSet<"
93
- Type: ts,tsx,js,jsx,cs
94
- Output: files_with_matches
95
- ```
96
-
97
- **Fase B2: Ler Arquivos de Query**
98
-
99
- Para cada arquivo encontrado, use **Read** para extrair:
100
- - Nomes de tabelas: `from('leads')`, `DbSet<Lead>`, `FROM leads`
101
- - Nomes de colunas: `.select('fullname, phonenumber')`, `l.FullName`
102
- - Tipos de dados: TypeScript interfaces, C# DTOs
103
- - Relacionamentos: JOIN clauses, navigation properties
104
-
105
- **Fase B3: Encontrar Type Definitions**
106
-
107
- ```
108
- # TypeScript/JavaScript:
109
- Glob: "src/**/types/**/*.ts"
110
- Glob: "src/**/*.d.ts"
111
- Glob: "src/**/interfaces/*.ts"
112
-
113
- # .NET:
114
- Glob: "**/*Dto.cs"
115
- Glob: "**/Entities/**/*.cs"
116
- Glob: "**/Models/**/*.cs"
117
- ```
118
-
119
- **Fase B4: Quando usar Task (subagent)**
120
-
121
- Use Task subagent **APENAS** quando:
122
- - Projeto tem 20+ arquivos de query
123
- - Múltiplos padrões de acesso a dados (Supabase + EF Core + raw SQL)
124
- - Análise precisa de contexto cruzado entre muitos arquivos
125
-
126
- Não use Task subagent quando:
127
- - Projeto tem < 10 arquivos de query (Read direto é mais rápido)
128
- - Padrão de acesso a dados é uniforme ( Supabase OU EF Core)
129
-
130
- ### Passo 3: Mapear Inconsistências
131
-
132
- Crie um mapa de:
133
-
134
- | Frontend/Código | Banco de Dados | Tipo | Problema |
135
- |----------------|----------------|------|----------|
136
- | user.name | users.fullname | string | ❌ MISMATCH |
137
- | lead.phone | leads.phonenumber | string | ❌ MISMATCH |
138
- | order.metadata | orders.metadata | JSONB | ⚠️ Type complex |
139
-
140
- ### Passo 4: Gerar `schema-analysis.md`
141
-
142
- Use o template em `framework/templates/docs/schema-analysis.md`:
143
-
144
- ```bash
145
- npx morph-spec template render docs/schema-analysis \
146
- .morph/features/{feature-name}/1-design/schema-analysis.md \
147
- '{ "FEATURE_NAME": "{feature-name}", "DATE": "..." }'
148
- ```
149
-
150
- OU use **Write** tool para criar diretamente com os dados coletados.
151
-
152
- ### Passo 5: Atualizar State
153
-
154
- ```bash
155
- npx morph-spec state mark-output {feature-name} schema-analysis
156
- ```
157
-
158
- ---
159
-
160
- ## Outputs
161
-
162
- - `.morph/features/{feature}/1-design/schema-analysis.md`
163
- - State atualizado com output `schemaAnalysis`
164
-
165
- ## CHECKPOINT
166
-
167
- Antes de prosseguir para contracts.cs, apresente ao usuário:
168
-
169
- - [ ] Analisei {N} tabelas
170
- - [ ] Encontrei {N} field name mismatches
171
- - [ ] Encontrei {N} type mismatches
172
- - [ ] Mapeei {N} relacionamentos
173
- - [ ] `schema-analysis.md` criado
174
-
175
- **Perguntas obrigatórias:**
176
- 1. "O schema analysis está correto?"
177
- 2. "Posso gerar contracts.cs com base nesse schema real?"
178
-
179
- ---
180
-
1
+ ---
2
+ name: phase-codebase-analysis
3
+ description: MORPH-SPEC Design sub-phase that analyzes existing codebase and database schema, producing schema-analysis.md with real column names, types, relationships, and field mismatches. Use at the start of Design phase before generating contracts.cs to prevent incorrect field names or types.
4
+ user-invocable: false
5
+ allowed-tools: Read, Write, Edit, Bash, Glob, Grep
6
+ cliVersion: "4.8.1"
7
+ ---
8
+
9
+ # MORPH Codebase Analysis - Sub-fase de DESIGN
10
+
11
+ > INTERNAL: Automation skill for schema analysis step within Phase 2 (Design).
12
+ > Called by `phase-design.md` Passo 2. Not a standalone user command.
13
+
14
+ Automatiza a análise de código existente para gerar `schema-analysis.md` com dados reais do banco/código.
15
+
16
+ ## Pré-requisitos
17
+
18
+ - [ ] FASE 1 (Setup) concluída
19
+ - [ ] Feature tem `proposal.md` aprovado
20
+ - [ ] Contexto do projeto carregado (stack, agentes)
21
+
22
+ ## Ferramentas Recomendadas
23
+
24
+ > **Ref:** `framework/skills/level-0-meta/tool-usage-guide/SKILL.md` para guia completo.
25
+ > **Ref:** `framework/standards/integration/mcp/mcp-tools.md` para referência MCP.
26
+
27
+ | Ação | Ferramenta | Alternativa |
28
+ |------|------------|-------------|
29
+ | Listar tabelas do banco | **Supabase MCP** `list_tables()` | **Grep** `.from(` no código |
30
+ | Obter schema de tabela | **Supabase MCP** `get_table_schema()` | **Read** type definitions |
31
+ | Obter relacionamentos FK | **Supabase MCP** `get_relationships()` | **Grep** JOIN/FK patterns |
32
+ | Obter políticas RLS | **Supabase MCP** `query()` | **Read** policy files |
33
+ | Encontrar queries no código | **Grep** `\.from\(` em `*.ts,*.tsx,*.js,*.cs` | — |
34
+ | Encontrar type definitions | **Glob** `src/**/types/**/*.ts` ou `**/Entities/**/*.cs` | — |
35
+ | Ler arquivos encontrados | **Read** cada arquivo | |
36
+ | Análise multi-arquivo complexa | **Task** (subagent Explore) | Read individual |
37
+ | Gerar schema-analysis.md | **Write** usando template | **Bash** template render |
38
+
39
+ **MCPs desta fase:** Supabase (schema — **PRIORITÁRIO**), Database MCPs genéricos.
40
+
41
+ ---
42
+
43
+ ## Workflow Automatizado
44
+
45
+ ### Passo 1: Detectar Método de Análise
46
+
47
+ ```
48
+ SE MCP Supabase disponível:
49
+ Usar Método A (MCP direto)
50
+ SE MCP Database disponível:
51
+ → Usar Método A adaptado
52
+ SENÃO:
53
+ → Usar Método B (análise estática de código)
54
+ ```
55
+
56
+ ### Passo 2A: Método MCP (Preferencial)
57
+
58
+ **Ferramentas:** Supabase MCP
59
+
60
+ ```javascript
61
+ // 1. Listar todas as tabelas
62
+ const tables = await mcp__supabase__list_tables();
63
+
64
+ // 2. Para cada tabela relevante à feature:
65
+ for (const table of relevantTables) {
66
+ // 2a. Schema completo
67
+ const schema = await mcp__supabase__get_table_schema({ table: table.name });
68
+ // → column_name, data_type, is_nullable, column_default
69
+
70
+ // 2b. Relacionamentos
71
+ const rels = await mcp__supabase__get_relationships({ table: table.name });
72
+ // → foreign_table, foreign_column, constraint_type
73
+
74
+ // 2c. Indexes
75
+ const indexes = await mcp__supabase__query({
76
+ query: `SELECT indexname, indexdef FROM pg_indexes WHERE tablename = '${table.name}'`
77
+ });
78
+
79
+ // 2d. RLS policies (segurança)
80
+ const policies = await mcp__supabase__query({
81
+ query: `SELECT policyname, cmd, qual FROM pg_policies WHERE tablename = '${table.name}'`
82
+ });
83
+ }
84
+ ```
85
+
86
+ ### Passo 2B: Método Análise Estática (Fallback)
87
+
88
+ **Ferramentas:** Grep, Glob, Read, Task (subagent para projetos grandes)
89
+
90
+ **Fase B1: Encontrar Queries**
91
+
92
+ ```
93
+ Grep: "\.from\(|\.select\(|SELECT |supabase\.|context\.|dbContext\.|DbSet<"
94
+ Type: ts,tsx,js,jsx,cs
95
+ Output: files_with_matches
96
+ ```
97
+
98
+ **Fase B2: Ler Arquivos de Query**
99
+
100
+ Para cada arquivo encontrado, use **Read** para extrair:
101
+ - Nomes de tabelas: `from('leads')`, `DbSet<Lead>`, `FROM leads`
102
+ - Nomes de colunas: `.select('fullname, phonenumber')`, `l.FullName`
103
+ - Tipos de dados: TypeScript interfaces, C# DTOs
104
+ - Relacionamentos: JOIN clauses, navigation properties
105
+
106
+ **Fase B3: Encontrar Type Definitions**
107
+
108
+ ```
109
+ # TypeScript/JavaScript:
110
+ Glob: "src/**/types/**/*.ts"
111
+ Glob: "src/**/*.d.ts"
112
+ Glob: "src/**/interfaces/*.ts"
113
+
114
+ # .NET:
115
+ Glob: "**/*Dto.cs"
116
+ Glob: "**/Entities/**/*.cs"
117
+ Glob: "**/Models/**/*.cs"
118
+ ```
119
+
120
+ **Fase B4: Quando usar Task (subagent)**
121
+
122
+ Use Task subagent **APENAS** quando:
123
+ - Projeto tem 20+ arquivos de query
124
+ - Múltiplos padrões de acesso a dados (Supabase + EF Core + raw SQL)
125
+ - Análise precisa de contexto cruzado entre muitos arquivos
126
+
127
+ Não use Task subagent quando:
128
+ - Projeto tem < 10 arquivos de query (Read direto é mais rápido)
129
+ - Padrão de acesso a dados é uniforme (só Supabase OU só EF Core)
130
+
131
+ ### Passo 3: Mapear Inconsistências
132
+
133
+ Crie um mapa de:
134
+
135
+ | Frontend/Código | Banco de Dados | Tipo | Problema |
136
+ |----------------|----------------|------|----------|
137
+ | user.name | users.fullname | string | ❌ MISMATCH |
138
+ | lead.phone | leads.phonenumber | string | MISMATCH |
139
+ | order.metadata | orders.metadata | JSONB | ⚠️ Type complex |
140
+
141
+ ### Passo 4: Gerar `schema-analysis.md`
142
+
143
+ Use o template em `framework/templates/docs/schema-analysis.md`:
144
+
145
+ ```bash
146
+ npx morph-spec template render docs/schema-analysis \
147
+ .morph/features/{feature-name}/1-design/schema-analysis.md \
148
+ '{ "FEATURE_NAME": "{feature-name}", "DATE": "..." }'
149
+ ```
150
+
151
+ OU use **Write** tool para criar diretamente com os dados coletados.
152
+
153
+ ### Passo 5: Atualizar State
154
+
155
+ ```bash
156
+ npx morph-spec state mark-output {feature-name} schema-analysis
157
+ ```
158
+
159
+ ---
160
+
161
+ ## Outputs
162
+
163
+ - `.morph/features/{feature}/1-design/schema-analysis.md`
164
+ - State atualizado com output `schemaAnalysis`
165
+
166
+ ## CHECKPOINT
167
+
168
+ Antes de prosseguir para contracts.cs, apresente ao usuário:
169
+
170
+ - [ ] Analisei {N} tabelas
171
+ - [ ] Encontrei {N} field name mismatches
172
+ - [ ] Encontrei {N} type mismatches
173
+ - [ ] Mapeei {N} relacionamentos
174
+ - [ ] `schema-analysis.md` criado
175
+
176
+ **Perguntas obrigatórias:**
177
+ 1. "O schema analysis está correto?"
178
+ 2. "Posso gerar contracts.cs com base nesse schema real?"
179
+
180
+ ---
181
+
181
182
  *MORPH-SPEC by Polymorphism Tech*