@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.
- package/CLAUDE.md +199 -196
- package/README.md +597 -579
- package/agentes/arquitecto-swl.md +0 -5
- package/agentes/backend-python-swl.md +0 -5
- package/agentes/implementador-swl.md +0 -5
- package/agentes/nemesis-auditor-swl.md +0 -5
- package/agentes/orquestador-swl.md +0 -5
- package/agentes/planificador-swl.md +0 -5
- package/agentes/revisor-codigo-swl.md +0 -5
- package/bin/swl-mcp-server.js +1 -1
- package/comandos/swl/adoptar-proyecto.md +253 -258
- package/comandos/swl/aprender.md +823 -828
- package/comandos/swl/claudemd.md +234 -239
- package/comandos/swl/ejecutar-fase.md +0 -5
- package/comandos/swl/nuevo-proyecto.md +200 -205
- package/comandos/swl/release.md +19 -5
- package/comandos/swl/revisar-impacto.md +0 -5
- package/habilidades/agent-browser/SKILL.md +0 -5
- package/habilidades/angular-moderno/SKILL.md +0 -5
- package/habilidades/api-rest-diseno/SKILL.md +0 -5
- package/habilidades/aprendizaje-continuo/SKILL.md +0 -5
- package/habilidades/auth-patrones/SKILL.md +0 -5
- package/habilidades/build-errors-nextjs/SKILL.md +0 -5
- package/habilidades/changelog-generator/SKILL.md +174 -179
- package/habilidades/checklist-seguridad/SKILL.md +0 -5
- package/habilidades/contenedores-docker/SKILL.md +0 -5
- package/habilidades/datos-etl/SKILL.md +0 -5
- package/habilidades/doc-sync/SKILL.md +0 -5
- package/habilidades/extractor-de-aprendizajes/SKILL.md +0 -5
- package/habilidades/fastapi-experto/SKILL.md +0 -5
- package/habilidades/frontend-avanzado/SKILL.md +0 -5
- package/habilidades/iam-secretos/SKILL.md +0 -5
- package/habilidades/manejo-errores/SKILL.md +0 -5
- package/habilidades/mapear-codebase/SKILL.md +0 -5
- package/habilidades/meta-skills-estandar/SKILL.md +0 -5
- package/habilidades/monitoring-alertas/SKILL.md +0 -5
- package/habilidades/nextjs-experto/SKILL.md +0 -5
- package/habilidades/nextjs-testing/SKILL.md +0 -5
- package/habilidades/node-experto/SKILL.md +0 -5
- package/habilidades/orquestacion-async/SKILL.md +0 -5
- package/habilidades/patrones-python/SKILL.md +227 -232
- package/habilidades/planear-fase/SKILL.md +336 -341
- package/habilidades/postgresql-experto/SKILL.md +0 -5
- package/habilidades/prevencion-sobreingenieria/SKILL.md +0 -5
- package/habilidades/protocolo-revision-swl/SKILL.md +0 -5
- package/habilidades/react-experto/SKILL.md +0 -5
- package/habilidades/release-semver/SKILL.md +0 -5
- package/habilidades/swl-claudemd/SKILL.md +0 -5
- package/habilidades/tdd-workflow/SKILL.md +710 -715
- package/habilidades/testing-python/SKILL.md +335 -340
- package/habilidades/verificar-trabajo/SKILL.md +0 -5
- package/hooks/lib/etapa-perfil-usuario.js +1 -1
- package/hooks/lib/evolution-tracker.js +191 -35
- package/hooks/resumen-sesion.js +4 -4
- package/llms.txt +1 -1
- package/manifiestos/canonical-hashes.json +1310 -0
- package/manifiestos/modulos.json +3 -0
- package/manifiestos/skills-lock.json +70 -70
- package/package.json +1 -1
- package/plugin.json +1 -1
- package/scripts/doctor.js +13 -0
- package/scripts/generar-canonical-hashes.js +147 -0
- package/scripts/instalador.js +140 -54
- package/scripts/lib/audit-evolved.js +76 -0
- package/scripts/lib/canonical-hash.js +94 -0
- package/scripts/lib/evolved-fuente.js +138 -0
- package/scripts/lib/manifiestos.js +1 -1
- package/scripts/publicar.js +42 -5
- package/scripts/remediar-evolved-instaladas.js +242 -0
- package/scripts/validar.js +14 -0
- package/scripts/vendor/claude-usage/__pycache__/scanner.cpython-314.pyc +0 -0
- package/scripts/verificar-evolucion.js +36 -0
- package/scripts/verificar-release.js +33 -0
- package/agentes/.evolved.json +0 -9
- package/comandos/swl/.evolved.json +0 -23
- package/habilidades/auth-patrones/.evolved.json +0 -9
- package/habilidades/extractor-de-aprendizajes/.evolved.json +0 -9
- package/habilidades/instalar-sistema/.evolved.json +0 -9
- package/habilidades/manejo-errores/.evolved.json +0 -9
- package/habilidades/node-experto/.evolved.json +0 -9
- 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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
-
|
|
57
|
-
-
|
|
58
|
-
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
- **
|
|
62
|
-
- **
|
|
63
|
-
- **
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
- **
|
|
100
|
-
- **
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
- **
|
|
117
|
-
- **
|
|
118
|
-
- **
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
-
|
|
130
|
-
- **
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
-
|
|
142
|
-
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
-
|
|
166
|
-
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
```
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
- **Si existe
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
- `
|
|
212
|
-
- `
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
✓ .planning/
|
|
228
|
-
✓ .planning/
|
|
229
|
-
✓ .planning/
|
|
230
|
-
✓ .planning/
|
|
231
|
-
✓ .
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
-
|
|
252
|
-
-
|
|
253
|
-
-
|
|
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 6 — Generar `.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.
|