@saulwade/swl-ses 1.0.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 (702) hide show
  1. package/CLAUDE.md +238 -0
  2. package/README.md +560 -0
  3. package/_userland/agentes/.gitkeep +0 -0
  4. package/_userland/habilidades/.gitkeep +0 -0
  5. package/agentes/.evolved.json +9 -0
  6. package/agentes/accesibilidad-wcag-swl.md +692 -0
  7. package/agentes/arquitecto-swl.md +238 -0
  8. package/agentes/auto-evolucion-swl.md +854 -0
  9. package/agentes/backend-api-swl.md +470 -0
  10. package/agentes/backend-csharp-swl.md +418 -0
  11. package/agentes/backend-go-swl.md +388 -0
  12. package/agentes/backend-java-swl.md +279 -0
  13. package/agentes/backend-node-swl.md +477 -0
  14. package/agentes/backend-python-swl.md +608 -0
  15. package/agentes/backend-rust-swl.md +362 -0
  16. package/agentes/backend-workers-swl.md +480 -0
  17. package/agentes/cloud-infra-swl.md +485 -0
  18. package/agentes/consolidador-swl.md +539 -0
  19. package/agentes/datos-swl.md +584 -0
  20. package/agentes/depurador-swl.md +349 -0
  21. package/agentes/devops-ci-swl.md +374 -0
  22. package/agentes/disenador-ui-swl.md +558 -0
  23. package/agentes/documentador-swl.md +343 -0
  24. package/agentes/evals/arquitecto-swl.evals.json +56 -0
  25. package/agentes/evals/auto-evolucion-swl.evals.json +68 -0
  26. package/agentes/evals/implementador-swl.evals.json +56 -0
  27. package/agentes/evals/orquestador-swl.evals.json +60 -0
  28. package/agentes/evals/perfilador-usuario-swl.evals.json +60 -0
  29. package/agentes/evals/red-team-swl.evals.json +59 -0
  30. package/agentes/evals/revisor-codigo-swl.evals.json +59 -0
  31. package/agentes/frontend-angular-swl.md +627 -0
  32. package/agentes/frontend-css-swl.md +720 -0
  33. package/agentes/frontend-react-swl.md +696 -0
  34. package/agentes/frontend-swl.md +500 -0
  35. package/agentes/frontend-tailwind-swl.md +830 -0
  36. package/agentes/implementador-swl.md +328 -0
  37. package/agentes/investigador-swl.md +430 -0
  38. package/agentes/investigador-ux-swl.md +500 -0
  39. package/agentes/llm-apps-swl.md +276 -0
  40. package/agentes/migrador-swl.md +417 -0
  41. package/agentes/mobile-android-swl.md +509 -0
  42. package/agentes/mobile-cross-swl.md +539 -0
  43. package/agentes/mobile-ios-swl.md +500 -0
  44. package/agentes/mobile-testing-swl.md +300 -0
  45. package/agentes/notificador-swl.md +916 -0
  46. package/agentes/observabilidad-swl.md +436 -0
  47. package/agentes/orquestador-swl.md +884 -0
  48. package/agentes/pagos-swl.md +283 -0
  49. package/agentes/perfilador-usuario-swl.md +306 -0
  50. package/agentes/planificador-swl.md +402 -0
  51. package/agentes/producto-prd-swl.md +587 -0
  52. package/agentes/red-team-swl.md +216 -0
  53. package/agentes/release-manager-swl.md +568 -0
  54. package/agentes/rendimiento-swl.md +714 -0
  55. package/agentes/resolutor-build-swl.md +243 -0
  56. package/agentes/revisor-angular-swl.md +276 -0
  57. package/agentes/revisor-codigo-swl.md +348 -0
  58. package/agentes/revisor-csharp-swl.md +262 -0
  59. package/agentes/revisor-go-swl.md +257 -0
  60. package/agentes/revisor-java-swl.md +255 -0
  61. package/agentes/revisor-kotlin-swl.md +271 -0
  62. package/agentes/revisor-nextjs-swl.md +279 -0
  63. package/agentes/revisor-php-swl.md +269 -0
  64. package/agentes/revisor-react-swl.md +276 -0
  65. package/agentes/revisor-rust-swl.md +344 -0
  66. package/agentes/revisor-seguridad-swl.md +390 -0
  67. package/agentes/revisor-swift-swl.md +266 -0
  68. package/agentes/revisor-typescript-swl.md +344 -0
  69. package/agentes/sre-swl.md +265 -0
  70. package/agentes/tdd-qa-swl.md +354 -0
  71. package/agentes/ux-disenador-swl.md +501 -0
  72. package/bin/lib/bot-comandos.js +1030 -0
  73. package/bin/lib/bot-discovery.js +182 -0
  74. package/bin/lib/bot-git.js +142 -0
  75. package/bin/swl-ses.js +325 -0
  76. package/bin/swl-telegram-bot.js +442 -0
  77. package/bin/swl-telegram-bot.plist +21 -0
  78. package/bin/swl-telegram-bot.service +14 -0
  79. package/comandos/swl/.evolved.json +23 -0
  80. package/comandos/swl/actualizar.md +174 -0
  81. package/comandos/swl/adoptar-proyecto.md +207 -0
  82. package/comandos/swl/aprender.md +701 -0
  83. package/comandos/swl/auditar-deps.md +134 -0
  84. package/comandos/swl/autoresearch.md +170 -0
  85. package/comandos/swl/ayuda.md +224 -0
  86. package/comandos/swl/brainstorm.md +50 -0
  87. package/comandos/swl/checkpoint.md +330 -0
  88. package/comandos/swl/compactar.md +283 -0
  89. package/comandos/swl/configurar-ci.md +227 -0
  90. package/comandos/swl/contexto.md +112 -0
  91. package/comandos/swl/contribuir.md +233 -0
  92. package/comandos/swl/crear-skill.md +292 -0
  93. package/comandos/swl/cron.md +196 -0
  94. package/comandos/swl/dashboard.md +146 -0
  95. package/comandos/swl/discutir-fase.md +230 -0
  96. package/comandos/swl/ejecutar-fase.md +135 -0
  97. package/comandos/swl/evaluar-skill.md +487 -0
  98. package/comandos/swl/evolucion-estado.md +142 -0
  99. package/comandos/swl/evolucionar.md +259 -0
  100. package/comandos/swl/exportar-vault.md +189 -0
  101. package/comandos/swl/gateway.md +158 -0
  102. package/comandos/swl/inbox.md +116 -0
  103. package/comandos/swl/instalar.md +220 -0
  104. package/comandos/swl/instintos.md +86 -0
  105. package/comandos/swl/mapear-codebase.md +312 -0
  106. package/comandos/swl/mcp-status.md +175 -0
  107. package/comandos/swl/metricas.md +270 -0
  108. package/comandos/swl/modelo.md +102 -0
  109. package/comandos/swl/notificaciones.md +396 -0
  110. package/comandos/swl/nuevo-proyecto.md +154 -0
  111. package/comandos/swl/planear-fase.md +221 -0
  112. package/comandos/swl/plugins.md +256 -0
  113. package/comandos/swl/reflect-skills.md +125 -0
  114. package/comandos/swl/release.md +217 -0
  115. package/comandos/swl/revisar-impacto.md +206 -0
  116. package/comandos/swl/revisar.md +330 -0
  117. package/comandos/swl/salud.md +363 -0
  118. package/comandos/swl/sesiones.md +200 -0
  119. package/comandos/swl/skill-search.md +113 -0
  120. package/comandos/swl/verificar.md +585 -0
  121. package/comandos/swl/wiki.md +620 -0
  122. package/contextos/dev.md +32 -0
  123. package/contextos/research.md +30 -0
  124. package/contextos/review.md +31 -0
  125. package/habilidades/accesibilidad-a11y/SKILL.md +201 -0
  126. package/habilidades/accesibilidad-a11y/evals/evals.json +56 -0
  127. package/habilidades/accesibilidad-a11y/recursos/ejemplos-y-checklist-completo.md +441 -0
  128. package/habilidades/agent-browser/SKILL.md +218 -0
  129. package/habilidades/agentes-como-servicio/SKILL.md +218 -0
  130. package/habilidades/ai-runtime-security/SKILL.md +273 -0
  131. package/habilidades/angular-avanzado/SKILL.md +164 -0
  132. package/habilidades/angular-avanzado/recursos/ejemplos-avanzados.md +219 -0
  133. package/habilidades/angular-moderno/SKILL.md +186 -0
  134. package/habilidades/angular-moderno/evals/evals.json +45 -0
  135. package/habilidades/angular-moderno/recursos/ejemplos-avanzados.md +106 -0
  136. package/habilidades/api-rest-diseno/SKILL.md +191 -0
  137. package/habilidades/api-rest-diseno/recursos/openapi-template.yaml +506 -0
  138. package/habilidades/api-rest-diseno/recursos/referencia-api.md +140 -0
  139. package/habilidades/aprendizaje-continuo/SKILL.md +151 -0
  140. package/habilidades/aprendizaje-continuo/evals/evals.json +53 -0
  141. package/habilidades/aprendizaje-continuo/recursos/referencia-instintos.md +290 -0
  142. package/habilidades/async-python/SKILL.md +149 -0
  143. package/habilidades/async-python/evals/evals.json +47 -0
  144. package/habilidades/async-python/recursos/patrones-y-ejemplos-completos.md +292 -0
  145. package/habilidades/auth-patrones/.evolved.json +9 -0
  146. package/habilidades/auth-patrones/SKILL.md +413 -0
  147. package/habilidades/auth-patrones/recursos/implementaciones-completas.md +229 -0
  148. package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -0
  149. package/habilidades/auto-evolucion-protocolo/evals/evals.json +55 -0
  150. package/habilidades/auto-evolucion-protocolo/recursos/referencia-completa.md +145 -0
  151. package/habilidades/autoresearch/SKILL.md +268 -0
  152. package/habilidades/autoresearch/evals/evals.json +41 -0
  153. package/habilidades/autoresearch/recursos/checklist-template.md +191 -0
  154. package/habilidades/autoresearch/scripts/calcular-score.js +88 -0
  155. package/habilidades/azure-cloud/SKILL.md +308 -0
  156. package/habilidades/azure-cloud/recursos/aks.md +327 -0
  157. package/habilidades/backend-mcp-servidor/SKILL.md +270 -0
  158. package/habilidades/backend-production-resilience/SKILL.md +288 -0
  159. package/habilidades/brainstorming/SKILL.md +295 -0
  160. package/habilidades/brainstorming/recursos/componentes-html.md +247 -0
  161. package/habilidades/build-errors-cpp/SKILL.md +270 -0
  162. package/habilidades/build-errors-csharp/SKILL.md +265 -0
  163. package/habilidades/build-errors-go/SKILL.md +306 -0
  164. package/habilidades/build-errors-java/SKILL.md +278 -0
  165. package/habilidades/build-errors-kotlin/SKILL.md +303 -0
  166. package/habilidades/build-errors-nextjs/SKILL.md +312 -0
  167. package/habilidades/build-errors-php/SKILL.md +270 -0
  168. package/habilidades/build-errors-python/SKILL.md +292 -0
  169. package/habilidades/build-errors-rust/SKILL.md +284 -0
  170. package/habilidades/build-errors-swift/SKILL.md +272 -0
  171. package/habilidades/build-errors-typescript/SKILL.md +369 -0
  172. package/habilidades/checklist-calidad/SKILL.md +271 -0
  173. package/habilidades/checklist-calidad/recursos/quality-report-template.md +148 -0
  174. package/habilidades/checklist-seguridad/SKILL.md +285 -0
  175. package/habilidades/checkpoints-verificacion/SKILL.md +298 -0
  176. package/habilidades/checkpoints-verificacion/recursos/checkpoint-templates.md +360 -0
  177. package/habilidades/ci-cd-pipelines/SKILL.md +157 -0
  178. package/habilidades/ci-cd-pipelines/recursos/github-actions-template.yaml +403 -0
  179. package/habilidades/ci-cd-pipelines/recursos/pipelines-completos.md +487 -0
  180. package/habilidades/cloud-aws/SKILL.md +142 -0
  181. package/habilidades/cloud-aws/recursos/servicios-aws-referencia.md +321 -0
  182. package/habilidades/compactacion-contexto/SKILL.md +247 -0
  183. package/habilidades/contenedores-docker/SKILL.md +137 -0
  184. package/habilidades/contenedores-docker/recursos/dockerfile-template.dockerfile +160 -0
  185. package/habilidades/contenedores-docker/recursos/ejemplos-y-configuraciones.md +327 -0
  186. package/habilidades/context-builder/SKILL.md +170 -0
  187. package/habilidades/control-profundidad/SKILL.md +128 -0
  188. package/habilidades/csharp-experto/SKILL.md +322 -0
  189. package/habilidades/csharp-patrones/SKILL.md +316 -0
  190. package/habilidades/csharp-testing/SKILL.md +286 -0
  191. package/habilidades/css-moderno/SKILL.md +166 -0
  192. package/habilidades/css-moderno/evals/evals.json +43 -0
  193. package/habilidades/css-moderno/recursos/ejemplos-y-patrones-completos.md +337 -0
  194. package/habilidades/datos-etl/SKILL.md +129 -0
  195. package/habilidades/datos-etl/recursos/implementaciones-completas.md +322 -0
  196. package/habilidades/dbml-experto/SKILL.md +339 -0
  197. package/habilidades/dbml-experto/evals/evals.json +56 -0
  198. package/habilidades/dependencias-auditoria/SKILL.md +320 -0
  199. package/habilidades/deprecacion-migracion/SKILL.md +169 -0
  200. package/habilidades/deprecacion-migracion/recursos/implementaciones-completas.md +220 -0
  201. package/habilidades/design-tokens/SKILL.md +158 -0
  202. package/habilidades/design-tokens/recursos/tokens-y-configuracion.md +363 -0
  203. package/habilidades/devsecops-pipeline-security/SKILL.md +309 -0
  204. package/habilidades/diagrama-arquitectura/SKILL.md +165 -0
  205. package/habilidades/diagrama-arquitectura/assets/template.html +276 -0
  206. package/habilidades/discutir-fase/SKILL.md +188 -0
  207. package/habilidades/diseno-herramientas-agente/SKILL.md +199 -0
  208. package/habilidades/diseno-responsivo/SKILL.md +186 -0
  209. package/habilidades/diseno-responsivo/recursos/ejemplos-layouts.md +156 -0
  210. package/habilidades/django-experto/SKILL.md +205 -0
  211. package/habilidades/django-experto/recursos/async-django.md +390 -0
  212. package/habilidades/django-experto/recursos/drf-patrones.md +438 -0
  213. package/habilidades/django-experto/recursos/orm-avanzado.md +382 -0
  214. package/habilidades/django-experto/recursos/referencia-completa.md +188 -0
  215. package/habilidades/django-experto/recursos/testing-django.md +415 -0
  216. package/habilidades/doc-sync/SKILL.md +280 -0
  217. package/habilidades/drift-detection/SKILL.md +179 -0
  218. package/habilidades/ejecutar-fase/SKILL.md +468 -0
  219. package/habilidades/estilo-sin-ai-isms/SKILL.md +775 -0
  220. package/habilidades/estilo-sin-ai-isms/evals/evals.json +63 -0
  221. package/habilidades/estilo-sin-ai-isms/scripts/detectar_aiisms.py +500 -0
  222. package/habilidades/estructura-proyecto-claude/SKILL.md +215 -0
  223. package/habilidades/estructura-proyecto-claude/recursos/claude-md-template.md +261 -0
  224. package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +176 -0
  225. package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +289 -0
  226. package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +77 -0
  227. package/habilidades/estructura-proyecto-claude/recursos/variantes-por-stack.md +177 -0
  228. package/habilidades/evaluacion-agentes/SKILL.md +314 -0
  229. package/habilidades/event-driven/SKILL.md +153 -0
  230. package/habilidades/event-driven/recursos/implementaciones-completas.md +423 -0
  231. package/habilidades/extraccion-documentos/SKILL.md +221 -0
  232. package/habilidades/extractor-de-aprendizajes/.evolved.json +9 -0
  233. package/habilidades/extractor-de-aprendizajes/SKILL.md +311 -0
  234. package/habilidades/extractor-de-aprendizajes/evals/evals.json +55 -0
  235. package/habilidades/fastapi-experto/SKILL.md +221 -0
  236. package/habilidades/fastapi-experto/recursos/async-patterns.md +438 -0
  237. package/habilidades/fastapi-experto/recursos/dependency-injection.md +330 -0
  238. package/habilidades/fastapi-experto/recursos/referencia-completa.md +79 -0
  239. package/habilidades/fastapi-experto/recursos/testing-httpx.md +420 -0
  240. package/habilidades/filament-admin/SKILL.md +290 -0
  241. package/habilidades/frontend-avanzado/SKILL.md +257 -0
  242. package/habilidades/frontend-avanzado/recursos/apis-nativas-ejemplos.md +341 -0
  243. package/habilidades/gcp-cloud/SKILL.md +260 -0
  244. package/habilidades/gcp-cloud/recursos/gke.md +234 -0
  245. package/habilidades/gcp-cloud/recursos/terraform-gcp.md +307 -0
  246. package/habilidades/generacion-mermaid/SKILL.md +229 -0
  247. package/habilidades/git-worktrees-paralelo/SKILL.md +270 -0
  248. package/habilidades/go-experto/SKILL.md +305 -0
  249. package/habilidades/go-patrones/SKILL.md +299 -0
  250. package/habilidades/go-testing/SKILL.md +291 -0
  251. package/habilidades/graphql-experto/SKILL.md +323 -0
  252. package/habilidades/guardrail-semantico/SKILL.md +282 -0
  253. package/habilidades/harness-claude-code/SKILL.md +299 -0
  254. package/habilidades/iam-secretos/SKILL.md +265 -0
  255. package/habilidades/iam-secretos/recursos/implementaciones-completas.md +356 -0
  256. package/habilidades/infra-github-actions/SKILL.md +166 -0
  257. package/habilidades/instalar-sistema/.evolved.json +9 -0
  258. package/habilidades/instalar-sistema/SKILL.md +221 -0
  259. package/habilidades/java-experto/SKILL.md +290 -0
  260. package/habilidades/java-patrones/SKILL.md +275 -0
  261. package/habilidades/java-testing/SKILL.md +288 -0
  262. package/habilidades/kotlin-compose/SKILL.md +278 -0
  263. package/habilidades/kotlin-compose/recursos/animaciones-performance.md +93 -0
  264. package/habilidades/kotlin-experto/SKILL.md +318 -0
  265. package/habilidades/kotlin-testing/SKILL.md +267 -0
  266. package/habilidades/kotlin-testing/recursos/testing-avanzado.md +74 -0
  267. package/habilidades/kubernetes-orquestacion/SKILL.md +152 -0
  268. package/habilidades/kubernetes-orquestacion/recursos/manifiestos-completos.md +452 -0
  269. package/habilidades/langchain-langraph/SKILL.md +386 -0
  270. package/habilidades/langchain-langraph/recursos/evaluacion-rag.md +321 -0
  271. package/habilidades/langchain-langraph/recursos/rag-maturity-model.md +225 -0
  272. package/habilidades/langchain-langraph/recursos/vectorstores.md +306 -0
  273. package/habilidades/legacy-code-rescue/SKILL.md +267 -0
  274. package/habilidades/likec4-experto/SKILL.md +412 -0
  275. package/habilidades/likec4-experto/evals/evals.json +69 -0
  276. package/habilidades/manejo-errores/.evolved.json +9 -0
  277. package/habilidades/manejo-errores/SKILL.md +407 -0
  278. package/habilidades/manejo-errores/recursos/implementaciones-completas.md +248 -0
  279. package/habilidades/mapear-codebase/SKILL.md +275 -0
  280. package/habilidades/memoria-busqueda/SKILL.md +194 -0
  281. package/habilidades/memoria-busqueda/evals/evals.json +44 -0
  282. package/habilidades/meta-skills-estandar/SKILL.md +298 -0
  283. package/habilidades/meta-skills-estandar/recursos/anti-patrones-y-leyes.md +205 -0
  284. package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +107 -0
  285. package/habilidades/meta-skills-estandar/recursos/idiomas-framework.md +60 -0
  286. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -0
  287. package/habilidades/microservicios/SKILL.md +155 -0
  288. package/habilidades/microservicios/recursos/patrones-y-ejemplos-completos.md +325 -0
  289. package/habilidades/mobile-flutter/SKILL.md +199 -0
  290. package/habilidades/mobile-flutter/recursos/ejemplos-completos.md +319 -0
  291. package/habilidades/mobile-react-native/SKILL.md +176 -0
  292. package/habilidades/mobile-react-native/recursos/ejemplos-completos.md +216 -0
  293. package/habilidades/mongodb-experto/SKILL.md +302 -0
  294. package/habilidades/monitoring-alertas/SKILL.md +201 -0
  295. package/habilidades/monitoring-alertas/recursos/instrumentacion-y-alertas.md +301 -0
  296. package/habilidades/nestjs-experto/SKILL.md +307 -0
  297. package/habilidades/nestjs-experto/recursos/guards-interceptors.md +339 -0
  298. package/habilidades/nestjs-experto/recursos/modulos-di.md +287 -0
  299. package/habilidades/nestjs-experto/recursos/testing-nestjs.md +354 -0
  300. package/habilidades/nextjs-experto/SKILL.md +335 -0
  301. package/habilidades/nextjs-patrones/SKILL.md +303 -0
  302. package/habilidades/nextjs-testing/SKILL.md +331 -0
  303. package/habilidades/node-experto/.evolved.json +9 -0
  304. package/habilidades/node-experto/SKILL.md +266 -0
  305. package/habilidades/node-experto/recursos/patrones-completos.md +283 -0
  306. package/habilidades/notificaciones-multicanal/SKILL.md +159 -0
  307. package/habilidades/notificaciones-multicanal/recursos/config-template.json +115 -0
  308. package/habilidades/notificaciones-multicanal/recursos/configuracion-y-templates.md +303 -0
  309. package/habilidades/nuevo-proyecto/SKILL.md +204 -0
  310. package/habilidades/orquestacion-async/SKILL.md +303 -0
  311. package/habilidades/paid-media-tracking/SKILL.md +269 -0
  312. package/habilidades/paid-media-tracking/recursos/auditoria-tracking.md +220 -0
  313. package/habilidades/paid-media-tracking/recursos/google-ads-api.md +215 -0
  314. package/habilidades/patrones-python/SKILL.md +228 -0
  315. package/habilidades/patrones-python/evals/evals.json +56 -0
  316. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -0
  317. package/habilidades/patrones-python/recursos/referencia-completa.md +202 -0
  318. package/habilidades/perfil-usuario/SKILL.md +200 -0
  319. package/habilidades/perfil-usuario/evals/evals.json +55 -0
  320. package/habilidades/performance-baseline/SKILL.md +297 -0
  321. package/habilidades/php-experto/SKILL.md +291 -0
  322. package/habilidades/php-patrones/SKILL.md +306 -0
  323. package/habilidades/php-testing/SKILL.md +280 -0
  324. package/habilidades/planear-fase/SKILL.md +269 -0
  325. package/habilidades/postgresql-experto/SKILL.md +151 -0
  326. package/habilidades/postgresql-experto/evals/evals.json +53 -0
  327. package/habilidades/postgresql-experto/recursos/referencia-completa.md +215 -0
  328. package/habilidades/prevencion-racionalizacion/SKILL.md +175 -0
  329. package/habilidades/prevencion-sobreingenieria/SKILL.md +323 -0
  330. package/habilidades/privacy-memoria/SKILL.md +141 -0
  331. package/habilidades/privacy-memoria/evals/evals.json +43 -0
  332. package/habilidades/prompt-engineering/SKILL.md +518 -0
  333. package/habilidades/prompt-engineering/recursos/patrones-avanzados.md +467 -0
  334. package/habilidades/rag-arquitectura/SKILL.md +338 -0
  335. package/habilidades/rails-experto/SKILL.md +237 -0
  336. package/habilidades/rails-experto/recursos/active-record.md +260 -0
  337. package/habilidades/rails-experto/recursos/hotwire-turbo.md +293 -0
  338. package/habilidades/rails-experto/recursos/testing-rspec.md +362 -0
  339. package/habilidades/react-experto/SKILL.md +209 -0
  340. package/habilidades/react-experto/evals/evals.json +55 -0
  341. package/habilidades/react-experto/recursos/patrones-y-ejemplos-completos.md +240 -0
  342. package/habilidades/react-optimizacion/SKILL.md +174 -0
  343. package/habilidades/react-optimizacion/recursos/patrones-avanzados.md +138 -0
  344. package/habilidades/redis-experto/SKILL.md +305 -0
  345. package/habilidades/release-semver/.evolved.json +9 -0
  346. package/habilidades/release-semver/SKILL.md +248 -0
  347. package/habilidades/release-semver/scripts/generar-changelog.sh +238 -0
  348. package/habilidades/rust-experto/SKILL.md +400 -0
  349. package/habilidades/rust-patrones/SKILL.md +296 -0
  350. package/habilidades/rust-testing/SKILL.md +311 -0
  351. package/habilidades/seguridad-skills-ia/SKILL.md +262 -0
  352. package/habilidades/sql-optimizacion/SKILL.md +200 -0
  353. package/habilidades/sql-optimizacion/evals/evals.json +54 -0
  354. package/habilidades/sql-optimizacion/recursos/patrones-sql-avanzados.md +131 -0
  355. package/habilidades/sre-patrones/SKILL.md +333 -0
  356. package/habilidades/sre-patrones/recursos/chaos-engineering.md +241 -0
  357. package/habilidades/sre-patrones/recursos/oncall-design.md +236 -0
  358. package/habilidades/stripe-pagos/SKILL.md +550 -0
  359. package/habilidades/stripe-pagos/recursos/errores-reintentos.md +390 -0
  360. package/habilidades/stripe-pagos/recursos/stripe-connect.md +290 -0
  361. package/habilidades/structured-outputs/SKILL.md +343 -0
  362. package/habilidades/swift-experto/SKILL.md +320 -0
  363. package/habilidades/swift-experto/recursos/keychain-y-wrappers.md +110 -0
  364. package/habilidades/swift-patrones/SKILL.md +313 -0
  365. package/habilidades/swift-patrones/recursos/tca-ejemplo-completo.md +113 -0
  366. package/habilidades/swift-testing/SKILL.md +254 -0
  367. package/habilidades/swift-testing/recursos/xcuitest-planes.md +143 -0
  368. package/habilidades/swl-dashboard/SKILL.md +370 -0
  369. package/habilidades/swl-markitdown/SKILL.md +285 -0
  370. package/habilidades/swl-markitdown/evals/evals.json +52 -0
  371. package/habilidades/swl-revisar-impacto/SKILL.md +233 -0
  372. package/habilidades/tailwind-experto/SKILL.md +240 -0
  373. package/habilidades/tailwind-experto/recursos/referencia-completa.md +184 -0
  374. package/habilidades/tdd-workflow/SKILL.md +293 -0
  375. package/habilidades/terraform-experto/SKILL.md +321 -0
  376. package/habilidades/testing-python/SKILL.md +340 -0
  377. package/habilidades/testing-python/recursos/ejemplos-completos.md +167 -0
  378. package/habilidades/threat-model-lite/SKILL.md +246 -0
  379. package/habilidades/tracing-processor/SKILL.md +212 -0
  380. package/habilidades/tracking-measurement/SKILL.md +239 -0
  381. package/habilidades/tracking-measurement/recursos/consent-mode.md +231 -0
  382. package/habilidades/tracking-measurement/recursos/gtm-datalayer.md +216 -0
  383. package/habilidades/tracking-measurement/recursos/meta-capi.md +262 -0
  384. package/habilidades/typescript-avanzado/SKILL.md +144 -0
  385. package/habilidades/typescript-avanzado/evals/evals.json +55 -0
  386. package/habilidades/typescript-avanzado/recursos/patrones-y-ejemplos-completos.md +298 -0
  387. package/habilidades/typescript-diagnosticos/SKILL.md +513 -0
  388. package/habilidades/ux-diseno/SKILL.md +116 -0
  389. package/habilidades/ux-diseno/evals/evals.json +43 -0
  390. package/habilidades/ux-diseno/recursos/patrones-ux-referencia.md +214 -0
  391. package/habilidades/validacion-ci-sistema/SKILL.md +136 -0
  392. package/habilidades/validacion-ci-sistema/recursos/validadores-completos.md +369 -0
  393. package/habilidades/validacion-ci-sistema/scripts/validar-sistema.sh +286 -0
  394. package/habilidades/verificacion-evidencia/SKILL.md +160 -0
  395. package/habilidades/verificar-trabajo/SKILL.md +303 -0
  396. package/habilidades/verificar-trabajo/recursos/plantilla-verificacion.md +60 -0
  397. package/habilidades/wiki-conocimiento/SKILL.md +276 -0
  398. package/habilidades/wireframes-flujos/SKILL.md +212 -0
  399. package/habilidades/wireframes-flujos/recursos/referencia-completa.md +192 -0
  400. package/habilidades/workflow-claude-code/SKILL.md +260 -0
  401. package/habilidades/workflow-claude-code/recursos/referencia-completa.md +109 -0
  402. package/hooks/_run-hook.sh +57 -0
  403. package/hooks/actualizar-perfil-usuario.js +364 -0
  404. package/hooks/agente-lifecycle.js +71 -0
  405. package/hooks/aiisms-detector.js +173 -0
  406. package/hooks/audit-trail.js +204 -0
  407. package/hooks/auto-background.js +97 -0
  408. package/hooks/auto-consolidacion.js +178 -0
  409. package/hooks/auto-evolucion.js +666 -0
  410. package/hooks/auto-restaurar-settings.js +360 -0
  411. package/hooks/calidad-pre-commit.js +929 -0
  412. package/hooks/calidad-typescript.js +511 -0
  413. package/hooks/captura-feedback-usuario.js +148 -0
  414. package/hooks/check-update.js +211 -0
  415. package/hooks/clasificador-mensajes.js +271 -0
  416. package/hooks/degradacion-instintos.js +272 -0
  417. package/hooks/escaneo-secretos.js +389 -0
  418. package/hooks/extraccion-aprendizajes.js +763 -0
  419. package/hooks/grafo-contexto.js +129 -0
  420. package/hooks/graph-update.js +67 -0
  421. package/hooks/guardrail-modelo.js +247 -0
  422. package/hooks/inbox-aviso.js +75 -0
  423. package/hooks/inyeccion-contexto.js +246 -0
  424. package/hooks/lib/abort-registry.js +214 -0
  425. package/hooks/lib/agent-backend.js +210 -0
  426. package/hooks/lib/agent-comms.js +263 -0
  427. package/hooks/lib/agent-issue-codes.js +284 -0
  428. package/hooks/lib/agent-matcher.js +189 -0
  429. package/hooks/lib/async-hook-registry.js +252 -0
  430. package/hooks/lib/atomic-write.js +130 -0
  431. package/hooks/lib/auto-consolidator.js +335 -0
  432. package/hooks/lib/canary-skills.js +187 -0
  433. package/hooks/lib/consolidation-lock.js +291 -0
  434. package/hooks/lib/context-builder.js +430 -0
  435. package/hooks/lib/context-compressor.js +657 -0
  436. package/hooks/lib/convergence-detector.js +105 -0
  437. package/hooks/lib/delegation-tracker.js +198 -0
  438. package/hooks/lib/detectar-package-manager.js +423 -0
  439. package/hooks/lib/edit-accumulator.js +171 -0
  440. package/hooks/lib/error-classifier.js +308 -0
  441. package/hooks/lib/event-bus.js +112 -0
  442. package/hooks/lib/evolution-tracker.js +442 -0
  443. package/hooks/lib/execution-state.js +316 -0
  444. package/hooks/lib/fingerprint-id.js +135 -0
  445. package/hooks/lib/gateway-notify.js +116 -0
  446. package/hooks/lib/graph-security.js +75 -0
  447. package/hooks/lib/guardrail-metrics.js +202 -0
  448. package/hooks/lib/hook-circuit-breaker.js +206 -0
  449. package/hooks/lib/loop-detector.js +267 -0
  450. package/hooks/lib/mcp-health.js +184 -0
  451. package/hooks/lib/mcp-pool.js +436 -0
  452. package/hooks/lib/memory-search.js +506 -0
  453. package/hooks/lib/merkle-audit.js +96 -0
  454. package/hooks/lib/model-router.js +222 -0
  455. package/hooks/lib/normalize-error.js +324 -0
  456. package/hooks/lib/normalize-input.js +65 -0
  457. package/hooks/lib/nudge-tracker.js +306 -0
  458. package/hooks/lib/otlp-exporter.js +365 -0
  459. package/hooks/lib/performance-marks.js +239 -0
  460. package/hooks/lib/privacy-filter.js +128 -0
  461. package/hooks/lib/prompt-injection-scanner.js +209 -0
  462. package/hooks/lib/provenance-tracker.js +183 -0
  463. package/hooks/lib/rate-limit-tracker.js +253 -0
  464. package/hooks/lib/reflect-classifier.js +164 -0
  465. package/hooks/lib/resource-quota.js +122 -0
  466. package/hooks/lib/retry-jitter.js +165 -0
  467. package/hooks/lib/risk-engine.js +368 -0
  468. package/hooks/lib/run-log.js +408 -0
  469. package/hooks/lib/session-fts.js +379 -0
  470. package/hooks/lib/session-store.js +293 -0
  471. package/hooks/lib/singleton-guard.js +159 -0
  472. package/hooks/lib/skill-auditor.js +588 -0
  473. package/hooks/lib/sync-status.js +228 -0
  474. package/hooks/lib/taint-tracker.js +107 -0
  475. package/hooks/lib/task-service.js +295 -0
  476. package/hooks/lib/tech-skills-map.js +146 -0
  477. package/hooks/lib/telegram-cliente.js +159 -0
  478. package/hooks/lib/telegram-config.js +170 -0
  479. package/hooks/lib/token-budget.js +156 -0
  480. package/hooks/lib/token-estimator.js +420 -0
  481. package/hooks/lib/toon-compressor.js +245 -0
  482. package/hooks/lib/usage-model.js +183 -0
  483. package/hooks/lib/variable-resolver.js +230 -0
  484. package/hooks/linea-estado.js +324 -0
  485. package/hooks/metricas-evolucion.js +209 -0
  486. package/hooks/monitor-contexto.js +325 -0
  487. package/hooks/notificacion-sesion-stop.js +198 -0
  488. package/hooks/notificacion-telegram-notification.js +4 -0
  489. package/hooks/notificacion-telegram-subagent.js +4 -0
  490. package/hooks/notificacion-telegram.js +267 -0
  491. package/hooks/preservar-estado-pre-compact.js +150 -0
  492. package/hooks/proteccion-rutas.js +366 -0
  493. package/hooks/registro-turnos.js +209 -0
  494. package/hooks/resumen-sesion.js +249 -0
  495. package/hooks/risk-scoring.js +323 -0
  496. package/hooks/rotar-audit-auto.js +122 -0
  497. package/hooks/sugerir-regenerar-inventario.js +170 -0
  498. package/hooks/telemetria-agentes.js +167 -0
  499. package/hooks/tracking-costos.js +688 -0
  500. package/instintos/global.yaml +8 -0
  501. package/instintos/perfil-usuario.yaml +53 -0
  502. package/instintos/prompt-appendices.yaml +57 -0
  503. package/instintos/proyecto.yaml +372 -0
  504. package/manifiestos/gateway-config.json +77 -0
  505. package/manifiestos/handoff-context.json +223 -0
  506. package/manifiestos/hook-profiles.json +44 -0
  507. package/manifiestos/hooks-config.json +360 -0
  508. package/manifiestos/modulos.json +1173 -0
  509. package/manifiestos/perfiles.json +404 -0
  510. package/package.json +86 -0
  511. package/plantillas/ESTADO.md +109 -0
  512. package/plantillas/HOJA-RUTA.md +143 -0
  513. package/plantillas/PROYECTO.md +122 -0
  514. package/plantillas/REQUISITOS.md +132 -0
  515. package/plantillas/auditor-veto-template.md +105 -0
  516. package/plantillas/github-workflows/README.md +47 -0
  517. package/plantillas/github-workflows/release-please.yml +44 -0
  518. package/plantillas/github-workflows/swl-ci.yml +107 -0
  519. package/plantillas/github-workflows/swl-security.yml +51 -0
  520. package/plantillas/mcp-mineru.json +13 -0
  521. package/plantillas/research/ARQUITECTURA.md +220 -0
  522. package/plantillas/research/FUNCIONALIDADES.md +175 -0
  523. package/plantillas/research/RESUMEN.md +165 -0
  524. package/plantillas/research/STACK.md +233 -0
  525. package/plantillas/research/TRAMPAS.md +299 -0
  526. package/plantillas/skill-evals-template.json +44 -0
  527. package/plugin.json +343 -0
  528. package/reglas/accesibilidad.md +269 -0
  529. package/reglas/api-diseno.md +400 -0
  530. package/reglas/arquitectura.md +352 -0
  531. package/reglas/brevedad-output.md +124 -0
  532. package/reglas/cloud-infra.md +247 -0
  533. package/reglas/docs.md +245 -0
  534. package/reglas/estilo-codigo.md +201 -0
  535. package/reglas/git-workflow.md +245 -0
  536. package/reglas/gobernanza.md +271 -0
  537. package/reglas/harness-claude-code.md +213 -0
  538. package/reglas/hooks.md +186 -0
  539. package/reglas/lenguajes/csharp/estilo-codigo.md +231 -0
  540. package/reglas/lenguajes/csharp/hooks.md +281 -0
  541. package/reglas/lenguajes/csharp/patrones.md +226 -0
  542. package/reglas/lenguajes/csharp/seguridad.md +258 -0
  543. package/reglas/lenguajes/csharp/testing.md +176 -0
  544. package/reglas/lenguajes/go/estilo-codigo.md +195 -0
  545. package/reglas/lenguajes/go/hooks.md +249 -0
  546. package/reglas/lenguajes/go/patrones.md +249 -0
  547. package/reglas/lenguajes/go/seguridad.md +225 -0
  548. package/reglas/lenguajes/go/testing.md +272 -0
  549. package/reglas/lenguajes/java/estilo-codigo.md +217 -0
  550. package/reglas/lenguajes/java/hooks.md +251 -0
  551. package/reglas/lenguajes/java/patrones.md +226 -0
  552. package/reglas/lenguajes/java/seguridad.md +233 -0
  553. package/reglas/lenguajes/java/testing.md +238 -0
  554. package/reglas/lenguajes/kotlin/estilo-codigo.md +208 -0
  555. package/reglas/lenguajes/kotlin/hooks.md +245 -0
  556. package/reglas/lenguajes/kotlin/patrones.md +201 -0
  557. package/reglas/lenguajes/kotlin/seguridad.md +202 -0
  558. package/reglas/lenguajes/kotlin/testing.md +236 -0
  559. package/reglas/lenguajes/nextjs/estilo-codigo.md +175 -0
  560. package/reglas/lenguajes/nextjs/hooks.md +186 -0
  561. package/reglas/lenguajes/nextjs/patrones.md +225 -0
  562. package/reglas/lenguajes/nextjs/seguridad.md +216 -0
  563. package/reglas/lenguajes/nextjs/testing.md +193 -0
  564. package/reglas/lenguajes/php/estilo-codigo.md +228 -0
  565. package/reglas/lenguajes/php/hooks.md +165 -0
  566. package/reglas/lenguajes/php/patrones.md +233 -0
  567. package/reglas/lenguajes/php/seguridad.md +186 -0
  568. package/reglas/lenguajes/php/testing.md +205 -0
  569. package/reglas/lenguajes/rust/estilo-codigo.md +207 -0
  570. package/reglas/lenguajes/rust/hooks.md +240 -0
  571. package/reglas/lenguajes/rust/patrones.md +250 -0
  572. package/reglas/lenguajes/rust/seguridad.md +221 -0
  573. package/reglas/lenguajes/rust/testing.md +194 -0
  574. package/reglas/lenguajes/swift/estilo-codigo.md +238 -0
  575. package/reglas/lenguajes/swift/hooks.md +257 -0
  576. package/reglas/lenguajes/swift/patrones.md +235 -0
  577. package/reglas/lenguajes/swift/seguridad.md +248 -0
  578. package/reglas/lenguajes/swift/testing.md +242 -0
  579. package/reglas/markitdown.md +60 -0
  580. package/reglas/memoria-consolidada.md +209 -0
  581. package/reglas/patrones.md +225 -0
  582. package/reglas/performance.md +195 -0
  583. package/reglas/pruebas.md +159 -0
  584. package/reglas/seguridad-agentes.md +351 -0
  585. package/reglas/seguridad.md +151 -0
  586. package/reglas/skills-estandar.md +373 -0
  587. package/reglas/testing.md +193 -0
  588. package/schemas/agent-contract.json +176 -0
  589. package/schemas/agent-frontmatter.schema.json +149 -0
  590. package/schemas/agent-message.schema.json +53 -0
  591. package/schemas/agent-output-implementacion.schema.json +85 -0
  592. package/schemas/agent-output-planificacion.schema.json +113 -0
  593. package/schemas/agent-output-review.schema.json +78 -0
  594. package/schemas/diary-entry.schema.json +80 -0
  595. package/schemas/hook-profiles.schema.json +39 -0
  596. package/schemas/hooks-config.schema.json +74 -0
  597. package/schemas/instinct.schema.json +115 -0
  598. package/schemas/modulos.schema.json +29 -0
  599. package/schemas/perfiles.schema.json +28 -0
  600. package/schemas/plugin.schema.json +64 -0
  601. package/schemas/skill-evals.schema.json +95 -0
  602. package/schemas/skill-frontmatter.schema.json +170 -0
  603. package/scripts/actualizar.js +145 -0
  604. package/scripts/audit-skills.sh +78 -0
  605. package/scripts/auditar-agentes-gaps.js +149 -0
  606. package/scripts/auditar-cobertura-frameworks.js +241 -0
  607. package/scripts/auditar-skills-gaps.js +206 -0
  608. package/scripts/bootstrap-instintos.js +259 -0
  609. package/scripts/check-update.js +109 -0
  610. package/scripts/comandos/agents.js +105 -0
  611. package/scripts/comandos/info.js +108 -0
  612. package/scripts/comandos/install-asistido.js +186 -0
  613. package/scripts/comandos/skills.js +211 -0
  614. package/scripts/configurar-branch-protection.js +418 -0
  615. package/scripts/daemon-swl.py +388 -0
  616. package/scripts/desinstalar.js +130 -0
  617. package/scripts/doctor.js +559 -0
  618. package/scripts/field-report.js +199 -0
  619. package/scripts/generar-inventario.js +317 -0
  620. package/scripts/inbox-tmux-inject.js +161 -0
  621. package/scripts/inferir-herramientas-permitidas.js +586 -0
  622. package/scripts/inicializar.js +133 -0
  623. package/scripts/instalador.js +1031 -0
  624. package/scripts/instalar-git-hook.js +122 -0
  625. package/scripts/lib/agp-frontmatter.js +222 -0
  626. package/scripts/lib/append-con-marcadores.js +199 -0
  627. package/scripts/lib/artefactos-python.js +43 -0
  628. package/scripts/lib/audit-query.js +221 -0
  629. package/scripts/lib/autostart-linux.js +347 -0
  630. package/scripts/lib/autostart-macos.js +360 -0
  631. package/scripts/lib/autostart-windows.js +307 -0
  632. package/scripts/lib/budget-enforcer.js +252 -0
  633. package/scripts/lib/claude-sessions.js +285 -0
  634. package/scripts/lib/configurar-ci.js +380 -0
  635. package/scripts/lib/console-span-exporter.js +92 -0
  636. package/scripts/lib/contadores-inventario.js +217 -0
  637. package/scripts/lib/dashboard-widgets.js +290 -0
  638. package/scripts/lib/detectar-runtime.js +279 -0
  639. package/scripts/lib/detectar-stack.js +187 -0
  640. package/scripts/lib/diary-entry.js +234 -0
  641. package/scripts/lib/drift-detector.js +545 -0
  642. package/scripts/lib/estado.js +124 -0
  643. package/scripts/lib/gestor-componentes.js +243 -0
  644. package/scripts/lib/gitignore-manifest.js +305 -0
  645. package/scripts/lib/graph-analyze.py +556 -0
  646. package/scripts/lib/graph-builder.py +485 -0
  647. package/scripts/lib/graph-cluster.py +259 -0
  648. package/scripts/lib/health-row.js +168 -0
  649. package/scripts/lib/hooks-settings.js +789 -0
  650. package/scripts/lib/manifiestos.js +138 -0
  651. package/scripts/lib/mc-client.js +137 -0
  652. package/scripts/lib/notificaciones-telegram.js +1107 -0
  653. package/scripts/lib/npm-version.js +261 -0
  654. package/scripts/lib/paquetes-conocidos.js +50 -0
  655. package/scripts/lib/preservar-usuario.js +586 -0
  656. package/scripts/lib/prompt-builder.js +264 -0
  657. package/scripts/lib/resolver-externo.js +332 -0
  658. package/scripts/lib/schedule-parser.js +305 -0
  659. package/scripts/lib/scoring-instintos.js +240 -0
  660. package/scripts/lib/seguridad.js +160 -0
  661. package/scripts/lib/selector-interactivo.js +152 -0
  662. package/scripts/lib/semantic-search.js +242 -0
  663. package/scripts/lib/skill-discovery.js +234 -0
  664. package/scripts/lib/skill-metrics.js +246 -0
  665. package/scripts/lib/skill-normalizer.js +112 -0
  666. package/scripts/lib/skills-hub.js +340 -0
  667. package/scripts/lib/span-schema.js +134 -0
  668. package/scripts/lib/tool-cost-analyzer.js +255 -0
  669. package/scripts/lib/tracing-processor-interface.js +286 -0
  670. package/scripts/lib/transformadores/base.js +80 -0
  671. package/scripts/lib/transformadores/claude.js +124 -0
  672. package/scripts/lib/transformadores/codex.js +115 -0
  673. package/scripts/lib/transformadores/copilot.js +106 -0
  674. package/scripts/lib/transformadores/gemini.js +74 -0
  675. package/scripts/lib/transformadores/index.js +35 -0
  676. package/scripts/lib/transformadores/opencode.js +75 -0
  677. package/scripts/lib/ui.js +259 -0
  678. package/scripts/limpiar-artefactos-python.js +131 -0
  679. package/scripts/mcp-orchestrator.py +386 -0
  680. package/scripts/mcp-pool-manager.py +352 -0
  681. package/scripts/mcp-telemetry.py +378 -0
  682. package/scripts/poblar-evolvable.js +226 -0
  683. package/scripts/publicar.js +287 -0
  684. package/scripts/reflect-skills.js +403 -0
  685. package/scripts/rotar-audit-logs.js +185 -0
  686. package/scripts/run-skill-evals.js +242 -0
  687. package/scripts/smoke-test.js +374 -0
  688. package/scripts/token-analysis.py +471 -0
  689. package/scripts/validar-manifest.js +195 -0
  690. package/scripts/validar-memoria.js +321 -0
  691. package/scripts/validar-tests-aislamiento.js +184 -0
  692. package/scripts/validar-tokens-test.js +208 -0
  693. package/scripts/validar.js +147 -0
  694. package/scripts/validate-markdown.py +339 -0
  695. package/scripts/validate-skills.py +385 -0
  696. package/scripts/vendor/claude-usage/README.md +116 -0
  697. package/scripts/vendor/claude-usage/cli.py +334 -0
  698. package/scripts/vendor/claude-usage/dashboard.py +795 -0
  699. package/scripts/vendor/claude-usage/scanner.py +467 -0
  700. package/scripts/vendor/markitdown/cli.py +194 -0
  701. package/scripts/verificar-evolucion.js +289 -0
  702. package/scripts/verificar-release.js +494 -0
@@ -0,0 +1,487 @@
1
+ ---
2
+ name: swl:evaluar-skill
3
+ description: Evalúa la calidad de un agente o skill SWL con 10 dimensiones, detecta anti-patrones y asigna badge de calidad (Platino/Oro/Plata/Bronce). Ejecutar antes de hacer merge de agentes o skills nuevas.
4
+ argument-hint: <nombre-skill-o-agente> [--agente]
5
+ allowed_tools: ["Read", "Bash", "Glob", "Grep"]
6
+ ---
7
+
8
+ # /swl:evaluar-skill — Evaluación de calidad de skills y agentes SWL
9
+
10
+ Evalúa la calidad de una skill o agente SWL con un framework de 2 capas. La
11
+ **Capa 1** usa verificaciones deterministas (análisis estático con herramientas
12
+ del sistema). La **Capa 2** es evaluación semántica profunda realizada por el
13
+ propio modelo al leer el contenido completo.
14
+
15
+ Al finalizar, emite un reporte con score por dimensión, badge asignado y
16
+ recomendaciones priorizadas de mejora.
17
+
18
+ ## Uso
19
+
20
+ ```
21
+ /swl:evaluar-skill django-experto — Evalúa la skill habilidades/django-experto/SKILL.md
22
+ /swl:evaluar-skill backend-python-swl --agente — Evalúa el agente agentes/backend-python-swl.md
23
+ /swl:evaluar-skill — Lista skills disponibles y pide que se especifique
24
+ ```
25
+
26
+ ## Paso 0 — Resolver argumento
27
+
28
+ Si no se pasa argumento, listar las opciones disponibles y detenerse:
29
+
30
+ ```bash
31
+ echo "=== SKILLS DISPONIBLES ===" && ls -d habilidades/*/ 2>/dev/null | xargs -I{} basename {} | sort
32
+ echo "=== AGENTES DISPONIBLES ===" && ls agentes/*.md 2>/dev/null | xargs -I{} basename {} .md | sort
33
+ ```
34
+
35
+ Informar al usuario que especifique el nombre y si es agente agregar `--agente`.
36
+
37
+ Si se pasa argumento sin `--agente`, buscar en `habilidades/<nombre>/SKILL.md`.
38
+ Si el argumento incluye `--agente`, buscar en `agentes/<nombre>.md` (quitar el flag del nombre).
39
+
40
+ Si el archivo no existe, informar y terminar:
41
+
42
+ ```
43
+ No se encontró: habilidades/<nombre>/SKILL.md
44
+ Verifica el nombre con /swl:evaluar-skill (sin argumentos) para ver las opciones.
45
+ ```
46
+
47
+ ## Paso 1 — Capa 1: Análisis estático
48
+
49
+ Ejecutar todas las verificaciones deterministas. Registrar cada error (E0XX) y
50
+ advertencia (W0XX) encontrado. No usar juicio subjetivo en esta capa.
51
+
52
+ ### 1.1 Verificaciones de frontmatter
53
+
54
+ ```bash
55
+ SKILL_FILE="habilidades/<nombre>/SKILL.md" # o agentes/<nombre>.md
56
+
57
+ # Extraer frontmatter
58
+ head -30 "$SKILL_FILE"
59
+
60
+ # Verificar YAML válido del frontmatter (entre los ---) usando Python
61
+ python3 -c "
62
+ import sys, re
63
+ content = open('$SKILL_FILE').read()
64
+ match = re.match(r'^---\n(.*?)\n---', content, re.DOTALL)
65
+ if not match:
66
+ print('E001 YAML_INVALIDO: no se encontró bloque frontmatter')
67
+ sys.exit(1)
68
+ import yaml
69
+ try:
70
+ data = yaml.safe_load(match.group(1))
71
+ print('YAML OK:', list(data.keys()) if data else 'vacío')
72
+ except Exception as e:
73
+ print('E001 YAML_INVALIDO:', e)
74
+ " 2>/dev/null || echo "E001 YAML_INVALIDO"
75
+ ```
76
+
77
+ Verificar campo `name`:
78
+ ```bash
79
+ grep -m1 "^name:" "$SKILL_FILE" || echo "E002 NAME_AUSENTE"
80
+ ```
81
+
82
+ Verificar campo `description`:
83
+ ```bash
84
+ desc=$(grep -m1 "^description:" "$SKILL_FILE" | sed 's/^description:[[:space:]]*//')
85
+ [ -z "$desc" ] && echo "E003 DESCRIPTION_AUSENTE" || echo "description OK: ${#desc} chars"
86
+ ```
87
+
88
+ Verificar formato kebab-case de `name`:
89
+ ```bash
90
+ name_val=$(grep -m1 "^name:" "$SKILL_FILE" | sed 's/^name:[[:space:]]*//')
91
+ echo "$name_val" | grep -qE '^[a-z0-9][a-z0-9-]*$' || echo "E004 NAME_FORMATO: '$name_val' no es kebab-case"
92
+ ```
93
+
94
+ Verificar longitud de `name` (máx 64 caracteres):
95
+ ```bash
96
+ name_len=$(grep -m1 "^name:" "$SKILL_FILE" | sed 's/^name:[[:space:]]*//' | wc -c)
97
+ [ "$name_len" -gt 64 ] && echo "E005 NAME_LONGITUD: $name_len chars" || echo "name length OK"
98
+ ```
99
+
100
+ Verificar que `name` no use términos reservados:
101
+ ```bash
102
+ name_val=$(grep -m1 "^name:" "$SKILL_FILE" | sed 's/^name:[[:space:]]*//')
103
+ echo "$name_val" | grep -qiE '(anthropic|claude|swl|^tests?$|testing)' && echo "E006 NAME_RESERVADO: '$name_val'" || echo "name reservado OK"
104
+ ```
105
+
106
+ Verificar coincidencia entre `name` y nombre del directorio (solo para skills):
107
+ ```bash
108
+ dir_name="<nombre>"
109
+ name_val=$(grep -m1 "^name:" "$SKILL_FILE" | sed 's/^name:[[:space:]]*//')
110
+ [ "$name_val" != "$dir_name" ] && echo "E007 NAME_DIRECTORIO: name='$name_val' != dir='$dir_name'" || echo "name/dir OK"
111
+ ```
112
+
113
+ Verificar longitud de `description` (máx 1,024 caracteres):
114
+ ```bash
115
+ desc_len=$(grep -m1 "^description:" "$SKILL_FILE" | sed 's/^description:[[:space:]]*//' | wc -c)
116
+ [ "$desc_len" -gt 1024 ] && echo "E008 DESCRIPTION_LONGITUD: $desc_len chars" || echo "description length OK"
117
+ ```
118
+
119
+ ### 1.2 Verificaciones de contenido
120
+
121
+ Verificar presencia de trigger "Cargar cuando" o "Invocar cuando":
122
+ ```bash
123
+ grep -qi "Cargar cuando\|Invocar cuando" "$SKILL_FILE" || echo "E009 MISSING_TRIGGER"
124
+ ```
125
+
126
+ Verificar referencias a recursos internos:
127
+ ```bash
128
+ # Encontrar referencias a recursos/X.md dentro del SKILL.md
129
+ grep -oE 'recursos/[^)"\s]+\.md' "$SKILL_FILE" | while read ref; do
130
+ dir=$(dirname "$SKILL_FILE")
131
+ [ ! -f "$dir/$ref" ] && echo "E010 REFERENCIA_ROTA: $ref"
132
+ done
133
+ echo "referencias OK"
134
+ ```
135
+
136
+ ### 1.3 Verificaciones de advertencias
137
+
138
+ Verificar si la skill supera 300 líneas:
139
+ ```bash
140
+ lines=$(wc -l < "$SKILL_FILE")
141
+ [ "$lines" -gt 300 ] && echo "W001 BLOATED_SKILL: $lines líneas (máx 300)" || echo "W001 OK: $lines líneas"
142
+ ```
143
+
144
+ Verificar uso excesivo de directivas absolutas:
145
+ ```bash
146
+ count=$(grep -cE '\bMUST\b|\bALWAYS\b|\bNEVER\b|\bNUNCA\b|\bSIEMPRE\b' "$SKILL_FILE" || echo 0)
147
+ [ "$count" -gt 15 ] && echo "W002 OVER_CONSTRAINED: $count ocurrencias" || echo "W002 OK: $count ocurrencias"
148
+ ```
149
+
150
+ Verificar archivos huérfanos en recursos/:
151
+ ```bash
152
+ skill_dir=$(dirname "$SKILL_FILE")
153
+ if [ -d "$skill_dir/recursos" ]; then
154
+ for rec in "$skill_dir/recursos/"*.md; do
155
+ base=$(basename "$rec")
156
+ grep -q "$base" "$SKILL_FILE" || echo "W003 HUERFANO: recursos/$base no referenciado"
157
+ done
158
+ fi
159
+ ```
160
+
161
+ Verificar presencia de ejemplos de código si la skill cubre implementación:
162
+ ```bash
163
+ code_blocks=$(grep -c '```' "$SKILL_FILE" || echo 0)
164
+ [ "$code_blocks" -eq 0 ] && echo "W004 SIN_EJEMPLO_CODIGO: cero bloques de código" || echo "W004 OK: $code_blocks delimitadores de bloque"
165
+ ```
166
+
167
+ Verificar sección de "cuándo NO usar":
168
+ ```bash
169
+ grep -qi "cuándo no\|cuando no\|no usar\|no cargar\|no invocar" "$SKILL_FILE" || echo "W005 SIN_CUANDO_NO_USAR"
170
+ ```
171
+
172
+ Verificar presencia de sección Gotchas o equivalente:
173
+ ```bash
174
+ # W008: skills sin sección Gotchas
175
+ # Penalización inicial suave (-5) durante período de migración de Fase 3.
176
+ # Tras la migración se promoverá a -12 para hacer la sección obligatoria.
177
+ grep -qi "Gotcha\|Errores comunes\|trampas\|Errores no obvios\|Fallas conocidas" "$SKILL_FILE" || \
178
+ echo "W008 SIN_GOTCHAS: skill sin seccion Gotchas (penalizacion -5 en robustness)"
179
+ ```
180
+
181
+ Verificar uso de campos legacy en inglés (sin alias en español):
182
+ ```bash
183
+ # W010: uso de campos legacy (inglés) sin alias en español (penalización -6 en robustness)
184
+ # Promovido 2026-04-24 tras v5.11.2 (2 releases desde introducción) — período de gracia concluido.
185
+ node -e "
186
+ const fs = require('fs');
187
+ const norm = require('./scripts/lib/skill-normalizer.js');
188
+ const raw = fs.readFileSync(process.argv[1], 'utf8');
189
+ const match = raw.match(/^---\n([\s\S]*?)\n---/);
190
+ if (!match) process.exit(0);
191
+ const fm = {};
192
+ for (const linea of match[1].split(/\r?\n/)) {
193
+ const m = linea.match(/^(\w[\w_-]*):\s*(.+)\$/);
194
+ if (m) fm[m[1]] = m[2];
195
+ }
196
+ const legacy = norm.detectarUsoLegacy(fm);
197
+ const divergente = norm.detectarDivergencias(fm);
198
+ [...legacy, ...divergente].forEach(w => process.stderr.write(w.mensaje + '\n'));
199
+ " "\$SKILL_FILE" 2>&1 | grep W010 || echo "W010 OK: sin campos legacy"
200
+ ```
201
+
202
+ Verificar justificación en directivas absolutas:
203
+ ```bash
204
+ # W009: directivas absolutas sin justificación
205
+ # Si hay más de 3 directivas MUST/ALWAYS/NEVER/NUNCA/SIEMPRE y ninguna está
206
+ # acompañada de palabras justificativas en la misma línea o la siguiente,
207
+ # el modelo obedece pero no puede generalizar a casos edge.
208
+ directive_count=$(grep -cE '\bMUST\b|\bALWAYS\b|\bNEVER\b|\bNUNCA\b|\bSIEMPRE\b' "$SKILL_FILE" || echo 0)
209
+ if [ "$directive_count" -gt 3 ]; then
210
+ justified=$(grep -E '\bMUST\b|\bALWAYS\b|\bNEVER\b|\bNUNCA\b|\bSIEMPRE\b' "$SKILL_FILE" | \
211
+ grep -ciE 'porque|ya que|para evitar|si no|since|because|para que' || echo 0)
212
+ [ "$justified" -eq 0 ] && echo "W009 DIRECTIVAS_SIN_JUSTIFICACION: $directive_count directivas absolutas sin palabras justificativas (penalizacion -8 en output_quality)" || echo "W009 OK: $justified/$directive_count directivas con justificacion"
213
+ fi
214
+ ```
215
+
216
+ ### 1.4 Resumen de Capa 1
217
+
218
+ Tabular todos los errores y advertencias encontrados. Aplicar penalizaciones:
219
+
220
+ | Código | Tipo | Penalización |
221
+ |--------|------|-------------|
222
+ | E001–E010 | ERROR | Dimensión relacionada → 0 |
223
+ | W001 | ADVERTENCIA | -8 en `progressive_disclosure` |
224
+ | W002 | ADVERTENCIA | -5 en `scope_calibration` |
225
+ | W003 | ADVERTENCIA | -3 en `structural_completeness` |
226
+ | W004 | ADVERTENCIA | -10 en `code_template_quality` |
227
+ | W005 | ADVERTENCIA | -5 en `scope_calibration` |
228
+ | W008 | ADVERTENCIA | -5 en `robustness` (período de migración; se promoverá a -12 tras Fase 3) |
229
+ | W009 | ADVERTENCIA | -8 en `output_quality` |
230
+ | W010 | ADVERTENCIA | -6 en `robustness` (promovido 2026-04-24 tras v5.11.2; período de migración concluido — campos en español SWL son ahora esperados) |
231
+
232
+ Mapeo de errores a dimensiones afectadas:
233
+ - E001, E002, E003, E008 → `structural_completeness`
234
+ - E004, E005, E006, E007 → `ecosystem_coherence`
235
+ - E009 → `triggering_accuracy`
236
+ - E010 → `structural_completeness`
237
+
238
+ ### 1.5 Métricas cuantitativas de calidad
239
+
240
+ Calcular métricas de eficiencia de tokens y duplicación:
241
+
242
+ ```bash
243
+ SKILL_FILE="habilidades/<nombre>/SKILL.md"
244
+
245
+ # Estimar tokens del skill
246
+ node -e "
247
+ const { estimateTokens } = require('./hooks/lib/token-budget');
248
+ const fs = require('fs');
249
+ const content = fs.readFileSync('$SKILL_FILE', 'utf8');
250
+ const tokens = estimateTokens(content, 'mixed');
251
+ const lines = content.split('\n').length;
252
+ const ratio = (tokens / lines).toFixed(1);
253
+ console.log('TOKENS: ' + tokens);
254
+ console.log('LINEAS: ' + lines);
255
+ console.log('DENSIDAD: ' + ratio + ' tokens/línea');
256
+ console.log(tokens > 5000 ? 'W006 TOKEN_EXCESIVO: ' + tokens + ' tokens (máx 5000)' : 'tokens OK');
257
+ "
258
+ ```
259
+
260
+ Detección de duplicación con otros skills del sistema:
261
+
262
+ ```bash
263
+ # Comparar contenido con skills del mismo dominio
264
+ node -e "
265
+ const { jaccardSimilarity } = require('./hooks/lib/fingerprint-id');
266
+ const fs = require('fs');
267
+ const path = require('path');
268
+ const target = fs.readFileSync('$SKILL_FILE', 'utf8');
269
+ const skillsDir = 'habilidades';
270
+ const dirs = fs.readdirSync(skillsDir, {withFileTypes:true}).filter(d=>d.isDirectory());
271
+ const results = [];
272
+ for (const d of dirs) {
273
+ const p = path.join(skillsDir, d.name, 'SKILL.md');
274
+ if (p === '$SKILL_FILE' || !fs.existsSync(p)) continue;
275
+ const content = fs.readFileSync(p, 'utf8');
276
+ const sim = jaccardSimilarity(target, content);
277
+ if (sim > 0.3) results.push({name: d.name, similarity: (sim*100).toFixed(1)});
278
+ }
279
+ results.sort((a,b) => b.similarity - a.similarity);
280
+ if (results.length > 0) {
281
+ console.log('SIMILITUD con otros skills:');
282
+ results.slice(0,5).forEach(r => {
283
+ const flag = r.similarity > 50 ? ' W007 DUPLICADO_POTENCIAL' : '';
284
+ console.log(' ' + r.name + ': ' + r.similarity + '%' + flag);
285
+ });
286
+ } else {
287
+ console.log('Sin duplicación detectada con otros skills.');
288
+ }
289
+ "
290
+ ```
291
+
292
+ Mapeo de advertencias nuevas:
293
+
294
+ | Código | Tipo | Penalización |
295
+ |--------|------|-------------|
296
+ | W006 | ADVERTENCIA | -8 en `token_efficiency` |
297
+ | W007 | ADVERTENCIA | -10 en `orchestration_fitness` (posible duplicación) |
298
+
299
+ ## Paso 2 — Capa 2: Evaluación semántica
300
+
301
+ Leer el archivo completo con `Read`. Evaluar cada dimensión de 0 a 100 con
302
+ criterio honesto: si la skill tiene problemas reales, el score debe reflejarlos.
303
+
304
+ ### Tabla de dimensiones
305
+
306
+ | Dimensión | Peso | Qué medir |
307
+ |-----------|------|-----------|
308
+ | `triggering_accuracy` | 25% | ¿La `description` activa la skill en los momentos correctos? ¿El trigger es ni muy amplio ni muy estrecho? ¿Evita activaciones falsas? |
309
+ | `orchestration_fitness` | 20% | ¿Coordina bien con otras skills del sistema? ¿Invoca correctamente otras skills con `Skill("nombre")`? ¿Evita duplicar contenido de otras skills? |
310
+ | `output_quality` | 15% | ¿Los ejemplos de código son reales y funcionales? ¿Las reglas son específicas, no genéricas? ¿El contenido refleja patrones idiomáticos del framework? ¿Las directivas MUST/ALWAYS/NEVER/NUNCA/SIEMPRE incluyen justificación de por qué la regla existe? Una directiva sin justificación no permite al modelo generalizar a casos edge (ver W009). |
311
+ | `scope_calibration` | 12% | ¿El scope es coherente? ¿No cubre demasiado? ¿Hay sección de "cuándo NO usar"? ¿El contenido es específico del dominio declarado? |
312
+ | `progressive_disclosure` | 10% | ¿El SKILL.md principal es conciso (< 300 líneas)? ¿El contenido extenso está en `recursos/`? ¿Las referencias a recursos son claras y útiles? |
313
+ | `token_efficiency` | 6% | ¿Hay contenido redundante o repetitivo? ¿Los ejemplos son concisos pero completos? ¿Se evita documentación genérica que no agrega valor? |
314
+ | `robustness` | 5% | ¿Documenta casos edge y anti-patrones? ¿Cubre los errores más comunes del dominio? |
315
+ | `structural_completeness` | 3% | ¿Tiene todas las secciones mínimas requeridas? ¿El frontmatter tiene todos los campos obligatorios? |
316
+ | `code_template_quality` | 2% | ¿Los ejemplos de código compilan/ejecutan? ¿Usan sintaxis actual del lenguaje o framework? |
317
+ | `ecosystem_coherence` | 2% | ¿El naming sigue las convenciones del sistema SWL (kebab-case)? ¿Los patrones son consistentes con las otras skills? |
318
+
319
+ **Guía de calibración de scores:**
320
+ - 90-100: Excelente — referente del sistema
321
+ - 80-89: Sólido — listo para uso en producción
322
+ - 70-79: Funcional — mejoras menores posibles
323
+ - 60-69: Aceptable — requiere revisión antes de merge
324
+ - 40-59: Deficiente — problemas claros que afectan efectividad
325
+ - 0-39: Insuficiente — necesita reescritura
326
+
327
+ ## Paso 3 — Cálculo del score final
328
+
329
+ Calcular score ponderado:
330
+
331
+ ```
332
+ score_final = Σ(score_dimensión × peso_dimensión)
333
+
334
+ Ejemplo:
335
+ triggering_accuracy = 85 × 0.25 = 21.25
336
+ orchestration_fitness = 78 × 0.20 = 15.60
337
+ output_quality = 90 × 0.15 = 13.50
338
+ scope_calibration = 72 × 0.12 = 8.64
339
+ progressive_disclosure = 80 × 0.10 = 8.00
340
+ token_efficiency = 70 × 0.06 = 4.20
341
+ robustness = 65 × 0.05 = 3.25
342
+ structural_completeness= 95 × 0.03 = 2.85
343
+ code_template_quality = 85 × 0.02 = 1.70
344
+ ecosystem_coherence = 90 × 0.02 = 1.80
345
+ ─────────────────────────────────────────────
346
+ score_final = 80.79
347
+ ```
348
+
349
+ Asignar badge:
350
+
351
+ ```
352
+ ≥ 90 → Platino — production-ready, puede usarse como referencia
353
+ ≥ 80 → Oro — listo para merge
354
+ ≥ 70 → Plata — necesita mejoras menores antes del merge
355
+ ≥ 60 → Bronce — requiere revisión antes de merge
356
+ < 60 → Sin badge — no hacer merge hasta corregir
357
+ ```
358
+
359
+ ## Paso 4 — Emitir reporte
360
+
361
+ Generar el siguiente reporte directamente en la conversación:
362
+
363
+ ```markdown
364
+ ## Evaluación de skill: [nombre]
365
+ **Archivo**: habilidades/[nombre]/SKILL.md (o agentes/[nombre].md)
366
+ **Fecha**: [fecha actual]
367
+
368
+ ### Capa 1 — Análisis estático
369
+
370
+ [PASS si no hay errores ni advertencias]
371
+ [O listar cada E0XX / W0XX con descripción breve]
372
+
373
+ ### Capa 2 — Evaluación semántica
374
+
375
+ | Dimensión | Peso | Score | Contribución |
376
+ |-----------|------|-------|-------------|
377
+ | Triggering accuracy | 25% | XX/100 | XX.XX |
378
+ | Orchestration fitness | 20% | XX/100 | XX.XX |
379
+ | Output quality | 15% | XX/100 | XX.XX |
380
+ | Scope calibration | 12% | XX/100 | XX.XX |
381
+ | Progressive disclosure | 10% | XX/100 | XX.XX |
382
+ | Token efficiency | 6% | XX/100 | XX.XX |
383
+ | Robustness | 5% | XX/100 | XX.XX |
384
+ | Structural completeness | 3% | XX/100 | XX.XX |
385
+ | Code template quality | 2% | XX/100 | XX.XX |
386
+ | Ecosystem coherence | 2% | XX/100 | XX.XX |
387
+
388
+ **Score final: XX.XX/100 — Badge: [🏆/🥇/🥈/🥉/❌] [Platino/Oro/Plata/Bronce/Sin badge]**
389
+
390
+ ### Hallazgos principales
391
+
392
+ **Fortalezas:**
393
+ - [2-3 aspectos bien ejecutados con evidencia específica del contenido]
394
+
395
+ **Áreas de mejora:**
396
+ - [hallazgos específicos con sugerencia concreta y línea o sección afectada]
397
+
398
+ ### Recomendaciones para subir el score
399
+
400
+ [Lista priorizada de cambios concretos que mejorarían el score,
401
+ ordenados de mayor a menor impacto. Incluir la dimensión afectada.]
402
+ ```
403
+
404
+ ## Paso 3 — Capa 3 opcional: Evals estructurados
405
+
406
+ Si el artefacto tiene un archivo de evals en formato `skill-evals.schema.json`:
407
+
408
+ ```bash
409
+ EVALS_PATH="habilidades/<nombre>/evals/evals.json"
410
+ [ -f "$EVALS_PATH" ] && echo "EVALS_DISPONIBLES" || EVALS_PATH="agentes/evals/<nombre>.evals.json"
411
+ [ -f "$EVALS_PATH" ] && echo "EVALS_DISPONIBLES" || echo "SIN_EVALS"
412
+ ```
413
+
414
+ Si existen, ejecutar la Capa 3:
415
+
416
+ ### 3.1 — Validar el artefacto contra el schema
417
+
418
+ ```bash
419
+ # Validación mínima de estructura (zero-deps): comprobar que es JSON válido y
420
+ # que tiene los campos obligatorios. Validación completa del schema queda para
421
+ # consumidores externos (ajv, etc.) — SWL no arrastra deps.
422
+ node -e "
423
+ const ev = require('./$EVALS_PATH');
424
+ const req = ['skill_name','schema_version','evals'];
425
+ const missing = req.filter(k => !(k in ev));
426
+ if (missing.length) { console.error('FALTAN:', missing.join(',')); process.exit(1); }
427
+ if (!Array.isArray(ev.evals) || ev.evals.length === 0) { console.error('evals vacío'); process.exit(1); }
428
+ console.log('OK', ev.evals.length, 'evals');
429
+ "
430
+ ```
431
+
432
+ Si falla la validación, reportar y continuar solo con Capa 1+2 (no bloquear).
433
+
434
+ ### 3.2 — Ejecutar cada eval contra el skill cargado
435
+
436
+ Para cada `eval` del artefacto:
437
+
438
+ 1. Cargar el skill con `Skill("<nombre>")`.
439
+ 2. Enviar el `prompt` exacto al modelo en una respuesta aislada (sin historial).
440
+ 3. Capturar la respuesta.
441
+ 4. Para cada entrada de `expectations[]`, verificar si la respuesta la cumple
442
+ (match semántico honesto, no literal).
443
+ 5. Computar `pass = true` solo si TODAS las expectations se cumplen.
444
+ 6. Aplicar `weight` (default 1.0) al score.
445
+
446
+ ### 3.3 — Score de Capa 3
447
+
448
+ ```
449
+ score_evals = sum(pass_i * weight_i) / sum(weight_i) * 100
450
+ ```
451
+
452
+ ### 3.4 — Integración con score final
453
+
454
+ El score final combinado es:
455
+
456
+ - Sin evals: `score_final = score_capa_1_2`
457
+ - Con evals: `score_final = score_capa_1_2 * 0.7 + score_evals * 0.3`
458
+
459
+ Reportar ambos separadamente para trazabilidad. Si `score_evals < 60`, marcar
460
+ alerta: la skill puede ser declarativa pero falla en evaluación ejecutable.
461
+
462
+ ### 3.5 — Reporte por eval
463
+
464
+ ```
465
+ | ID | Tags | Peso | Resultado | Expectations fallidas |
466
+ |----|------|------|-----------|----------------------|
467
+ | 0 | primary-flow | 1.0 | ✓ pass | — |
468
+ | 1 | edge-case | 1.0 | ✗ fail | "La respuesta distingue X de Y" |
469
+ | anti-pattern-substitution | anti-pattern,regression | 1.5 | ✓ pass | — |
470
+
471
+ Score evals: 82.4/100 (peso 30% del final)
472
+ ```
473
+
474
+ ## Reglas de comportamiento
475
+
476
+ - La Capa 1 es **determinista**: ejecutar los scripts Bash y registrar resultados exactos. No inferir ni interpretar.
477
+ - La Capa 2 es **semántica honesta**: si la skill tiene problemas reales el score debe reflejarlos. No inflar scores por cortesía.
478
+ - La Capa 3 es **opcional**: si no existe `evals/evals.json`, omitirla sin penalizar. Si existe, es autoridad primaria sobre Capa 2 en caso de discrepancia (los evals son reproducibles; la evaluación semántica no).
479
+ - Un skill con Capa 3 activa y `score_evals ≥ 90` es candidato a badge **Platino** aunque Capa 2 sea 85.
480
+ - Los evals NUNCA se inventan en este comando — solo se ejecutan los declarados por el autor del skill. Crear evals nuevos es tarea de `/swl:aprender` o del autor del skill directamente, siguiendo `plantillas/skill-evals-template.json`.
481
+ - Si el archivo no existe, informar al usuario con el path exacto y terminar.
482
+ - Si `--agente` se pasa sin nombre, listar los agentes disponibles y terminar.
483
+ - El reporte siempre se emite en la conversación. No crear archivos.
484
+ - Las "Fortalezas" deben ser específicas del contenido leído, no genéricas.
485
+ - Las "Áreas de mejora" deben incluir la sección o línea aproximada donde se detectó el problema.
486
+ - Si la Capa 1 genera errores E001–E010, reflejar el impacto en el score de la dimensión afectada antes de sumar las contribuciones ponderadas.
487
+ - Score mínimo aprobado para merge: **80/100** (badge Oro). Por debajo de ese umbral, indicar claramente que **no está listo para merge**.
@@ -0,0 +1,142 @@
1
+ ---
2
+ name: swl:evolucion-estado
3
+ description: Dashboard del ciclo de auto-evolución del sistema SWL. Muestra health_score compuesto, tasa de acción de nudges, densidad de instintos, fallos de agentes, evoluciones aplicadas/revertidas y alertas persistentes. Responde en una pantalla a "¿SWL está aprendiendo esta semana?".
4
+ argument-hint: [--json | --dias=N | --regenerar]
5
+ allowed_tools: ["Read", "Bash"]
6
+ user-invocable: true
7
+ version: "1.0.0"
8
+ ---
9
+
10
+ # /swl:evolucion-estado — Dashboard del ciclo de evolución
11
+
12
+ Emite un reporte compacto del estado de auto-evolución del sistema SWL en la
13
+ ventana reciente (default 14 días). Su propósito: responder a la pregunta
14
+ **"¿el sistema está aprendiendo?"** con datos, no impresiones.
15
+
16
+ ## Flags
17
+
18
+ - `--json` → emite el JSON crudo de `metricas.json` (útil para pipes).
19
+ - `--dias=N` → regenera métricas con ventana de N días (default 14).
20
+ - `--regenerar` → fuerza recomputo ejecutando el hook `metricas-evolucion.js`.
21
+ Útil cuando no se ha disparado Stop recientemente.
22
+
23
+ ## Paso 0 — Asegurar métricas frescas
24
+
25
+ Si se pasó `--regenerar` o `metricas.json` tiene > 24h:
26
+
27
+ ```bash
28
+ PATH="/c/Program Files/nodejs:/c/Program Files (x86)/nodejs:$PATH" echo '{}' | node hooks/metricas-evolucion.js
29
+ ```
30
+
31
+ ## Paso 1 — Cargar métricas
32
+
33
+ ```bash
34
+ cat .planning/evolucion/metricas.json
35
+ ```
36
+
37
+ Si el archivo no existe: ejecutar el regenerado del Paso 0. Si sigue sin
38
+ existir: reportar "el ciclo de evolución no ha corrido aún; ejecuta cualquier
39
+ tarea para poblar métricas iniciales".
40
+
41
+ ## Paso 2 — Emitir el dashboard (formato humano)
42
+
43
+ Template de salida:
44
+
45
+ ```
46
+ ═══════════════════════════════════════════════════════════════
47
+ SWL — Estado del ciclo de evolución
48
+ Ventana: últimos N días · Generado: <ts>
49
+ ═══════════════════════════════════════════════════════════════
50
+
51
+ Health score: <N>/100 <badge>
52
+
53
+ NUDGES
54
+ Emitidos .............. <total>
55
+ Accionados ............ <n> (<tasa>%)
56
+ Pendientes ............ <n>
57
+ Por tipo:
58
+ perfil-usuario <a>/<t> (<%>)
59
+ auto-evolucion <a>/<t> (<%>)
60
+ consolidacion <a>/<t> (<%>)
61
+
62
+ INSTINTOS
63
+ Proyecto .............. <n>
64
+ Global ................ <n>
65
+ Perfil-usuario ........ <n>
66
+ Aprendizajes totales .. <n>
67
+
68
+ AGENTES (14d)
69
+ Runs totales .......... <n>
70
+ Fallos ................ <n>
71
+ Tasa de éxito ......... <%>
72
+
73
+ EVOLUCIONES (30d)
74
+ Aplicadas ............. <n>
75
+ Revertidas ............ <n>
76
+ Neta .................. <n>
77
+
78
+ ALERTAS PERSISTENTES
79
+ <si alertasActivas.length === 0>
80
+ Sin alertas.
81
+ <sino>
82
+ [!] kind=X target=Y count=Z (primera: fecha)
83
+ ...
84
+
85
+ ═══════════════════════════════════════════════════════════════
86
+ ```
87
+
88
+ ## Paso 3 — Calcular badge del health_score
89
+
90
+ | Rango | Badge | Interpretación |
91
+ |-------|-------|----------------|
92
+ | ≥ 90 | 🏆 Óptimo | ciclo completo, cerrado y saludable |
93
+ | ≥ 75 | 🥇 Saludable | funcionando con pequeñas mejoras pendientes |
94
+ | ≥ 60 | 🥈 Parcial | hay piezas sin activar; revisar recomendaciones |
95
+ | ≥ 40 | 🥉 Esqueleto | infraestructura existe pero poco uso real |
96
+ | < 40 | ⚠️ Dormido | el ciclo no está corriendo |
97
+
98
+ ## Paso 4 — Recomendaciones contextuales
99
+
100
+ Al final del dashboard, sugerir acciones según las métricas:
101
+
102
+ - Si `instintos.proyecto === 0` y `aprendizajes_totales > 10`:
103
+ → `node scripts/bootstrap-instintos.js` (pobla desde APRENDIZAJES.md)
104
+
105
+ - Si `nudges.tasaAccion < 0.3` y `nudges.total > 5`:
106
+ → "Muchos nudges ignorados. Revisa `.planning/evolucion/alertas-persistentes.json`"
107
+
108
+ - Si `alertasActivas.length > 0`:
109
+ → listar cada alerta con `/swl:evolucionar <target>` o cmd correspondiente
110
+
111
+ - Si `agentes.tasaExito < 70` y `totalRuns > 5`:
112
+ → "Agentes con tasa de éxito baja. Candidatos a `/swl:evolucionar`:
113
+ <top 3 de porAgente con más fallos>"
114
+
115
+ - Si `evoluciones.revertidas > evoluciones.aplicadas / 2`:
116
+ → "Muchas evoluciones revertidas — revisar si el gate de regresión
117
+ está siendo demasiado laxo o si los evals son inconsistentes"
118
+
119
+ - Si `health_score >= 90`:
120
+ → "Sistema en óptimo. Posible candidato a habilitar modo autónomo
121
+ de `auto-evolucion-swl`. Ver `agentes/auto-evolucion-swl.md` —
122
+ sección 'Autonomía condicional'"
123
+
124
+ - Si `health_score < 95`:
125
+ → "Para subir el score, consultar `.planning/ROADMAP-EVOLUCION.md` —
126
+ documenta los 5 hitos por fase y cuánto aporta cada uno. Sin uso
127
+ operacional real (nudges accionados, runs reales, evoluciones), el
128
+ score no sube por infraestructura sola."
129
+
130
+ ## Anti-substitution guardrails
131
+
132
+ - Archivo de métricas: **siempre** `.planning/evolucion/metricas.json` (nunca `.planning/metricas.json`, `evolucion.json`, `estado-evolucion.json`).
133
+ - Hook que regenera: **siempre** `hooks/metricas-evolucion.js` (nunca `metrics.js`, `evolucion-metricas.js`, `evolution-metrics.js`).
134
+ - Para forzar regen: pipe `echo '{}' | node ...`, nunca invocar `require()` directo.
135
+
136
+ ## Response Discipline
137
+
138
+ Si el usuario pasa `--json`: respuesta = **contenido crudo del archivo**,
139
+ sin prosa ni comentarios.
140
+
141
+ Si no: dashboard formateado con las 5 secciones. Las recomendaciones del
142
+ Paso 4 van al final, máximo 3 items priorizados. Sin repetir datos del dashboard.