@saulwade/swl-ses 1.6.0 → 1.6.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 +32 -61
- package/README.md +4 -4
- package/agentes/_intent-spec.md +73 -0
- package/agentes/auto-evolucion-swl.md +24 -0
- package/agentes/cloud-infra-swl.md +25 -0
- package/agentes/datos-swl.md +24 -1
- package/agentes/devops-ci-swl.md +24 -0
- package/agentes/frontend-angular-swl.md +7 -7
- package/agentes/frontend-css-swl.md +4 -4
- package/agentes/frontend-react-swl.md +7 -7
- package/agentes/frontend-swl.md +9 -9
- package/agentes/frontend-tailwind-swl.md +4 -4
- package/agentes/migrador-swl.md +22 -0
- package/agentes/pagos-swl.md +25 -0
- package/agentes/release-manager-swl.md +24 -0
- package/agentes/rendimiento-swl.md +2 -2
- package/agentes/sre-swl.md +24 -0
- package/comandos/swl/brainstorm.md +1 -0
- package/comandos/swl/compactar.md +1 -1
- package/comandos/swl/discutir-fase.md +15 -1
- package/comandos/swl/mapear-codebase.md +1 -1
- package/comandos/swl/nemesis.md +29 -0
- package/comandos/swl/planear-fase.md +18 -2
- package/comandos/swl/verificar.md +4 -4
- package/habilidades/aprender-de-git-diff/SKILL.md +288 -0
- package/habilidades/aprendizaje-continuo/SKILL.md +7 -1
- package/habilidades/diseno-herramientas-agente/SKILL.md +17 -0
- package/habilidades/doc-sync/SKILL.md +441 -1
- package/habilidades/doubt-driven-review/SKILL.md +177 -171
- package/habilidades/feynman-auditor-swl/SKILL.md +129 -123
- package/habilidades/infra-github-actions/SKILL.md +172 -166
- package/habilidades/meta-skills-estandar/SKILL.md +6 -0
- package/habilidades/meta-skills-estandar/recursos/skill-judge-rubrica.md +281 -0
- package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
- package/habilidades/nemesis-evaluacion-json/SKILL.md +5 -0
- package/habilidades/nemesis-redistribuir/SKILL.md +5 -0
- package/habilidades/node-experto/SKILL.md +197 -3
- package/habilidades/prevencion-racionalizacion/SKILL.md +1 -0
- package/habilidades/privacy-memoria/SKILL.md +1 -0
- package/habilidades/proceso-autoverificacion-evidencias/SKILL.md +258 -0
- package/habilidades/proceso-confianza-pre-implementacion/SKILL.md +246 -0
- package/habilidades/proceso-ddia-fundamentos/SKILL.md +255 -0
- package/habilidades/proceso-ddia-streaming/SKILL.md +231 -0
- package/habilidades/proceso-intent-engineering/SKILL.md +269 -0
- package/habilidades/reducir-entropia/SKILL.md +219 -0
- package/habilidades/sre-patrones/SKILL.md +1 -1
- package/habilidades/state-inconsistency-auditor-swl/SKILL.md +172 -166
- package/habilidades/tdd-workflow/SKILL.md +178 -3
- package/habilidades/verificacion-evidencia/SKILL.md +1 -0
- package/habilidades/web-fetcher-routing/SKILL.md +81 -75
- package/habilidades/workflow-claude-code/SKILL.md +2 -2
- package/hooks/lib/task-budget.js +218 -0
- package/hooks/validar-intent-spec.js +222 -0
- package/manifiestos/hooks-config.json +9 -0
- package/manifiestos/modulos.json +12 -2
- package/manifiestos/skills-lock.json +1191 -1142
- package/package.json +5 -3
- package/plugin.json +9 -2
- package/reglas/auditorias-documentales-estructurales.md +205 -0
- package/reglas/fragmentos-compartidos.md +26 -0
- package/reglas/intent-engineering.md +214 -0
- package/reglas/registro-componentes-nuevos.md +38 -0
- package/schemas/agent-frontmatter.schema.json +294 -167
- package/schemas/agent-message.schema.json +73 -53
- package/schemas/agent-output-implementacion.schema.json +114 -85
- package/schemas/agent-output-planificacion.schema.json +150 -113
- package/schemas/agent-output-review.schema.json +98 -78
- package/schemas/diary-entry.schema.json +42 -10
- package/schemas/hook-profiles.schema.json +54 -39
- package/schemas/hooks-config.schema.json +89 -74
- package/schemas/instinct.schema.json +152 -115
- package/schemas/modulos.schema.json +38 -29
- package/schemas/perfiles.schema.json +36 -28
- package/schemas/plugin.schema.json +77 -64
- package/schemas/skill-evals.schema.json +119 -95
- package/schemas/skill-frontmatter.schema.json +245 -170
- package/scripts/generar-inventario.js +452 -420
- package/scripts/lib/schema-version.js +164 -0
- package/scripts/validar-manifest.js +1 -1
- package/scripts/validar.js +3 -2
- package/scripts/verificar-docs-vs-codigo.js +654 -425
- package/scripts/verificar-evolucion.js +19 -3
|
@@ -1,166 +1,172 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: infra-github-actions
|
|
3
|
-
description: >
|
|
4
|
-
GitHub Actions CI/CD para proyectos que usan swl-ses. Cubre los tres workflows
|
|
5
|
-
distribuidos (swl-security.yml, swl-ci.yml, release-please.yml), setup del secret
|
|
6
|
-
CLAUDE_API_KEY, branch protection y troubleshooting. Cargar cuando se configura
|
|
7
|
-
CI/CD con GitHub Actions en un proyecto donde está instalado swl-ses.
|
|
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
|
-
con
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
Fix:
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
1
|
+
---
|
|
2
|
+
name: infra-github-actions
|
|
3
|
+
description: >
|
|
4
|
+
GitHub Actions CI/CD para proyectos que usan swl-ses. Cubre los tres workflows
|
|
5
|
+
distribuidos (swl-security.yml, swl-ci.yml, release-please.yml), setup del secret
|
|
6
|
+
CLAUDE_API_KEY, branch protection y troubleshooting. Cargar cuando se configura
|
|
7
|
+
CI/CD con GitHub Actions en un proyecto donde está instalado swl-ses.
|
|
8
|
+
version: "1.0.0"
|
|
9
|
+
exclusiones:
|
|
10
|
+
- "No cargar para otros sistemas CI/CD (GitLab CI, CircleCI, Jenkins) — este skill cubre solo GitHub Actions; para GitLab usar el workflow YAML estándar de GitLab."
|
|
11
|
+
- "No cargar para configuración de pipelines internos del repo swl-ses — esos están en .github/workflows/ y no son distribuibles a usuarios."
|
|
12
|
+
- "No cargar para troubleshooting de runners self-hosted — este skill asume GitHub-hosted runners; runners propios requieren guía aparte."
|
|
13
|
+
- "No cargar para definir nuevos workflows desde cero sin relación con swl-security/swl-ci/release-please — para workflows custom usar la documentación oficial de GitHub Actions."
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
# infra-github-actions — GitHub Actions con swl-ses
|
|
17
|
+
|
|
18
|
+
## Cuándo cargar
|
|
19
|
+
|
|
20
|
+
- Al ejecutar `/swl:configurar-ci init` y necesitar guía de setup
|
|
21
|
+
- Al depurar un workflow que no dispara o falla por API key
|
|
22
|
+
- Al configurar branch protection en el proyecto
|
|
23
|
+
- Al decidir si adoptar release-please vs el flujo manual actual
|
|
24
|
+
|
|
25
|
+
## Cuándo NO cargar
|
|
26
|
+
|
|
27
|
+
- El proyecto usa Azure DevOps Pipelines o GitLab CI — esos tienen su propia configuración
|
|
28
|
+
- El objetivo es Kubernetes, Terraform o infraestructura cloud (cargar `kubernetes-orquestacion` o `terraform-experto`)
|
|
29
|
+
- La tarea es solo correr tests localmente sin CI
|
|
30
|
+
- El proyecto no usa GitHub como repositorio
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
|
|
34
|
+
## Workflows distribuidos por swl-ses
|
|
35
|
+
|
|
36
|
+
| Archivo | Propósito | Secrets requeridos |
|
|
37
|
+
|---------|-----------|-------------------|
|
|
38
|
+
| `swl-security.yml` | Revisión semántica de seguridad con Claude en cada PR | `CLAUDE_API_KEY` |
|
|
39
|
+
| `swl-ci.yml` | Lint + tests en push y PRs. Node 22+24, Python/Rust/Go comentados | Ninguno |
|
|
40
|
+
| `release-please.yml` | Release PR automático + tag + GitHub Release | Ninguno (`GITHUB_TOKEN` automático) |
|
|
41
|
+
|
|
42
|
+
Instalación con: `/swl:configurar-ci init`
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## Reglas obligatorias
|
|
47
|
+
|
|
48
|
+
**NUNCA** commitear API keys en código ni en archivos de workflow.
|
|
49
|
+
Todo secret va en GitHub Settings → Secrets and variables → Actions.
|
|
50
|
+
|
|
51
|
+
**Permisos mínimos siempre**: declarar solo `contents: read` y `pull-requests: write`
|
|
52
|
+
en el nivel del workflow. Nunca `permissions: write-all`.
|
|
53
|
+
|
|
54
|
+
**Los workflows de forks externos no reciben secrets** por diseño de GitHub.
|
|
55
|
+
La revisión de seguridad con Claude solo funciona en PRs desde ramas del mismo repo,
|
|
56
|
+
no desde repos forked. Es un comportamiento de GitHub, no un bug.
|
|
57
|
+
|
|
58
|
+
**No hardcodear nombres de rama** más allá de `main`. Si el proyecto usa otra rama
|
|
59
|
+
por defecto, editar el `on: push: branches` en los workflows copiados.
|
|
60
|
+
|
|
61
|
+
---
|
|
62
|
+
|
|
63
|
+
## Setup de CLAUDE_API_KEY
|
|
64
|
+
|
|
65
|
+
1. Ir a https://console.anthropic.com y crear o copiar la API key
|
|
66
|
+
2. En GitHub: Settings → Secrets and variables → Actions → New repository secret
|
|
67
|
+
- Nombre: `CLAUDE_API_KEY`
|
|
68
|
+
- Valor: la API key
|
|
69
|
+
3. La key necesita permisos tanto para Claude API como para Claude Code
|
|
70
|
+
|
|
71
|
+
Verificar con gh CLI si el secret ya existe:
|
|
72
|
+
```bash
|
|
73
|
+
gh secret list | grep CLAUDE_API_KEY
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
Para configurar vía CLI (valor desde stdin, no queda en historial):
|
|
77
|
+
```bash
|
|
78
|
+
gh secret set CLAUDE_API_KEY
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
---
|
|
82
|
+
|
|
83
|
+
## Branch protection
|
|
84
|
+
|
|
85
|
+
Aplicar después de tener CI funcionando. El script del repo swl-ses:
|
|
86
|
+
|
|
87
|
+
```bash
|
|
88
|
+
# Ver qué haría sin aplicar cambios
|
|
89
|
+
node scripts/configurar-branch-protection.js --dry-run
|
|
90
|
+
|
|
91
|
+
# Aplicar
|
|
92
|
+
node scripts/configurar-branch-protection.js
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
Requiere `gh` CLI autenticado y permisos de admin en el repositorio.
|
|
96
|
+
|
|
97
|
+
Configura: require PR, status checks (`test (22)`, `test (24)`, `smoke`),
|
|
98
|
+
1 approval, bloquea force-push y deletions.
|
|
99
|
+
|
|
100
|
+
---
|
|
101
|
+
|
|
102
|
+
## Adoptar release-please (opt-in)
|
|
103
|
+
|
|
104
|
+
Ver `docs/RELEASE-PLEASE-MIGRATION.md` para comparativa completa.
|
|
105
|
+
|
|
106
|
+
El flujo actual del repo swl-ses usa `scripts/publicar.js` (manual). release-please
|
|
107
|
+
es una alternativa automática viable para proyectos de usuarios.
|
|
108
|
+
|
|
109
|
+
Instalar:
|
|
110
|
+
```
|
|
111
|
+
/swl:configurar-ci --with-release-please
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
Una vez activo, el flujo es:
|
|
115
|
+
1. Hacer merge de commits convencionales a main
|
|
116
|
+
2. release-please abre un "Release PR" automático con bump de versión y CHANGELOG
|
|
117
|
+
3. Al mergear ese PR → tag git + GitHub Release creado automáticamente
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
## Gotchas / Errores comunes no obvios
|
|
122
|
+
|
|
123
|
+
**GitHub Free + repo privado → 403 en branch protection Y Rulesets**: tanto el endpoint legacy
|
|
124
|
+
`/repos/.../branches/{}/protection` como el endpoint moderno `/repos/.../rulesets` requieren
|
|
125
|
+
**plan de pago** en repos privados (HTTP 403 "Upgrade to GitHub Pro or make this repository public"
|
|
126
|
+
en ambos). Mi documentación inicial afirmó incorrectamente que Rulesets era gratis para repos
|
|
127
|
+
privados Free — verificación empírica posterior confirmó que NO. Ambos endpoints están bloqueados.
|
|
128
|
+
|
|
129
|
+
Planes que destraban la feature en privado:
|
|
130
|
+
- **Pro** ($4/mes): aplica a repos en cuenta personal del titular Pro.
|
|
131
|
+
- **Team** ($4/usuario/mes): aplica solo a repos **de la organización** que paga Team. NO aplica
|
|
132
|
+
a repos en la cuenta personal del admin de la org. Para que Team aplique al repo, transferirlo:
|
|
133
|
+
`gh repo transfer cuenta-personal/repo --new-owner org`.
|
|
134
|
+
|
|
135
|
+
Sin plan de pago y manteniendo repo privado, las opciones son: pre-push hook local
|
|
136
|
+
(bypasseable con `--no-verify`) y workflow advisory (no bloquea push, crea issue post-hoc).
|
|
137
|
+
|
|
138
|
+
**Push directo a main bloqueado tras activar branch protection**: si configuraste
|
|
139
|
+
branch protection antes de que tu usuario tuviera al menos un PR mergeado con los
|
|
140
|
+
status checks pasando, el repo puede quedar en estado donde nadie puede mergear.
|
|
141
|
+
Causa: GitHub verifica los status checks declarados antes de permitir el merge; si
|
|
142
|
+
los checks no han corrido en el branch, el botón de merge queda bloqueado.
|
|
143
|
+
Fix: crear una rama temporal con un cambio trivial, abrir PR, dejar que los checks
|
|
144
|
+
corran, y mergear. Luego ya funciona el flujo normal.
|
|
145
|
+
|
|
146
|
+
**GITHUB_TOKEN no puede aprobar su propio PR** al usar release-please: release-please
|
|
147
|
+
crea un Release PR con el GITHUB_TOKEN del bot — ese mismo token no puede aprobarlo
|
|
148
|
+
si el repo requiere al menos 1 approval humano. Causa: GitHub bloquea la auto-aprobación
|
|
149
|
+
con el token de Actions por defecto.
|
|
150
|
+
Fix: crear un Personal Access Token (PAT) con scope `repo` y usarlo en el workflow:
|
|
151
|
+
`token: ${{ secrets.MY_RELEASE_TOKEN }}`. O reducir el required approvals a 0 para
|
|
152
|
+
el Release PR (no recomendado en repos con múltiples contribuidores).
|
|
153
|
+
|
|
154
|
+
**`anthropics/claude-code-security-review@main` falla con "API key not set"**: el
|
|
155
|
+
secret `CLAUDE_API_KEY` no está configurado o el nombre no coincide exactamente.
|
|
156
|
+
La action es sensible a mayúsculas — `claude_api_key` (minúsculas) no funciona.
|
|
157
|
+
Fix: verificar con `gh secret list`. El nombre debe ser exactamente `CLAUDE_API_KEY`.
|
|
158
|
+
|
|
159
|
+
**El workflow `swl-ci.yml` pasa localmente pero falla en CI con "lint script not found"**:
|
|
160
|
+
el campo `lint` no está definido en `package.json` del proyecto del usuario. La plantilla
|
|
161
|
+
usa `npm run lint --if-present` precisamente para ser tolerante, pero si el proyecto
|
|
162
|
+
tiene un nombre distinto (ej: `eslint`, `check`) el step se salta silenciosamente.
|
|
163
|
+
Fix: agregar el script `"lint": "..."` en `package.json` o editar el workflow para usar
|
|
164
|
+
el nombre correcto.
|
|
165
|
+
|
|
166
|
+
**release-please genera changelog con commits `chore(release)` del repo padre swl-ses**:
|
|
167
|
+
si el proyecto del usuario adoptó los mensajes de commit de swl-ses que incluyen
|
|
168
|
+
`chore(release): v5.X.Y`, release-please los interpreta como commits de release
|
|
169
|
+
y puede generar bumps incorrectos.
|
|
170
|
+
Fix: usar mensajes de commit convencionales estándar para el proyecto del usuario,
|
|
171
|
+
separados del estilo de swl-ses. Los prefijos `feat:`, `fix:`, `chore:` sin el
|
|
172
|
+
patrón `(release): vX.Y.Z` no causan conflicto.
|
|
@@ -272,6 +272,12 @@ el contenido específico, sin inflar el contexto con cada invocación:
|
|
|
272
272
|
valor depende de mostrar diff MAL→BIEN lado a lado (decisiones, arquitectura,
|
|
273
273
|
anti-patrones sutiles). NO retroactiva — las 63 carpetas `recursos/` existentes
|
|
274
274
|
no se renombran. Ver [recursos/convencion-examples.md](recursos/convencion-examples.md).
|
|
275
|
+
- **Rúbrica skill-judge (Knowledge Delta + Freedom Calibration + 5 patrones)** —
|
|
276
|
+
tres lentes complementarios a las 10 dimensiones de `/swl:evaluar-skill`
|
|
277
|
+
para autoría: detectar contenido redundante, matchear libertad a fragilidad,
|
|
278
|
+
elegir patrón estructural al inicio. NO reemplaza el gate `/swl:evaluar-skill`;
|
|
279
|
+
aplica durante la escritura. Ver [recursos/skill-judge-rubrica.md](recursos/skill-judge-rubrica.md).
|
|
280
|
+
Origen: ADR-0024.
|
|
275
281
|
|
|
276
282
|
Cada recurso tiene ToC al inicio y es autocontenido — leer solo el relevante
|
|
277
283
|
al caso en cuestión en lugar de los tres.
|
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
# Rúbrica skill-judge — 3 dimensiones complementarias a `evaluar-skill`
|
|
2
|
+
|
|
3
|
+
Recurso opcional que se carga bajo demanda cuando se autora un SKILL.md y se
|
|
4
|
+
quieren aplicar tres lentes adicionales que el comando `/swl:evaluar-skill`
|
|
5
|
+
no mide directamente. Adaptación de la rúbrica `skill-judge` (agent-toolkit,
|
|
6
|
+
8 dimensiones × 120 puntos) para complementar las 10 dimensiones ponderadas
|
|
7
|
+
del comando SWL.
|
|
8
|
+
|
|
9
|
+
**Origen**: análisis comparativo documentado en ADR-0024 — Opción B.
|
|
10
|
+
**NO reemplaza** `/swl:evaluar-skill`; añade tres lentes de autoría que el
|
|
11
|
+
comando deja fuera por ser difíciles de medir programáticamente.
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Por qué este recurso existe
|
|
16
|
+
|
|
17
|
+
El comando `/swl:evaluar-skill` mide 10 dimensiones que cubren bien:
|
|
18
|
+
trigger, orquestación, scope, progressive disclosure, robustez, completitud
|
|
19
|
+
estructural. Tras comparar con la rúbrica de 8 dimensiones de
|
|
20
|
+
`temp/agent-toolkit/skills/skill-judge/`, detecté tres lentes que aporta
|
|
21
|
+
valor agregado al **autor del skill**, no al evaluador automático:
|
|
22
|
+
|
|
23
|
+
| Lente skill-judge | Por qué falta en SWL | Cuándo aporta |
|
|
24
|
+
|---|---|---|
|
|
25
|
+
| **Knowledge Delta** | Difícil de medir programáticamente | Al escribir skill nuevo: detectar contenido redundante |
|
|
26
|
+
| **Freedom Calibration** | Subjetivo (alta/media/baja libertad) | Al elegir nivel de prescripción según fragilidad |
|
|
27
|
+
| **Pattern Recognition (5 patrones)** | Clasificación, no calidad | Al elegir estructura del skill al inicio |
|
|
28
|
+
|
|
29
|
+
Estas tres dimensiones se aplican durante la **autoría**, no la **evaluación
|
|
30
|
+
final**. Para el gate de calidad sigue usándose `/swl:evaluar-skill`.
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
|
|
34
|
+
## Lente 1 — Knowledge Delta
|
|
35
|
+
|
|
36
|
+
> **Buen Skill = Conocimiento de experto − lo que el modelo ya sabe.**
|
|
37
|
+
|
|
38
|
+
El valor de un skill se mide por su **delta de conocimiento** — la brecha
|
|
39
|
+
entre lo que provee y lo que el modelo ya tiene en sus pesos.
|
|
40
|
+
|
|
41
|
+
### Las 3 categorías de contenido
|
|
42
|
+
|
|
43
|
+
| Tipo | Definición | Tratamiento |
|
|
44
|
+
|------|-----------|-------------|
|
|
45
|
+
| **Expert** | El modelo genuinamente no lo sabe | Mantener — es el valor del skill |
|
|
46
|
+
| **Activation** | El modelo lo sabe pero podría no pensar en ello | Mantener si es breve — funciona como recordatorio |
|
|
47
|
+
| **Redundant** | El modelo definitivamente lo sabe | Borrar — desperdicia tokens |
|
|
48
|
+
|
|
49
|
+
### Red flags (contenido a borrar agresivamente)
|
|
50
|
+
|
|
51
|
+
- "¿Qué es [concepto básico]?" — el modelo lo sabe.
|
|
52
|
+
- Tutoriales paso a paso para operaciones estándar (open file, read, write).
|
|
53
|
+
- Explicaciones de uso de librerías comunes (cómo usar `requests`,
|
|
54
|
+
`fetch`, etc.).
|
|
55
|
+
- Best practices genéricas ("escribe código limpio", "maneja errores").
|
|
56
|
+
- Definiciones de términos estándar de la industria.
|
|
57
|
+
|
|
58
|
+
### Green flags (contenido de alto valor)
|
|
59
|
+
|
|
60
|
+
- Decision trees para decisiones no obvias ("cuando X falla, intenta Y
|
|
61
|
+
porque Z").
|
|
62
|
+
- Trade-offs que solo un experto conoce ("A es más rápido pero B maneja
|
|
63
|
+
el edge case C").
|
|
64
|
+
- Edge cases de experiencia real ("MissingGreenlet pasa cuando…").
|
|
65
|
+
- "NEVER hagas X porque [razón no obvia]".
|
|
66
|
+
- Frameworks de pensamiento específicos del dominio.
|
|
67
|
+
|
|
68
|
+
### Test mental
|
|
69
|
+
|
|
70
|
+
Al revisar cada sección de tu SKILL.md, preguntar:
|
|
71
|
+
|
|
72
|
+
1. *¿El modelo ya sabe esto?* Si sí → marcar como Redundant, borrar.
|
|
73
|
+
2. *¿Esto explica TO el modelo o FOR el modelo?* TO = redundant; FOR = valor.
|
|
74
|
+
3. Calcular ratio E:A:R. Bueno: >70% Expert, <20% Activation, <10% Redundant.
|
|
75
|
+
|
|
76
|
+
### Conexión con `reducir-entropia`
|
|
77
|
+
|
|
78
|
+
El skill SWL `reducir-entropia` aplica el mismo principio al codebase
|
|
79
|
+
(menos líneas finales = win). Knowledge delta lo aplica al SKILL.md
|
|
80
|
+
(menos tokens redundantes = win). Mismo lente, distinto target.
|
|
81
|
+
|
|
82
|
+
---
|
|
83
|
+
|
|
84
|
+
## Lente 2 — Freedom Calibration
|
|
85
|
+
|
|
86
|
+
> **Match freedom to fragility.**
|
|
87
|
+
|
|
88
|
+
Diferentes tareas requieren diferentes niveles de restricción en el skill.
|
|
89
|
+
|
|
90
|
+
### El espectro
|
|
91
|
+
|
|
92
|
+
| Tipo de tarea | Debería tener | Por qué |
|
|
93
|
+
|---|---|---|
|
|
94
|
+
| Creativo / Diseño | Alta libertad | Múltiples caminos válidos; diferenciación es el valor |
|
|
95
|
+
| Code review | Libertad media | Hay principios, pero juicio requerido |
|
|
96
|
+
| Operaciones en formato de archivo | Baja libertad | Un byte mal corrompe el archivo |
|
|
97
|
+
|
|
98
|
+
### Ejemplos
|
|
99
|
+
|
|
100
|
+
**Alta libertad** (principios, no pasos):
|
|
101
|
+
|
|
102
|
+
```markdown
|
|
103
|
+
Commit a una dirección estética BOLD. Elige un extremo: minimalismo
|
|
104
|
+
brutal, caos maximalista, retro-futurista, orgánico natural…
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
**Libertad media** (priorización + criterio):
|
|
108
|
+
|
|
109
|
+
```markdown
|
|
110
|
+
Prioridad de revisión:
|
|
111
|
+
1. Vulnerabilidades de seguridad (must fix)
|
|
112
|
+
2. Errores de lógica (must fix)
|
|
113
|
+
3. Performance (should fix)
|
|
114
|
+
4. Mantenibilidad (opcional)
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
**Baja libertad** (script exacto):
|
|
118
|
+
|
|
119
|
+
```markdown
|
|
120
|
+
**OBLIGATORIO**: usar exactamente `scripts/create-doc.py` con parámetros
|
|
121
|
+
`--title "X" --author "Y"`. NO modificar el script.
|
|
122
|
+
```
|
|
123
|
+
|
|
124
|
+
### Test
|
|
125
|
+
|
|
126
|
+
Pregunta: *si el modelo comete error, ¿cuál es la consecuencia?*
|
|
127
|
+
|
|
128
|
+
- Consecuencia alta → libertad baja (prescriptivo).
|
|
129
|
+
- Consecuencia baja → libertad alta (principios).
|
|
130
|
+
|
|
131
|
+
### Errores comunes de calibración
|
|
132
|
+
|
|
133
|
+
- **Rígido para tarea creativa**: skill que prescribe paso a paso una
|
|
134
|
+
decisión estética destruye el valor del skill.
|
|
135
|
+
- **Vago para operación frágil**: skill que dice "ten cuidado al editar
|
|
136
|
+
XML" sin reglas exactas garantiza archivos corruptos.
|
|
137
|
+
|
|
138
|
+
---
|
|
139
|
+
|
|
140
|
+
## Lente 3 — Patrones reconocibles (5 patrones del agent-toolkit)
|
|
141
|
+
|
|
142
|
+
Al elegir la **estructura** de un skill nuevo, identificar a cuál de
|
|
143
|
+
estos 5 patrones se ajusta. Ayuda a calibrar tamaño y profundidad.
|
|
144
|
+
|
|
145
|
+
| Patrón | Líneas | Características clave | Cuándo usarlo |
|
|
146
|
+
|---|---|---|---|
|
|
147
|
+
| **Mindset** | ~50 | Pensamiento > técnica, NEVER list fuerte, alta libertad | Tareas creativas que requieren gusto |
|
|
148
|
+
| **Navigation** | ~30 | SKILL.md mínimo, rutea a sub-archivos en `recursos/` | Múltiples escenarios distintos |
|
|
149
|
+
| **Philosophy** | ~150 | Dos pasos: Filosofía → Express, enfatiza craft | Arte/creación que requiere originalidad |
|
|
150
|
+
| **Process** | ~200 | Workflow por fases, checkpoints, libertad media | Proyectos multi-paso complejos |
|
|
151
|
+
| **Tool** | ~300 | Decision trees, ejemplos de código, libertad baja | Operaciones precisas en formato específico |
|
|
152
|
+
|
|
153
|
+
### Guía de selección
|
|
154
|
+
|
|
155
|
+
| Tu tarea es… | Patrón recomendado |
|
|
156
|
+
|---|---|
|
|
157
|
+
| Requiere gusto y creatividad | Mindset (~50 líneas) |
|
|
158
|
+
| Requiere originalidad y craft quality | Philosophy (~150 líneas) |
|
|
159
|
+
| Tiene múltiples sub-escenarios distintos | Navigation (~30 líneas) |
|
|
160
|
+
| Proyecto complejo multi-paso | Process (~200 líneas) |
|
|
161
|
+
| Operación precisa en formato específico | Tool (~300 líneas) |
|
|
162
|
+
|
|
163
|
+
### Mapeo a skills SWL existentes (referencia)
|
|
164
|
+
|
|
165
|
+
- `meta-skills-estandar` — Philosophy/Process (526 líneas; rebasa el ideal
|
|
166
|
+
pero contiene 5 secciones extendidas justificadas por ADR).
|
|
167
|
+
- `tdd-workflow` — Process.
|
|
168
|
+
- `verificar-trabajo` — Process con decision trees.
|
|
169
|
+
- `discutir-fase` — Process.
|
|
170
|
+
- `reducir-entropia` — Mindset (~200 líneas, anti-patrón consciente).
|
|
171
|
+
- `proceso-confianza-pre-implementacion` — Process.
|
|
172
|
+
- `proceso-autoverificacion-evidencias` — Process.
|
|
173
|
+
- `aprender-de-git-diff` — Mindset/Process híbrido.
|
|
174
|
+
- Skills de formato de archivo (cuando aplique) — Tool.
|
|
175
|
+
|
|
176
|
+
---
|
|
177
|
+
|
|
178
|
+
## Las 7 fallas comunes (Common Failure Patterns)
|
|
179
|
+
|
|
180
|
+
Adaptado de skill-judge "Common Failure Patterns". Si tu skill cae en uno
|
|
181
|
+
de estos, refactorizar antes de mergear.
|
|
182
|
+
|
|
183
|
+
### 1. The Tutorial
|
|
184
|
+
|
|
185
|
+
**Síntoma**: explica qué es PDF, cómo funciona Python, uso básico de librería.
|
|
186
|
+
**Causa**: autor asume que el skill debe "enseñar" al modelo.
|
|
187
|
+
**Fix**: el modelo ya sabe esto. Borrar todas las explicaciones básicas.
|
|
188
|
+
Enfocar en decisiones de experto, trade-offs, anti-patrones.
|
|
189
|
+
|
|
190
|
+
### 2. The Dump
|
|
191
|
+
|
|
192
|
+
**Síntoma**: SKILL.md de 800+ líneas con todo incluido.
|
|
193
|
+
**Causa**: sin diseño de progressive disclosure.
|
|
194
|
+
**Fix**: routing y decision trees en SKILL.md (<300 líneas ideal). Contenido
|
|
195
|
+
detallado a `recursos/`, cargado bajo demanda.
|
|
196
|
+
|
|
197
|
+
### 3. The Orphan References
|
|
198
|
+
|
|
199
|
+
**Síntoma**: directorio `recursos/` existe pero los archivos nunca se cargan.
|
|
200
|
+
**Causa**: sin triggers explícitos de carga.
|
|
201
|
+
**Fix**: agregar "OBLIGATORIO — LEER ARCHIVO COMPLETO" en puntos de
|
|
202
|
+
decisión del workflow. Agregar "NO cargar" para prevenir sobre-carga.
|
|
203
|
+
|
|
204
|
+
### 4. The Checkbox Procedure
|
|
205
|
+
|
|
206
|
+
**Síntoma**: Paso 1, Paso 2, Paso 3… procedimientos mecánicos.
|
|
207
|
+
**Causa**: autor piensa en procedimientos, no en frameworks de pensamiento.
|
|
208
|
+
**Fix**: transformar en "Antes de hacer X, pregúntate…". Enfocar en
|
|
209
|
+
principios de decisión, no secuencias de operación.
|
|
210
|
+
|
|
211
|
+
### 5. The Vague Warning
|
|
212
|
+
|
|
213
|
+
**Síntoma**: "Ten cuidado", "evita errores", "considera edge cases".
|
|
214
|
+
**Causa**: autor sabe que cosas pueden salir mal pero no las articuló.
|
|
215
|
+
**Fix**: NEVER list específico con ejemplos concretos y razones no obvias.
|
|
216
|
+
"NEVER uses X porque [problema específico que solo experiencia enseña]".
|
|
217
|
+
|
|
218
|
+
### 6. The Invisible Skill
|
|
219
|
+
|
|
220
|
+
**Síntoma**: gran contenido pero el skill raramente se activa.
|
|
221
|
+
**Causa**: description vaga, sin keywords, sin trigger scenarios.
|
|
222
|
+
**Fix**: description responde WHAT + WHEN + KEYWORDS. "Usar cuando…" +
|
|
223
|
+
escenarios específicos + términos buscables.
|
|
224
|
+
|
|
225
|
+
### 7. The Over-Engineered
|
|
226
|
+
|
|
227
|
+
**Síntoma**: README.md, CHANGELOG.md, INSTALLATION_GUIDE.md, CONTRIBUTING.md
|
|
228
|
+
dentro del directorio del skill.
|
|
229
|
+
**Causa**: tratar al skill como proyecto de software.
|
|
230
|
+
**Fix**: borrar todos los archivos auxiliares. Solo incluir lo que el
|
|
231
|
+
modelo necesita para la tarea. Cero documentación sobre el skill mismo.
|
|
232
|
+
|
|
233
|
+
---
|
|
234
|
+
|
|
235
|
+
## NUNCA al evaluar (skill-judge)
|
|
236
|
+
|
|
237
|
+
- **NUNCA** dar score alto solo porque "se ve profesional" o bien formateado.
|
|
238
|
+
- **NUNCA** ignorar token waste — cada párrafo redundante penaliza.
|
|
239
|
+
- **NUNCA** dejar que la longitud te impresione — un skill de 43 líneas
|
|
240
|
+
puede superar a uno de 500.
|
|
241
|
+
- **NUNCA** saltarse el test mental de los decision trees — ¿realmente
|
|
242
|
+
llevan a la elección correcta?
|
|
243
|
+
- **NUNCA** perdonar explicaciones básicas con "pero da contexto útil".
|
|
244
|
+
- **NUNCA** subvalorar el campo `description` — pobre description = skill
|
|
245
|
+
nunca se activa.
|
|
246
|
+
|
|
247
|
+
---
|
|
248
|
+
|
|
249
|
+
## La pregunta meta
|
|
250
|
+
|
|
251
|
+
Al revisar cualquier skill, regresar a:
|
|
252
|
+
|
|
253
|
+
> **"¿Un experto en este dominio, mirando este skill, diría: 'sí, esto
|
|
254
|
+
> captura conocimiento que me tomó años aprender'?"**
|
|
255
|
+
|
|
256
|
+
Si la respuesta es sí → valor genuino.
|
|
257
|
+
Si la respuesta es no → comprime lo que el modelo ya sabe → basura.
|
|
258
|
+
|
|
259
|
+
Los mejores skills son **cerebros expertos comprimidos** — toman 10 años
|
|
260
|
+
de acumulación de un diseñador y los comprimen en 43 líneas, o la
|
|
261
|
+
experiencia operacional de un experto en documentos en un decision tree
|
|
262
|
+
de 200 líneas.
|
|
263
|
+
|
|
264
|
+
Lo que se comprime debe ser cosas que el modelo NO tiene. De lo contrario,
|
|
265
|
+
es compresión basura.
|
|
266
|
+
|
|
267
|
+
---
|
|
268
|
+
|
|
269
|
+
## Cómo aplicar este recurso durante autoría
|
|
270
|
+
|
|
271
|
+
1. **Antes de escribir**: identificar patrón (Mindset/Navigation/Philosophy/
|
|
272
|
+
Process/Tool) según la tabla de selección. Esto define tamaño objetivo.
|
|
273
|
+
2. **Durante escritura**: aplicar Freedom Calibration — match libertad a
|
|
274
|
+
fragilidad.
|
|
275
|
+
3. **Después de primera versión**: pasar el lente de Knowledge Delta sección
|
|
276
|
+
por sección. Marcar E/A/R. Borrar Redundant agresivamente.
|
|
277
|
+
4. **Antes de commit**: revisar contra las 7 fallas comunes.
|
|
278
|
+
5. **Antes de merge**: ejecutar `/swl:evaluar-skill <nombre>` para el score
|
|
279
|
+
formal de las 10 dimensiones SWL.
|
|
280
|
+
|
|
281
|
+
Los 3 lentes de este recurso son aditivos al gate formal. No lo reemplazan.
|