@saulwade/swl-ses 2.2.0 → 2.2.3

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 (81) hide show
  1. package/CLAUDE.md +199 -196
  2. package/README.md +597 -579
  3. package/agentes/arquitecto-swl.md +0 -5
  4. package/agentes/backend-python-swl.md +0 -5
  5. package/agentes/implementador-swl.md +0 -5
  6. package/agentes/nemesis-auditor-swl.md +0 -5
  7. package/agentes/orquestador-swl.md +0 -5
  8. package/agentes/planificador-swl.md +0 -5
  9. package/agentes/revisor-codigo-swl.md +0 -5
  10. package/bin/swl-mcp-server.js +1 -1
  11. package/comandos/swl/adoptar-proyecto.md +253 -258
  12. package/comandos/swl/aprender.md +823 -828
  13. package/comandos/swl/claudemd.md +234 -239
  14. package/comandos/swl/ejecutar-fase.md +0 -5
  15. package/comandos/swl/nuevo-proyecto.md +200 -205
  16. package/comandos/swl/release.md +19 -5
  17. package/comandos/swl/revisar-impacto.md +0 -5
  18. package/habilidades/agent-browser/SKILL.md +0 -5
  19. package/habilidades/angular-moderno/SKILL.md +0 -5
  20. package/habilidades/api-rest-diseno/SKILL.md +0 -5
  21. package/habilidades/aprendizaje-continuo/SKILL.md +0 -5
  22. package/habilidades/auth-patrones/SKILL.md +0 -5
  23. package/habilidades/build-errors-nextjs/SKILL.md +0 -5
  24. package/habilidades/changelog-generator/SKILL.md +174 -179
  25. package/habilidades/checklist-seguridad/SKILL.md +0 -5
  26. package/habilidades/contenedores-docker/SKILL.md +0 -5
  27. package/habilidades/datos-etl/SKILL.md +0 -5
  28. package/habilidades/doc-sync/SKILL.md +0 -5
  29. package/habilidades/extractor-de-aprendizajes/SKILL.md +0 -5
  30. package/habilidades/fastapi-experto/SKILL.md +0 -5
  31. package/habilidades/frontend-avanzado/SKILL.md +0 -5
  32. package/habilidades/iam-secretos/SKILL.md +0 -5
  33. package/habilidades/manejo-errores/SKILL.md +0 -5
  34. package/habilidades/mapear-codebase/SKILL.md +0 -5
  35. package/habilidades/meta-skills-estandar/SKILL.md +0 -5
  36. package/habilidades/monitoring-alertas/SKILL.md +0 -5
  37. package/habilidades/nextjs-experto/SKILL.md +0 -5
  38. package/habilidades/nextjs-testing/SKILL.md +0 -5
  39. package/habilidades/node-experto/SKILL.md +0 -5
  40. package/habilidades/orquestacion-async/SKILL.md +0 -5
  41. package/habilidades/patrones-python/SKILL.md +227 -232
  42. package/habilidades/planear-fase/SKILL.md +336 -341
  43. package/habilidades/postgresql-experto/SKILL.md +0 -5
  44. package/habilidades/prevencion-sobreingenieria/SKILL.md +0 -5
  45. package/habilidades/protocolo-revision-swl/SKILL.md +0 -5
  46. package/habilidades/react-experto/SKILL.md +0 -5
  47. package/habilidades/release-semver/SKILL.md +0 -5
  48. package/habilidades/swl-claudemd/SKILL.md +0 -5
  49. package/habilidades/tdd-workflow/SKILL.md +710 -715
  50. package/habilidades/testing-python/SKILL.md +335 -340
  51. package/habilidades/verificar-trabajo/SKILL.md +0 -5
  52. package/hooks/lib/etapa-perfil-usuario.js +1 -1
  53. package/hooks/lib/evolution-tracker.js +191 -35
  54. package/hooks/resumen-sesion.js +4 -4
  55. package/llms.txt +1 -1
  56. package/manifiestos/canonical-hashes.json +1310 -0
  57. package/manifiestos/modulos.json +3 -0
  58. package/manifiestos/skills-lock.json +70 -70
  59. package/package.json +1 -1
  60. package/plugin.json +1 -1
  61. package/scripts/doctor.js +13 -0
  62. package/scripts/generar-canonical-hashes.js +147 -0
  63. package/scripts/instalador.js +140 -54
  64. package/scripts/lib/audit-evolved.js +76 -0
  65. package/scripts/lib/canonical-hash.js +94 -0
  66. package/scripts/lib/evolved-fuente.js +138 -0
  67. package/scripts/lib/manifiestos.js +1 -1
  68. package/scripts/publicar.js +42 -5
  69. package/scripts/remediar-evolved-instaladas.js +242 -0
  70. package/scripts/validar.js +14 -0
  71. package/scripts/vendor/claude-usage/__pycache__/scanner.cpython-314.pyc +0 -0
  72. package/scripts/verificar-evolucion.js +36 -0
  73. package/scripts/verificar-release.js +33 -0
  74. package/agentes/.evolved.json +0 -9
  75. package/comandos/swl/.evolved.json +0 -23
  76. package/habilidades/auth-patrones/.evolved.json +0 -9
  77. package/habilidades/extractor-de-aprendizajes/.evolved.json +0 -9
  78. package/habilidades/instalar-sistema/.evolved.json +0 -9
  79. package/habilidades/manejo-errores/.evolved.json +0 -9
  80. package/habilidades/node-experto/.evolved.json +0 -9
  81. package/habilidades/release-semver/.evolved.json +0 -9
@@ -1,258 +1,253 @@
1
- ---
2
- name: swl:adoptar-proyecto
3
- description: Incorpora un proyecto existente al sistema SWL. Analiza automáticamente el codebase (stack, arquitectura, dependencias, estado git) y combina los hallazgos con una entrevista corta al usuario para generar los 9 archivos de .planning/ con información real del proyecto — no plantillas vacías.
4
- allowed_tools: ["Read", "Write", "Edit", "Bash", "Glob", "Grep", "Agent"]
5
- evolved: true
6
- evolved-from: "1.6.8"
7
- evolved-at: "2026-05-22"
8
- evolved-by: "aprender"
9
- evolved-note: "Paso 8 validación síncrona del auditor tras modificar CLAUDE.md (contrato cruzado con /swl:claudemd)"
10
- ---
11
-
12
- # /swl:adoptar-proyecto — Incorporar un proyecto existente al sistema SWL
13
-
14
- Eres el coordinador de adopción de proyectos existentes. Tu misión es convertir un codebase que ya existe en un proyecto SWL completamente documentado, combinando análisis automático del código con preguntas específicas al usuario para lo que no se puede inferir.
15
-
16
- **Diferencia con `/swl:nuevo-proyecto`**: ese comando parte de cero con entrevista larga. Este comando parte de un codebase existente primero analiza lo que hay, luego solo pregunta lo que falta.
17
-
18
- ## Cuándo usar este comando
19
-
20
- - Al incorporar un proyecto existente al sistema SWL
21
- - Cuando un proyecto ya tiene código pero no tiene `.planning/`
22
- - Cuando se heredó un proyecto y se quiere estructurar con SWL
23
- - Cuando `swl-ses init` ya creó las plantillas vacías y se necesita poblarlas con datos reales
24
-
25
- ## Prerrequisitos
26
-
27
- 1. **SWL instalado** — `swl-ses install` ya ejecutado (global o local)
28
- 2. **Codebase existente** — el proyecto debe tener código fuente (no un directorio vacío para eso usar `/swl:nuevo-proyecto`)
29
- 3. **Git inicializado** se usa para detectar estado, ramas y actividad reciente
30
-
31
- ## Paso 0 Verificar entorno
32
-
33
- 1. Confirmar directorio de trabajo actual.
34
- 2. Verificar que es un repositorio git (`git rev-parse --show-toplevel`).
35
- 3. Si no existe `.planning/`, crearlo junto con `.planning/research/`.
36
- 4. Si ya existen archivos en `.planning/` con contenido real (no plantillas), preguntar:
37
- ```
38
- Ya existe .planning/ con contenido que parece haber sido editado.
39
- ¿Deseas sobrescribirlo o solo llenar los archivos que aún son plantillas vacías?
40
- ```
41
- 5. Leer `CLAUDE.md` y `README.md` si existen dan contexto rápido.
42
-
43
- ### Detección de plantillas vacías vs contenido real
44
-
45
- Un archivo es "plantilla vacía" si contiene los marcadores originales de las plantillas SWL:
46
- - `[Nombre del Proyecto]` o `[Nombre del proyecto]`
47
- - `YYYY-MM-DD` (más de 2 ocurrencias)
48
- - `[ej.` (ejemplos no reemplazados)
49
- - Tablas con todas las celdas vacías (`| | | |`)
50
-
51
- Un archivo con estos marcadores se sobrescribe. Un archivo sin ellos se preserva.
52
-
53
- ## Paso 1 Análisis automático del codebase
54
-
55
- Ejecutar `/swl:mapear-codebase` internamente. Este comando genera:
56
- - `.planning/research/ARQUITECTURA.md` análisis completo de la arquitectura
57
- - `.planning/research/STACK.md` evaluación del stack tecnológico detectado
58
- - `.planning/research/TRAMPAS.md` anti-patrones y deuda técnica encontrada
59
-
60
- Capturar los hallazgos clave para usarlos en los pasos siguientes:
61
- - **Nombre del proyecto**: de `package.json`, `pyproject.toml`, `Cargo.toml`, `go.mod`, `pom.xml`, o nombre del directorio raíz
62
- - **Descripción**: de `README.md` (primer párrafo) o del campo `description` del manifiesto
63
- - **Stack**: lenguajes, frameworks, bases de datos detectados
64
- - **Estructura**: módulos principales y sus responsabilidades
65
- - **Dependencias**: lista clasificada del manifiesto
66
- - **Estado git**: rama actual, último commit, ramas activas, tags existentes
67
- - **Puntos de entrada**: archivos main/index/app detectados
68
- - **Deuda técnica**: TODOs, FIXMEs, archivos grandes, dependencias desactualizadas
69
-
70
- ## Paso 2 Entrevista corta (solo lo que no se puede inferir)
71
-
72
- Presentar al usuario un resumen de lo detectado y hacer SOLO las preguntas que el análisis no puede responder. Agrupar en un solo bloque:
73
-
74
- ```
75
- He analizado tu proyecto. Esto es lo que detecté:
76
-
77
- Nombre: [detectado]
78
- Descripción: [detectada]
79
- Stack: [detectado]
80
- Módulos: [N] módulos principales detectados
81
- Dependencias: [N] de producción, [N] de desarrollo
82
- Estado git: rama [nombre], [N] commits, último hace [tiempo]
83
-
84
- Para completar la documentación necesito que me confirmes o ajustes:
85
-
86
- 1. ¿La descripción de arriba es correcta? Si no, ¿cuál es la descripción correcta del proyecto?
87
- 2. ¿Quiénes son los usuarios finales? (internos, clientes, público)
88
- 3. ¿Hay una fecha límite o hito próximo importante?
89
- 4. ¿Cuál es la prioridad actual? (nueva feature, estabilización, refactor, migración)
90
- 5. ¿Hay algo roto o urgente que deba reflejarse como riesgo activo?
91
- ```
92
-
93
- ESPERAR respuesta antes de continuar. No inventar respuestas.
94
-
95
- ## Paso 3 Generar `.planning/PROYECTO.md`
96
-
97
- Combinar los datos detectados con las respuestas del usuario:
98
-
99
- - **Visión**: de la descripción confirmada por el usuario
100
- - **Stack tecnológico**: tabla auto-llenada desde el análisis de dependencias
101
- - **Restricciones técnicas**: inferidas del stack (versiones pinneadas, runtime requerido)
102
- - **Restricciones de negocio**: de la respuesta sobre fechas y prioridades
103
- - **Objetivos**: derivados de la prioridad actual indicada por el usuario
104
- - **No-objetivos**: dejar la sección con nota "Definir con `/swl:discutir-fase`"
105
- - **Equipo**: detectar del git log (contribuidores recientes) + preguntar si aplica
106
-
107
- Para la sección de equipo, inferir desde git:
108
- ```bash
109
- git shortlog -sne --since="6 months ago" | head -10
110
- ```
111
-
112
- ## Paso 4 Generar `.planning/ESTADO.md`
113
-
114
- Auto-llenar completamente desde el estado actual del repositorio:
115
-
116
- - **Fase activa**: "Adopción inicial incorporación al sistema SWL"
117
- - **Progreso**: basado en si hay tests, CI, docs
118
- - **Lo hecho en la última sesión**: "Proyecto adoptado por SWL. Análisis inicial completado."
119
- - **Decisiones tomadas**: tabla vacía (se llenará conforme se trabaje)
120
- - **Riesgos activos**: de la deuda técnica detectada + lo que reportó el usuario
121
- - **Métricas actuales**: cobertura de tests (si se detecta), linter status, dependencias outdated
122
- - **Bloqueantes**: lo reportado por el usuario como urgente
123
- - **Próximos pasos**: sugerir `/swl:discutir-fase 1` como siguiente acción
124
-
125
- ## Paso 5 Generar `.planning/HOJA-RUTA.md`
126
-
127
- Crear un roadmap inicial basado en el estado del proyecto:
128
-
129
- - **Fase 0** (completada): "Adopción SWL análisis del codebase"
130
- - **Fase 1** (pendiente): Basada en la prioridad indicada por el usuario:
131
- - Si "nueva feature" → "Implementación de [feature descrita]"
132
- - Si "estabilización" → "Estabilización tests, CI, docs"
133
- - Si "refactor" → "Refactorización de [área detectada con más deuda]"
134
- - Si "migración" "Migración de [tecnología origen] a [destino]"
135
- - **Fases 2-3**: Marcar como "Por definir con `/swl:discutir-fase`"
136
-
137
- ## Paso 6 Generar `.planning/REQUISITOS.md`
138
-
139
- Crear una versión inicial con:
140
-
141
- - **Requisitos funcionales**: extraer de los endpoints/rutas detectados, agrupados por módulo
142
- - Listar cada endpoint o funcionalidad detectable como REQ-NNN en estado "Completado" (ya existe)
143
- - Esto da visibilidad de lo que el sistema YA hace
144
- - **Requisitos no funcionales**: parcialmente inferibles:
145
- - Performance: si hay benchmarks o métricas configuradas
146
- - Seguridad: si hay auth configurada (JWT, OAuth, etc.)
147
- - Tests: cobertura actual como baseline
148
- - **Nota**: "Los requisitos de nuevas funcionalidades se definen con `/swl:discutir-fase`"
149
-
150
- ## Paso 7 Generar archivos de research restantes
151
-
152
- ### `.planning/research/FUNCIONALIDADES.md`
153
-
154
- Listar las funcionalidades detectadas en el codebase:
155
- - Por cada endpoint/ruta encontrada: método, path, descripción inferida
156
- - Por cada modelo/entidad: nombre, campos principales
157
- - Por cada job/worker: nombre, propósito detectado
158
-
159
- ### `.planning/research/RESUMEN.md`
160
-
161
- Consolidar el resumen ejecutivo:
162
- - TL;DR del proyecto (3-5 bullets)
163
- - Stack confirmado con versiones
164
- - Estado actual: qué funciona, qué falta
165
- - Riesgos principales
166
- - Recomendación de próximos pasos
167
-
168
- ### `.planning/research/TRAMPAS.md`
169
-
170
- Si `/swl:mapear-codebase` ya lo generó (opción B), solo verificar. Si no:
171
- - TODOs y FIXMEs agrupados por módulo
172
- - Anti-patrones detectados en el stack (N+1, eval, shell=True, etc.)
173
- - Dependencias con CVEs conocidos (si `pip-audit` o `npm audit` están disponibles)
174
- - Archivos con más de 500 líneas
175
-
176
- ## Paso 8 Verificar/actualizar CLAUDE.md del proyecto
177
-
178
- Verificar el estado de `CLAUDE.md` en la raíz del proyecto:
179
-
180
- - **Si NO existe**: generarlo con la estructura mínima de `/swl:claudemd init-project`.
181
- **OBLIGATORIO** incluir como primera sección bajo el título:
182
- ```markdown
183
- ## Reglas obligatorias
184
-
185
- Aplica la regla global `usar-sistema-swl.md` (matriz operacional del sistema
186
- SWL), auto-cargada desde `.claude/rules/`. NO duplicar su contenido aquí.
187
- ```
188
- - **Si existe pero NO menciona la regla global `usar-sistema-swl`**: agregar la
189
- mención en una sección "Reglas obligatorias" cerca del inicio del archivo,
190
- preservando el contenido existente. NUNCA usar `@reglas/usar-sistema-swl.md`
191
- esa ruta no existe en proyectos downstream (las reglas viven en
192
- `.claude/rules/`).
193
- - **Si existe e incluye la mención**: no tocar.
194
-
195
- Esta mención recuerda la matriz operacional del sistema SWL y es el contrato
196
- base de uso del sistema para el proyecto adoptado.
197
-
198
- ### Validación síncrona post-modificación (contrato cruzado con /swl:claudemd)
199
-
200
- Tras generar o modificar `CLAUDE.md` en este paso, ejecutar el auditor
201
- síncrono para verificar que respeta el contrato canónico:
202
-
203
- ```bash
204
- swl-ses audit-claudemd --json
205
- # Fallback si el script no está en el proyecto destino:
206
- npx -y @saulwade/swl-ses@latest audit-claudemd --json
207
- ```
208
-
209
- Evaluar `veredicto`:
210
-
211
- - `OK` → continuar al Paso 9.
212
- - `WARN tamano-total` → el CLAUDE.md preexistente más la modificación
213
- excedió el umbral. Reportar al usuario y proponer extracción a
214
- `@docs/lessons-<tema>.md` antes de cerrar.
215
- - `WARN bullet-gigante` → revisar y condensar el bullet detectado.
216
- - `WARN` otras reglas reportar al usuario pero permitir continuar.
217
- - `ERROR placeholders` → **DETENER**, revertir la modificación y reportar.
218
-
219
- Detalle del contrato cruzado en `@docs/contrato-aprender-claudemd.md`.
220
-
221
- ## Paso 9 — Reporte final
222
-
223
- ```
224
- === Proyecto adoptado exitosamente ===
225
-
226
- Archivos generados:
227
- ✓ .planning/PROYECTO.md [N] secciones con datos reales
228
- ✓ .planning/ESTADO.md estado actual del repositorio
229
- ✓ .planning/HOJA-RUTA.md roadmap inicial con [N] fases
230
- ✓ .planning/REQUISITOS.md [N] requisitos existentes documentados
231
- ✓ .planning/research/ARQUITECTURA.md análisis completo del codebase
232
- ✓ .planning/research/STACK.md — evaluación del stack tecnológico
233
- .planning/research/FUNCIONALIDADES.md — inventario de funcionalidades
234
- .planning/research/RESUMEN.md — resumen ejecutivo consolidado
235
- .planning/research/TRAMPAS.md — deuda técnica y anti-patrones
236
- ✓ CLAUDE.md — creado o actualizado con mención de la regla global usar-sistema-swl
237
-
238
- Hallazgos clave:
239
- 1. [hallazgo más importante]
240
- 2. [segundo hallazgo]
241
- 3. [tercer hallazgo]
242
-
243
- Riesgo principal: [descripción]
244
-
245
- Próximo paso recomendado:
246
- /swl:discutir-fase 1 ← para definir la primera fase de trabajo
247
- ```
248
-
249
- ## Reglas de comportamiento
250
-
251
- - NUNCA inventar información que no se detectó ni el usuario proporcionó. Si un campo no se puede inferir, dejarlo con nota "Pendiente — definir con `/swl:discutir-fase`".
252
- - NUNCA modificar archivos de código fuente solo generar documentación en `.planning/`.
253
- - Si el proyecto tiene menos de 5 archivos de código, sugerir `/swl:nuevo-proyecto` en su lugar.
254
- - Si `.planning/` tiene archivos con contenido real, preservarlos y solo llenar los vacíos.
255
- - La entrevista DEBE ser corta (5 preguntas máximo). Lo que se puede inferir del código, se infiere.
256
- - Los archivos generados deben ser útiles INMEDIATAMENTE — no plantillas con placeholders.
257
- - Si un análisis falla (ej: no hay tests, no hay CI), documentar la ausencia como hallazgo, no como error.
258
- - Preferir exactitud sobre completitud: es mejor un archivo con 3 secciones correctas que uno con 10 secciones adivinadas.
1
+ ---
2
+ name: swl:adoptar-proyecto
3
+ description: Incorpora un proyecto existente al sistema SWL. Analiza automáticamente el codebase (stack, arquitectura, dependencias, estado git) y combina los hallazgos con una entrevista corta al usuario para generar los 9 archivos de .planning/ con información real del proyecto — no plantillas vacías.
4
+ allowed_tools: ["Read", "Write", "Edit", "Bash", "Glob", "Grep", "Agent"]
5
+ ---
6
+
7
+ # /swl:adoptar-proyecto — Incorporar un proyecto existente al sistema SWL
8
+
9
+ Eres el coordinador de adopción de proyectos existentes. Tu misión es convertir un codebase que ya existe en un proyecto SWL completamente documentado, combinando análisis automático del código con preguntas específicas al usuario para lo que no se puede inferir.
10
+
11
+ **Diferencia con `/swl:nuevo-proyecto`**: ese comando parte de cero con entrevista larga. Este comando parte de un codebase existente — primero analiza lo que hay, luego solo pregunta lo que falta.
12
+
13
+ ## Cuándo usar este comando
14
+
15
+ - Al incorporar un proyecto existente al sistema SWL
16
+ - Cuando un proyecto ya tiene código pero no tiene `.planning/`
17
+ - Cuando se heredó un proyecto y se quiere estructurar con SWL
18
+ - Cuando `swl-ses init` ya creó las plantillas vacías y se necesita poblarlas con datos reales
19
+
20
+ ## Prerrequisitos
21
+
22
+ 1. **SWL instalado** `swl-ses install` ya ejecutado (global o local)
23
+ 2. **Codebase existente** el proyecto debe tener código fuente (no un directorio vacío para eso usar `/swl:nuevo-proyecto`)
24
+ 3. **Git inicializado** — se usa para detectar estado, ramas y actividad reciente
25
+
26
+ ## Paso 0 — Verificar entorno
27
+
28
+ 1. Confirmar directorio de trabajo actual.
29
+ 2. Verificar que es un repositorio git (`git rev-parse --show-toplevel`).
30
+ 3. Si no existe `.planning/`, crearlo junto con `.planning/research/`.
31
+ 4. Si ya existen archivos en `.planning/` con contenido real (no plantillas), preguntar:
32
+ ```
33
+ Ya existe .planning/ con contenido que parece haber sido editado.
34
+ ¿Deseas sobrescribirlo o solo llenar los archivos que aún son plantillas vacías?
35
+ ```
36
+ 5. Leer `CLAUDE.md` y `README.md` si existen dan contexto rápido.
37
+
38
+ ### Detección de plantillas vacías vs contenido real
39
+
40
+ Un archivo es "plantilla vacía" si contiene los marcadores originales de las plantillas SWL:
41
+ - `[Nombre del Proyecto]` o `[Nombre del proyecto]`
42
+ - `YYYY-MM-DD` (más de 2 ocurrencias)
43
+ - `[ej.` (ejemplos no reemplazados)
44
+ - Tablas con todas las celdas vacías (`| | | |`)
45
+
46
+ Un archivo con estos marcadores se sobrescribe. Un archivo sin ellos se preserva.
47
+
48
+ ## Paso 1 Análisis automático del codebase
49
+
50
+ Ejecutar `/swl:mapear-codebase` internamente. Este comando genera:
51
+ - `.planning/research/ARQUITECTURA.md` análisis completo de la arquitectura
52
+ - `.planning/research/STACK.md` — evaluación del stack tecnológico detectado
53
+ - `.planning/research/TRAMPAS.md`anti-patrones y deuda técnica encontrada
54
+
55
+ Capturar los hallazgos clave para usarlos en los pasos siguientes:
56
+ - **Nombre del proyecto**: de `package.json`, `pyproject.toml`, `Cargo.toml`, `go.mod`, `pom.xml`, o nombre del directorio raíz
57
+ - **Descripción**: de `README.md` (primer párrafo) o del campo `description` del manifiesto
58
+ - **Stack**: lenguajes, frameworks, bases de datos detectados
59
+ - **Estructura**: módulos principales y sus responsabilidades
60
+ - **Dependencias**: lista clasificada del manifiesto
61
+ - **Estado git**: rama actual, último commit, ramas activas, tags existentes
62
+ - **Puntos de entrada**: archivos main/index/app detectados
63
+ - **Deuda técnica**: TODOs, FIXMEs, archivos grandes, dependencias desactualizadas
64
+
65
+ ## Paso 2 Entrevista corta (solo lo que no se puede inferir)
66
+
67
+ Presentar al usuario un resumen de lo detectado y hacer SOLO las preguntas que el análisis no puede responder. Agrupar en un solo bloque:
68
+
69
+ ```
70
+ He analizado tu proyecto. Esto es lo que detecté:
71
+
72
+ Nombre: [detectado]
73
+ Descripción: [detectada]
74
+ Stack: [detectado]
75
+ Módulos: [N] módulos principales detectados
76
+ Dependencias: [N] de producción, [N] de desarrollo
77
+ Estado git: rama [nombre], [N] commits, último hace [tiempo]
78
+
79
+ Para completar la documentación necesito que me confirmes o ajustes:
80
+
81
+ 1. ¿La descripción de arriba es correcta? Si no, ¿cuál es la descripción correcta del proyecto?
82
+ 2. ¿Quiénes son los usuarios finales? (internos, clientes, público)
83
+ 3. ¿Hay una fecha límite o hito próximo importante?
84
+ 4. ¿Cuál es la prioridad actual? (nueva feature, estabilización, refactor, migración)
85
+ 5. ¿Hay algo roto o urgente que deba reflejarse como riesgo activo?
86
+ ```
87
+
88
+ ESPERAR respuesta antes de continuar. No inventar respuestas.
89
+
90
+ ## Paso 3 Generar `.planning/PROYECTO.md`
91
+
92
+ Combinar los datos detectados con las respuestas del usuario:
93
+
94
+ - **Visión**: de la descripción confirmada por el usuario
95
+ - **Stack tecnológico**: tabla auto-llenada desde el análisis de dependencias
96
+ - **Restricciones técnicas**: inferidas del stack (versiones pinneadas, runtime requerido)
97
+ - **Restricciones de negocio**: de la respuesta sobre fechas y prioridades
98
+ - **Objetivos**: derivados de la prioridad actual indicada por el usuario
99
+ - **No-objetivos**: dejar la sección con nota "Definir con `/swl:discutir-fase`"
100
+ - **Equipo**: detectar del git log (contribuidores recientes) + preguntar si aplica
101
+
102
+ Para la sección de equipo, inferir desde git:
103
+ ```bash
104
+ git shortlog -sne --since="6 months ago" | head -10
105
+ ```
106
+
107
+ ## Paso 4 Generar `.planning/ESTADO.md`
108
+
109
+ Auto-llenar completamente desde el estado actual del repositorio:
110
+
111
+ - **Fase activa**: "Adopción inicial — incorporación al sistema SWL"
112
+ - **Progreso**: basado en si hay tests, CI, docs
113
+ - **Lo hecho en la última sesión**: "Proyecto adoptado por SWL. Análisis inicial completado."
114
+ - **Decisiones tomadas**: tabla vacía (se llenará conforme se trabaje)
115
+ - **Riesgos activos**: de la deuda técnica detectada + lo que reportó el usuario
116
+ - **Métricas actuales**: cobertura de tests (si se detecta), linter status, dependencias outdated
117
+ - **Bloqueantes**: lo reportado por el usuario como urgente
118
+ - **Próximos pasos**: sugerir `/swl:discutir-fase 1` como siguiente acción
119
+
120
+ ## Paso 5 Generar `.planning/HOJA-RUTA.md`
121
+
122
+ Crear un roadmap inicial basado en el estado del proyecto:
123
+
124
+ - **Fase 0** (completada): "Adopción SWL — análisis del codebase"
125
+ - **Fase 1** (pendiente): Basada en la prioridad indicada por el usuario:
126
+ - Si "nueva feature" → "Implementación de [feature descrita]"
127
+ - Si "estabilización" "Estabilización tests, CI, docs"
128
+ - Si "refactor" → "Refactorización de [área detectada con más deuda]"
129
+ - Si "migración" "Migración de [tecnología origen] a [destino]"
130
+ - **Fases 2-3**: Marcar como "Por definir con `/swl:discutir-fase`"
131
+
132
+ ## Paso 6Generar `.planning/REQUISITOS.md`
133
+
134
+ Crear una versión inicial con:
135
+
136
+ - **Requisitos funcionales**: extraer de los endpoints/rutas detectados, agrupados por módulo
137
+ - Listar cada endpoint o funcionalidad detectable como REQ-NNN en estado "Completado" (ya existe)
138
+ - Esto da visibilidad de lo que el sistema YA hace
139
+ - **Requisitos no funcionales**: parcialmente inferibles:
140
+ - Performance: si hay benchmarks o métricas configuradas
141
+ - Seguridad: si hay auth configurada (JWT, OAuth, etc.)
142
+ - Tests: cobertura actual como baseline
143
+ - **Nota**: "Los requisitos de nuevas funcionalidades se definen con `/swl:discutir-fase`"
144
+
145
+ ## Paso 7 Generar archivos de research restantes
146
+
147
+ ### `.planning/research/FUNCIONALIDADES.md`
148
+
149
+ Listar las funcionalidades detectadas en el codebase:
150
+ - Por cada endpoint/ruta encontrada: método, path, descripción inferida
151
+ - Por cada modelo/entidad: nombre, campos principales
152
+ - Por cada job/worker: nombre, propósito detectado
153
+
154
+ ### `.planning/research/RESUMEN.md`
155
+
156
+ Consolidar el resumen ejecutivo:
157
+ - TL;DR del proyecto (3-5 bullets)
158
+ - Stack confirmado con versiones
159
+ - Estado actual: qué funciona, qué falta
160
+ - Riesgos principales
161
+ - Recomendación de próximos pasos
162
+
163
+ ### `.planning/research/TRAMPAS.md`
164
+
165
+ Si `/swl:mapear-codebase` ya lo generó (opción B), solo verificar. Si no:
166
+ - TODOs y FIXMEs agrupados por módulo
167
+ - Anti-patrones detectados en el stack (N+1, eval, shell=True, etc.)
168
+ - Dependencias con CVEs conocidos (si `pip-audit` o `npm audit` están disponibles)
169
+ - Archivos con más de 500 líneas
170
+
171
+ ## Paso 8 Verificar/actualizar CLAUDE.md del proyecto
172
+
173
+ Verificar el estado de `CLAUDE.md` en la raíz del proyecto:
174
+
175
+ - **Si NO existe**: generarlo con la estructura mínima de `/swl:claudemd init-project`.
176
+ **OBLIGATORIO** incluir como primera sección bajo el título:
177
+ ```markdown
178
+ ## Reglas obligatorias
179
+
180
+ Aplica la regla global `usar-sistema-swl.md` (matriz operacional del sistema
181
+ SWL), auto-cargada desde `.claude/rules/`. NO duplicar su contenido aquí.
182
+ ```
183
+ - **Si existe pero NO menciona la regla global `usar-sistema-swl`**: agregar la
184
+ mención en una sección "Reglas obligatorias" cerca del inicio del archivo,
185
+ preservando el contenido existente. NUNCA usar `@reglas/usar-sistema-swl.md`
186
+ esa ruta no existe en proyectos downstream (las reglas viven en
187
+ `.claude/rules/`).
188
+ - **Si existe e incluye la mención**: no tocar.
189
+
190
+ Esta mención recuerda la matriz operacional del sistema SWL y es el contrato
191
+ base de uso del sistema para el proyecto adoptado.
192
+
193
+ ### Validación síncrona post-modificación (contrato cruzado con /swl:claudemd)
194
+
195
+ Tras generar o modificar `CLAUDE.md` en este paso, ejecutar el auditor
196
+ síncrono para verificar que respeta el contrato canónico:
197
+
198
+ ```bash
199
+ swl-ses audit-claudemd --json
200
+ # Fallback si el script no está en el proyecto destino:
201
+ npx -y @saulwade/swl-ses@latest audit-claudemd --json
202
+ ```
203
+
204
+ Evaluar `veredicto`:
205
+
206
+ - `OK` continuar al Paso 9.
207
+ - `WARN tamano-total` → el CLAUDE.md preexistente más la modificación
208
+ excedió el umbral. Reportar al usuario y proponer extracción a
209
+ `@docs/lessons-<tema>.md` antes de cerrar.
210
+ - `WARN bullet-gigante` → revisar y condensar el bullet detectado.
211
+ - `WARN` otras reglas reportar al usuario pero permitir continuar.
212
+ - `ERROR placeholders` → **DETENER**, revertir la modificación y reportar.
213
+
214
+ Detalle del contrato cruzado en `@docs/contrato-aprender-claudemd.md`.
215
+
216
+ ## Paso 9 Reporte final
217
+
218
+ ```
219
+ === Proyecto adoptado exitosamente ===
220
+
221
+ Archivos generados:
222
+ ✓ .planning/PROYECTO.md — [N] secciones con datos reales
223
+ ✓ .planning/ESTADO.md — estado actual del repositorio
224
+ .planning/HOJA-RUTA.md — roadmap inicial con [N] fases
225
+ ✓ .planning/REQUISITOS.md — [N] requisitos existentes documentados
226
+ .planning/research/ARQUITECTURA.md — análisis completo del codebase
227
+ ✓ .planning/research/STACK.md evaluación del stack tecnológico
228
+ ✓ .planning/research/FUNCIONALIDADES.md inventario de funcionalidades
229
+ ✓ .planning/research/RESUMEN.md resumen ejecutivo consolidado
230
+ ✓ .planning/research/TRAMPAS.md deuda técnica y anti-patrones
231
+ CLAUDE.md creado o actualizado con mención de la regla global usar-sistema-swl
232
+
233
+ Hallazgos clave:
234
+ 1. [hallazgo más importante]
235
+ 2. [segundo hallazgo]
236
+ 3. [tercer hallazgo]
237
+
238
+ Riesgo principal: [descripción]
239
+
240
+ Próximo paso recomendado:
241
+ /swl:discutir-fase 1 ← para definir la primera fase de trabajo
242
+ ```
243
+
244
+ ## Reglas de comportamiento
245
+
246
+ - NUNCA inventar información que no se detectó ni el usuario proporcionó. Si un campo no se puede inferir, dejarlo con nota "Pendiente — definir con `/swl:discutir-fase`".
247
+ - NUNCA modificar archivos de código fuente — solo generar documentación en `.planning/`.
248
+ - Si el proyecto tiene menos de 5 archivos de código, sugerir `/swl:nuevo-proyecto` en su lugar.
249
+ - Si `.planning/` tiene archivos con contenido real, preservarlos y solo llenar los vacíos.
250
+ - La entrevista DEBE ser corta (5 preguntas máximo). Lo que se puede inferir del código, se infiere.
251
+ - Los archivos generados deben ser útiles INMEDIATAMENTE no plantillas con placeholders.
252
+ - Si un análisis falla (ej: no hay tests, no hay CI), documentar la ausencia como hallazgo, no como error.
253
+ - Preferir exactitud sobre completitud: es mejor un archivo con 3 secciones correctas que uno con 10 secciones adivinadas.