@saulwade/swl-ses 1.9.0 → 2.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/CLAUDE.md +196 -196
- package/README.md +579 -579
- package/agentes/_propose-step.md +90 -0
- package/agentes/accesibilidad-wcag-swl.md +3 -3
- package/agentes/auto-evolucion-swl.md +908 -908
- package/agentes/disenador-ui-swl.md +6 -5
- package/agentes/frontend-angular-swl.md +2 -2
- package/agentes/frontend-css-swl.md +2 -2
- package/agentes/frontend-react-swl.md +4 -4
- package/agentes/frontend-swl.md +6 -6
- package/agentes/implementador-swl.md +2 -0
- package/agentes/investigador-ux-swl.md +5 -5
- package/agentes/orquestador-swl.md +9 -7
- package/agentes/perfilador-usuario-swl.md +321 -308
- package/agentes/producto-prd-swl.md +1 -1
- package/agentes/red-team-swl.md +218 -218
- package/agentes/tdd-qa-swl.md +17 -1
- package/bin/swl-ses.js +1 -1
- package/comandos/swl/actualizar.md +1 -1
- package/comandos/swl/aprender.md +2 -2
- package/comandos/swl/aprobar-plan.md +153 -0
- package/comandos/swl/ayuda.md +3 -3
- package/comandos/swl/briefing.md +122 -0
- package/comandos/swl/compactar.md +29 -2
- package/comandos/swl/discutir-fase.md +23 -2
- package/comandos/swl/ejecutar-fase.md +59 -6
- package/comandos/swl/evolucionar.md +1 -1
- package/comandos/swl/inbox.md +1 -1
- package/comandos/swl/instalar.md +1 -1
- package/comandos/swl/nemesis.md +1 -1
- package/comandos/swl/planear-fase.md +19 -1
- package/comandos/swl/plugins.md +1 -1
- package/comandos/swl/release.md +47 -1
- package/comandos/swl/status.md +348 -0
- package/comandos/swl/verificar.md +27 -1
- package/habilidades/ai-runtime-security/SKILL.md +1 -1
- package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -276
- package/habilidades/benchmark-memoria/SKILL.md +1 -1
- package/habilidades/calidad-contract-testing/SKILL.md +165 -0
- package/habilidades/changelog-generator/SKILL.md +9 -2
- package/habilidades/changelog-generator/scripts/parse-commits.js +13 -1
- package/habilidades/diagrama-arquitectura/SKILL.md +1 -1
- package/habilidades/drift-detection/SKILL.md +179 -179
- package/habilidades/ejecutar-fase/SKILL.md +541 -468
- package/habilidades/estructura-proyecto-claude/SKILL.md +17 -14
- package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +34 -23
- package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +70 -53
- package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +57 -77
- package/habilidades/extractor-de-aprendizajes/SKILL.md +9 -5
- package/habilidades/harness-claude-code/SKILL.md +10 -7
- package/{reglas/harness-claude-code.md → habilidades/harness-claude-code/recursos/disciplina-harness-regla.md} +2 -2
- package/habilidades/instalar-sistema/SKILL.md +3 -3
- package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +1 -1
- package/habilidades/perfil-usuario/SKILL.md +200 -200
- package/habilidades/planear-fase/SKILL.md +26 -4
- package/habilidades/proceso-ddia-fundamentos/SKILL.md +1 -1
- package/habilidades/proceso-ddia-streaming/SKILL.md +4 -4
- package/habilidades/proceso-debate-adversarial/SKILL.md +2 -2
- package/habilidades/protocolo-revision-swl/SKILL.md +1 -1
- package/habilidades/seguridad-skills-ia/SKILL.md +1 -1
- package/habilidades/swl-claudemd/SKILL.md +50 -210
- package/habilidades/swl-claudemd/recursos/contrato-aprender.md +83 -0
- package/habilidades/swl-claudemd/recursos/duplicacion-reglas-globales.md +85 -0
- package/habilidades/swl-claudemd/recursos/plantillas-init.md +94 -0
- package/habilidades/swl-dashboard/SKILL.md +9 -9
- package/habilidades/swl-revisar-impacto/SKILL.md +1 -1
- package/habilidades/tdd-workflow/SKILL.md +715 -673
- package/habilidades/validacion-ci-sistema/SKILL.md +20 -4
- package/hooks/calidad-pre-commit.js +344 -3
- package/hooks/check-update.js +39 -1
- package/hooks/ciclo-evolucion-subagente.js +26 -0
- package/hooks/ciclo-evolucion.js +26 -0
- package/hooks/extraccion-aprendizajes.js +13 -0
- package/hooks/lib/autonomia.js +208 -0
- package/hooks/lib/briefing.js +474 -0
- package/hooks/lib/ciclo-evolucion.js +47 -0
- package/hooks/{auto-evolucion.js → lib/etapa-auto-evolucion.js} +701 -700
- package/hooks/{metricas-evolucion.js → lib/etapa-metricas.js} +388 -376
- package/hooks/{actualizar-perfil-usuario.js → lib/etapa-perfil-usuario.js} +376 -364
- package/hooks/lib/evolution-tracker.js +24 -3
- package/hooks/lib/propose-step.js +357 -0
- package/hooks/session-briefing.js +98 -0
- package/hooks/spec-gate.js +211 -0
- package/hooks/tdd-gate.js +241 -0
- package/hooks/telemetria-skill-routing.js +100 -0
- package/hooks/validar-intent-spec.js +30 -10
- package/instintos/autonomia.yaml +27 -0
- package/llms.txt +6 -6
- package/manifiestos/hooks-config.json +44 -17
- package/manifiestos/modulos.json +40 -15
- package/manifiestos/skills-lock.json +64 -57
- package/package.json +93 -93
- package/plugin.json +371 -375
- package/reglas/accesibilidad.md +10 -0
- package/reglas/analizar-directorios-antes-de-escribir.md +228 -0
- package/reglas/api-diseno.md +9 -0
- package/reglas/auditorias-documentales-estructurales.md +7 -0
- package/reglas/cloud-infra.md +8 -0
- package/reglas/consultar-vault-primero.md +195 -0
- package/reglas/debatir-antes-de-aceptar.md +158 -0
- package/reglas/fragmentos-compartidos.md +5 -0
- package/reglas/git-coauthor.md +100 -0
- package/reglas/gobernanza.md +4 -4
- package/reglas/hooks.md +6 -0
- package/reglas/intent-engineering.md +4 -0
- package/reglas/markitdown.md +8 -0
- package/reglas/memoria-consolidada.md +1 -1
- package/reglas/monitor-ci.md +309 -0
- package/reglas/patrones.md +6 -0
- package/reglas/registro-componentes-nuevos.md +39 -2
- package/reglas/seguridad-agentes.md +1 -1
- package/reglas/sesiones-paralelas.md +180 -0
- package/reglas/skills-estandar.md +6 -0
- package/reglas/testing.md +7 -0
- package/reglas/tests-cleanup.md +4 -0
- package/reglas/usar-code-review-graph.md +155 -0
- package/reglas/usar-sistema-swl.md +1 -1
- package/reglas/verificar-citas-normativas.md +548 -0
- package/scripts/instalador.js +52 -6
- package/scripts/lib/ci-reader.js +193 -0
- package/scripts/lib/detectar-host-swl.js +175 -0
- package/scripts/lib/evidencia-release.js +322 -0
- package/scripts/lib/gate-hooks-requires.js +249 -0
- package/scripts/lib/gate-licencias.js +212 -0
- package/scripts/lib/git-metricas.js +257 -0
- package/scripts/lib/gitignore-manifest.js +29 -1
- package/scripts/lib/metricas-dora.js +204 -0
- package/scripts/lib/plan-lock.js +275 -0
- package/scripts/migrar-fase-dominio.js +0 -1
- package/scripts/tui/ejecutores.js +1 -1
- package/scripts/validar-manifest.js +92 -1
- package/scripts/verificar-evolucion.js +54 -4
- package/scripts/verificar-release.js +102 -0
- package/scripts/verificar-trazabilidad.js +298 -0
- package/agentes/ux-disenador-swl.md +0 -503
- package/comandos/swl/dashboard.md +0 -146
- package/comandos/swl/evolucion-estado.md +0 -191
- package/comandos/swl/metricas.md +0 -376
- package/comandos/swl/salud.md +0 -481
- package/reglas/arquitectura.evolved.json +0 -7
- package/reglas/seguridad.evolved.json +0 -7
- package/reglas/verificar-citas-temporales.md +0 -139
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
# Regla: Coordinación obligatoria al detectar sesión paralela
|
|
2
|
+
|
|
3
|
+
Esta regla es OBLIGATORIA y aplica cuando Claude detecta — o el usuario
|
|
4
|
+
informa — que **otra sesión de IA** (Claude Code, Codex CLI, Cursor, otro
|
|
5
|
+
agente) está trabajando **simultáneamente** sobre el mismo repositorio /
|
|
6
|
+
proyecto.
|
|
7
|
+
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
## Principio
|
|
11
|
+
|
|
12
|
+
> Cuando detectes que otra sesión está activa sobre el mismo repo y los
|
|
13
|
+
> cambios pueden colisionar en archivos compartidos, **DETÉN tu flujo
|
|
14
|
+
> actual y presenta 4 opciones explícitas de coordinación al usuario antes
|
|
15
|
+
> de proceder con cualquier escritura**. NUNCA decidas unilateralmente
|
|
16
|
+
> continuar.
|
|
17
|
+
|
|
18
|
+
El patrón opuesto (continuar y resolver conflictos al final) es costoso:
|
|
19
|
+
resolución manual de merge conflicts en archivos canónicos del sistema
|
|
20
|
+
(`package.json`, `plugin.json`, `CHANGELOG.md`, manifiestos) toma 30+
|
|
21
|
+
minutos vs 2 minutos de coordinación previa.
|
|
22
|
+
|
|
23
|
+
---
|
|
24
|
+
|
|
25
|
+
## Cómo detectar sesión paralela
|
|
26
|
+
|
|
27
|
+
Señales que disparan la regla:
|
|
28
|
+
|
|
29
|
+
- El usuario lo informa explícitamente: *"hay otra sesión trabajando en
|
|
30
|
+
esto agregando X"*.
|
|
31
|
+
- `git status` muestra archivos modificados que tú no modificaste en esta
|
|
32
|
+
sesión.
|
|
33
|
+
- Commits aparecen en `git log --oneline` con timestamps muy recientes
|
|
34
|
+
cuyo autor o mensaje no coinciden con tu trabajo.
|
|
35
|
+
- ADRs o PLAN.md aparecen en `.planning/` con números cercanos pero
|
|
36
|
+
contenido que no escribiste (`0019-X-completa.md` cuando tu trabajo era
|
|
37
|
+
ADR-0020).
|
|
38
|
+
- Archivos `.swl-install-state.json` o lockfiles con mtime posterior al
|
|
39
|
+
inicio de tu sesión.
|
|
40
|
+
|
|
41
|
+
Tras detectar cualquier señal: **pausar inmediatamente** antes de la
|
|
42
|
+
siguiente escritura.
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## Las 4 opciones obligatorias
|
|
47
|
+
|
|
48
|
+
Presentar al usuario **literalmente** estas 4 opciones (sin inventar
|
|
49
|
+
variantes hasta que el usuario las pida):
|
|
50
|
+
|
|
51
|
+
| Opción | Estrategia | Cuándo conviene |
|
|
52
|
+
|--------|-----------|-----------------|
|
|
53
|
+
| **A — Ceder prioridad** | Pausar tu trabajo. Revertir cambios no commiteados. Esperar a que la otra sesión termine. Retomar después con `git pull` y rebase. | La otra sesión está cerca de terminar y tu trabajo es ortogonal o no urgente. |
|
|
54
|
+
| **B — Avance no-conflictivo** | Continuar trabajando, pero SOLO en archivos que la otra sesión NO toca. Identificar y enumerar el subconjunto seguro. Diferir cambios en archivos compartidos hasta que la otra sesión cierre. | Tu trabajo cabe en archivos disjuntos (skills nuevos, scripts nuevos, tests). |
|
|
55
|
+
| **C — Release combinada** | Coordinar con la otra sesión un cierre conjunto: mismo release, mismo PR, ambos trabajos integrados. Implica sincronización explícita en docs canónicas, CHANGELOG, versión. | Ambas líneas de trabajo apuntan al mismo bump de versión y los cambios son complementarios. |
|
|
56
|
+
| **D — Continuar conflictivo** | Continuar todo tu plan. Resolver merge conflicts al final manualmente. **NO RECOMENDADO** salvo bloqueador urgente. | Solo si la coordinación es imposible (otra sesión inalcanzable) y el trabajo es bloqueante. |
|
|
57
|
+
|
|
58
|
+
Tras presentar las opciones, **esperar la decisión del usuario** antes de
|
|
59
|
+
escribir cualquier archivo. La excepción son lecturas (`Read`, `Grep`,
|
|
60
|
+
`Glob`) que no modifican estado.
|
|
61
|
+
|
|
62
|
+
---
|
|
63
|
+
|
|
64
|
+
## Cómo presentar el reporte al usuario
|
|
65
|
+
|
|
66
|
+
Formato mínimo del mensaje de detección:
|
|
67
|
+
|
|
68
|
+
```markdown
|
|
69
|
+
Pauso inmediatamente. Hay riesgo de conflicto crítico entre las dos sesiones.
|
|
70
|
+
|
|
71
|
+
## Estado actual de las dos sesiones
|
|
72
|
+
|
|
73
|
+
### Sesión actual (esta) — <descripción breve>
|
|
74
|
+
**Cambios en disco**: <lista de archivos modificados por mí>
|
|
75
|
+
**Pendiente**: <sub-fases restantes>
|
|
76
|
+
|
|
77
|
+
### Sesión paralela — <descripción de qué hace>
|
|
78
|
+
**Cambios detectados**: <archivos modificados por la otra sesión>
|
|
79
|
+
|
|
80
|
+
## Archivos en colisión potencial al avanzar
|
|
81
|
+
|
|
82
|
+
| Archivo | Mi necesidad | Otra sesión | Riesgo |
|
|
83
|
+
|---------|-------------|-------------|--------|
|
|
84
|
+
| package.json (versión) | bump vX → vY | bump probablemente también | ALTO |
|
|
85
|
+
| plugin.json | +N skills | posiblemente +runtimes | Medio |
|
|
86
|
+
| CHANGELOG.md | sección nueva | sección nueva | ALTO — conflict garantizado |
|
|
87
|
+
| docs canónicas | docs feature X | docs feature Y | Medio |
|
|
88
|
+
|
|
89
|
+
## Opciones
|
|
90
|
+
|
|
91
|
+
[A/B/C/D con descripciones]
|
|
92
|
+
|
|
93
|
+
## Recomendación
|
|
94
|
+
|
|
95
|
+
[Opción recomendada con justificación en 1 párrafo]
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
---
|
|
99
|
+
|
|
100
|
+
## Reglas duras
|
|
101
|
+
|
|
102
|
+
- **NUNCA decidir unilateralmente** continuar tras detectar sesión paralela.
|
|
103
|
+
- **NUNCA hacer commits** en archivos compartidos hasta que el usuario
|
|
104
|
+
confirme la estrategia de coordinación.
|
|
105
|
+
- **NUNCA pushear** cambios sin saber el estado de la otra sesión.
|
|
106
|
+
- Tras decidir Opción B (avance no-conflictivo): **mantener una lista
|
|
107
|
+
explícita** de archivos seguros vs archivos diferidos. Verificar antes
|
|
108
|
+
de cada `Write`/`Edit` que el archivo no está en la zona diferida.
|
|
109
|
+
- Si durante el trabajo aparece un nuevo conflicto no anticipado, **pausar
|
|
110
|
+
de nuevo y reportar** — no resolver en silencio.
|
|
111
|
+
- Tras decidir Opción C (release combinada): coordinar **versión y
|
|
112
|
+
ubicaciones canónicas** explícitamente (¿quién bumpea? ¿en qué orden se
|
|
113
|
+
mergean los PRs? ¿quién regenera INVENTARIO.md al final?).
|
|
114
|
+
- **NUNCA revertir cambios pendientes en working tree de una sesión paralela
|
|
115
|
+
por interpretación errónea de una instrucción del usuario**. Si el usuario
|
|
116
|
+
dice "no cambies de versión", "no toques X", "deja Y como está" durante un
|
|
117
|
+
flujo del agente actual, esa instrucción **aplica al trabajo nuevo del
|
|
118
|
+
agente actual**, no al trabajo previo ya pendiente en working tree de
|
|
119
|
+
otra sesión. **Antes de revertir cualquier archivo modificado que no
|
|
120
|
+
modificó la sesión actual**, ejecutar:
|
|
121
|
+
```bash
|
|
122
|
+
git diff HEAD -- <archivo> # ver el cambio pendiente
|
|
123
|
+
git log --oneline -3 -- <archivo> # ver historia del archivo
|
|
124
|
+
grep -l "<bump-keyword>" .planning/APRENDIZAJES.md # buscar trazabilidad
|
|
125
|
+
```
|
|
126
|
+
Si el cambio pendiente está documentado como trabajo de sesión previa
|
|
127
|
+
(entry en APRENDIZAJES.md, mensaje del usuario citándolo, evidencia en
|
|
128
|
+
`.planning/sessions/diary/`), **NO revertirlo**. Reportar al usuario:
|
|
129
|
+
*"Detecté cambio pendiente en X de sesión paralela (evidencia: Y). Mi
|
|
130
|
+
instrucción de no-cambiar-versión aplica solo a mi trabajo nuevo — ¿confirmas
|
|
131
|
+
que preserve los bumps previos?"*. La instrucción del usuario sobre
|
|
132
|
+
versiones se interpreta **a partir del momento en que se emite**, no
|
|
133
|
+
retroactivamente sobre el working tree.
|
|
134
|
+
|
|
135
|
+
---
|
|
136
|
+
|
|
137
|
+
## Excepciones legítimas
|
|
138
|
+
|
|
139
|
+
NO aplicar la regla cuando:
|
|
140
|
+
|
|
141
|
+
1. **La otra sesión es de lectura pura** (consulta, exploración) y no
|
|
142
|
+
modifica archivos del repo.
|
|
143
|
+
2. **Las sesiones trabajan en branches distintas** y el merge a main será
|
|
144
|
+
por PR independiente (no hay riesgo de colisión hasta el merge final).
|
|
145
|
+
3. **El usuario explícitamente autorizó** continuar sin coordinación.
|
|
146
|
+
|
|
147
|
+
---
|
|
148
|
+
|
|
149
|
+
## Origen de esta regla
|
|
150
|
+
|
|
151
|
+
Sesión 2026-05-15 en swl-ses. Mientras una sesión analizaba `temp/cc-sdd-main`
|
|
152
|
+
para absorber patrones SDD (Opción B aprobada por el usuario), otra sesión
|
|
153
|
+
paralela trabajaba en agregar Codex y Cursor como targets de primera clase
|
|
154
|
+
(ADR-0019). Ambas sesiones modificaban `scripts/instalador.js`,
|
|
155
|
+
`manifiestos/modulos.json`, docs canónicas y planeaban bumpear a v1.5.0.
|
|
156
|
+
|
|
157
|
+
El usuario informó la situación con: *"hay otra sesion trabajando en el mismo
|
|
158
|
+
proyecto: 'Extension CLI' que esta agregando a swl-ses a codex y cursor como
|
|
159
|
+
targets"*. La sesión actual pausó, reportó 4 opciones, esperó decisión. El
|
|
160
|
+
usuario eligió Opción B (avance no-conflictivo en skills nuevos y scripts
|
|
161
|
+
disjuntos; deferir docs y release a "modo D" cuando la otra sesión
|
|
162
|
+
terminara). Resultado: **cero conflictos al cerrar v1.5.0** vía PR #25
|
|
163
|
+
unificado.
|
|
164
|
+
|
|
165
|
+
Sin esta regla, el patrón habitual hubiera sido continuar y resolver
|
|
166
|
+
conflictos en cada `git pull` — costo estimado ~30 min de merge resolution
|
|
167
|
+
en `CHANGELOG.md`, `plugin.json`, `package.json`, `manifiestos/modulos.json`
|
|
168
|
+
y `INVENTARIO.md`.
|
|
169
|
+
|
|
170
|
+
---
|
|
171
|
+
|
|
172
|
+
## Checklist al detectar sesión paralela
|
|
173
|
+
|
|
174
|
+
- [ ] Pausé mi escritura actual antes de la siguiente `Write`/`Edit`
|
|
175
|
+
- [ ] Ejecuté `git status` y `git log --since="1 hour ago"` para mapear cambios
|
|
176
|
+
- [ ] Identifiqué los archivos potencialmente compartidos
|
|
177
|
+
- [ ] Presenté al usuario un reporte con las 4 opciones (A/B/C/D) y mi recomendación
|
|
178
|
+
- [ ] Esperé decisión explícita antes de la siguiente escritura
|
|
179
|
+
- [ ] Si elegimos B: mantengo lista de archivos diferidos visible
|
|
180
|
+
- [ ] Si elegimos C: confirmé versión objetivo y orden de PRs
|
package/reglas/testing.md
CHANGED
package/reglas/tests-cleanup.md
CHANGED
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
# Regla: Usar code-review-graph antes de Read/Grep/Glob para explorar
|
|
2
|
+
|
|
3
|
+
Esta regla es OBLIGATORIA y aplica a todo proyecto del usuario donde el MCP
|
|
4
|
+
server `code-review-graph` esté disponible (sus herramientas
|
|
5
|
+
`mcp__code-review-graph__*` aparecen registradas o deferred en la sesión, o el
|
|
6
|
+
proyecto declara el grafo en su `CLAUDE.md`).
|
|
7
|
+
|
|
8
|
+
El grafo de conocimiento es un índice estructural del codebase construido con
|
|
9
|
+
Tree-sitter: nodos (archivos, clases, funciones, tipos, tests) y aristas
|
|
10
|
+
(llamadas, imports, dependencias, cobertura). Consultarlo es **más barato en
|
|
11
|
+
tokens**, **más rápido** y aporta **contexto estructural** (callers, dependents,
|
|
12
|
+
blast radius, tests) que un `Grep`/`Read` plano no puede dar.
|
|
13
|
+
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
## Principio
|
|
17
|
+
|
|
18
|
+
> Cuando necesites **explorar, entender, revisar o medir impacto** de código y
|
|
19
|
+
> el grafo `code-review-graph` esté disponible, **consúltalo PRIMERO** con las
|
|
20
|
+
> herramientas `mcp__code-review-graph__*`. Cae a `Read`/`Grep`/`Glob` solo
|
|
21
|
+
> cuando el grafo no cubre lo que necesitas (ver excepciones), no por inercia.
|
|
22
|
+
|
|
23
|
+
El costo de una consulta al grafo es de segundos y pocos tokens. El costo de
|
|
24
|
+
leer 5-10 archivos completos para reconstruir relaciones que el grafo ya conoce
|
|
25
|
+
es contexto desperdiciado y dinero.
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
## Cuándo usar el grafo PRIMERO (obligatorio)
|
|
30
|
+
|
|
31
|
+
| Necesidad | Herramienta del grafo | En vez de |
|
|
32
|
+
|---|---|---|
|
|
33
|
+
| Encontrar una función/clase/tipo por nombre o keyword | `semantic_search_nodes_tool` | `Grep` amplio |
|
|
34
|
+
| Entender la arquitectura de alto nivel | `get_architecture_overview_tool`, `list_communities_tool` | leer N archivos para inferir estructura |
|
|
35
|
+
| Trazar callers / callees / imports / tests | `query_graph_tool` (patrones callers_of, callees_of, imports_of, tests_for, dependencies) | `Grep` recursivo + lectura manual |
|
|
36
|
+
| Medir blast radius de un cambio | `get_impact_radius_tool` | rastrear imports a mano |
|
|
37
|
+
| Saber qué flujos de ejecución afecta un cambio | `get_affected_flows_tool` | inferir leyendo |
|
|
38
|
+
| Revisar cambios (code review) con riesgo puntuado | `detect_changes_tool` | `git diff` + leer archivos completos |
|
|
39
|
+
| Obtener snippets justos para revisar | `get_review_context_tool`, `get_minimal_context_tool` | `Read` de archivos enteros |
|
|
40
|
+
| Planear renames / detectar código muerto | `refactor_tool` | `Grep` + verificación manual |
|
|
41
|
+
| Funciones grandes / hubs / puentes arquitectónicos | `find_large_functions_tool`, `get_hub_nodes_tool`, `get_bridge_nodes_tool` | heurística manual |
|
|
42
|
+
| Verificar cobertura de tests de un símbolo | `query_graph_tool` pattern `tests_for` | `Grep` de nombres de test |
|
|
43
|
+
|
|
44
|
+
Antes de una sesión de exploración/revisión, vale `list_graph_stats_tool` para
|
|
45
|
+
confirmar que el grafo está construido y fresco (`Last updated`).
|
|
46
|
+
|
|
47
|
+
---
|
|
48
|
+
|
|
49
|
+
## Workflow estándar
|
|
50
|
+
|
|
51
|
+
1. **Localizar**: `semantic_search_nodes_tool` con el nombre/keyword del símbolo
|
|
52
|
+
o `get_architecture_overview_tool` para el mapa general.
|
|
53
|
+
2. **Relacionar**: `query_graph_tool` (callers/callees/imports/tests) o
|
|
54
|
+
`get_impact_radius_tool` para el blast radius.
|
|
55
|
+
3. **Leer dirigido**: `get_review_context_tool`/`get_minimal_context_tool` para
|
|
56
|
+
traer solo los snippets relevantes — no el archivo completo.
|
|
57
|
+
4. **Caer al filesystem solo entonces**: si el grafo no cubre el detalle
|
|
58
|
+
concreto (líneas exactas no indexadas, archivos no parseados, formatos no
|
|
59
|
+
soportados), ahí sí `Read`/`Grep` con foco específico.
|
|
60
|
+
|
|
61
|
+
El grafo se auto-actualiza vía hooks al cambiar archivos. Si `list_graph_stats`
|
|
62
|
+
muestra un `Last updated` viejo respecto a cambios recientes, reconstruir con
|
|
63
|
+
`build_or_update_graph_tool` antes de confiar en sus resultados.
|
|
64
|
+
|
|
65
|
+
---
|
|
66
|
+
|
|
67
|
+
## Cuándo SÍ usar Read/Grep/Glob directo (excepciones)
|
|
68
|
+
|
|
69
|
+
NO forzar el grafo cuando:
|
|
70
|
+
|
|
71
|
+
1. **El grafo no está disponible** — el proyecto no tiene `code-review-graph`
|
|
72
|
+
instalado, o `list_graph_stats_tool` falla. Usar Read/Grep sin más.
|
|
73
|
+
2. **Lenguaje/formato no indexado** — el grafo parsea código fuente (Python, JS,
|
|
74
|
+
TS, Go, Rust, Java, C#, bash). Para `.md`, `.json`, `.sql`, `.yaml`, `.env`,
|
|
75
|
+
migraciones, seeds, configs → Read/Grep directo (el grafo no los modela).
|
|
76
|
+
3. **Necesitas líneas exactas o contenido literal** — verificar una cita
|
|
77
|
+
`archivo:línea`, leer el cuerpo completo de un archivo que vas a editar,
|
|
78
|
+
confirmar texto exacto. El grafo da estructura, no sustituye `Read` del
|
|
79
|
+
archivo que vas a modificar.
|
|
80
|
+
4. **El usuario pidió explícitamente** leer un archivo concreto o hacer un grep
|
|
81
|
+
puntual.
|
|
82
|
+
5. **Operación de un solo archivo ya conocido** — sabes exactamente qué archivo
|
|
83
|
+
y qué línea; un `Read` dirigido es más simple que el grafo.
|
|
84
|
+
6. **El grafo está desactualizado** para el cambio recién hecho y no quieres
|
|
85
|
+
reconstruirlo en ese instante — usa Grep para lo recién escrito.
|
|
86
|
+
|
|
87
|
+
Antes de editar un archivo, SIEMPRE `Read` del archivo (la regla de Edit lo
|
|
88
|
+
exige y la verificación de citas `archivo:línea` también). El grafo localiza
|
|
89
|
+
**qué** leer; no reemplaza la lectura del archivo que vas a tocar.
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
93
|
+
## Anti-patrones
|
|
94
|
+
|
|
95
|
+
- **`Grep` amplio del codebase** para encontrar una función cuando
|
|
96
|
+
`semantic_search_nodes_tool` la ubica en una llamada.
|
|
97
|
+
- **Leer 5+ archivos completos** para entender la arquitectura sin haber
|
|
98
|
+
consultado `get_architecture_overview_tool` primero.
|
|
99
|
+
- **Rastrear imports a mano con `Grep`** para estimar el impacto de un cambio en
|
|
100
|
+
vez de `get_impact_radius_tool` / `get_affected_flows_tool`.
|
|
101
|
+
- **`git diff` + leer archivos enteros** para revisar cuando `detect_changes_tool`
|
|
102
|
+
da el diff con riesgo puntuado y `get_review_context_tool` los snippets justos.
|
|
103
|
+
- **Defaultear a Read/Grep "porque es lo de siempre"** cuando las herramientas
|
|
104
|
+
`mcp__code-review-graph__*` aparecen deferred (schemas not loaded) — deferred
|
|
105
|
+
≠ ausente: cargar el schema con `ToolSearch(query="select:<tool>")` y usarlo.
|
|
106
|
+
Confundir "no cargado" con "no disponible" es el mismo error documentado para
|
|
107
|
+
el MCP `obsidian` en `consultar-vault-primero.md`.
|
|
108
|
+
- **Confiar en el grafo sin verificar frescura** tras cambios recientes — si
|
|
109
|
+
`Last updated` es anterior al cambio, reconstruir o caer a Grep para esa parte.
|
|
110
|
+
|
|
111
|
+
---
|
|
112
|
+
|
|
113
|
+
## Relación con otras reglas
|
|
114
|
+
|
|
115
|
+
- `~/.claude/rules/consultar-vault-primero.md` — patrón hermano: consultar la
|
|
116
|
+
fuente curada (vault Obsidian para decisiones; grafo para estructura de
|
|
117
|
+
código) antes de leer múltiples archivos. Mismo principio de economía de
|
|
118
|
+
tokens y mismo anti-patrón de "deferred ≠ ausente".
|
|
119
|
+
- `~/.claude/rules/verificar-citas-normativas.md § Familia 2` — el grafo
|
|
120
|
+
**localiza** la cita `archivo:línea`; verificarla aún exige `Read` del archivo
|
|
121
|
+
real. El grafo no exime de la verificación de citas.
|
|
122
|
+
- `~/.claude/rules/harness-claude-code.md § Disciplina de input format` — repos
|
|
123
|
+
grandes (>500 archivos) son donde el grafo da el mayor ahorro de tokens
|
|
124
|
+
(6.8-49× por review según la nota de ese harness).
|
|
125
|
+
- `~/.claude/rules/analizar-directorios-antes-de-escribir.md` — para decidir
|
|
126
|
+
DÓNDE escribir docs sigue siendo `ls`/`Glob`; el grafo es para explorar
|
|
127
|
+
**código**, no estructura de directorios de documentación.
|
|
128
|
+
|
|
129
|
+
---
|
|
130
|
+
|
|
131
|
+
## Aplicabilidad
|
|
132
|
+
|
|
133
|
+
Aplica a:
|
|
134
|
+
- Claude Code (CLI, Desktop, IDE) en proyectos con `code-review-graph` activo.
|
|
135
|
+
- Sesiones de exploración, debugging, code review, refactor, análisis de impacto.
|
|
136
|
+
|
|
137
|
+
NO aplica a:
|
|
138
|
+
- Proyectos sin el grafo instalado.
|
|
139
|
+
- Exploración de documentación/configuración no indexada por el grafo.
|
|
140
|
+
- Sub-agentes que operan sobre un único archivo pasado como argumento.
|
|
141
|
+
|
|
142
|
+
---
|
|
143
|
+
|
|
144
|
+
## Origen
|
|
145
|
+
|
|
146
|
+
Formalizada el 2026-06-09 a petición explícita del usuario tras observar que en
|
|
147
|
+
una sesión larga (feature B-1 de SIGM) se usó `Grep`/`Read`/`Bash` directo de
|
|
148
|
+
forma intensiva para explorar el codebase mientras el MCP `code-review-graph`
|
|
149
|
+
estaba disponible y auto-actualizado (9336 nodos, 78247 aristas). El proyecto
|
|
150
|
+
SIGM ya documentaba la preferencia en su `CLAUDE.md` ("ALWAYS use the
|
|
151
|
+
code-review-graph MCP tools BEFORE using Grep/Glob/Read"), pero el usuario pidió
|
|
152
|
+
promoverla a regla global para que aplique a todo proyecto con el grafo, no solo
|
|
153
|
+
a SIGM. La regla global es ahora la fuente de verdad del comportamiento; el
|
|
154
|
+
`CLAUDE.md` de cada proyecto solo debe declarar que el grafo está disponible
|
|
155
|
+
(no re-derivar el comportamiento — ver `sin-duplicacion-reglas-globales.md`).
|
|
@@ -78,7 +78,7 @@ de ejecutar.
|
|
|
78
78
|
| Capturar aprendizaje recurrente | `/swl:aprender` → APRENDIZAJES.md → posible promoción a regla/skill |
|
|
79
79
|
| Release con bump de versión | `/swl:release` (sincronización de ubicaciones de versión) |
|
|
80
80
|
| Documentación viva post-feature | `documentador-swl` |
|
|
81
|
-
| Diagnóstico del sistema | `/swl:salud` |
|
|
81
|
+
| Diagnóstico del sistema | `/swl:status salud` |
|
|
82
82
|
|
|
83
83
|
### Para tareas de búsqueda y contexto
|
|
84
84
|
|