@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.
- package/CLAUDE.md +238 -0
- package/README.md +560 -0
- package/_userland/agentes/.gitkeep +0 -0
- package/_userland/habilidades/.gitkeep +0 -0
- package/agentes/.evolved.json +9 -0
- package/agentes/accesibilidad-wcag-swl.md +692 -0
- package/agentes/arquitecto-swl.md +238 -0
- package/agentes/auto-evolucion-swl.md +854 -0
- package/agentes/backend-api-swl.md +470 -0
- package/agentes/backend-csharp-swl.md +418 -0
- package/agentes/backend-go-swl.md +388 -0
- package/agentes/backend-java-swl.md +279 -0
- package/agentes/backend-node-swl.md +477 -0
- package/agentes/backend-python-swl.md +608 -0
- package/agentes/backend-rust-swl.md +362 -0
- package/agentes/backend-workers-swl.md +480 -0
- package/agentes/cloud-infra-swl.md +485 -0
- package/agentes/consolidador-swl.md +539 -0
- package/agentes/datos-swl.md +584 -0
- package/agentes/depurador-swl.md +349 -0
- package/agentes/devops-ci-swl.md +374 -0
- package/agentes/disenador-ui-swl.md +558 -0
- package/agentes/documentador-swl.md +343 -0
- package/agentes/evals/arquitecto-swl.evals.json +56 -0
- package/agentes/evals/auto-evolucion-swl.evals.json +68 -0
- package/agentes/evals/implementador-swl.evals.json +56 -0
- package/agentes/evals/orquestador-swl.evals.json +60 -0
- package/agentes/evals/perfilador-usuario-swl.evals.json +60 -0
- package/agentes/evals/red-team-swl.evals.json +59 -0
- package/agentes/evals/revisor-codigo-swl.evals.json +59 -0
- package/agentes/frontend-angular-swl.md +627 -0
- package/agentes/frontend-css-swl.md +720 -0
- package/agentes/frontend-react-swl.md +696 -0
- package/agentes/frontend-swl.md +500 -0
- package/agentes/frontend-tailwind-swl.md +830 -0
- package/agentes/implementador-swl.md +328 -0
- package/agentes/investigador-swl.md +430 -0
- package/agentes/investigador-ux-swl.md +500 -0
- package/agentes/llm-apps-swl.md +276 -0
- package/agentes/migrador-swl.md +417 -0
- package/agentes/mobile-android-swl.md +509 -0
- package/agentes/mobile-cross-swl.md +539 -0
- package/agentes/mobile-ios-swl.md +500 -0
- package/agentes/mobile-testing-swl.md +300 -0
- package/agentes/notificador-swl.md +916 -0
- package/agentes/observabilidad-swl.md +436 -0
- package/agentes/orquestador-swl.md +884 -0
- package/agentes/pagos-swl.md +283 -0
- package/agentes/perfilador-usuario-swl.md +306 -0
- package/agentes/planificador-swl.md +402 -0
- package/agentes/producto-prd-swl.md +587 -0
- package/agentes/red-team-swl.md +216 -0
- package/agentes/release-manager-swl.md +568 -0
- package/agentes/rendimiento-swl.md +714 -0
- package/agentes/resolutor-build-swl.md +243 -0
- package/agentes/revisor-angular-swl.md +276 -0
- package/agentes/revisor-codigo-swl.md +348 -0
- package/agentes/revisor-csharp-swl.md +262 -0
- package/agentes/revisor-go-swl.md +257 -0
- package/agentes/revisor-java-swl.md +255 -0
- package/agentes/revisor-kotlin-swl.md +271 -0
- package/agentes/revisor-nextjs-swl.md +279 -0
- package/agentes/revisor-php-swl.md +269 -0
- package/agentes/revisor-react-swl.md +276 -0
- package/agentes/revisor-rust-swl.md +344 -0
- package/agentes/revisor-seguridad-swl.md +390 -0
- package/agentes/revisor-swift-swl.md +266 -0
- package/agentes/revisor-typescript-swl.md +344 -0
- package/agentes/sre-swl.md +265 -0
- package/agentes/tdd-qa-swl.md +354 -0
- package/agentes/ux-disenador-swl.md +501 -0
- package/bin/lib/bot-comandos.js +1030 -0
- package/bin/lib/bot-discovery.js +182 -0
- package/bin/lib/bot-git.js +142 -0
- package/bin/swl-ses.js +325 -0
- package/bin/swl-telegram-bot.js +442 -0
- package/bin/swl-telegram-bot.plist +21 -0
- package/bin/swl-telegram-bot.service +14 -0
- package/comandos/swl/.evolved.json +23 -0
- package/comandos/swl/actualizar.md +174 -0
- package/comandos/swl/adoptar-proyecto.md +207 -0
- package/comandos/swl/aprender.md +701 -0
- package/comandos/swl/auditar-deps.md +134 -0
- package/comandos/swl/autoresearch.md +170 -0
- package/comandos/swl/ayuda.md +224 -0
- package/comandos/swl/brainstorm.md +50 -0
- package/comandos/swl/checkpoint.md +330 -0
- package/comandos/swl/compactar.md +283 -0
- package/comandos/swl/configurar-ci.md +227 -0
- package/comandos/swl/contexto.md +112 -0
- package/comandos/swl/contribuir.md +233 -0
- package/comandos/swl/crear-skill.md +292 -0
- package/comandos/swl/cron.md +196 -0
- package/comandos/swl/dashboard.md +146 -0
- package/comandos/swl/discutir-fase.md +230 -0
- package/comandos/swl/ejecutar-fase.md +135 -0
- package/comandos/swl/evaluar-skill.md +487 -0
- package/comandos/swl/evolucion-estado.md +142 -0
- package/comandos/swl/evolucionar.md +259 -0
- package/comandos/swl/exportar-vault.md +189 -0
- package/comandos/swl/gateway.md +158 -0
- package/comandos/swl/inbox.md +116 -0
- package/comandos/swl/instalar.md +220 -0
- package/comandos/swl/instintos.md +86 -0
- package/comandos/swl/mapear-codebase.md +312 -0
- package/comandos/swl/mcp-status.md +175 -0
- package/comandos/swl/metricas.md +270 -0
- package/comandos/swl/modelo.md +102 -0
- package/comandos/swl/notificaciones.md +396 -0
- package/comandos/swl/nuevo-proyecto.md +154 -0
- package/comandos/swl/planear-fase.md +221 -0
- package/comandos/swl/plugins.md +256 -0
- package/comandos/swl/reflect-skills.md +125 -0
- package/comandos/swl/release.md +217 -0
- package/comandos/swl/revisar-impacto.md +206 -0
- package/comandos/swl/revisar.md +330 -0
- package/comandos/swl/salud.md +363 -0
- package/comandos/swl/sesiones.md +200 -0
- package/comandos/swl/skill-search.md +113 -0
- package/comandos/swl/verificar.md +585 -0
- package/comandos/swl/wiki.md +620 -0
- package/contextos/dev.md +32 -0
- package/contextos/research.md +30 -0
- package/contextos/review.md +31 -0
- package/habilidades/accesibilidad-a11y/SKILL.md +201 -0
- package/habilidades/accesibilidad-a11y/evals/evals.json +56 -0
- package/habilidades/accesibilidad-a11y/recursos/ejemplos-y-checklist-completo.md +441 -0
- package/habilidades/agent-browser/SKILL.md +218 -0
- package/habilidades/agentes-como-servicio/SKILL.md +218 -0
- package/habilidades/ai-runtime-security/SKILL.md +273 -0
- package/habilidades/angular-avanzado/SKILL.md +164 -0
- package/habilidades/angular-avanzado/recursos/ejemplos-avanzados.md +219 -0
- package/habilidades/angular-moderno/SKILL.md +186 -0
- package/habilidades/angular-moderno/evals/evals.json +45 -0
- package/habilidades/angular-moderno/recursos/ejemplos-avanzados.md +106 -0
- package/habilidades/api-rest-diseno/SKILL.md +191 -0
- package/habilidades/api-rest-diseno/recursos/openapi-template.yaml +506 -0
- package/habilidades/api-rest-diseno/recursos/referencia-api.md +140 -0
- package/habilidades/aprendizaje-continuo/SKILL.md +151 -0
- package/habilidades/aprendizaje-continuo/evals/evals.json +53 -0
- package/habilidades/aprendizaje-continuo/recursos/referencia-instintos.md +290 -0
- package/habilidades/async-python/SKILL.md +149 -0
- package/habilidades/async-python/evals/evals.json +47 -0
- package/habilidades/async-python/recursos/patrones-y-ejemplos-completos.md +292 -0
- package/habilidades/auth-patrones/.evolved.json +9 -0
- package/habilidades/auth-patrones/SKILL.md +413 -0
- package/habilidades/auth-patrones/recursos/implementaciones-completas.md +229 -0
- package/habilidades/auto-evolucion-protocolo/SKILL.md +276 -0
- package/habilidades/auto-evolucion-protocolo/evals/evals.json +55 -0
- package/habilidades/auto-evolucion-protocolo/recursos/referencia-completa.md +145 -0
- package/habilidades/autoresearch/SKILL.md +268 -0
- package/habilidades/autoresearch/evals/evals.json +41 -0
- package/habilidades/autoresearch/recursos/checklist-template.md +191 -0
- package/habilidades/autoresearch/scripts/calcular-score.js +88 -0
- package/habilidades/azure-cloud/SKILL.md +308 -0
- package/habilidades/azure-cloud/recursos/aks.md +327 -0
- package/habilidades/backend-mcp-servidor/SKILL.md +270 -0
- package/habilidades/backend-production-resilience/SKILL.md +288 -0
- package/habilidades/brainstorming/SKILL.md +295 -0
- package/habilidades/brainstorming/recursos/componentes-html.md +247 -0
- package/habilidades/build-errors-cpp/SKILL.md +270 -0
- package/habilidades/build-errors-csharp/SKILL.md +265 -0
- package/habilidades/build-errors-go/SKILL.md +306 -0
- package/habilidades/build-errors-java/SKILL.md +278 -0
- package/habilidades/build-errors-kotlin/SKILL.md +303 -0
- package/habilidades/build-errors-nextjs/SKILL.md +312 -0
- package/habilidades/build-errors-php/SKILL.md +270 -0
- package/habilidades/build-errors-python/SKILL.md +292 -0
- package/habilidades/build-errors-rust/SKILL.md +284 -0
- package/habilidades/build-errors-swift/SKILL.md +272 -0
- package/habilidades/build-errors-typescript/SKILL.md +369 -0
- package/habilidades/checklist-calidad/SKILL.md +271 -0
- package/habilidades/checklist-calidad/recursos/quality-report-template.md +148 -0
- package/habilidades/checklist-seguridad/SKILL.md +285 -0
- package/habilidades/checkpoints-verificacion/SKILL.md +298 -0
- package/habilidades/checkpoints-verificacion/recursos/checkpoint-templates.md +360 -0
- package/habilidades/ci-cd-pipelines/SKILL.md +157 -0
- package/habilidades/ci-cd-pipelines/recursos/github-actions-template.yaml +403 -0
- package/habilidades/ci-cd-pipelines/recursos/pipelines-completos.md +487 -0
- package/habilidades/cloud-aws/SKILL.md +142 -0
- package/habilidades/cloud-aws/recursos/servicios-aws-referencia.md +321 -0
- package/habilidades/compactacion-contexto/SKILL.md +247 -0
- package/habilidades/contenedores-docker/SKILL.md +137 -0
- package/habilidades/contenedores-docker/recursos/dockerfile-template.dockerfile +160 -0
- package/habilidades/contenedores-docker/recursos/ejemplos-y-configuraciones.md +327 -0
- package/habilidades/context-builder/SKILL.md +170 -0
- package/habilidades/control-profundidad/SKILL.md +128 -0
- package/habilidades/csharp-experto/SKILL.md +322 -0
- package/habilidades/csharp-patrones/SKILL.md +316 -0
- package/habilidades/csharp-testing/SKILL.md +286 -0
- package/habilidades/css-moderno/SKILL.md +166 -0
- package/habilidades/css-moderno/evals/evals.json +43 -0
- package/habilidades/css-moderno/recursos/ejemplos-y-patrones-completos.md +337 -0
- package/habilidades/datos-etl/SKILL.md +129 -0
- package/habilidades/datos-etl/recursos/implementaciones-completas.md +322 -0
- package/habilidades/dbml-experto/SKILL.md +339 -0
- package/habilidades/dbml-experto/evals/evals.json +56 -0
- package/habilidades/dependencias-auditoria/SKILL.md +320 -0
- package/habilidades/deprecacion-migracion/SKILL.md +169 -0
- package/habilidades/deprecacion-migracion/recursos/implementaciones-completas.md +220 -0
- package/habilidades/design-tokens/SKILL.md +158 -0
- package/habilidades/design-tokens/recursos/tokens-y-configuracion.md +363 -0
- package/habilidades/devsecops-pipeline-security/SKILL.md +309 -0
- package/habilidades/diagrama-arquitectura/SKILL.md +165 -0
- package/habilidades/diagrama-arquitectura/assets/template.html +276 -0
- package/habilidades/discutir-fase/SKILL.md +188 -0
- package/habilidades/diseno-herramientas-agente/SKILL.md +199 -0
- package/habilidades/diseno-responsivo/SKILL.md +186 -0
- package/habilidades/diseno-responsivo/recursos/ejemplos-layouts.md +156 -0
- package/habilidades/django-experto/SKILL.md +205 -0
- package/habilidades/django-experto/recursos/async-django.md +390 -0
- package/habilidades/django-experto/recursos/drf-patrones.md +438 -0
- package/habilidades/django-experto/recursos/orm-avanzado.md +382 -0
- package/habilidades/django-experto/recursos/referencia-completa.md +188 -0
- package/habilidades/django-experto/recursos/testing-django.md +415 -0
- package/habilidades/doc-sync/SKILL.md +280 -0
- package/habilidades/drift-detection/SKILL.md +179 -0
- package/habilidades/ejecutar-fase/SKILL.md +468 -0
- package/habilidades/estilo-sin-ai-isms/SKILL.md +775 -0
- package/habilidades/estilo-sin-ai-isms/evals/evals.json +63 -0
- package/habilidades/estilo-sin-ai-isms/scripts/detectar_aiisms.py +500 -0
- package/habilidades/estructura-proyecto-claude/SKILL.md +215 -0
- package/habilidades/estructura-proyecto-claude/recursos/claude-md-template.md +261 -0
- package/habilidades/estructura-proyecto-claude/recursos/configuracion-y-extensiones.md +176 -0
- package/habilidades/estructura-proyecto-claude/recursos/frontmatter-y-hooks-referencia.md +289 -0
- package/habilidades/estructura-proyecto-claude/recursos/mcp-json-template.json +77 -0
- package/habilidades/estructura-proyecto-claude/recursos/variantes-por-stack.md +177 -0
- package/habilidades/evaluacion-agentes/SKILL.md +314 -0
- package/habilidades/event-driven/SKILL.md +153 -0
- package/habilidades/event-driven/recursos/implementaciones-completas.md +423 -0
- package/habilidades/extraccion-documentos/SKILL.md +221 -0
- package/habilidades/extractor-de-aprendizajes/.evolved.json +9 -0
- package/habilidades/extractor-de-aprendizajes/SKILL.md +311 -0
- package/habilidades/extractor-de-aprendizajes/evals/evals.json +55 -0
- package/habilidades/fastapi-experto/SKILL.md +221 -0
- package/habilidades/fastapi-experto/recursos/async-patterns.md +438 -0
- package/habilidades/fastapi-experto/recursos/dependency-injection.md +330 -0
- package/habilidades/fastapi-experto/recursos/referencia-completa.md +79 -0
- package/habilidades/fastapi-experto/recursos/testing-httpx.md +420 -0
- package/habilidades/filament-admin/SKILL.md +290 -0
- package/habilidades/frontend-avanzado/SKILL.md +257 -0
- package/habilidades/frontend-avanzado/recursos/apis-nativas-ejemplos.md +341 -0
- package/habilidades/gcp-cloud/SKILL.md +260 -0
- package/habilidades/gcp-cloud/recursos/gke.md +234 -0
- package/habilidades/gcp-cloud/recursos/terraform-gcp.md +307 -0
- package/habilidades/generacion-mermaid/SKILL.md +229 -0
- package/habilidades/git-worktrees-paralelo/SKILL.md +270 -0
- package/habilidades/go-experto/SKILL.md +305 -0
- package/habilidades/go-patrones/SKILL.md +299 -0
- package/habilidades/go-testing/SKILL.md +291 -0
- package/habilidades/graphql-experto/SKILL.md +323 -0
- package/habilidades/guardrail-semantico/SKILL.md +282 -0
- package/habilidades/harness-claude-code/SKILL.md +299 -0
- package/habilidades/iam-secretos/SKILL.md +265 -0
- package/habilidades/iam-secretos/recursos/implementaciones-completas.md +356 -0
- package/habilidades/infra-github-actions/SKILL.md +166 -0
- package/habilidades/instalar-sistema/.evolved.json +9 -0
- package/habilidades/instalar-sistema/SKILL.md +221 -0
- package/habilidades/java-experto/SKILL.md +290 -0
- package/habilidades/java-patrones/SKILL.md +275 -0
- package/habilidades/java-testing/SKILL.md +288 -0
- package/habilidades/kotlin-compose/SKILL.md +278 -0
- package/habilidades/kotlin-compose/recursos/animaciones-performance.md +93 -0
- package/habilidades/kotlin-experto/SKILL.md +318 -0
- package/habilidades/kotlin-testing/SKILL.md +267 -0
- package/habilidades/kotlin-testing/recursos/testing-avanzado.md +74 -0
- package/habilidades/kubernetes-orquestacion/SKILL.md +152 -0
- package/habilidades/kubernetes-orquestacion/recursos/manifiestos-completos.md +452 -0
- package/habilidades/langchain-langraph/SKILL.md +386 -0
- package/habilidades/langchain-langraph/recursos/evaluacion-rag.md +321 -0
- package/habilidades/langchain-langraph/recursos/rag-maturity-model.md +225 -0
- package/habilidades/langchain-langraph/recursos/vectorstores.md +306 -0
- package/habilidades/legacy-code-rescue/SKILL.md +267 -0
- package/habilidades/likec4-experto/SKILL.md +412 -0
- package/habilidades/likec4-experto/evals/evals.json +69 -0
- package/habilidades/manejo-errores/.evolved.json +9 -0
- package/habilidades/manejo-errores/SKILL.md +407 -0
- package/habilidades/manejo-errores/recursos/implementaciones-completas.md +248 -0
- package/habilidades/mapear-codebase/SKILL.md +275 -0
- package/habilidades/memoria-busqueda/SKILL.md +194 -0
- package/habilidades/memoria-busqueda/evals/evals.json +44 -0
- package/habilidades/meta-skills-estandar/SKILL.md +298 -0
- package/habilidades/meta-skills-estandar/recursos/anti-patrones-y-leyes.md +205 -0
- package/habilidades/meta-skills-estandar/recursos/frameworks-seguridad.md +107 -0
- package/habilidades/meta-skills-estandar/recursos/idiomas-framework.md +60 -0
- package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -0
- package/habilidades/microservicios/SKILL.md +155 -0
- package/habilidades/microservicios/recursos/patrones-y-ejemplos-completos.md +325 -0
- package/habilidades/mobile-flutter/SKILL.md +199 -0
- package/habilidades/mobile-flutter/recursos/ejemplos-completos.md +319 -0
- package/habilidades/mobile-react-native/SKILL.md +176 -0
- package/habilidades/mobile-react-native/recursos/ejemplos-completos.md +216 -0
- package/habilidades/mongodb-experto/SKILL.md +302 -0
- package/habilidades/monitoring-alertas/SKILL.md +201 -0
- package/habilidades/monitoring-alertas/recursos/instrumentacion-y-alertas.md +301 -0
- package/habilidades/nestjs-experto/SKILL.md +307 -0
- package/habilidades/nestjs-experto/recursos/guards-interceptors.md +339 -0
- package/habilidades/nestjs-experto/recursos/modulos-di.md +287 -0
- package/habilidades/nestjs-experto/recursos/testing-nestjs.md +354 -0
- package/habilidades/nextjs-experto/SKILL.md +335 -0
- package/habilidades/nextjs-patrones/SKILL.md +303 -0
- package/habilidades/nextjs-testing/SKILL.md +331 -0
- package/habilidades/node-experto/.evolved.json +9 -0
- package/habilidades/node-experto/SKILL.md +266 -0
- package/habilidades/node-experto/recursos/patrones-completos.md +283 -0
- package/habilidades/notificaciones-multicanal/SKILL.md +159 -0
- package/habilidades/notificaciones-multicanal/recursos/config-template.json +115 -0
- package/habilidades/notificaciones-multicanal/recursos/configuracion-y-templates.md +303 -0
- package/habilidades/nuevo-proyecto/SKILL.md +204 -0
- package/habilidades/orquestacion-async/SKILL.md +303 -0
- package/habilidades/paid-media-tracking/SKILL.md +269 -0
- package/habilidades/paid-media-tracking/recursos/auditoria-tracking.md +220 -0
- package/habilidades/paid-media-tracking/recursos/google-ads-api.md +215 -0
- package/habilidades/patrones-python/SKILL.md +228 -0
- package/habilidades/patrones-python/evals/evals.json +56 -0
- package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -0
- package/habilidades/patrones-python/recursos/referencia-completa.md +202 -0
- package/habilidades/perfil-usuario/SKILL.md +200 -0
- package/habilidades/perfil-usuario/evals/evals.json +55 -0
- package/habilidades/performance-baseline/SKILL.md +297 -0
- package/habilidades/php-experto/SKILL.md +291 -0
- package/habilidades/php-patrones/SKILL.md +306 -0
- package/habilidades/php-testing/SKILL.md +280 -0
- package/habilidades/planear-fase/SKILL.md +269 -0
- package/habilidades/postgresql-experto/SKILL.md +151 -0
- package/habilidades/postgresql-experto/evals/evals.json +53 -0
- package/habilidades/postgresql-experto/recursos/referencia-completa.md +215 -0
- package/habilidades/prevencion-racionalizacion/SKILL.md +175 -0
- package/habilidades/prevencion-sobreingenieria/SKILL.md +323 -0
- package/habilidades/privacy-memoria/SKILL.md +141 -0
- package/habilidades/privacy-memoria/evals/evals.json +43 -0
- package/habilidades/prompt-engineering/SKILL.md +518 -0
- package/habilidades/prompt-engineering/recursos/patrones-avanzados.md +467 -0
- package/habilidades/rag-arquitectura/SKILL.md +338 -0
- package/habilidades/rails-experto/SKILL.md +237 -0
- package/habilidades/rails-experto/recursos/active-record.md +260 -0
- package/habilidades/rails-experto/recursos/hotwire-turbo.md +293 -0
- package/habilidades/rails-experto/recursos/testing-rspec.md +362 -0
- package/habilidades/react-experto/SKILL.md +209 -0
- package/habilidades/react-experto/evals/evals.json +55 -0
- package/habilidades/react-experto/recursos/patrones-y-ejemplos-completos.md +240 -0
- package/habilidades/react-optimizacion/SKILL.md +174 -0
- package/habilidades/react-optimizacion/recursos/patrones-avanzados.md +138 -0
- package/habilidades/redis-experto/SKILL.md +305 -0
- package/habilidades/release-semver/.evolved.json +9 -0
- package/habilidades/release-semver/SKILL.md +248 -0
- package/habilidades/release-semver/scripts/generar-changelog.sh +238 -0
- package/habilidades/rust-experto/SKILL.md +400 -0
- package/habilidades/rust-patrones/SKILL.md +296 -0
- package/habilidades/rust-testing/SKILL.md +311 -0
- package/habilidades/seguridad-skills-ia/SKILL.md +262 -0
- package/habilidades/sql-optimizacion/SKILL.md +200 -0
- package/habilidades/sql-optimizacion/evals/evals.json +54 -0
- package/habilidades/sql-optimizacion/recursos/patrones-sql-avanzados.md +131 -0
- package/habilidades/sre-patrones/SKILL.md +333 -0
- package/habilidades/sre-patrones/recursos/chaos-engineering.md +241 -0
- package/habilidades/sre-patrones/recursos/oncall-design.md +236 -0
- package/habilidades/stripe-pagos/SKILL.md +550 -0
- package/habilidades/stripe-pagos/recursos/errores-reintentos.md +390 -0
- package/habilidades/stripe-pagos/recursos/stripe-connect.md +290 -0
- package/habilidades/structured-outputs/SKILL.md +343 -0
- package/habilidades/swift-experto/SKILL.md +320 -0
- package/habilidades/swift-experto/recursos/keychain-y-wrappers.md +110 -0
- package/habilidades/swift-patrones/SKILL.md +313 -0
- package/habilidades/swift-patrones/recursos/tca-ejemplo-completo.md +113 -0
- package/habilidades/swift-testing/SKILL.md +254 -0
- package/habilidades/swift-testing/recursos/xcuitest-planes.md +143 -0
- package/habilidades/swl-dashboard/SKILL.md +370 -0
- package/habilidades/swl-markitdown/SKILL.md +285 -0
- package/habilidades/swl-markitdown/evals/evals.json +52 -0
- package/habilidades/swl-revisar-impacto/SKILL.md +233 -0
- package/habilidades/tailwind-experto/SKILL.md +240 -0
- package/habilidades/tailwind-experto/recursos/referencia-completa.md +184 -0
- package/habilidades/tdd-workflow/SKILL.md +293 -0
- package/habilidades/terraform-experto/SKILL.md +321 -0
- package/habilidades/testing-python/SKILL.md +340 -0
- package/habilidades/testing-python/recursos/ejemplos-completos.md +167 -0
- package/habilidades/threat-model-lite/SKILL.md +246 -0
- package/habilidades/tracing-processor/SKILL.md +212 -0
- package/habilidades/tracking-measurement/SKILL.md +239 -0
- package/habilidades/tracking-measurement/recursos/consent-mode.md +231 -0
- package/habilidades/tracking-measurement/recursos/gtm-datalayer.md +216 -0
- package/habilidades/tracking-measurement/recursos/meta-capi.md +262 -0
- package/habilidades/typescript-avanzado/SKILL.md +144 -0
- package/habilidades/typescript-avanzado/evals/evals.json +55 -0
- package/habilidades/typescript-avanzado/recursos/patrones-y-ejemplos-completos.md +298 -0
- package/habilidades/typescript-diagnosticos/SKILL.md +513 -0
- package/habilidades/ux-diseno/SKILL.md +116 -0
- package/habilidades/ux-diseno/evals/evals.json +43 -0
- package/habilidades/ux-diseno/recursos/patrones-ux-referencia.md +214 -0
- package/habilidades/validacion-ci-sistema/SKILL.md +136 -0
- package/habilidades/validacion-ci-sistema/recursos/validadores-completos.md +369 -0
- package/habilidades/validacion-ci-sistema/scripts/validar-sistema.sh +286 -0
- package/habilidades/verificacion-evidencia/SKILL.md +160 -0
- package/habilidades/verificar-trabajo/SKILL.md +303 -0
- package/habilidades/verificar-trabajo/recursos/plantilla-verificacion.md +60 -0
- package/habilidades/wiki-conocimiento/SKILL.md +276 -0
- package/habilidades/wireframes-flujos/SKILL.md +212 -0
- package/habilidades/wireframes-flujos/recursos/referencia-completa.md +192 -0
- package/habilidades/workflow-claude-code/SKILL.md +260 -0
- package/habilidades/workflow-claude-code/recursos/referencia-completa.md +109 -0
- package/hooks/_run-hook.sh +57 -0
- package/hooks/actualizar-perfil-usuario.js +364 -0
- package/hooks/agente-lifecycle.js +71 -0
- package/hooks/aiisms-detector.js +173 -0
- package/hooks/audit-trail.js +204 -0
- package/hooks/auto-background.js +97 -0
- package/hooks/auto-consolidacion.js +178 -0
- package/hooks/auto-evolucion.js +666 -0
- package/hooks/auto-restaurar-settings.js +360 -0
- package/hooks/calidad-pre-commit.js +929 -0
- package/hooks/calidad-typescript.js +511 -0
- package/hooks/captura-feedback-usuario.js +148 -0
- package/hooks/check-update.js +211 -0
- package/hooks/clasificador-mensajes.js +271 -0
- package/hooks/degradacion-instintos.js +272 -0
- package/hooks/escaneo-secretos.js +389 -0
- package/hooks/extraccion-aprendizajes.js +763 -0
- package/hooks/grafo-contexto.js +129 -0
- package/hooks/graph-update.js +67 -0
- package/hooks/guardrail-modelo.js +247 -0
- package/hooks/inbox-aviso.js +75 -0
- package/hooks/inyeccion-contexto.js +246 -0
- package/hooks/lib/abort-registry.js +214 -0
- package/hooks/lib/agent-backend.js +210 -0
- package/hooks/lib/agent-comms.js +263 -0
- package/hooks/lib/agent-issue-codes.js +284 -0
- package/hooks/lib/agent-matcher.js +189 -0
- package/hooks/lib/async-hook-registry.js +252 -0
- package/hooks/lib/atomic-write.js +130 -0
- package/hooks/lib/auto-consolidator.js +335 -0
- package/hooks/lib/canary-skills.js +187 -0
- package/hooks/lib/consolidation-lock.js +291 -0
- package/hooks/lib/context-builder.js +430 -0
- package/hooks/lib/context-compressor.js +657 -0
- package/hooks/lib/convergence-detector.js +105 -0
- package/hooks/lib/delegation-tracker.js +198 -0
- package/hooks/lib/detectar-package-manager.js +423 -0
- package/hooks/lib/edit-accumulator.js +171 -0
- package/hooks/lib/error-classifier.js +308 -0
- package/hooks/lib/event-bus.js +112 -0
- package/hooks/lib/evolution-tracker.js +442 -0
- package/hooks/lib/execution-state.js +316 -0
- package/hooks/lib/fingerprint-id.js +135 -0
- package/hooks/lib/gateway-notify.js +116 -0
- package/hooks/lib/graph-security.js +75 -0
- package/hooks/lib/guardrail-metrics.js +202 -0
- package/hooks/lib/hook-circuit-breaker.js +206 -0
- package/hooks/lib/loop-detector.js +267 -0
- package/hooks/lib/mcp-health.js +184 -0
- package/hooks/lib/mcp-pool.js +436 -0
- package/hooks/lib/memory-search.js +506 -0
- package/hooks/lib/merkle-audit.js +96 -0
- package/hooks/lib/model-router.js +222 -0
- package/hooks/lib/normalize-error.js +324 -0
- package/hooks/lib/normalize-input.js +65 -0
- package/hooks/lib/nudge-tracker.js +306 -0
- package/hooks/lib/otlp-exporter.js +365 -0
- package/hooks/lib/performance-marks.js +239 -0
- package/hooks/lib/privacy-filter.js +128 -0
- package/hooks/lib/prompt-injection-scanner.js +209 -0
- package/hooks/lib/provenance-tracker.js +183 -0
- package/hooks/lib/rate-limit-tracker.js +253 -0
- package/hooks/lib/reflect-classifier.js +164 -0
- package/hooks/lib/resource-quota.js +122 -0
- package/hooks/lib/retry-jitter.js +165 -0
- package/hooks/lib/risk-engine.js +368 -0
- package/hooks/lib/run-log.js +408 -0
- package/hooks/lib/session-fts.js +379 -0
- package/hooks/lib/session-store.js +293 -0
- package/hooks/lib/singleton-guard.js +159 -0
- package/hooks/lib/skill-auditor.js +588 -0
- package/hooks/lib/sync-status.js +228 -0
- package/hooks/lib/taint-tracker.js +107 -0
- package/hooks/lib/task-service.js +295 -0
- package/hooks/lib/tech-skills-map.js +146 -0
- package/hooks/lib/telegram-cliente.js +159 -0
- package/hooks/lib/telegram-config.js +170 -0
- package/hooks/lib/token-budget.js +156 -0
- package/hooks/lib/token-estimator.js +420 -0
- package/hooks/lib/toon-compressor.js +245 -0
- package/hooks/lib/usage-model.js +183 -0
- package/hooks/lib/variable-resolver.js +230 -0
- package/hooks/linea-estado.js +324 -0
- package/hooks/metricas-evolucion.js +209 -0
- package/hooks/monitor-contexto.js +325 -0
- package/hooks/notificacion-sesion-stop.js +198 -0
- package/hooks/notificacion-telegram-notification.js +4 -0
- package/hooks/notificacion-telegram-subagent.js +4 -0
- package/hooks/notificacion-telegram.js +267 -0
- package/hooks/preservar-estado-pre-compact.js +150 -0
- package/hooks/proteccion-rutas.js +366 -0
- package/hooks/registro-turnos.js +209 -0
- package/hooks/resumen-sesion.js +249 -0
- package/hooks/risk-scoring.js +323 -0
- package/hooks/rotar-audit-auto.js +122 -0
- package/hooks/sugerir-regenerar-inventario.js +170 -0
- package/hooks/telemetria-agentes.js +167 -0
- package/hooks/tracking-costos.js +688 -0
- package/instintos/global.yaml +8 -0
- package/instintos/perfil-usuario.yaml +53 -0
- package/instintos/prompt-appendices.yaml +57 -0
- package/instintos/proyecto.yaml +372 -0
- package/manifiestos/gateway-config.json +77 -0
- package/manifiestos/handoff-context.json +223 -0
- package/manifiestos/hook-profiles.json +44 -0
- package/manifiestos/hooks-config.json +360 -0
- package/manifiestos/modulos.json +1173 -0
- package/manifiestos/perfiles.json +404 -0
- package/package.json +86 -0
- package/plantillas/ESTADO.md +109 -0
- package/plantillas/HOJA-RUTA.md +143 -0
- package/plantillas/PROYECTO.md +122 -0
- package/plantillas/REQUISITOS.md +132 -0
- package/plantillas/auditor-veto-template.md +105 -0
- package/plantillas/github-workflows/README.md +47 -0
- package/plantillas/github-workflows/release-please.yml +44 -0
- package/plantillas/github-workflows/swl-ci.yml +107 -0
- package/plantillas/github-workflows/swl-security.yml +51 -0
- package/plantillas/mcp-mineru.json +13 -0
- package/plantillas/research/ARQUITECTURA.md +220 -0
- package/plantillas/research/FUNCIONALIDADES.md +175 -0
- package/plantillas/research/RESUMEN.md +165 -0
- package/plantillas/research/STACK.md +233 -0
- package/plantillas/research/TRAMPAS.md +299 -0
- package/plantillas/skill-evals-template.json +44 -0
- package/plugin.json +343 -0
- package/reglas/accesibilidad.md +269 -0
- package/reglas/api-diseno.md +400 -0
- package/reglas/arquitectura.md +352 -0
- package/reglas/brevedad-output.md +124 -0
- package/reglas/cloud-infra.md +247 -0
- package/reglas/docs.md +245 -0
- package/reglas/estilo-codigo.md +201 -0
- package/reglas/git-workflow.md +245 -0
- package/reglas/gobernanza.md +271 -0
- package/reglas/harness-claude-code.md +213 -0
- package/reglas/hooks.md +186 -0
- package/reglas/lenguajes/csharp/estilo-codigo.md +231 -0
- package/reglas/lenguajes/csharp/hooks.md +281 -0
- package/reglas/lenguajes/csharp/patrones.md +226 -0
- package/reglas/lenguajes/csharp/seguridad.md +258 -0
- package/reglas/lenguajes/csharp/testing.md +176 -0
- package/reglas/lenguajes/go/estilo-codigo.md +195 -0
- package/reglas/lenguajes/go/hooks.md +249 -0
- package/reglas/lenguajes/go/patrones.md +249 -0
- package/reglas/lenguajes/go/seguridad.md +225 -0
- package/reglas/lenguajes/go/testing.md +272 -0
- package/reglas/lenguajes/java/estilo-codigo.md +217 -0
- package/reglas/lenguajes/java/hooks.md +251 -0
- package/reglas/lenguajes/java/patrones.md +226 -0
- package/reglas/lenguajes/java/seguridad.md +233 -0
- package/reglas/lenguajes/java/testing.md +238 -0
- package/reglas/lenguajes/kotlin/estilo-codigo.md +208 -0
- package/reglas/lenguajes/kotlin/hooks.md +245 -0
- package/reglas/lenguajes/kotlin/patrones.md +201 -0
- package/reglas/lenguajes/kotlin/seguridad.md +202 -0
- package/reglas/lenguajes/kotlin/testing.md +236 -0
- package/reglas/lenguajes/nextjs/estilo-codigo.md +175 -0
- package/reglas/lenguajes/nextjs/hooks.md +186 -0
- package/reglas/lenguajes/nextjs/patrones.md +225 -0
- package/reglas/lenguajes/nextjs/seguridad.md +216 -0
- package/reglas/lenguajes/nextjs/testing.md +193 -0
- package/reglas/lenguajes/php/estilo-codigo.md +228 -0
- package/reglas/lenguajes/php/hooks.md +165 -0
- package/reglas/lenguajes/php/patrones.md +233 -0
- package/reglas/lenguajes/php/seguridad.md +186 -0
- package/reglas/lenguajes/php/testing.md +205 -0
- package/reglas/lenguajes/rust/estilo-codigo.md +207 -0
- package/reglas/lenguajes/rust/hooks.md +240 -0
- package/reglas/lenguajes/rust/patrones.md +250 -0
- package/reglas/lenguajes/rust/seguridad.md +221 -0
- package/reglas/lenguajes/rust/testing.md +194 -0
- package/reglas/lenguajes/swift/estilo-codigo.md +238 -0
- package/reglas/lenguajes/swift/hooks.md +257 -0
- package/reglas/lenguajes/swift/patrones.md +235 -0
- package/reglas/lenguajes/swift/seguridad.md +248 -0
- package/reglas/lenguajes/swift/testing.md +242 -0
- package/reglas/markitdown.md +60 -0
- package/reglas/memoria-consolidada.md +209 -0
- package/reglas/patrones.md +225 -0
- package/reglas/performance.md +195 -0
- package/reglas/pruebas.md +159 -0
- package/reglas/seguridad-agentes.md +351 -0
- package/reglas/seguridad.md +151 -0
- package/reglas/skills-estandar.md +373 -0
- package/reglas/testing.md +193 -0
- package/schemas/agent-contract.json +176 -0
- package/schemas/agent-frontmatter.schema.json +149 -0
- package/schemas/agent-message.schema.json +53 -0
- package/schemas/agent-output-implementacion.schema.json +85 -0
- package/schemas/agent-output-planificacion.schema.json +113 -0
- package/schemas/agent-output-review.schema.json +78 -0
- package/schemas/diary-entry.schema.json +80 -0
- package/schemas/hook-profiles.schema.json +39 -0
- package/schemas/hooks-config.schema.json +74 -0
- package/schemas/instinct.schema.json +115 -0
- package/schemas/modulos.schema.json +29 -0
- package/schemas/perfiles.schema.json +28 -0
- package/schemas/plugin.schema.json +64 -0
- package/schemas/skill-evals.schema.json +95 -0
- package/schemas/skill-frontmatter.schema.json +170 -0
- package/scripts/actualizar.js +145 -0
- package/scripts/audit-skills.sh +78 -0
- package/scripts/auditar-agentes-gaps.js +149 -0
- package/scripts/auditar-cobertura-frameworks.js +241 -0
- package/scripts/auditar-skills-gaps.js +206 -0
- package/scripts/bootstrap-instintos.js +259 -0
- package/scripts/check-update.js +109 -0
- package/scripts/comandos/agents.js +105 -0
- package/scripts/comandos/info.js +108 -0
- package/scripts/comandos/install-asistido.js +186 -0
- package/scripts/comandos/skills.js +211 -0
- package/scripts/configurar-branch-protection.js +418 -0
- package/scripts/daemon-swl.py +388 -0
- package/scripts/desinstalar.js +130 -0
- package/scripts/doctor.js +559 -0
- package/scripts/field-report.js +199 -0
- package/scripts/generar-inventario.js +317 -0
- package/scripts/inbox-tmux-inject.js +161 -0
- package/scripts/inferir-herramientas-permitidas.js +586 -0
- package/scripts/inicializar.js +133 -0
- package/scripts/instalador.js +1031 -0
- package/scripts/instalar-git-hook.js +122 -0
- package/scripts/lib/agp-frontmatter.js +222 -0
- package/scripts/lib/append-con-marcadores.js +199 -0
- package/scripts/lib/artefactos-python.js +43 -0
- package/scripts/lib/audit-query.js +221 -0
- package/scripts/lib/autostart-linux.js +347 -0
- package/scripts/lib/autostart-macos.js +360 -0
- package/scripts/lib/autostart-windows.js +307 -0
- package/scripts/lib/budget-enforcer.js +252 -0
- package/scripts/lib/claude-sessions.js +285 -0
- package/scripts/lib/configurar-ci.js +380 -0
- package/scripts/lib/console-span-exporter.js +92 -0
- package/scripts/lib/contadores-inventario.js +217 -0
- package/scripts/lib/dashboard-widgets.js +290 -0
- package/scripts/lib/detectar-runtime.js +279 -0
- package/scripts/lib/detectar-stack.js +187 -0
- package/scripts/lib/diary-entry.js +234 -0
- package/scripts/lib/drift-detector.js +545 -0
- package/scripts/lib/estado.js +124 -0
- package/scripts/lib/gestor-componentes.js +243 -0
- package/scripts/lib/gitignore-manifest.js +305 -0
- package/scripts/lib/graph-analyze.py +556 -0
- package/scripts/lib/graph-builder.py +485 -0
- package/scripts/lib/graph-cluster.py +259 -0
- package/scripts/lib/health-row.js +168 -0
- package/scripts/lib/hooks-settings.js +789 -0
- package/scripts/lib/manifiestos.js +138 -0
- package/scripts/lib/mc-client.js +137 -0
- package/scripts/lib/notificaciones-telegram.js +1107 -0
- package/scripts/lib/npm-version.js +261 -0
- package/scripts/lib/paquetes-conocidos.js +50 -0
- package/scripts/lib/preservar-usuario.js +586 -0
- package/scripts/lib/prompt-builder.js +264 -0
- package/scripts/lib/resolver-externo.js +332 -0
- package/scripts/lib/schedule-parser.js +305 -0
- package/scripts/lib/scoring-instintos.js +240 -0
- package/scripts/lib/seguridad.js +160 -0
- package/scripts/lib/selector-interactivo.js +152 -0
- package/scripts/lib/semantic-search.js +242 -0
- package/scripts/lib/skill-discovery.js +234 -0
- package/scripts/lib/skill-metrics.js +246 -0
- package/scripts/lib/skill-normalizer.js +112 -0
- package/scripts/lib/skills-hub.js +340 -0
- package/scripts/lib/span-schema.js +134 -0
- package/scripts/lib/tool-cost-analyzer.js +255 -0
- package/scripts/lib/tracing-processor-interface.js +286 -0
- package/scripts/lib/transformadores/base.js +80 -0
- package/scripts/lib/transformadores/claude.js +124 -0
- package/scripts/lib/transformadores/codex.js +115 -0
- package/scripts/lib/transformadores/copilot.js +106 -0
- package/scripts/lib/transformadores/gemini.js +74 -0
- package/scripts/lib/transformadores/index.js +35 -0
- package/scripts/lib/transformadores/opencode.js +75 -0
- package/scripts/lib/ui.js +259 -0
- package/scripts/limpiar-artefactos-python.js +131 -0
- package/scripts/mcp-orchestrator.py +386 -0
- package/scripts/mcp-pool-manager.py +352 -0
- package/scripts/mcp-telemetry.py +378 -0
- package/scripts/poblar-evolvable.js +226 -0
- package/scripts/publicar.js +287 -0
- package/scripts/reflect-skills.js +403 -0
- package/scripts/rotar-audit-logs.js +185 -0
- package/scripts/run-skill-evals.js +242 -0
- package/scripts/smoke-test.js +374 -0
- package/scripts/token-analysis.py +471 -0
- package/scripts/validar-manifest.js +195 -0
- package/scripts/validar-memoria.js +321 -0
- package/scripts/validar-tests-aislamiento.js +184 -0
- package/scripts/validar-tokens-test.js +208 -0
- package/scripts/validar.js +147 -0
- package/scripts/validate-markdown.py +339 -0
- package/scripts/validate-skills.py +385 -0
- package/scripts/vendor/claude-usage/README.md +116 -0
- package/scripts/vendor/claude-usage/cli.py +334 -0
- package/scripts/vendor/claude-usage/dashboard.py +795 -0
- package/scripts/vendor/claude-usage/scanner.py +467 -0
- package/scripts/vendor/markitdown/cli.py +194 -0
- package/scripts/verificar-evolucion.js +289 -0
- 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.
|