create-sdd-workflow 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/AGENTS.md +110 -0
- package/README.md +45 -0
- package/bin/create-sdd-workflow.js +249 -0
- package/manual_workflow_sdd_grillme_tlc.md +472 -0
- package/package.json +38 -0
- package/skills/iniciar-projeto-sdd/SKILL.md +150 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/00-AGENTS-template.md +110 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/01-brief-template.md +17 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/02-grillme-brief-prompt.md +27 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/03-grillme-product-prompt.md +37 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/04-prd-template.md +37 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/05-prd-compression-prompt.md +33 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/06-prespec-prompt.md +52 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/07-derive-docs-prompt.md +32 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/08-tlc-execution-prompt.md +32 -0
- package/skills/iniciar-projeto-sdd/assets/workflow/09-quality-checklists.md +35 -0
- package/skills/iniciar-projeto-sdd/references/workflow-summary.md +69 -0
- package/skills/iniciar-projeto-sdd/scripts/init_sdd_project.sh +182 -0
- package/workflow/00-AGENTS-template.md +110 -0
- package/workflow/01-brief-template.md +17 -0
- package/workflow/02-grillme-brief-prompt.md +27 -0
- package/workflow/03-grillme-product-prompt.md +37 -0
- package/workflow/04-prd-template.md +37 -0
- package/workflow/05-prd-compression-prompt.md +33 -0
- package/workflow/06-prespec-prompt.md +52 -0
- package/workflow/07-derive-docs-prompt.md +32 -0
- package/workflow/08-tlc-execution-prompt.md +32 -0
- package/workflow/09-quality-checklists.md +35 -0
|
@@ -0,0 +1,472 @@
|
|
|
1
|
+
# Tutorial — Usando a skill `iniciar-projeto-sdd`
|
|
2
|
+
|
|
3
|
+
Este tutorial explica como usar a skill `iniciar-projeto-sdd` para transformar uma ideia inicial em documentação de produto, documentação técnica e specs executáveis por fatias verticais.
|
|
4
|
+
|
|
5
|
+
A skill conduz um workflow SDD com:
|
|
6
|
+
|
|
7
|
+
- Brief Inicial;
|
|
8
|
+
- Grill-me do Brief Inicial;
|
|
9
|
+
- Grill-me de produto;
|
|
10
|
+
- PRD Principal;
|
|
11
|
+
- compressão/revisão do PRD;
|
|
12
|
+
- PreSpec Técnica;
|
|
13
|
+
- documentos técnicos derivados;
|
|
14
|
+
- specs TLC por fatia vertical.
|
|
15
|
+
|
|
16
|
+
O objetivo não é implementar código imediatamente. O objetivo é criar uma base clara de produto e engenharia antes da execução.
|
|
17
|
+
|
|
18
|
+
## 1. Quando usar
|
|
19
|
+
|
|
20
|
+
Use esta skill quando você estiver começando um projeto novo e quiser gerar documentação guiada antes de implementar.
|
|
21
|
+
|
|
22
|
+
Exemplos de pedidos:
|
|
23
|
+
|
|
24
|
+
```txt
|
|
25
|
+
/iniciar-projeto-sdd
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
```txt
|
|
29
|
+
/iniciar-projeto-sdd Nome: Meu Produto. Ideia: Uma ferramenta para organizar estudos com IA.
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
```txt
|
|
33
|
+
iniciar projeto sdd
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
```txt
|
|
37
|
+
crie a estrutura do workflow SDD
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
Para retomar depois:
|
|
41
|
+
|
|
42
|
+
```txt
|
|
43
|
+
/continuar-sdd
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
## 2. O que a skill cria
|
|
47
|
+
|
|
48
|
+
Ao iniciar, a skill cria a estrutura base do projeto:
|
|
49
|
+
|
|
50
|
+
```txt
|
|
51
|
+
workflow/
|
|
52
|
+
00-AGENTS-template.md
|
|
53
|
+
01-brief-template.md
|
|
54
|
+
02-grillme-brief-prompt.md
|
|
55
|
+
03-grillme-product-prompt.md
|
|
56
|
+
04-prd-template.md
|
|
57
|
+
05-prd-compression-prompt.md
|
|
58
|
+
06-prespec-prompt.md
|
|
59
|
+
07-derive-docs-prompt.md
|
|
60
|
+
08-tlc-execution-prompt.md
|
|
61
|
+
09-quality-checklists.md
|
|
62
|
+
|
|
63
|
+
docs/
|
|
64
|
+
product/
|
|
65
|
+
technical/
|
|
66
|
+
decisions/
|
|
67
|
+
|
|
68
|
+
.specs/
|
|
69
|
+
project/
|
|
70
|
+
STATE.md
|
|
71
|
+
features/
|
|
72
|
+
|
|
73
|
+
AGENTS.md
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
O arquivo `.specs/project/STATE.md` é o marcador de estado do fluxo. Antes de continuar qualquer etapa, a skill deve ler esse arquivo.
|
|
77
|
+
|
|
78
|
+
## 3. Setup inicial
|
|
79
|
+
|
|
80
|
+
Existem dois jeitos de começar.
|
|
81
|
+
|
|
82
|
+
### Com nome e ideia
|
|
83
|
+
|
|
84
|
+
Se você passar nome e ideia no comando inicial, a skill cria a estrutura e registra esses dados no `STATE.md`.
|
|
85
|
+
|
|
86
|
+
Exemplo:
|
|
87
|
+
|
|
88
|
+
```txt
|
|
89
|
+
/iniciar-projeto-sdd Nome: StudyFlow. Ideia: Um app para ajudar estudantes a organizar revisões.
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
Resultado esperado:
|
|
93
|
+
|
|
94
|
+
- estrutura do workflow criada;
|
|
95
|
+
- `AGENTS.md` criado;
|
|
96
|
+
- `.specs/project/STATE.md` criado;
|
|
97
|
+
- nome e ideia registrados como contexto inicial.
|
|
98
|
+
|
|
99
|
+
Depois disso, o agente inicia o Grill-me do Brief Inicial. Ele pode usar nome e ideia como contexto e fazer apenas as perguntas que ainda forem necessárias.
|
|
100
|
+
|
|
101
|
+
### Sem nome ou ideia
|
|
102
|
+
|
|
103
|
+
Se você rodar apenas:
|
|
104
|
+
|
|
105
|
+
```txt
|
|
106
|
+
/iniciar-projeto-sdd
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
a skill cria somente a estrutura e o `STATE.md`.
|
|
110
|
+
|
|
111
|
+
Ela não cria `docs/product/Brief_Inicial.md` vazio.
|
|
112
|
+
|
|
113
|
+
Nesse caso, o agente inicia o Grill-me do Brief Inicial perguntando primeiro o essencial para conseguir gerar o brief.
|
|
114
|
+
|
|
115
|
+
## 4. Brief Inicial
|
|
116
|
+
|
|
117
|
+
O Brief Inicial é um documento curto para registrar a ideia bruta sem inventar detalhes demais.
|
|
118
|
+
|
|
119
|
+
Arquivo gerado:
|
|
120
|
+
|
|
121
|
+
```txt
|
|
122
|
+
docs/product/Brief_Inicial.md
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
Regras importantes:
|
|
126
|
+
|
|
127
|
+
- você não preenche esse template manualmente;
|
|
128
|
+
- a skill usa um Grill-me curto para preencher o brief;
|
|
129
|
+
- o limite é de até 3 perguntas;
|
|
130
|
+
- as perguntas vêm uma por vez;
|
|
131
|
+
- cada pergunta vem com uma resposta recomendada;
|
|
132
|
+
- registra lacunas como dúvidas iniciais;
|
|
133
|
+
- usa premissas apenas quando forem seguras;
|
|
134
|
+
- não pergunta sobre stack, banco, framework, deploy, arquitetura ou código.
|
|
135
|
+
|
|
136
|
+
Depois de gerar o Brief Inicial, a skill mostra opções numeradas:
|
|
137
|
+
|
|
138
|
+
```txt
|
|
139
|
+
Escolha o próximo passo:
|
|
140
|
+
|
|
141
|
+
1. Enriquecer o Brief Inicial.
|
|
142
|
+
2. Continuar para o Grill-me de produto.
|
|
143
|
+
3. Pausar para revisão manual.
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
Você responde com o número da opção.
|
|
147
|
+
|
|
148
|
+
## 5. Grill-me do brief
|
|
149
|
+
|
|
150
|
+
Esta etapa acontece automaticamente para criar o Brief Inicial.
|
|
151
|
+
|
|
152
|
+
Ela também pode ser usada depois, caso você escolha a opção de enriquecer o brief.
|
|
153
|
+
|
|
154
|
+
Limites:
|
|
155
|
+
|
|
156
|
+
- até 3 perguntas;
|
|
157
|
+
- uma pergunta por vez;
|
|
158
|
+
- cada pergunta deve vir com uma resposta recomendada;
|
|
159
|
+
- perguntas apenas sobre as 8 seções do Brief Inicial.
|
|
160
|
+
|
|
161
|
+
Ao final, a skill cria ou atualiza `docs/product/Brief_Inicial.md` e mostra opções numeradas para o próximo passo.
|
|
162
|
+
|
|
163
|
+
## 6. Grill-me de produto
|
|
164
|
+
|
|
165
|
+
Esta é a etapa principal de descoberta de produto.
|
|
166
|
+
|
|
167
|
+
A skill usa o Brief Inicial como fonte base e faz perguntas para gerar um PRD enxuto e autoexplicativo.
|
|
168
|
+
|
|
169
|
+
Você chega nesta etapa escolhendo a opção `Continuar para o Grill-me de produto` depois do Brief Inicial.
|
|
170
|
+
|
|
171
|
+
Limites:
|
|
172
|
+
|
|
173
|
+
- até 30 blocos;
|
|
174
|
+
- cada bloco tem de 3 a 5 perguntas;
|
|
175
|
+
- cada pergunta vem com uma resposta recomendada;
|
|
176
|
+
- o limite é por blocos, não por número total de perguntas.
|
|
177
|
+
|
|
178
|
+
O Grill-me de produto pode cobrir:
|
|
179
|
+
|
|
180
|
+
- problema e contexto;
|
|
181
|
+
- público-alvo;
|
|
182
|
+
- proposta de valor;
|
|
183
|
+
- escopo do MVP;
|
|
184
|
+
- funcionalidades principais;
|
|
185
|
+
- regras de negócio;
|
|
186
|
+
- fluxos principais;
|
|
187
|
+
- métricas, riscos e decisões em aberto.
|
|
188
|
+
|
|
189
|
+
Nesta etapa a skill não deve perguntar sobre:
|
|
190
|
+
|
|
191
|
+
- stack;
|
|
192
|
+
- banco;
|
|
193
|
+
- framework;
|
|
194
|
+
- endpoints;
|
|
195
|
+
- schema;
|
|
196
|
+
- ORM;
|
|
197
|
+
- deploy;
|
|
198
|
+
- arquitetura;
|
|
199
|
+
- implementação.
|
|
200
|
+
|
|
201
|
+
Quando a entrevista termina ou atinge o limite, a skill gera automaticamente o PRD Principal.
|
|
202
|
+
|
|
203
|
+
## 7. PRD Principal
|
|
204
|
+
|
|
205
|
+
Arquivo gerado:
|
|
206
|
+
|
|
207
|
+
```txt
|
|
208
|
+
docs/product/PRD_Principal.md
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
O PRD é a fonte de verdade de produto.
|
|
212
|
+
|
|
213
|
+
Ele deve conter:
|
|
214
|
+
|
|
215
|
+
1. Resumo
|
|
216
|
+
2. Problema
|
|
217
|
+
3. Público-alvo
|
|
218
|
+
4. Proposta de valor
|
|
219
|
+
5. Objetivos do MVP
|
|
220
|
+
6. Escopo do MVP
|
|
221
|
+
7. Funcionalidades principais
|
|
222
|
+
8. Regras de negócio principais
|
|
223
|
+
9. Fluxos principais
|
|
224
|
+
10. Requisitos funcionais
|
|
225
|
+
11. Requisitos não funcionais
|
|
226
|
+
12. Critérios de aceite
|
|
227
|
+
13. Métricas de sucesso
|
|
228
|
+
14. Riscos e mitigação
|
|
229
|
+
15. Decisões tomadas
|
|
230
|
+
16. Decisões em aberto
|
|
231
|
+
|
|
232
|
+
Depois de gerar o PRD, a skill deve:
|
|
233
|
+
|
|
234
|
+
- atualizar `.specs/project/STATE.md`;
|
|
235
|
+
- parar o fluxo;
|
|
236
|
+
- mostrar opções numeradas antes da compressão/revisão.
|
|
237
|
+
|
|
238
|
+
Exemplo:
|
|
239
|
+
|
|
240
|
+
```txt
|
|
241
|
+
Escolha o próximo passo:
|
|
242
|
+
|
|
243
|
+
1. Revisar e compactar o PRD.
|
|
244
|
+
2. Pausar para revisão manual.
|
|
245
|
+
```
|
|
246
|
+
|
|
247
|
+
## 8. Compressão e revisão do PRD
|
|
248
|
+
|
|
249
|
+
Esta etapa só começa quando você escolhe a opção `Revisar e compactar o PRD`.
|
|
250
|
+
|
|
251
|
+
Objetivo:
|
|
252
|
+
|
|
253
|
+
- reduzir redundância;
|
|
254
|
+
- melhorar clareza;
|
|
255
|
+
- preservar decisões importantes;
|
|
256
|
+
- preservar escopo e fora de escopo;
|
|
257
|
+
- preservar critérios de aceite;
|
|
258
|
+
- remover detalhes técnicos prematuros.
|
|
259
|
+
|
|
260
|
+
Limite:
|
|
261
|
+
|
|
262
|
+
- até 5 perguntas, apenas se houver lacunas importantes.
|
|
263
|
+
|
|
264
|
+
Ao final, a skill atualiza o PRD e o `STATE.md`.
|
|
265
|
+
|
|
266
|
+
Depois disso, ela para novamente e pede aprovação explícita do PRD revisado antes de iniciar a PreSpec Técnica.
|
|
267
|
+
|
|
268
|
+
Exemplo:
|
|
269
|
+
|
|
270
|
+
```txt
|
|
271
|
+
Escolha o próximo passo:
|
|
272
|
+
|
|
273
|
+
1. Aprovar PRD revisado e gerar PreSpec Técnica.
|
|
274
|
+
2. Fazer ajustes no PRD.
|
|
275
|
+
3. Pausar.
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
## 9. PreSpec Técnica
|
|
279
|
+
|
|
280
|
+
Esta etapa só começa depois que você escolhe a opção `Aprovar PRD revisado e gerar PreSpec Técnica`.
|
|
281
|
+
|
|
282
|
+
Arquivo gerado:
|
|
283
|
+
|
|
284
|
+
```txt
|
|
285
|
+
docs/technical/PreSpec_Tecnica.md
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
A PreSpec é a ponte entre produto e engenharia. Ela ainda não escolhe stack nem entra em implementação detalhada.
|
|
289
|
+
|
|
290
|
+
Ela pode tratar de:
|
|
291
|
+
|
|
292
|
+
- entidades conceituais;
|
|
293
|
+
- permissões;
|
|
294
|
+
- dados essenciais;
|
|
295
|
+
- regras de domínio;
|
|
296
|
+
- validações;
|
|
297
|
+
- contratos conceituais;
|
|
298
|
+
- riscos técnicos;
|
|
299
|
+
- estratégia inicial de testes;
|
|
300
|
+
- backlog por fatias verticais.
|
|
301
|
+
|
|
302
|
+
Limite:
|
|
303
|
+
|
|
304
|
+
- até 10 perguntas técnicas conceituais, se forem necessárias.
|
|
305
|
+
|
|
306
|
+
Não deve perguntar sobre:
|
|
307
|
+
|
|
308
|
+
- framework específico;
|
|
309
|
+
- ORM específico;
|
|
310
|
+
- biblioteca específica;
|
|
311
|
+
- provedor de deploy;
|
|
312
|
+
- código;
|
|
313
|
+
- implementação detalhada.
|
|
314
|
+
|
|
315
|
+
## 10. Derivação técnica
|
|
316
|
+
|
|
317
|
+
Depois da PreSpec, a skill deriva os documentos técnicos especializados.
|
|
318
|
+
|
|
319
|
+
Arquivos esperados:
|
|
320
|
+
|
|
321
|
+
```txt
|
|
322
|
+
docs/technical/Domain_Model.md
|
|
323
|
+
docs/technical/Architecture.md
|
|
324
|
+
docs/technical/API_Contracts.md
|
|
325
|
+
docs/technical/Test_Strategy.md
|
|
326
|
+
docs/decisions/ADR-*.md
|
|
327
|
+
.specs/project/PROJECT.md
|
|
328
|
+
.specs/project/ROADMAP.md
|
|
329
|
+
.specs/features/[feature]/spec.md
|
|
330
|
+
.specs/features/[feature]/design.md
|
|
331
|
+
.specs/features/[feature]/tasks.md
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
Regra principal:
|
|
335
|
+
|
|
336
|
+
- a skill não faz nova entrevista nessa etapa, salvo inconsistência crítica entre PRD e PreSpec.
|
|
337
|
+
|
|
338
|
+
É nessa fase, e não no setup, que `PROJECT.md` e `ROADMAP.md` devem nascer.
|
|
339
|
+
|
|
340
|
+
## 11. TLC por fatia vertical
|
|
341
|
+
|
|
342
|
+
Depois que os documentos técnicos e specs existem, a execução passa a ser por fatia vertical.
|
|
343
|
+
|
|
344
|
+
Cada fatia deve ter:
|
|
345
|
+
|
|
346
|
+
```txt
|
|
347
|
+
.specs/features/[feature]/spec.md
|
|
348
|
+
.specs/features/[feature]/design.md
|
|
349
|
+
.specs/features/[feature]/tasks.md
|
|
350
|
+
```
|
|
351
|
+
|
|
352
|
+
A skill deve trabalhar uma fatia por vez.
|
|
353
|
+
|
|
354
|
+
Regras:
|
|
355
|
+
|
|
356
|
+
- não alterar escopo global sem atualizar documentação;
|
|
357
|
+
- não implementar fora da fatia selecionada;
|
|
358
|
+
- fazer até 5 perguntas se houver lacunas relevantes;
|
|
359
|
+
- atualizar `STATE.md` ao final;
|
|
360
|
+
- marcar tasks concluídas;
|
|
361
|
+
- registrar decisões importantes como ADR.
|
|
362
|
+
|
|
363
|
+
## 12. Máquina de estados
|
|
364
|
+
|
|
365
|
+
A skill não segue uma lista linear cega. Ela lê `.specs/project/STATE.md` e decide o próximo passo.
|
|
366
|
+
|
|
367
|
+
Fluxo resumido:
|
|
368
|
+
|
|
369
|
+
```txt
|
|
370
|
+
Setup
|
|
371
|
+
↓
|
|
372
|
+
Grill-me do Brief Inicial
|
|
373
|
+
↓
|
|
374
|
+
Brief Inicial gerado
|
|
375
|
+
↓
|
|
376
|
+
opções: enriquecer brief / continuar / pausar
|
|
377
|
+
↓
|
|
378
|
+
Grill-me de produto
|
|
379
|
+
↓
|
|
380
|
+
PRD Principal
|
|
381
|
+
↓
|
|
382
|
+
checkpoint: confirmar compressão/revisão
|
|
383
|
+
↓
|
|
384
|
+
PRD revisado
|
|
385
|
+
↓
|
|
386
|
+
checkpoint: aprovar PRD revisado
|
|
387
|
+
↓
|
|
388
|
+
PreSpec Técnica
|
|
389
|
+
↓
|
|
390
|
+
Docs técnicos derivados
|
|
391
|
+
↓
|
|
392
|
+
Specs TLC
|
|
393
|
+
↓
|
|
394
|
+
Execução por fatia vertical
|
|
395
|
+
```
|
|
396
|
+
|
|
397
|
+
Se houver uma próxima etapa inequívoca no `STATE.md`, a skill pode continuar automaticamente.
|
|
398
|
+
|
|
399
|
+
Se houver mais de um caminho válido, ela deve mostrar opções numeradas e aguardar sua escolha.
|
|
400
|
+
|
|
401
|
+
## 13. Checkpoints obrigatórios
|
|
402
|
+
|
|
403
|
+
A skill deve parar e pedir confirmação nestes pontos:
|
|
404
|
+
|
|
405
|
+
1. depois de criar ou atualizar o Brief Inicial;
|
|
406
|
+
2. depois de gerar o PRD Principal;
|
|
407
|
+
3. depois de revisar/compactar o PRD;
|
|
408
|
+
4. antes de iniciar implementação de uma fatia vertical se houver lacunas relevantes.
|
|
409
|
+
|
|
410
|
+
Essa confirmação deve ser apresentada como opções numeradas, não como exigência de digitar uma frase específica.
|
|
411
|
+
|
|
412
|
+
O checkpoint mais importante é este:
|
|
413
|
+
|
|
414
|
+
```txt
|
|
415
|
+
PRD revisado → aprovação explícita → PreSpec Técnica
|
|
416
|
+
```
|
|
417
|
+
|
|
418
|
+
Isso evita que decisões técnicas nasçam antes da fonte de verdade de produto estar aprovada.
|
|
419
|
+
|
|
420
|
+
## 14. Comandos úteis
|
|
421
|
+
|
|
422
|
+
Iniciar estrutura sem brief:
|
|
423
|
+
|
|
424
|
+
```txt
|
|
425
|
+
/iniciar-projeto-sdd
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
Iniciar com brief:
|
|
429
|
+
|
|
430
|
+
```txt
|
|
431
|
+
/iniciar-projeto-sdd Nome: [nome]. Ideia: [ideia].
|
|
432
|
+
```
|
|
433
|
+
|
|
434
|
+
Continuar fluxo:
|
|
435
|
+
|
|
436
|
+
```txt
|
|
437
|
+
/continuar-sdd
|
|
438
|
+
```
|
|
439
|
+
|
|
440
|
+
Nos checkpoints, escolha uma das opções numeradas mostradas pelo agente.
|
|
441
|
+
|
|
442
|
+
## 15. Checklist rápido de uso
|
|
443
|
+
|
|
444
|
+
Para usar em um projeto novo:
|
|
445
|
+
|
|
446
|
+
1. Rode `/iniciar-projeto-sdd`.
|
|
447
|
+
2. Responda o Grill-me curto do Brief Inicial.
|
|
448
|
+
3. A skill gera `docs/product/Brief_Inicial.md`.
|
|
449
|
+
4. Escolha se deseja enriquecer o brief, continuar ou pausar.
|
|
450
|
+
5. Se escolher continuar, responda o Grill-me de produto.
|
|
451
|
+
6. Responda os blocos de perguntas.
|
|
452
|
+
7. Revise o PRD gerado.
|
|
453
|
+
8. Escolha se deseja revisar/compactar o PRD.
|
|
454
|
+
9. Depois da revisão, escolha se aprova o PRD revisado e gera a PreSpec.
|
|
455
|
+
10. Gere a PreSpec Técnica.
|
|
456
|
+
11. Derive os documentos técnicos.
|
|
457
|
+
12. Execute uma fatia vertical por vez.
|
|
458
|
+
|
|
459
|
+
## 16. Distribuição futura via npm/npx
|
|
460
|
+
|
|
461
|
+
A skill foi organizada para poder virar um pacote npm/npx no futuro.
|
|
462
|
+
|
|
463
|
+
O pacote deve incluir:
|
|
464
|
+
|
|
465
|
+
- `skills/iniciar-projeto-sdd/SKILL.md`;
|
|
466
|
+
- `skills/iniciar-projeto-sdd/scripts/init_sdd_project.sh`;
|
|
467
|
+
- `skills/iniciar-projeto-sdd/assets/workflow/`;
|
|
468
|
+
- `skills/iniciar-projeto-sdd/references/workflow-summary.md`.
|
|
469
|
+
|
|
470
|
+
O comando npx deve conseguir rodar em qualquer diretório alvo, copiar os templates de `assets/workflow` e preservar `SDD_WORKFLOW_TEMPLATE_DIR` como opção para desenvolvimento local.
|
|
471
|
+
|
|
472
|
+
Instalação global em `~/.agents/skills` não é parte obrigatória deste fluxo. Ela pode ser usada como conveniência local, mas a distribuição planejada é via npm/npx.
|
package/package.json
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "create-sdd-workflow",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Scaffold an SDD documentation workflow with Brief, PRD, PreSpec, technical docs, and vertical-slice specs.",
|
|
5
|
+
"type": "commonjs",
|
|
6
|
+
"bin": {
|
|
7
|
+
"create-sdd-workflow": "bin/create-sdd-workflow.js"
|
|
8
|
+
},
|
|
9
|
+
"files": [
|
|
10
|
+
"bin/",
|
|
11
|
+
"workflow/",
|
|
12
|
+
"skills/iniciar-projeto-sdd/",
|
|
13
|
+
"manual_workflow_sdd_grillme_tlc.md",
|
|
14
|
+
"AGENTS.md",
|
|
15
|
+
"README.md"
|
|
16
|
+
],
|
|
17
|
+
"keywords": [
|
|
18
|
+
"sdd",
|
|
19
|
+
"spec-driven",
|
|
20
|
+
"workflow",
|
|
21
|
+
"documentation",
|
|
22
|
+
"prd",
|
|
23
|
+
"prespec",
|
|
24
|
+
"scaffold",
|
|
25
|
+
"codex"
|
|
26
|
+
],
|
|
27
|
+
"author": "Vonderheidon",
|
|
28
|
+
"license": "MIT",
|
|
29
|
+
"publishConfig": {
|
|
30
|
+
"access": "public"
|
|
31
|
+
},
|
|
32
|
+
"scripts": {
|
|
33
|
+
"smoke": "node bin/create-sdd-workflow.js /tmp/create-sdd-workflow-smoke --force --name Smoke --idea \"Validate package scaffold\""
|
|
34
|
+
},
|
|
35
|
+
"engines": {
|
|
36
|
+
"node": ">=18"
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: iniciar-projeto-sdd
|
|
3
|
+
description: Inicializa e conduz um workflow SDD com Grill-me, Brief Inicial, PRD, PreSpec Técnica, docs derivados e TLC por fatias verticais. Use quando o usuário pedir /iniciar-projeto-sdd, iniciar um projeto SDD, criar a estrutura /workflow, ou transformar uma ideia em documentação guiada.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Iniciar Projeto SDD
|
|
7
|
+
|
|
8
|
+
Use esta skill para inicializar automaticamente um projeto com o workflow SDD + Grill-me + PreSpec + TLC.
|
|
9
|
+
|
|
10
|
+
## Fluxo
|
|
11
|
+
|
|
12
|
+
1. Extraia do pedido do usuário, se existirem, `Nome` e `Ideia`.
|
|
13
|
+
2. Rode `scripts/init_sdd_project.sh` no diretório alvo para criar a estrutura base sem sobrescrever arquivos existentes.
|
|
14
|
+
- Se houver nome e ideia, passe `--name "[nome]" --idea "[ideia]"` para registrar esses dados no estado inicial.
|
|
15
|
+
- Se não houver nome e ideia, rode apenas o setup.
|
|
16
|
+
3. O setup deve criar `.specs/project/STATE.md` desde o começo.
|
|
17
|
+
4. O setup não deve criar `.specs/project/PROJECT.md` nem `.specs/project/ROADMAP.md`; esses arquivos só nascem na derivação técnica, depois da PreSpec.
|
|
18
|
+
5. O setup não deve criar `docs/product/Brief_Inicial.md` vazio.
|
|
19
|
+
6. Após o setup, inicie o Grill-me do Brief Inicial automaticamente para preencher o brief.
|
|
20
|
+
7. Faça no máximo 3 perguntas de brief, uma por vez, cada uma com resposta recomendada.
|
|
21
|
+
8. Se nome e ideia já foram fornecidos, trate-os como contexto inicial e pergunte apenas o que ainda for necessário.
|
|
22
|
+
9. Não faça perguntas fora do escopo das 8 seções do Brief Inicial.
|
|
23
|
+
10. Ao terminar a entrevista curta, gere `docs/product/Brief_Inicial.md` usando exatamente `workflow/01-brief-template.md`.
|
|
24
|
+
11. Use premissas e dúvidas iniciais para preencher lacunas que não bloqueiam o entendimento.
|
|
25
|
+
12. Atualize `.specs/project/STATE.md` com a etapa atual, próxima decisão e log curto.
|
|
26
|
+
13. Depois de criar ou atualizar o Brief Inicial, pare e apresente opções numeradas para o usuário escolher.
|
|
27
|
+
14. Só avance para PRD depois que o usuário escolher a opção de continuar para o Grill-me de produto.
|
|
28
|
+
|
|
29
|
+
## Regras da Etapa 1
|
|
30
|
+
|
|
31
|
+
- O Brief Inicial deve conter exatamente estas seções:
|
|
32
|
+
1. Ideia em uma frase
|
|
33
|
+
2. Problema percebido
|
|
34
|
+
3. Público imaginado
|
|
35
|
+
4. Solução imaginada
|
|
36
|
+
5. Contexto de uso
|
|
37
|
+
6. Resultado esperado
|
|
38
|
+
7. Restrições conhecidas
|
|
39
|
+
8. Dúvidas iniciais
|
|
40
|
+
- Não adicione seções.
|
|
41
|
+
- Não pergunte sobre stack, banco, framework, arquitetura, implementação, deploy ou código.
|
|
42
|
+
- Não crie `docs/product/Brief_Inicial.md` vazio durante o setup.
|
|
43
|
+
- Use Grill-me para preencher o Brief Inicial; o usuário não deve precisar preencher o template manualmente.
|
|
44
|
+
- Faça no máximo 3 perguntas de brief, uma por vez.
|
|
45
|
+
- Para cada pergunta, forneça uma resposta recomendada.
|
|
46
|
+
- Mantenha o Brief Inicial conservador: não preencha lacunas relevantes por inferência forte.
|
|
47
|
+
- Se algo puder ser assumido sem grande risco, registre como premissa na seção mais adequada.
|
|
48
|
+
- Se algo não for essencial agora, registre em `8. Dúvidas iniciais`.
|
|
49
|
+
- Após gerar o brief, apresente opções numeradas em vez de exigir comandos em linguagem natural.
|
|
50
|
+
|
|
51
|
+
## Comandos de ativação esperados
|
|
52
|
+
|
|
53
|
+
Trate estes pedidos como equivalentes:
|
|
54
|
+
|
|
55
|
+
- `/iniciar-projeto-sdd`
|
|
56
|
+
- `/iniciar-projeto-sdd Nome: X. Ideia: Y.`
|
|
57
|
+
- `iniciar projeto sdd`
|
|
58
|
+
- `use iniciar-projeto-sdd`
|
|
59
|
+
- `crie a estrutura do workflow SDD`
|
|
60
|
+
|
|
61
|
+
## Continuação do fluxo
|
|
62
|
+
|
|
63
|
+
Trate `/continuar-sdd` e `continuar sdd` como pedidos para retomar o fluxo a partir do estado atual.
|
|
64
|
+
|
|
65
|
+
Antes de continuar, leia `.specs/project/STATE.md` e `docs/product/Brief_Inicial.md`.
|
|
66
|
+
|
|
67
|
+
Se o estado indicar que o Brief Inicial ainda não existe, continue o Grill-me do Brief Inicial.
|
|
68
|
+
|
|
69
|
+
Se houver uma próxima etapa inequívoca no `STATE.md`, continue automaticamente.
|
|
70
|
+
|
|
71
|
+
Se houver mais de um caminho válido, mostre opções numeradas e aguarde escolha do usuário.
|
|
72
|
+
|
|
73
|
+
Após gerar o Brief Inicial, apresente opções como:
|
|
74
|
+
|
|
75
|
+
1. Enriquecer o Brief Inicial com até 3 perguntas.
|
|
76
|
+
2. Continuar para o Grill-me de produto.
|
|
77
|
+
3. Pausar para revisão manual.
|
|
78
|
+
|
|
79
|
+
Após gerar o PRD Principal, apresente opções como:
|
|
80
|
+
|
|
81
|
+
1. Revisar e compactar o PRD.
|
|
82
|
+
2. Pausar para revisão manual.
|
|
83
|
+
|
|
84
|
+
Após revisar/compactar o PRD, apresente opções como:
|
|
85
|
+
|
|
86
|
+
1. Aprovar PRD revisado e gerar PreSpec Técnica.
|
|
87
|
+
2. Fazer ajustes no PRD.
|
|
88
|
+
3. Pausar.
|
|
89
|
+
|
|
90
|
+
Se o usuário escolher enriquecer o brief, use `workflow/02-grillme-brief-prompt.md`.
|
|
91
|
+
|
|
92
|
+
Se o usuário escolher continuar para produto, use `workflow/03-grillme-product-prompt.md`.
|
|
93
|
+
|
|
94
|
+
No Grill-me de produto, faça até 30 blocos, com 3 a 5 perguntas por bloco.
|
|
95
|
+
|
|
96
|
+
O limite se aplica aos blocos, não ao número total de perguntas. Cada pergunta dentro do bloco deve vir acompanhada de uma resposta recomendada.
|
|
97
|
+
|
|
98
|
+
Quando o Grill-me de produto terminar ou atingir o limite de blocos, gere automaticamente `docs/product/PRD_Principal.md` usando `workflow/04-prd-template.md`.
|
|
99
|
+
|
|
100
|
+
Não peça confirmação adicional para gerar o PRD depois que a entrevista de produto estiver concluída.
|
|
101
|
+
|
|
102
|
+
Após gerar o PRD, pare o fluxo, atualize `.specs/project/STATE.md` e peça confirmação antes de iniciar a compressão/revisão do PRD.
|
|
103
|
+
|
|
104
|
+
## Próximas etapas
|
|
105
|
+
|
|
106
|
+
Conduza o fluxo como uma máquina de estados baseada em `.specs/project/STATE.md`, não como uma lista linear.
|
|
107
|
+
|
|
108
|
+
### Estados e transições
|
|
109
|
+
|
|
110
|
+
1. **Setup sem Brief Inicial**
|
|
111
|
+
- Pré-condição: `docs/product/Brief_Inicial.md` não existe.
|
|
112
|
+
- Próxima ação: conduzir o Grill-me do Brief Inicial.
|
|
113
|
+
- Faça até 3 perguntas, uma por vez, com resposta recomendada.
|
|
114
|
+
- Ao final, gere `docs/product/Brief_Inicial.md`.
|
|
115
|
+
- Não rode Grill-me de brief, Grill-me de produto ou PRD.
|
|
116
|
+
|
|
117
|
+
2. **Brief Inicial em rascunho**
|
|
118
|
+
- Pré-condição: `docs/product/Brief_Inicial.md` existe.
|
|
119
|
+
- Mostre opções numeradas:
|
|
120
|
+
1. Enriquecer o Brief Inicial.
|
|
121
|
+
2. Continuar para o Grill-me de produto.
|
|
122
|
+
3. Pausar para revisão manual.
|
|
123
|
+
- Aguarde escolha.
|
|
124
|
+
|
|
125
|
+
3. **Grill-me de produto concluído**
|
|
126
|
+
- Gere automaticamente `docs/product/PRD_Principal.md` usando `workflow/04-prd-template.md`.
|
|
127
|
+
- Atualize `.specs/project/STATE.md`.
|
|
128
|
+
- Pare e mostre opções numeradas antes de iniciar `workflow/05-prd-compression-prompt.md`.
|
|
129
|
+
|
|
130
|
+
4. **PRD gerado, aguardando compressão/revisão**
|
|
131
|
+
- Só use `workflow/05-prd-compression-prompt.md` após o usuário escolher essa opção.
|
|
132
|
+
- Ao concluir a compressão/revisão, atualize `docs/product/PRD_Principal.md` e `.specs/project/STATE.md`.
|
|
133
|
+
- Pare e mostre opções numeradas antes de iniciar a PreSpec.
|
|
134
|
+
|
|
135
|
+
5. **PRD revisado/aprovado, aguardando PreSpec**
|
|
136
|
+
- Só use `workflow/06-prespec-prompt.md` após o usuário escolher aprovar o PRD revisado e gerar a PreSpec.
|
|
137
|
+
- Gere `docs/technical/PreSpec_Tecnica.md`.
|
|
138
|
+
- Atualize `.specs/project/STATE.md`.
|
|
139
|
+
|
|
140
|
+
6. **PreSpec concluída, aguardando derivação técnica**
|
|
141
|
+
- Use `workflow/07-derive-docs-prompt.md`.
|
|
142
|
+
- Não faça nova entrevista, salvo inconsistência crítica.
|
|
143
|
+
- Crie `.specs/project/PROJECT.md` e `.specs/project/ROADMAP.md` apenas nesta fase ou depois dela.
|
|
144
|
+
|
|
145
|
+
7. **Docs técnicos e specs derivados**
|
|
146
|
+
- Use `workflow/08-tlc-execution-prompt.md` para executar uma fatia vertical por vez.
|
|
147
|
+
|
|
148
|
+
Crie `.specs/project/PROJECT.md` e `.specs/project/ROADMAP.md` apenas durante a derivação técnica, depois da PreSpec.
|
|
149
|
+
|
|
150
|
+
Use `references/workflow-summary.md` apenas quando precisar relembrar limites e responsabilidades de cada etapa.
|