@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.
Files changed (142) hide show
  1. package/CLAUDE.md +196 -196
  2. package/README.md +579 -579
  3. package/agentes/_propose-step.md +90 -0
  4. package/agentes/accesibilidad-wcag-swl.md +3 -3
  5. package/agentes/auto-evolucion-swl.md +908 -908
  6. package/agentes/disenador-ui-swl.md +6 -5
  7. package/agentes/frontend-angular-swl.md +2 -2
  8. package/agentes/frontend-css-swl.md +2 -2
  9. package/agentes/frontend-react-swl.md +4 -4
  10. package/agentes/frontend-swl.md +6 -6
  11. package/agentes/implementador-swl.md +2 -0
  12. package/agentes/investigador-ux-swl.md +5 -5
  13. package/agentes/orquestador-swl.md +9 -7
  14. package/agentes/perfilador-usuario-swl.md +321 -308
  15. package/agentes/producto-prd-swl.md +1 -1
  16. package/agentes/red-team-swl.md +218 -218
  17. package/agentes/tdd-qa-swl.md +17 -1
  18. package/bin/swl-ses.js +1 -1
  19. package/comandos/swl/actualizar.md +1 -1
  20. package/comandos/swl/aprender.md +2 -2
  21. package/comandos/swl/aprobar-plan.md +153 -0
  22. package/comandos/swl/ayuda.md +3 -3
  23. package/comandos/swl/briefing.md +122 -0
  24. package/comandos/swl/compactar.md +29 -2
  25. package/comandos/swl/discutir-fase.md +23 -2
  26. package/comandos/swl/ejecutar-fase.md +59 -6
  27. package/comandos/swl/evolucionar.md +1 -1
  28. package/comandos/swl/inbox.md +1 -1
  29. package/comandos/swl/instalar.md +1 -1
  30. package/comandos/swl/nemesis.md +1 -1
  31. package/comandos/swl/planear-fase.md +19 -1
  32. package/comandos/swl/plugins.md +1 -1
  33. package/comandos/swl/release.md +47 -1
  34. package/comandos/swl/status.md +348 -0
  35. package/comandos/swl/verificar.md +27 -1
  36. package/habilidades/ai-runtime-security/SKILL.md +1 -1
  37. package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -276
  38. package/habilidades/benchmark-memoria/SKILL.md +1 -1
  39. package/habilidades/calidad-contract-testing/SKILL.md +165 -0
  40. package/habilidades/changelog-generator/SKILL.md +9 -2
  41. package/habilidades/changelog-generator/scripts/parse-commits.js +13 -1
  42. package/habilidades/diagrama-arquitectura/SKILL.md +1 -1
  43. package/habilidades/drift-detection/SKILL.md +179 -179
  44. package/habilidades/ejecutar-fase/SKILL.md +541 -468
  45. package/habilidades/estructura-proyecto-claude/SKILL.md +17 -14
  46. package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +34 -23
  47. package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +70 -53
  48. package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +57 -77
  49. package/habilidades/extractor-de-aprendizajes/SKILL.md +9 -5
  50. package/habilidades/harness-claude-code/SKILL.md +10 -7
  51. package/{reglas/harness-claude-code.md → habilidades/harness-claude-code/recursos/disciplina-harness-regla.md} +2 -2
  52. package/habilidades/instalar-sistema/SKILL.md +3 -3
  53. package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +1 -1
  54. package/habilidades/perfil-usuario/SKILL.md +200 -200
  55. package/habilidades/planear-fase/SKILL.md +26 -4
  56. package/habilidades/proceso-ddia-fundamentos/SKILL.md +1 -1
  57. package/habilidades/proceso-ddia-streaming/SKILL.md +4 -4
  58. package/habilidades/proceso-debate-adversarial/SKILL.md +2 -2
  59. package/habilidades/protocolo-revision-swl/SKILL.md +1 -1
  60. package/habilidades/seguridad-skills-ia/SKILL.md +1 -1
  61. package/habilidades/swl-claudemd/SKILL.md +50 -210
  62. package/habilidades/swl-claudemd/recursos/contrato-aprender.md +83 -0
  63. package/habilidades/swl-claudemd/recursos/duplicacion-reglas-globales.md +85 -0
  64. package/habilidades/swl-claudemd/recursos/plantillas-init.md +94 -0
  65. package/habilidades/swl-dashboard/SKILL.md +9 -9
  66. package/habilidades/swl-revisar-impacto/SKILL.md +1 -1
  67. package/habilidades/tdd-workflow/SKILL.md +715 -673
  68. package/habilidades/validacion-ci-sistema/SKILL.md +20 -4
  69. package/hooks/calidad-pre-commit.js +344 -3
  70. package/hooks/check-update.js +39 -1
  71. package/hooks/ciclo-evolucion-subagente.js +26 -0
  72. package/hooks/ciclo-evolucion.js +26 -0
  73. package/hooks/extraccion-aprendizajes.js +13 -0
  74. package/hooks/lib/autonomia.js +208 -0
  75. package/hooks/lib/briefing.js +474 -0
  76. package/hooks/lib/ciclo-evolucion.js +47 -0
  77. package/hooks/{auto-evolucion.js → lib/etapa-auto-evolucion.js} +701 -700
  78. package/hooks/{metricas-evolucion.js → lib/etapa-metricas.js} +388 -376
  79. package/hooks/{actualizar-perfil-usuario.js → lib/etapa-perfil-usuario.js} +376 -364
  80. package/hooks/lib/evolution-tracker.js +24 -3
  81. package/hooks/lib/propose-step.js +357 -0
  82. package/hooks/session-briefing.js +98 -0
  83. package/hooks/spec-gate.js +211 -0
  84. package/hooks/tdd-gate.js +241 -0
  85. package/hooks/telemetria-skill-routing.js +100 -0
  86. package/hooks/validar-intent-spec.js +30 -10
  87. package/instintos/autonomia.yaml +27 -0
  88. package/llms.txt +6 -6
  89. package/manifiestos/hooks-config.json +44 -17
  90. package/manifiestos/modulos.json +40 -15
  91. package/manifiestos/skills-lock.json +64 -57
  92. package/package.json +93 -93
  93. package/plugin.json +371 -375
  94. package/reglas/accesibilidad.md +10 -0
  95. package/reglas/analizar-directorios-antes-de-escribir.md +228 -0
  96. package/reglas/api-diseno.md +9 -0
  97. package/reglas/auditorias-documentales-estructurales.md +7 -0
  98. package/reglas/cloud-infra.md +8 -0
  99. package/reglas/consultar-vault-primero.md +195 -0
  100. package/reglas/debatir-antes-de-aceptar.md +158 -0
  101. package/reglas/fragmentos-compartidos.md +5 -0
  102. package/reglas/git-coauthor.md +100 -0
  103. package/reglas/gobernanza.md +4 -4
  104. package/reglas/hooks.md +6 -0
  105. package/reglas/intent-engineering.md +4 -0
  106. package/reglas/markitdown.md +8 -0
  107. package/reglas/memoria-consolidada.md +1 -1
  108. package/reglas/monitor-ci.md +309 -0
  109. package/reglas/patrones.md +6 -0
  110. package/reglas/registro-componentes-nuevos.md +39 -2
  111. package/reglas/seguridad-agentes.md +1 -1
  112. package/reglas/sesiones-paralelas.md +180 -0
  113. package/reglas/skills-estandar.md +6 -0
  114. package/reglas/testing.md +7 -0
  115. package/reglas/tests-cleanup.md +4 -0
  116. package/reglas/usar-code-review-graph.md +155 -0
  117. package/reglas/usar-sistema-swl.md +1 -1
  118. package/reglas/verificar-citas-normativas.md +548 -0
  119. package/scripts/instalador.js +52 -6
  120. package/scripts/lib/ci-reader.js +193 -0
  121. package/scripts/lib/detectar-host-swl.js +175 -0
  122. package/scripts/lib/evidencia-release.js +322 -0
  123. package/scripts/lib/gate-hooks-requires.js +249 -0
  124. package/scripts/lib/gate-licencias.js +212 -0
  125. package/scripts/lib/git-metricas.js +257 -0
  126. package/scripts/lib/gitignore-manifest.js +29 -1
  127. package/scripts/lib/metricas-dora.js +204 -0
  128. package/scripts/lib/plan-lock.js +275 -0
  129. package/scripts/migrar-fase-dominio.js +0 -1
  130. package/scripts/tui/ejecutores.js +1 -1
  131. package/scripts/validar-manifest.js +92 -1
  132. package/scripts/verificar-evolucion.js +54 -4
  133. package/scripts/verificar-release.js +102 -0
  134. package/scripts/verificar-trazabilidad.js +298 -0
  135. package/agentes/ux-disenador-swl.md +0 -503
  136. package/comandos/swl/dashboard.md +0 -146
  137. package/comandos/swl/evolucion-estado.md +0 -191
  138. package/comandos/swl/metricas.md +0 -376
  139. package/comandos/swl/salud.md +0 -481
  140. package/reglas/arquitectura.evolved.json +0 -7
  141. package/reglas/seguridad.evolved.json +0 -7
  142. 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
@@ -1,3 +1,9 @@
1
+ ---
2
+ paths:
3
+ - "**/habilidades/**"
4
+ - "**/skills/**"
5
+ - "**/_userland/**"
6
+ ---
1
7
  # Regla: Estándar Oficial de Claude Agent Skills para el Sistema SWL
2
8
 
3
9
  **Aplica a**: Toda skill nueva o modificada en `habilidades/` y `skills/`
package/reglas/testing.md CHANGED
@@ -1,3 +1,10 @@
1
+ ---
2
+ paths:
3
+ - "**/*.tsx"
4
+ - "**/*.jsx"
5
+ - "**/vitest.config.{js,ts,mjs}"
6
+ - "**/playwright.config.{js,ts}"
7
+ ---
1
8
  # Regla: Testing — Next.js
2
9
 
3
10
  Probar Next.js con App Router requiere estrategia porque existen tres tipos de
@@ -1,3 +1,7 @@
1
+ ---
2
+ paths:
3
+ - "**/tests/**"
4
+ ---
1
5
  # Regla: Cleanup obligatorio de directorios temporales en tests
2
6
 
3
7
  Esta regla es **OBLIGATORIA** y aplica a todo test Node.js del sistema SWL
@@ -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