@luanpdd/kit-mcp 0.2.1 → 0.4.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.
Files changed (221) hide show
  1. package/CHANGELOG.md +43 -1
  2. package/README.md +35 -18
  3. package/kit/COMANDOS.md +123 -0
  4. package/kit/agents/advisor-researcher.md +121 -0
  5. package/kit/agents/assumptions-analyzer.md +122 -0
  6. package/kit/agents/codebase-mapper.md +787 -0
  7. package/kit/agents/debugger.md +796 -0
  8. package/kit/agents/executor.md +516 -0
  9. package/kit/agents/integration-checker.md +217 -0
  10. package/kit/agents/nyquist-auditor.md +195 -0
  11. package/kit/agents/phase-researcher.md +715 -0
  12. package/kit/agents/plan-checker.md +289 -0
  13. package/kit/agents/planner.md +1373 -0
  14. package/kit/agents/project-researcher.md +671 -0
  15. package/kit/agents/research-synthesizer.md +259 -0
  16. package/kit/agents/roadmapper.md +696 -0
  17. package/kit/agents/ui-auditor.md +458 -0
  18. package/kit/agents/ui-checker.md +319 -0
  19. package/kit/agents/ui-researcher.md +374 -0
  20. package/kit/agents/user-profiler.md +183 -0
  21. package/kit/agents/verifier.md +719 -0
  22. package/kit/commands/adicionar-backlog.md +76 -0
  23. package/kit/commands/adicionar-fase.md +43 -0
  24. package/kit/commands/adicionar-tarefa.md +47 -0
  25. package/kit/commands/adicionar-testes.md +41 -0
  26. package/kit/commands/ajuda.md +22 -0
  27. package/kit/commands/atualizar.md +37 -0
  28. package/kit/commands/auditar-marco.md +36 -0
  29. package/kit/commands/auditar-uat.md +24 -0
  30. package/kit/commands/autonomo.md +41 -0
  31. package/kit/commands/branch-pr.md +25 -0
  32. package/kit/commands/concluir-marco.md +136 -0
  33. package/kit/commands/configuracoes.md +36 -0
  34. package/kit/commands/definir-perfil.md +12 -0
  35. package/kit/commands/depurar.md +173 -0
  36. package/kit/commands/discutir-fase.md +64 -0
  37. package/kit/commands/entrar-discord.md +18 -0
  38. package/kit/commands/estatisticas.md +18 -0
  39. package/kit/commands/executar-fase.md +59 -0
  40. package/kit/commands/expresso.md +47 -0
  41. package/kit/commands/fase-ui.md +34 -0
  42. package/kit/commands/fazer.md +30 -0
  43. package/kit/commands/fio.md +126 -0
  44. package/kit/commands/fluxos-trabalho.md +64 -0
  45. package/kit/commands/forense.md +56 -0
  46. package/kit/commands/gerenciador.md +39 -0
  47. package/kit/commands/inserir-fase.md +32 -0
  48. package/kit/commands/limpeza.md +18 -0
  49. package/kit/commands/listar-hipoteses-fase.md +46 -0
  50. package/kit/commands/listar-workspaces.md +19 -0
  51. package/kit/commands/mapear-codebase.md +71 -0
  52. package/kit/commands/nota.md +34 -0
  53. package/kit/commands/novo-marco.md +44 -0
  54. package/kit/commands/novo-projeto.md +42 -0
  55. package/kit/commands/novo-workspace.md +44 -0
  56. package/kit/commands/pausar-trabalho.md +38 -0
  57. package/kit/commands/perfil-usuario.md +46 -0
  58. package/kit/commands/pesquisar-fase.md +195 -0
  59. package/kit/commands/planejar-fase.md +47 -0
  60. package/kit/commands/planejar-lacunas.md +34 -0
  61. package/kit/commands/plantar-ideia.md +26 -0
  62. package/kit/commands/progresso.md +24 -0
  63. package/kit/commands/proximo.md +24 -0
  64. package/kit/commands/publicar.md +370 -0
  65. package/kit/commands/rapido.md +30 -0
  66. package/kit/commands/reaplicar-patches.md +124 -0
  67. package/kit/commands/relatorio-sessao.md +19 -0
  68. package/kit/commands/remover-fase.md +31 -0
  69. package/kit/commands/remover-workspace.md +26 -0
  70. package/kit/commands/resumo-marco.md +51 -0
  71. package/kit/commands/retomar-trabalho.md +40 -0
  72. package/kit/commands/revisar-backlog.md +60 -0
  73. package/kit/commands/revisar-ui.md +32 -0
  74. package/kit/commands/revisar.md +37 -0
  75. package/kit/commands/saude.md +22 -0
  76. package/kit/commands/setup-notion.md +93 -0
  77. package/kit/commands/sync-main.md +68 -0
  78. package/kit/commands/validar-fase.md +35 -0
  79. package/kit/commands/verificar-tarefas.md +45 -0
  80. package/kit/commands/verificar-trabalho.md +38 -0
  81. package/kit/file-manifest.json +219 -0
  82. package/kit/framework/VERSION +1 -0
  83. package/kit/framework/bin/lib/commands.cjs +959 -0
  84. package/kit/framework/bin/lib/config.cjs +442 -0
  85. package/kit/framework/bin/lib/core.cjs +1230 -0
  86. package/kit/framework/bin/lib/frontmatter.cjs +336 -0
  87. package/kit/framework/bin/lib/init.cjs +1442 -0
  88. package/kit/framework/bin/lib/milestone.cjs +252 -0
  89. package/kit/framework/bin/lib/model-profiles.cjs +68 -0
  90. package/kit/framework/bin/lib/phase.cjs +888 -0
  91. package/kit/framework/bin/lib/profile-output.cjs +952 -0
  92. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -0
  93. package/kit/framework/bin/lib/roadmap.cjs +329 -0
  94. package/kit/framework/bin/lib/security.cjs +382 -0
  95. package/kit/framework/bin/lib/state.cjs +1031 -0
  96. package/kit/framework/bin/lib/template.cjs +222 -0
  97. package/kit/framework/bin/lib/uat.cjs +282 -0
  98. package/kit/framework/bin/lib/verify.cjs +888 -0
  99. package/kit/framework/bin/lib/workstream.cjs +491 -0
  100. package/kit/framework/bin/tools.cjs +918 -0
  101. package/kit/framework/commands/workstreams.md +63 -0
  102. package/kit/framework/references/checkpoints.md +778 -0
  103. package/kit/framework/references/continuation-format.md +249 -0
  104. package/kit/framework/references/decimal-phase-calculation.md +64 -0
  105. package/kit/framework/references/git-integration.md +295 -0
  106. package/kit/framework/references/git-planning-commit.md +38 -0
  107. package/kit/framework/references/model-profile-resolution.md +36 -0
  108. package/kit/framework/references/model-profiles.md +139 -0
  109. package/kit/framework/references/phase-argument-parsing.md +61 -0
  110. package/kit/framework/references/planning-config.md +202 -0
  111. package/kit/framework/references/questioning.md +162 -0
  112. package/kit/framework/references/tdd.md +263 -0
  113. package/kit/framework/references/ui-brand.md +160 -0
  114. package/kit/framework/references/user-profiling.md +657 -0
  115. package/kit/framework/references/verification-patterns.md +612 -0
  116. package/kit/framework/references/workstream-flag.md +58 -0
  117. package/kit/framework/templates/DEBUG.md +164 -0
  118. package/kit/framework/templates/UAT.md +265 -0
  119. package/kit/framework/templates/UI-SPEC.md +100 -0
  120. package/kit/framework/templates/VALIDATION.md +76 -0
  121. package/kit/framework/templates/claude-md.md +122 -0
  122. package/kit/framework/templates/codebase/architecture.md +185 -0
  123. package/kit/framework/templates/codebase/concerns.md +205 -0
  124. package/kit/framework/templates/codebase/conventions.md +204 -0
  125. package/kit/framework/templates/codebase/integrations.md +192 -0
  126. package/kit/framework/templates/codebase/stack.md +158 -0
  127. package/kit/framework/templates/codebase/structure.md +199 -0
  128. package/kit/framework/templates/codebase/testing.md +301 -0
  129. package/kit/framework/templates/config.json +44 -0
  130. package/kit/framework/templates/context.md +352 -0
  131. package/kit/framework/templates/continue-here.md +78 -0
  132. package/kit/framework/templates/copilot-instructions.md +7 -0
  133. package/kit/framework/templates/debug-subagent-prompt.md +91 -0
  134. package/kit/framework/templates/dev-preferences.md +20 -0
  135. package/kit/framework/templates/discovery.md +146 -0
  136. package/kit/framework/templates/discussion-log.md +63 -0
  137. package/kit/framework/templates/milestone-archive.md +123 -0
  138. package/kit/framework/templates/milestone.md +115 -0
  139. package/kit/framework/templates/phase-prompt.md +610 -0
  140. package/kit/framework/templates/planner-subagent-prompt.md +117 -0
  141. package/kit/framework/templates/project.md +186 -0
  142. package/kit/framework/templates/requirements.md +231 -0
  143. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -0
  144. package/kit/framework/templates/research-project/FEATURES.md +147 -0
  145. package/kit/framework/templates/research-project/PITFALLS.md +200 -0
  146. package/kit/framework/templates/research-project/STACK.md +120 -0
  147. package/kit/framework/templates/research-project/SUMMARY.md +170 -0
  148. package/kit/framework/templates/research.md +419 -0
  149. package/kit/framework/templates/retrospective.md +54 -0
  150. package/kit/framework/templates/roadmap.md +202 -0
  151. package/kit/framework/templates/state.md +176 -0
  152. package/kit/framework/templates/summary-complex.md +59 -0
  153. package/kit/framework/templates/summary-minimal.md +41 -0
  154. package/kit/framework/templates/summary-standard.md +48 -0
  155. package/kit/framework/templates/summary.md +209 -0
  156. package/kit/framework/templates/user-profile.md +146 -0
  157. package/kit/framework/templates/user-setup.md +256 -0
  158. package/kit/framework/templates/verification-report.md +258 -0
  159. package/kit/framework/workflows/add-phase.md +112 -0
  160. package/kit/framework/workflows/add-tests.md +351 -0
  161. package/kit/framework/workflows/add-todo.md +158 -0
  162. package/kit/framework/workflows/audit-milestone.md +340 -0
  163. package/kit/framework/workflows/audit-uat.md +109 -0
  164. package/kit/framework/workflows/autonomous.md +891 -0
  165. package/kit/framework/workflows/check-todos.md +177 -0
  166. package/kit/framework/workflows/cleanup.md +152 -0
  167. package/kit/framework/workflows/complete-milestone.md +696 -0
  168. package/kit/framework/workflows/diagnose-issues.md +231 -0
  169. package/kit/framework/workflows/discovery-phase.md +289 -0
  170. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -0
  171. package/kit/framework/workflows/discuss-phase.md +1049 -0
  172. package/kit/framework/workflows/do.md +104 -0
  173. package/kit/framework/workflows/execute-phase.md +838 -0
  174. package/kit/framework/workflows/execute-plan.md +510 -0
  175. package/kit/framework/workflows/fast.md +102 -0
  176. package/kit/framework/workflows/forensics.md +265 -0
  177. package/kit/framework/workflows/health.md +181 -0
  178. package/kit/framework/workflows/help.md +606 -0
  179. package/kit/framework/workflows/insert-phase.md +130 -0
  180. package/kit/framework/workflows/list-phase-assumptions.md +178 -0
  181. package/kit/framework/workflows/list-workspaces.md +56 -0
  182. package/kit/framework/workflows/manager.md +362 -0
  183. package/kit/framework/workflows/map-codebase.md +377 -0
  184. package/kit/framework/workflows/milestone-summary.md +223 -0
  185. package/kit/framework/workflows/new-milestone.md +486 -0
  186. package/kit/framework/workflows/new-project.md +1250 -0
  187. package/kit/framework/workflows/new-workspace.md +237 -0
  188. package/kit/framework/workflows/next.md +97 -0
  189. package/kit/framework/workflows/node-repair.md +92 -0
  190. package/kit/framework/workflows/note.md +156 -0
  191. package/kit/framework/workflows/pause-work.md +176 -0
  192. package/kit/framework/workflows/plan-milestone-gaps.md +273 -0
  193. package/kit/framework/workflows/plan-phase.md +859 -0
  194. package/kit/framework/workflows/plant-seed.md +169 -0
  195. package/kit/framework/workflows/pr-branch.md +129 -0
  196. package/kit/framework/workflows/profile-user.md +450 -0
  197. package/kit/framework/workflows/progress.md +507 -0
  198. package/kit/framework/workflows/quick.md +757 -0
  199. package/kit/framework/workflows/remove-phase.md +155 -0
  200. package/kit/framework/workflows/remove-workspace.md +90 -0
  201. package/kit/framework/workflows/research-phase.md +82 -0
  202. package/kit/framework/workflows/resume-project.md +326 -0
  203. package/kit/framework/workflows/review.md +228 -0
  204. package/kit/framework/workflows/session-report.md +146 -0
  205. package/kit/framework/workflows/settings.md +283 -0
  206. package/kit/framework/workflows/ship.md +228 -0
  207. package/kit/framework/workflows/stats.md +60 -0
  208. package/kit/framework/workflows/transition.md +671 -0
  209. package/kit/framework/workflows/ui-phase.md +302 -0
  210. package/kit/framework/workflows/ui-review.md +165 -0
  211. package/kit/framework/workflows/update.md +323 -0
  212. package/kit/framework/workflows/validate-phase.md +174 -0
  213. package/kit/framework/workflows/verify-phase.md +252 -0
  214. package/kit/framework/workflows/verify-work.md +637 -0
  215. package/kit/hooks/check-update.js +114 -0
  216. package/kit/hooks/context-monitor.js +156 -0
  217. package/kit/hooks/prompt-guard.js +96 -0
  218. package/kit/hooks/statusline.js +119 -0
  219. package/kit/hooks/workflow-guard.js +94 -0
  220. package/kit/settings.json +45 -0
  221. package/package.json +1 -1
package/CHANGELOG.md CHANGED
@@ -6,6 +6,46 @@ Format: [Keep a Changelog](https://keepachangelog.com/en/1.1.0/) · Versioning:
6
6
 
7
7
  ## [Unreleased]
8
8
 
9
+ ## [0.4.0] - 2026-05-03
10
+
11
+ ### Changed
12
+ - README rewritten: bundled workflow framed as the default install path; `--kit-root` framed as the escape hatch for users who want to replace it entirely.
13
+ - "What ships in the box" lists actual bundled folders (19 agents, 60 commands, framework, hooks) instead of "example kit".
14
+ - Quick start reordered: use bundled as-is first, replace with own kit second.
15
+ - CLI examples updated with real counts.
16
+
17
+ This release is content-equivalent to 0.3.0 plus the documentation overhaul. No code changes versus 0.3.0.
18
+
19
+ ## [0.3.0] - 2026-05-03
20
+
21
+ **Reverts the v0.2.0 cleanup.** kit-mcp goes back to shipping an opinionated, embedded workflow — installing `@luanpdd/kit-mcp` once again gives you the maintainer's brownfield planning workflow (PT-BR) ready to use. The "generic infrastructure, bring your own kit" framing of v0.2.0 was based on the wrong premise: the bundled content **is** the maintainer's workflow, intentionally distributed for anyone to inherit. The `--kit-root` / `KIT_MCP_KIT_ROOT` escape hatch from v0.2.0 stays — point it at your own folder if you want to replace the bundled workflow entirely.
22
+
23
+ ### Restored
24
+ - 19 agents — planner, executor, verifier, debugger, codebase-mapper, ui-auditor, ui-checker, ui-researcher, advisor-researcher, assumptions-analyzer, integration-checker, nyquist-auditor, phase-researcher, plan-checker, project-researcher, research-synthesizer, roadmapper, user-profiler (plus the example-reviewer kept from 0.2.0).
25
+ - 60 slash-commands in PT-BR — milestone lifecycle (`/novo-marco`, `/concluir-marco`, `/auditar-marco`, `/planejar-lacunas`, `/resumo-marco`), phase lifecycle (`/discutir-fase`, `/planejar-fase`, `/executar-fase`, `/validar-fase`, `/verificar-trabalho`, `/adicionar-fase`, `/inserir-fase`, `/remover-fase`), task & idea capture (`/adicionar-tarefa`, `/nota`, `/plantar-ideia`, `/adicionar-backlog`, `/revisar-backlog`), workflows (`/autonomo`, `/expresso`, `/rapido`, `/fazer`, `/proximo`, `/fluxos-trabalho`), debugging (`/depurar`, `/forense`), publishing (`/publicar`, `/setup-notion`, `/branch-pr`), and more.
26
+ - `kit/framework/` — workflows + templates + bin libs the agents and commands delegate into.
27
+ - `kit/hooks/` — workflow guards, prompt guards, statusline.
28
+ - `kit/COMANDOS.md`, `kit/file-manifest.json`, `kit/settings.json`.
29
+
30
+ ### Not restored (intentionally)
31
+ - The 13 skills from the Anthropic Cowork ecosystem (paperclip, design-guide, company-creator, paperclip-create-agent, paperclip-create-plugin, release, release-changelog, prcheckloop, pr-report, doc-maintenance, deal-with-security-advisory, create-agent-adapter, para-memory-files). These belong to Anthropic, not to this package — install them separately if you want them.
32
+
33
+ ### Changed
34
+ - `kit/commands/setup-notion.md` — hardcoded Notion page ID and "Trynux" workspace name replaced with placeholder `{NOTION_PARENT_PAGE_ID}` configurable via env var `KIT_NOTION_PARENT_PAGE_ID`.
35
+ - `kit/commands/publicar.md` — hardcoded GitHub repo URL `IEP-Advocacia/obsidian-chat-trynux` replaced with placeholder `${OBSIDIAN_VAULT_REPO}` configurable via env var `OBSIDIAN_VAULT_REPO`. If the env var isn't set, the Obsidian publishing step is skipped cleanly.
36
+ - README rewritten: bundled workflow framed as the default install path; `--kit-root` framed as the escape hatch for users who want to replace it entirely.
37
+
38
+ ### Migration
39
+
40
+ If you installed v0.2.0 expecting the empty/example kit and don't want the bundled workflow, set `KIT_MCP_KIT_ROOT` to your own kit folder before any sync command — nothing else changes:
41
+
42
+ ```bash
43
+ export KIT_MCP_KIT_ROOT=~/my-kit
44
+ npx -y @luanpdd/kit-mcp sync install claude-code --project-root .
45
+ ```
46
+
47
+ If you were on v0.1.x and want the original bundled workflow back, just upgrade — `npm install @luanpdd/kit-mcp@latest` ships it again. (Note: the Anthropic Cowork skills bundled in 0.1.x are still excluded.)
48
+
9
49
  ## [0.2.0] - 2026-05-03
10
50
 
11
51
  **BREAKING.** kit-mcp is now generic infrastructure. The bundled "personal kit" content was removed — bring your own via `--kit-root` or `KIT_MCP_KIT_ROOT`.
@@ -110,7 +150,9 @@ npx -y @luanpdd/kit-mcp sync install claude-code --project-root .
110
150
  - CLI mirror of all MCP tools.
111
151
  - `install` command that registers kit-mcp into an IDE's MCP config (JSON for Claude/Cursor/Gemini/Windsurf, TOML for Codex).
112
152
 
113
- [Unreleased]: https://github.com/luanpdd/kit-mcp/compare/v0.2.0...HEAD
153
+ [Unreleased]: https://github.com/luanpdd/kit-mcp/compare/v0.4.0...HEAD
154
+ [0.4.0]: https://github.com/luanpdd/kit-mcp/compare/v0.3.0...v0.4.0
155
+ [0.3.0]: https://github.com/luanpdd/kit-mcp/compare/v0.2.1...v0.3.0
114
156
  [0.2.0]: https://github.com/luanpdd/kit-mcp/compare/v0.1.6...v0.2.0
115
157
  [0.1.6]: https://github.com/luanpdd/kit-mcp/compare/v0.1.5...v0.1.6
116
158
  [0.1.5]: https://github.com/luanpdd/kit-mcp/compare/v0.1.4...v0.1.5
package/README.md CHANGED
@@ -5,11 +5,11 @@
5
5
  [![CI](https://github.com/luanpdd/kit-mcp/actions/workflows/ci.yml/badge.svg)](https://github.com/luanpdd/kit-mcp/actions/workflows/ci.yml)
6
6
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
7
7
 
8
- Generic infrastructure to ship **your personal kit** of agents, slash-commands and skills as an **MCP server**, with one-shot **sync** that projects the kit into every supported IDE's native layout — Claude Code, Cursor, Codex, Gemini CLI, Windsurf, Antigravity, Copilot, Trae.
8
+ An opinionated **brownfield planning workflow** (in PT-BR) agents, slash-commands, framework shipped as an **MCP server**, with one-shot **sync** that projects the kit into every supported IDE's native layout — Claude Code, Cursor, Codex, Gemini CLI, Windsurf, Antigravity, Copilot, Trae.
9
9
 
10
10
  > **One canonical source. N IDEs. Edit once, everywhere updated.**
11
11
  >
12
- > Bring your own `kit/` folder, or extend the bundled example.
12
+ > Install and inherit the bundled workflow, or point `--kit-root` at your own folder to replace it entirely.
13
13
 
14
14
  ---
15
15
 
@@ -27,11 +27,15 @@ Inspired by [vinilana/dotcontext](https://github.com/vinilana/dotcontext) — se
27
27
 
28
28
  ```
29
29
  kit-mcp/
30
- ├── kit/ ← bundled EXAMPLE kit (replace with your own)
31
- │ ├── agents/example-reviewer.md
32
- ├── commands/example-greeting.md
33
- │ ├── skills/example-skill/SKILL.md
34
- └── README.md format guide
30
+ ├── kit/ ← bundled brownfield workflow (PT-BR)
31
+ │ ├── agents/ 19 agents (planner, executor, verifier, debugger,
32
+ │ ui-auditor, codebase-mapper, …)
33
+ │ ├── commands/ 60 slash-commands (/novo-marco, /planejar-fase,
34
+ │ /executar-fase, /publicar, …)
35
+ │ ├── framework/ workflows + templates + bin libs the agents use
36
+ │ ├── hooks/ workflow guards, prompt guards, statusline
37
+ │ ├── skills/example-skill/ single example skill (replace with your own)
38
+ │ └── README.md file-format guide
35
39
 
36
40
  ├── gates/ ← reusable workflow gates (regression, confidence, dep-check, …)
37
41
 
@@ -53,6 +57,12 @@ kit-mcp/
53
57
 
54
58
  **Lines of source code:** ~1100. **Runtime dependencies:** 3 (`@modelcontextprotocol/sdk`, `commander`, `chokidar`). **Build step:** none — plain ESM Node.js 20+.
55
59
 
60
+ ### About the bundled workflow
61
+
62
+ The bundled `kit/` is an opinionated **brownfield planning workflow** in Portuguese — milestones, phases, requirements, planning, execution with atomic commits and checkpoints, retrospective auditing. Installing `@luanpdd/kit-mcp` and syncing into your IDE gives you all 60 slash-commands, 19 agents, plus the framework templates that they delegate into.
63
+
64
+ If that's not what you want, point `--kit-root` at your own folder and ignore everything under `kit/` — the infrastructure (registry, sync, gates, forensics, MCP server) works the same regardless of what kit you load.
65
+
56
66
  ---
57
67
 
58
68
  ## Prerequisites
@@ -65,14 +75,21 @@ kit-mcp/
65
75
 
66
76
  ## Quick start
67
77
 
68
- ### 1. Try the example kit (no setup)
78
+ ### 1. Use the bundled workflow as-is (recommended)
69
79
 
70
80
  ```bash
71
- npx -y @luanpdd/kit-mcp kit list-agents # see the bundled example agent
72
- npx -y @luanpdd/kit-mcp sync targets # see all supported IDEs
81
+ # Browse what's bundled
82
+ npx -y @luanpdd/kit-mcp kit list-agents # 19 agents
83
+ npx -y @luanpdd/kit-mcp kit list-commands # 60 commands
84
+ npx -y @luanpdd/kit-mcp sync targets # supported IDEs
85
+
86
+ # Install into your project for Claude Code
87
+ npx -y @luanpdd/kit-mcp sync install claude-code --project-root .
73
88
  ```
74
89
 
75
- ### 2. Bring your own kit
90
+ After that, open the project in Claude Code and the slash-commands (`/novo-marco`, `/planejar-fase`, `/executar-fase`, `/publicar`, …) and agents are immediately available.
91
+
92
+ ### 2. Replace the bundled workflow with your own kit
76
93
 
77
94
  Point kit-mcp at your own `kit/` folder via `--kit-root` or the `KIT_MCP_KIT_ROOT` env var:
78
95
 
@@ -86,7 +103,7 @@ export KIT_MCP_KIT_ROOT=~/my-kit
86
103
  npx -y @luanpdd/kit-mcp sync install claude-code --project-root .
87
104
  ```
88
105
 
89
- Your `~/my-kit/` follows the same layout as the bundled example:
106
+ Your `~/my-kit/` follows the same layout as the bundled kit:
90
107
 
91
108
  ```
92
109
  my-kit/
@@ -116,11 +133,11 @@ The CLI mirrors the MCP tools 1:1. Output is always JSON to stdout. The global `
116
133
  ### `kit kit ...` — browse the kit
117
134
 
118
135
  ```bash
119
- kit kit list-agents # bundled example: 1 agent
120
- kit kit list-commands # bundled example: 1 command
121
- kit kit list-skills # bundled example: 1 skill
122
- kit kit get agent example-reviewer
123
- kit kit search "review" # fuzzy match across all kinds
136
+ kit kit list-agents # 19 agents (bundled workflow)
137
+ kit kit list-commands # 60 commands (bundled workflow)
138
+ kit kit list-skills # 1 skill (example only — bring your own)
139
+ kit kit get agent planner
140
+ kit kit search "milestone" # fuzzy match across all kinds
124
141
  ```
125
142
 
126
143
  ### `kit sync ...` — project into an IDE
@@ -453,7 +470,7 @@ PRs welcome.
453
470
  ## Smoke tests
454
471
 
455
472
  ```bash
456
- node bin/cli.js kit list-agents | head -5 # bundled example agent
473
+ node bin/cli.js kit list-agents | head -5 # 19 bundled agents
457
474
  node bin/cli.js sync targets # 8 IDEs
458
475
  node bin/cli.js gates list # 5 gates
459
476
  node bin/cli.js install dry-run claude-code --via npx
@@ -0,0 +1,123 @@
1
+ # Comandos do framework — Referência Rápida
2
+
3
+ ## Fluxo Principal
4
+
5
+ | Comando | O que faz |
6
+ |---------|-----------|
7
+ | `/novo-projeto` | Inicializa um novo projeto com coleta profunda de contexto e PROJECT.md |
8
+ | `/novo-marco` | Inicia um novo ciclo de milestone — atualiza PROJECT.md e encaminha para requisitos |
9
+ | `/discutir-fase` | Reúne contexto da fase por questionamento adaptativo antes do planejamento (`--auto` para pular perguntas) |
10
+ | `/planejar-fase` | Cria plano detalhado da fase (PLAN.md) com loop de verificação |
11
+ | `/executar-fase` | Executa todos os planos de uma fase com paralelização por ondas |
12
+ | `/proximo` | Avança automaticamente para o próximo passo lógico no workflow framework |
13
+ | `/autonomo` | Executa todas as fases restantes de forma autônoma — discutir→planejar→executar por fase |
14
+
15
+ ## Tarefas Rápidas
16
+
17
+ | Comando | O que faz |
18
+ |---------|-----------|
19
+ | `/fazer` | Roteia texto livre para o comando do framework correto automaticamente |
20
+ | `/rapido` | Executa tarefa trivial inline — sem subagentes, sem overhead de planejamento |
21
+ | `/expresso` | Executa tarefa rápida com garantias framework (commits atômicos, rastreamento de estado), pula agentes opcionais |
22
+
23
+ ## Gerenciamento de Fases
24
+
25
+ | Comando | O que faz |
26
+ |---------|-----------|
27
+ | `/adicionar-fase` | Adiciona fase ao final do milestone atual no roadmap |
28
+ | `/inserir-fase` | Insere trabalho urgente como fase decimal (ex: 72.1) entre fases existentes |
29
+ | `/remover-fase` | Remove uma fase futura do roadmap e renumera as subsequentes |
30
+ | `/pesquisar-fase` | Pesquisa como implementar uma fase (standalone — normalmente use `/planejar-fase`) |
31
+ | `/listar-hipoteses-fase` | Mostra as hipóteses do Claude sobre a abordagem de uma fase antes do planejamento |
32
+
33
+ ## Milestones e Progresso
34
+
35
+ | Comando | O que faz |
36
+ |---------|-----------|
37
+ | `/progresso` | Verifica o progresso do projeto, mostra contexto e roteia para próxima ação |
38
+ | `/auditar-marco` | Audita a conclusão do milestone contra a intenção original antes de arquivar |
39
+ | `/concluir-marco` | Arquiva milestone concluído e prepara para próxima versão |
40
+ | `/resumo-marco` | Gera resumo abrangente do projeto para onboarding e revisão da equipe |
41
+ | `/planejar-lacunas` | Cria fases para fechar todas as lacunas identificadas pela auditoria de milestone |
42
+
43
+ ## Verificação e Qualidade
44
+
45
+ | Comando | O que faz |
46
+ |---------|-----------|
47
+ | `/verificar-trabalho` | Valida funcionalidades construídas através de UAT conversacional |
48
+ | `/validar-fase` | Audita retroativamente e preenche lacunas de validação Nyquist para uma fase concluída |
49
+ | `/auditar-uat` | Auditoria multi-fase de todos os itens de UAT e verificação pendentes |
50
+ | `/adicionar-testes` | Gera testes para uma fase concluída com base nos critérios de UAT e implementação |
51
+ | `/verificar-tarefas` | Lista todos os todos pendentes e seleciona um para trabalhar |
52
+
53
+ ## UI / Frontend
54
+
55
+ | Comando | O que faz |
56
+ |---------|-----------|
57
+ | `/fase-ui` | Gera contrato de design UI (UI-SPEC.md) para fases de frontend |
58
+ | `/revisar-ui` | Auditoria visual retroativa de 6 pilares do código frontend implementado |
59
+
60
+ ## Sessão e Contexto
61
+
62
+ | Comando | O que faz |
63
+ |---------|-----------|
64
+ | `/pausar-trabalho` | Cria handoff de contexto ao pausar trabalho no meio de uma fase |
65
+ | `/retomar-trabalho` | Retoma o trabalho da sessão anterior com restauração completa de contexto |
66
+ | `/relatorio-sessao` | Gera relatório da sessão com estimativas de uso de tokens, resumo de trabalho e resultados |
67
+ | `/fio` | Gerencia threads de contexto persistentes para trabalho entre sessões |
68
+
69
+ ## Análise e Diagnóstico
70
+
71
+ | Comando | O que faz |
72
+ |---------|-----------|
73
+ | `/mapear-codebase` | Analisa a base de código com agentes paralelos, produz documentos em `.planning/codebase/` |
74
+ | `/depurar` | Depuração sistemática com estado persistente entre resets de contexto |
75
+ | `/forense` | Investigação post-mortem de workflows framework com falha — analisa git, artefatos e estado |
76
+ | `/saude` | Diagnostica a integridade do diretório de planejamento e opcionalmente repara problemas |
77
+ | `/estatisticas` | Exibe estatísticas do projeto — fases, planos, requisitos, métricas git e linha do tempo |
78
+
79
+ ## Publicação e Colaboração
80
+
81
+ | Comando | O que faz |
82
+ |---------|-----------|
83
+ | `/publicar` | Cria PR, executa revisão e prepara para merge após a verificação passar |
84
+ | `/branch-pr` | Cria branch limpo para PR filtrando commits de `.planning/` — pronto para revisão de código |
85
+ | `/revisar` | Solicita revisão entre IAs de planos de fase a partir de CLIs externas |
86
+
87
+ ## Backlog e Ideias
88
+
89
+ | Comando | O que faz |
90
+ |---------|-----------|
91
+ | `/nota` | Captura de ideias sem fricção — adicionar, listar ou promover notas |
92
+ | `/adicionar-tarefa` | Captura ideia ou tarefa como todo a partir do contexto da conversa atual |
93
+ | `/adicionar-backlog` | Adiciona uma ideia ao estacionamento de backlog (numeração 999.x) |
94
+ | `/revisar-backlog` | Revisa e promove itens do backlog para o milestone ativo |
95
+ | `/plantar-ideia` | Captura ideia prospectiva com condições de gatilho — surge automaticamente no milestone certo |
96
+
97
+ ## Workspaces
98
+
99
+ | Comando | O que faz |
100
+ |---------|-----------|
101
+ | `/novo-workspace` | Cria workspace isolado com cópias de repos e `.planning/` independente |
102
+ | `/listar-workspaces` | Lista os workspaces framework ativos e seu status |
103
+ | `/remover-workspace` | Remove um workspace framework e limpa as worktrees |
104
+ | `/fluxos-trabalho` | Gerencia fluxos de trabalho paralelos — listar, criar, alternar, status, concluir e retomar |
105
+ | `/gerenciador` | Central de comando interativa para gerenciar múltiplas fases em um terminal |
106
+
107
+ ## Perfil e Configurações
108
+
109
+ | Comando | O que faz |
110
+ |---------|-----------|
111
+ | `/perfil-usuario` | Gera perfil comportamental do desenvolvedor e cria artefatos descobríveis pelo Claude |
112
+ | `/definir-perfil` | Altera o perfil de modelo para os agentes framework (quality/balanced/budget/inherit) |
113
+ | `/configuracoes` | Configura os toggles de workflow framework e perfil de modelo |
114
+
115
+ ## Utilitários
116
+
117
+ | Comando | O que faz |
118
+ |---------|-----------|
119
+ | `/ajuda` | Mostra os comandos do framework disponíveis e o guia de uso |
120
+ | `/atualizar` | Atualiza o framework para a versão mais recente com exibição de changelog |
121
+ | `/reaplicar-patches` | Reaplicar modificações locais após uma atualização do framework |
122
+ | `/limpeza` | Arquiva diretórios de fase acumulados de milestones concluídos |
123
+ | `/entrar-discord` | Link para entrar na comunidade framework no Discord |
@@ -0,0 +1,121 @@
1
+ ---
2
+ name: advisor-researcher
3
+ description: Pesquisa uma única decisão de área cinzenta e retorna uma tabela de comparação estruturada com justificativa. Invocado pelo modo advisor do discutir-fase.
4
+ tools: Read, Bash, Grep, Glob, WebSearch, WebFetch, mcp__context7__*
5
+ color: cyan
6
+ ---
7
+
8
+ <output_style>
9
+ **Estilo: caveman LITE — compressão moderada na narração, artefato (tabela) completo.**
10
+
11
+ Em mensagens conversacionais, logs e retorno estruturado ao agente principal:
12
+ - Cortar: filler (just/really/basically/actually/simply), pleasantries (claro/com certeza/feliz em ajudar), hedging desnecessário
13
+ - Manter artigos e estrutura de frase quando aumentam clareza
14
+ - Termos técnicos exatos. Caminhos de arquivo e citações literais.
15
+
16
+ **Boundary CRÍTICO — tabela de comparação é seu produto:**
17
+ A tabela de comparação com 5 colunas (incluindo trade-offs e justificativa) é o output que o agente principal vai sintetizar. Cada célula deve ser **suficiente para a decisão sem ambiguidade** — não comprima trade-offs em fragmentos cifrados. Caveman aplica-se SÓ ao raciocínio falado e progresso de pesquisa.
18
+
19
+ **Auto-clarity — sair completamente do caveman quando:**
20
+ - Discussão de trade-offs entre opções (preserva nuance — esse é literalmente seu trabalho)
21
+ - Avisos de segurança ou ações irreversíveis
22
+ - Usuário pediu clarificação ou está confuso
23
+ </output_style>
24
+
25
+ <role>
26
+ Você é um pesquisador consultor framework. Você pesquisa UMA área cinzenta e produz UMA tabela de comparação com justificativa.
27
+
28
+ Invocado por `discuss-phase` via `Task()`. Você NÃO apresenta saída diretamente ao usuário — você retorna saída estruturada para o agente principal sintetizar.
29
+
30
+ **Responsabilidades principais:**
31
+ - Pesquisar a área cinzenta atribuída usando o conhecimento do Claude, Context7 e busca na web
32
+ - Produzir uma tabela de comparação estruturada com 5 colunas com opções genuinamente viáveis
33
+ - Escrever um parágrafo de justificativa fundamentando a recomendação no contexto do projeto
34
+ - Retornar saída markdown estruturada para o agente principal sintetizar
35
+ </role>
36
+
37
+ <input>
38
+ Agente recebe via prompt:
39
+
40
+ - `<gray_area>` -- nome e descrição da área
41
+ - `<phase_context>` -- descrição da fase do roadmap
42
+ - `<project_context>` -- informações breves do projeto
43
+ - `<calibration_tier>` -- um de: `full_maturity`, `standard`, `minimal_decisive`
44
+ </input>
45
+
46
+ <calibration_tiers>
47
+ O nível de calibração controla a forma da saída. Siga as instruções do nível exatamente.
48
+
49
+ ### full_maturity
50
+ - **Opções:** 3-5 opções
51
+ - **Sinais de maturidade:** Incluir contagens de estrelas, idade do projeto, tamanho do ecossistema quando relevante
52
+ - **Recomendações:** Condicionais ("Rec se X", "Rec se Y"), com peso para ferramentas testadas em batalha
53
+ - **Justificativa:** Parágrafo completo com sinais de maturidade e contexto do projeto
54
+
55
+ ### standard
56
+ - **Opções:** 2-4 opções
57
+ - **Recomendações:** Condicionais ("Rec se X", "Rec se Y")
58
+ - **Justificativa:** Parágrafo padrão fundamentando recomendação no contexto do projeto
59
+
60
+ ### minimal_decisive
61
+ - **Opções:** Máximo 2 opções
62
+ - **Recomendações:** Recomendação única e decisiva
63
+ - **Justificativa:** Breve (1-2 frases)
64
+ </calibration_tiers>
65
+
66
+ <output_format>
67
+ Retornar EXATAMENTE esta estrutura:
68
+
69
+ ```
70
+ ## {area_name}
71
+
72
+ | Opção | Prós | Contras | Complexidade | Recomendação |
73
+ |-------|------|---------|--------------|--------------|
74
+ | {opção} | {prós} | {contras} | {superfície + risco} | {rec condicional} |
75
+
76
+ **Justificativa:** {parágrafo fundamentando recomendação no contexto do projeto}
77
+ ```
78
+
79
+ **Definições das colunas:**
80
+ - **Opção:** Nome da abordagem ou ferramenta
81
+ - **Prós:** Principais vantagens (separadas por vírgula dentro da célula)
82
+ - **Contras:** Principais desvantagens (separadas por vírgula dentro da célula)
83
+ - **Complexidade:** Superfície de impacto + risco (ex: "3 arquivos, nova dep -- Risco: memória, estado de scroll"). NUNCA estimativas de tempo.
84
+ - **Recomendação:** Recomendação condicional (ex: "Rec se mobile-first", "Rec se SEO importa"). NUNCA ranking de vencedor único.
85
+ </output_format>
86
+
87
+ <rules>
88
+ 1. **Complexidade = superfície de impacto + risco** (ex: "3 arquivos, nova dep -- Risco: memória, estado de scroll"). NUNCA estimativas de tempo.
89
+ 2. **Recomendação = condicional** ("Rec se mobile-first", "Rec se SEO importa"). Não ranking de vencedor único.
90
+ 3. Se existir apenas 1 opção viável, afirme diretamente em vez de inventar alternativas de preenchimento.
91
+ 4. Use o conhecimento do Claude + Context7 + busca na web para verificar melhores práticas atuais.
92
+ 5. Foque em opções genuinamente viáveis — sem enchimento.
93
+ 6. NÃO inclua análise extendida — apenas tabela + justificativa.
94
+ </rules>
95
+
96
+ <tool_strategy>
97
+
98
+ ## Prioridade de Ferramentas
99
+
100
+ | Prioridade | Ferramenta | Usar Para | Nível de Confiança |
101
+ |------------|------------|-----------|-------------------|
102
+ | 1º | Context7 | APIs de biblioteca, recursos, configuração, versões | ALTO |
103
+ | 2º | WebFetch | Docs oficiais/READMEs não no Context7, changelogs | ALTO-MÉDIO |
104
+ | 3º | WebSearch | Descoberta de ecossistema, padrões da comunidade, armadilhas | Necessita verificação |
105
+
106
+ **Fluxo Context7:**
107
+ 1. `mcp__context7__resolve-library-id` com libraryName
108
+ 2. `mcp__context7__query-docs` com ID resolvido + consulta específica
109
+
110
+ Mantenha a pesquisa focada na única área cinzenta. Não explore tópicos tangenciais.
111
+ </tool_strategy>
112
+
113
+ <anti_patterns>
114
+ - NÃO pesquise além da única área cinzenta atribuída
115
+ - NÃO apresente saída diretamente ao usuário (o agente principal sintetiza)
116
+ - NÃO adicione colunas além do formato de 5 colunas (Opção, Prós, Contras, Complexidade, Recomendação)
117
+ - NÃO use estimativas de tempo na coluna Complexidade
118
+ - NÃO classifique opções ou declare um único vencedor (use recomendações condicionais)
119
+ - NÃO invente opções de preenchimento para encher a tabela — apenas abordagens genuinamente viáveis
120
+ - NÃO produza parágrafos de análise extendida além do único parágrafo de justificativa
121
+ </anti_patterns>
@@ -0,0 +1,122 @@
1
+ ---
2
+ name: assumptions-analyzer
3
+ description: Analisa profundamente a codebase para uma fase e retorna hipóteses estruturadas com evidências. Invocado pelo modo assumptions do discutir-fase.
4
+ tools: Read, Bash, Grep, Glob
5
+ color: cyan
6
+ ---
7
+
8
+ <output_style>
9
+ **Estilo: caveman — compressão alta na fala, prosa normal em artefatos.**
10
+
11
+ Em mensagens conversacionais, logs e retorno estruturado ao workflow:
12
+ - Cortar: filler (just/really/basically/actually/simply), pleasantries (claro/com certeza/feliz em ajudar), hedging desnecessário, artigos quando não compromete clareza
13
+ - Fragments OK. Sinônimos curtos. Padrão: `[coisa] [ação] [razão]. [próximo passo].`
14
+ - Termos técnicos exatos. Código inalterado. Erros citados literais.
15
+
16
+ **Auto-clarity — sair do caveman quando:**
17
+ - Avisos de segurança ou ações destrutivas/irreversíveis
18
+ - Sequências multi-passo onde fragmentar arrisca má interpretação
19
+ - Usuário pediu clarificação ou está confuso
20
+
21
+ **Boundary crítico — caminhos de arquivo e citações de evidência:**
22
+ Caminhos completos, números de linha e identificadores de código permanecem **exatos e completos** (não abrevie `src/components/Foo.tsx` para `Foo`). Caveman aplica-se à *narração* das hipóteses, não às evidências em si.
23
+ </output_style>
24
+
25
+ <role>
26
+ Você é um analisador de hipóteses framework. Você analisa profundamente a codebase para UMA fase e produz hipóteses estruturadas com evidências e níveis de confiança.
27
+
28
+ Invocado por `discuss-phase-assumptions` via `Task()`. Você NÃO apresenta saída diretamente ao usuário — você retorna saída estruturada para o workflow principal apresentar e confirmar.
29
+
30
+ **Responsabilidades principais:**
31
+ - Ler a descrição da fase no ROADMAP.md e quaisquer arquivos CONTEXT.md anteriores
32
+ - Buscar na codebase arquivos relacionados à fase (componentes, padrões, funcionalidades similares)
33
+ - Ler 5-15 arquivos de código-fonte mais relevantes
34
+ - Produzir hipóteses estruturadas citando caminhos de arquivo como evidência
35
+ - Sinalizar tópicos onde a análise da codebase sozinha é insuficiente (precisa de pesquisa externa)
36
+ </role>
37
+
38
+ <input>
39
+ Agente recebe via prompt:
40
+
41
+ - `<phase>` -- número e nome da fase
42
+ - `<phase_goal>` -- descrição da fase do ROADMAP.md
43
+ - `<prior_decisions>` -- resumo de decisões bloqueadas de fases anteriores
44
+ - `<codebase_hints>` -- resultados de scout (arquivos relevantes, componentes, padrões encontrados)
45
+ - `<calibration_tier>` -- um de: `full_maturity`, `standard`, `minimal_decisive`
46
+ </input>
47
+
48
+ <calibration_tiers>
49
+ O nível de calibração controla a forma da saída. Siga as instruções do nível exatamente.
50
+
51
+ ### full_maturity
52
+ - **Áreas:** 3-5 áreas de hipóteses
53
+ - **Alternativas:** 2-3 por item Provável/Incerto
54
+ - **Profundidade de evidência:** Citações detalhadas de caminho de arquivo com especificidades de linha
55
+
56
+ ### standard
57
+ - **Áreas:** 3-4 áreas de hipóteses
58
+ - **Alternativas:** 2 por item Provável/Incerto
59
+ - **Profundidade de evidência:** Citações de caminho de arquivo
60
+
61
+ ### minimal_decisive
62
+ - **Áreas:** 2-3 áreas de hipóteses
63
+ - **Alternativas:** Recomendação única e decisiva por item
64
+ - **Profundidade de evidência:** Apenas caminhos de arquivo principais
65
+ </calibration_tiers>
66
+
67
+ <process>
68
+ 1. Ler ROADMAP.md e extrair a descrição da fase
69
+ 2. Ler quaisquer arquivos CONTEXT.md anteriores de fases anteriores (encontrar via `find .planning/phases -name "*-CONTEXT.md"`)
70
+ 3. Usar Glob e Grep para encontrar arquivos relacionados aos termos do objetivo da fase
71
+ 4. Ler 5-15 arquivos de código-fonte mais relevantes para entender padrões existentes
72
+ 5. Formar hipóteses com base no que a codebase revela
73
+ 6. Classificar confiança: Confiante (claro pelo código), Provável (inferência razoável), Incerto (pode ir de várias formas)
74
+ 7. Sinalizar quaisquer tópicos que precisam de pesquisa externa (compatibilidade de biblioteca, melhores práticas do ecossistema)
75
+ 8. Retornar saída estruturada no formato exato abaixo
76
+ </process>
77
+
78
+ <output_format>
79
+ Retornar EXATAMENTE esta estrutura:
80
+
81
+ ```
82
+ ## Hipóteses
83
+
84
+ ### [Nome da Área] (ex: "Abordagem Técnica")
85
+ - **Hipótese:** [Declaração de decisão]
86
+ - **Por que desta forma:** [Evidência da codebase -- citar caminhos de arquivo]
87
+ - **Se errado:** [Consequência concreta de isso estar errado]
88
+ - **Confiança:** Confiante | Provável | Incerto
89
+
90
+ ### [Nome da Área 2]
91
+ - **Hipótese:** [Declaração de decisão]
92
+ - **Por que desta forma:** [Evidência]
93
+ - **Se errado:** [Consequência]
94
+ - **Confiança:** Confiante | Provável | Incerto
95
+
96
+ (Repetir para 2-5 áreas baseado no nível de calibração)
97
+
98
+ ## Precisa de Pesquisa Externa
99
+ [Tópicos onde a codebase sozinha é insuficiente -- compatibilidade de versão de biblioteca,
100
+ melhores práticas do ecossistema, etc. Deixar vazio se a codebase fornece evidência suficiente.]
101
+ ```
102
+ </output_format>
103
+
104
+ <rules>
105
+ 1. Toda hipótese DEVE citar pelo menos um caminho de arquivo como evidência.
106
+ 2. Toda hipótese DEVE declarar uma consequência concreta se estiver errada (não vaga "poderia causar problemas").
107
+ 3. Níveis de confiança devem ser honestos — não infle Confiante quando a evidência é fraca.
108
+ 4. Minimize itens Incertos lendo mais arquivos antes de desistir.
109
+ 5. NÃO sugira expansão de escopo — mantenha-se dentro do limite da fase.
110
+ 6. NÃO inclua detalhes de implementação (isso é para o planejador).
111
+ 7. NÃO encha com hipóteses óbvias — apenas superfície decisões que podem ir de múltiplas formas.
112
+ 8. Se decisões anteriores já bloqueiam uma escolha, marque como Confiante e cite a fase anterior.
113
+ </rules>
114
+
115
+ <anti_patterns>
116
+ - NÃO apresente saída diretamente ao usuário (o workflow principal trata da apresentação)
117
+ - NÃO pesquise além do que a codebase contém (sinalize lacunas em "Precisa de Pesquisa Externa")
118
+ - NÃO use busca na web ou ferramentas externas (você tem apenas Read, Bash, Grep, Glob)
119
+ - NÃO inclua estimativas de tempo ou avaliações de complexidade
120
+ - NÃO gere mais áreas do que o nível de calibração especifica
121
+ - NÃO invente hipóteses sobre código que você não leu — leia primeiro, depois forme opiniões
122
+ </anti_patterns>