@saulwade/swl-ses 2.0.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/implementador-swl.md +2 -0
- package/agentes/orquestador-swl.md +2 -0
- package/agentes/perfilador-usuario-swl.md +14 -1
- package/bin/swl-ses.js +1 -1
- package/comandos/swl/aprobar-plan.md +3 -2
- package/comandos/swl/briefing.md +122 -0
- package/comandos/swl/compactar.md +29 -2
- package/comandos/swl/discutir-fase.md +8 -5
- package/comandos/swl/ejecutar-fase.md +6 -0
- package/comandos/swl/planear-fase.md +5 -3
- package/comandos/swl/release.md +46 -0
- package/comandos/swl/status.md +69 -0
- package/comandos/swl/verificar.md +3 -2
- package/habilidades/changelog-generator/scripts/parse-commits.js +6 -4
- package/habilidades/ejecutar-fase/SKILL.md +541 -518
- package/habilidades/planear-fase/SKILL.md +3 -2
- package/habilidades/tdd-workflow/SKILL.md +715 -713
- package/habilidades/validacion-ci-sistema/SKILL.md +17 -1
- package/hooks/calidad-pre-commit.js +5 -1
- package/hooks/check-update.js +39 -1
- package/hooks/lib/autonomia.js +208 -0
- package/hooks/lib/briefing.js +474 -0
- package/hooks/lib/propose-step.js +357 -0
- package/hooks/session-briefing.js +98 -0
- package/hooks/telemetria-skill-routing.js +100 -0
- package/instintos/autonomia.yaml +27 -0
- package/llms.txt +4 -4
- package/manifiestos/hooks-config.json +18 -0
- package/manifiestos/modulos.json +25 -3
- package/manifiestos/skills-lock.json +14 -14
- package/package.json +93 -93
- package/plugin.json +371 -371
- package/reglas/analizar-directorios-antes-de-escribir.md +228 -0
- package/reglas/consultar-vault-primero.md +195 -0
- package/reglas/debatir-antes-de-aceptar.md +158 -0
- package/reglas/git-coauthor.md +100 -0
- package/reglas/monitor-ci.md +309 -0
- package/reglas/registro-componentes-nuevos.md +38 -10
- package/reglas/sesiones-paralelas.md +180 -0
- package/reglas/usar-code-review-graph.md +155 -0
- 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/metricas-dora.js +204 -0
- 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 +11 -5
- package/reglas/arquitectura.evolved.json +0 -7
- package/reglas/seguridad.evolved.json +0 -7
|
@@ -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`).
|