@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.
Files changed (59) 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/implementador-swl.md +2 -0
  5. package/agentes/orquestador-swl.md +2 -0
  6. package/agentes/perfilador-usuario-swl.md +14 -1
  7. package/bin/swl-ses.js +1 -1
  8. package/comandos/swl/aprobar-plan.md +3 -2
  9. package/comandos/swl/briefing.md +122 -0
  10. package/comandos/swl/compactar.md +29 -2
  11. package/comandos/swl/discutir-fase.md +8 -5
  12. package/comandos/swl/ejecutar-fase.md +6 -0
  13. package/comandos/swl/planear-fase.md +5 -3
  14. package/comandos/swl/release.md +46 -0
  15. package/comandos/swl/status.md +69 -0
  16. package/comandos/swl/verificar.md +3 -2
  17. package/habilidades/changelog-generator/scripts/parse-commits.js +6 -4
  18. package/habilidades/ejecutar-fase/SKILL.md +541 -518
  19. package/habilidades/planear-fase/SKILL.md +3 -2
  20. package/habilidades/tdd-workflow/SKILL.md +715 -713
  21. package/habilidades/validacion-ci-sistema/SKILL.md +17 -1
  22. package/hooks/calidad-pre-commit.js +5 -1
  23. package/hooks/check-update.js +39 -1
  24. package/hooks/lib/autonomia.js +208 -0
  25. package/hooks/lib/briefing.js +474 -0
  26. package/hooks/lib/propose-step.js +357 -0
  27. package/hooks/session-briefing.js +98 -0
  28. package/hooks/telemetria-skill-routing.js +100 -0
  29. package/instintos/autonomia.yaml +27 -0
  30. package/llms.txt +4 -4
  31. package/manifiestos/hooks-config.json +18 -0
  32. package/manifiestos/modulos.json +25 -3
  33. package/manifiestos/skills-lock.json +14 -14
  34. package/package.json +93 -93
  35. package/plugin.json +371 -371
  36. package/reglas/analizar-directorios-antes-de-escribir.md +228 -0
  37. package/reglas/consultar-vault-primero.md +195 -0
  38. package/reglas/debatir-antes-de-aceptar.md +158 -0
  39. package/reglas/git-coauthor.md +100 -0
  40. package/reglas/monitor-ci.md +309 -0
  41. package/reglas/registro-componentes-nuevos.md +38 -10
  42. package/reglas/sesiones-paralelas.md +180 -0
  43. package/reglas/usar-code-review-graph.md +155 -0
  44. package/reglas/verificar-citas-normativas.md +548 -0
  45. package/scripts/instalador.js +52 -6
  46. package/scripts/lib/ci-reader.js +193 -0
  47. package/scripts/lib/detectar-host-swl.js +175 -0
  48. package/scripts/lib/evidencia-release.js +322 -0
  49. package/scripts/lib/gate-hooks-requires.js +249 -0
  50. package/scripts/lib/gate-licencias.js +212 -0
  51. package/scripts/lib/git-metricas.js +257 -0
  52. package/scripts/lib/metricas-dora.js +204 -0
  53. package/scripts/tui/ejecutores.js +1 -1
  54. package/scripts/validar-manifest.js +92 -1
  55. package/scripts/verificar-evolucion.js +54 -4
  56. package/scripts/verificar-release.js +102 -0
  57. package/scripts/verificar-trazabilidad.js +11 -5
  58. package/reglas/arquitectura.evolved.json +0 -7
  59. 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`).