@heytherevibin/skillforge 0.2.1
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/CHANGELOG.md +16 -0
- package/CODE_OF_CONDUCT.md +34 -0
- package/CONTRIBUTING.md +38 -0
- package/LICENSE +21 -0
- package/README.md +337 -0
- package/RELEASING.md +93 -0
- package/SECURITY.md +31 -0
- package/STRATEGY.md +26 -0
- package/bin/cli.js +547 -0
- package/lib/packs.js +184 -0
- package/package.json +38 -0
- package/python/app/__init__.py +0 -0
- package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
- package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
- package/python/app/__pycache__/main.cpython-312.pyc +0 -0
- package/python/app/auth.py +63 -0
- package/python/app/cli.py +78 -0
- package/python/app/db_paths.py +26 -0
- package/python/app/events_cli.py +175 -0
- package/python/app/main.py +647 -0
- package/python/app/materialize.py +138 -0
- package/python/app/mcp_server.py +610 -0
- package/python/app/route_cli.py +117 -0
- package/python/requirements-dev.txt +1 -0
- package/python/requirements.txt +7 -0
- package/python/tests/test_db_paths.py +41 -0
- package/skills/accessibility/SKILL.md +145 -0
- package/skills/agent-architecture-audit/SKILL.md +256 -0
- package/skills/agent-eval/SKILL.md +144 -0
- package/skills/agent-harness-construction/SKILL.md +72 -0
- package/skills/agent-introspection-debugging/SKILL.md +152 -0
- package/skills/agent-payment-x402/SKILL.md +224 -0
- package/skills/agent-sort/SKILL.md +214 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/agentic-os/SKILL.md +386 -0
- package/skills/ai-first-engineering/SKILL.md +50 -0
- package/skills/ai-regression-testing/SKILL.md +384 -0
- package/skills/android-clean-architecture/SKILL.md +338 -0
- package/skills/angular-developer/SKILL.md +153 -0
- package/skills/angular-developer/references/angular-animations.md +160 -0
- package/skills/angular-developer/references/angular-aria.md +410 -0
- package/skills/angular-developer/references/cli.md +86 -0
- package/skills/angular-developer/references/component-harnesses.md +59 -0
- package/skills/angular-developer/references/component-styling.md +91 -0
- package/skills/angular-developer/references/components.md +117 -0
- package/skills/angular-developer/references/creating-services.md +97 -0
- package/skills/angular-developer/references/data-resolvers.md +69 -0
- package/skills/angular-developer/references/define-routes.md +67 -0
- package/skills/angular-developer/references/defining-providers.md +72 -0
- package/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/skills/angular-developer/references/e2e-testing.md +56 -0
- package/skills/angular-developer/references/effects.md +83 -0
- package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/skills/angular-developer/references/host-elements.md +80 -0
- package/skills/angular-developer/references/injection-context.md +63 -0
- package/skills/angular-developer/references/inputs.md +101 -0
- package/skills/angular-developer/references/linked-signal.md +59 -0
- package/skills/angular-developer/references/loading-strategies.md +61 -0
- package/skills/angular-developer/references/mcp.md +108 -0
- package/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/skills/angular-developer/references/outputs.md +86 -0
- package/skills/angular-developer/references/reactive-forms.md +122 -0
- package/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/skills/angular-developer/references/resource.md +77 -0
- package/skills/angular-developer/references/route-animations.md +56 -0
- package/skills/angular-developer/references/route-guards.md +52 -0
- package/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/skills/angular-developer/references/router-testing.md +87 -0
- package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/skills/angular-developer/references/signal-forms.md +795 -0
- package/skills/angular-developer/references/signals-overview.md +94 -0
- package/skills/angular-developer/references/tailwind-css.md +69 -0
- package/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/skills/api-connector-builder/SKILL.md +120 -0
- package/skills/api-design/SKILL.md +522 -0
- package/skills/architecture-decision-records/SKILL.md +178 -0
- package/skills/article-writing/SKILL.md +78 -0
- package/skills/automation-audit-ops/SKILL.md +141 -0
- package/skills/autonomous-agent-harness/SKILL.md +272 -0
- package/skills/autonomous-loops/SKILL.md +609 -0
- package/skills/backend-patterns/SKILL.md +560 -0
- package/skills/benchmark/SKILL.md +92 -0
- package/skills/blueprint/SKILL.md +104 -0
- package/skills/browser-qa/SKILL.md +86 -0
- package/skills/bun-runtime/SKILL.md +83 -0
- package/skills/canary-watch/SKILL.md +98 -0
- package/skills/carrier-relationship-management/SKILL.md +211 -0
- package/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/skills/ck/SKILL.md +147 -0
- package/skills/ck/commands/forget.mjs +44 -0
- package/skills/ck/commands/info.mjs +24 -0
- package/skills/ck/commands/init.mjs +143 -0
- package/skills/ck/commands/list.mjs +40 -0
- package/skills/ck/commands/migrate.mjs +202 -0
- package/skills/ck/commands/resume.mjs +36 -0
- package/skills/ck/commands/save.mjs +210 -0
- package/skills/ck/commands/shared.mjs +387 -0
- package/skills/ck/hooks/session-start.mjs +224 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +438 -0
- package/skills/code-tour/SKILL.md +235 -0
- package/skills/codebase-onboarding/SKILL.md +232 -0
- package/skills/coding-standards/SKILL.md +548 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
- package/skills/connections-optimizer/SKILL.md +188 -0
- package/skills/content-engine/SKILL.md +126 -0
- package/skills/content-hash-cache-pattern/SKILL.md +160 -0
- package/skills/context-budget/SKILL.md +134 -0
- package/skills/continuous-agent-loop/SKILL.md +44 -0
- package/skills/continuous-learning/SKILL.md +129 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +358 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
- package/skills/cost-tracking/SKILL.md +147 -0
- package/skills/council/SKILL.md +202 -0
- package/skills/cpp-coding-standards/SKILL.md +722 -0
- package/skills/cpp-testing/SKILL.md +323 -0
- package/skills/crosspost/SKILL.md +110 -0
- package/skills/csharp-testing/SKILL.md +320 -0
- package/skills/customer-billing-ops/SKILL.md +139 -0
- package/skills/customs-trade-compliance/SKILL.md +262 -0
- package/skills/dart-flutter-patterns/SKILL.md +562 -0
- package/skills/dashboard-builder/SKILL.md +108 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +428 -0
- package/skills/deep-research/SKILL.md +158 -0
- package/skills/defi-amm-security/SKILL.md +166 -0
- package/skills/deployment-patterns/SKILL.md +426 -0
- package/skills/design-system/SKILL.md +81 -0
- package/skills/django-celery/SKILL.md +456 -0
- package/skills/django-patterns/SKILL.md +733 -0
- package/skills/django-security/SKILL.md +592 -0
- package/skills/django-tdd/SKILL.md +728 -0
- package/skills/django-verification/SKILL.md +468 -0
- package/skills/dmux-workflows/SKILL.md +190 -0
- package/skills/docker-patterns/SKILL.md +363 -0
- package/skills/documentation-lookup/SKILL.md +89 -0
- package/skills/dotnet-patterns/SKILL.md +320 -0
- package/skills/e2e-testing/SKILL.md +325 -0
- package/skills/email-ops/SKILL.md +120 -0
- package/skills/energy-procurement/SKILL.md +227 -0
- package/skills/enterprise-agent-ops/SKILL.md +49 -0
- package/skills/error-handling/SKILL.md +375 -0
- package/skills/eval-harness/SKILL.md +269 -0
- package/skills/evm-token-decimals/SKILL.md +130 -0
- package/skills/exa-search/SKILL.md +106 -0
- package/skills/fal-ai-media/SKILL.md +287 -0
- package/skills/fastapi-patterns/SKILL.md +327 -0
- package/skills/finance-billing-ops/SKILL.md +126 -0
- package/skills/flox-environments/SKILL.md +496 -0
- package/skills/flutter-dart-code-review/SKILL.md +434 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-design-direction/SKILL.md +92 -0
- package/skills/frontend-patterns/SKILL.md +641 -0
- package/skills/frontend-slides/SKILL.md +183 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-slides/animation-patterns.md +122 -0
- package/skills/frontend-slides/html-template.md +419 -0
- package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/skills/frontend-slides/viewport-base.css +153 -0
- package/skills/fsharp-testing/SKILL.md +279 -0
- package/skills/gan-style-harness/SKILL.md +278 -0
- package/skills/gateguard/SKILL.md +125 -0
- package/skills/git-workflow/SKILL.md +714 -0
- package/skills/github-ops/SKILL.md +143 -0
- package/skills/golang-patterns/SKILL.md +673 -0
- package/skills/golang-testing/SKILL.md +719 -0
- package/skills/google-workspace-ops/SKILL.md +94 -0
- package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/skills/hermes-imports/SKILL.md +87 -0
- package/skills/hexagonal-architecture/SKILL.md +275 -0
- package/skills/hipaa-compliance/SKILL.md +78 -0
- package/skills/homelab-network-readiness/SKILL.md +169 -0
- package/skills/homelab-network-setup/SKILL.md +129 -0
- package/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/skills/hookify-rules/SKILL.md +128 -0
- package/skills/inventory-demand-planning/SKILL.md +246 -0
- package/skills/investor-materials/SKILL.md +95 -0
- package/skills/investor-outreach/SKILL.md +90 -0
- package/skills/ios-icon-gen/SKILL.md +157 -0
- package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/skills/iterative-retrieval/SKILL.md +209 -0
- package/skills/java-coding-standards/SKILL.md +382 -0
- package/skills/jira-integration/SKILL.md +292 -0
- package/skills/jpa-patterns/SKILL.md +150 -0
- package/skills/knowledge-ops/SKILL.md +153 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
- package/skills/kotlin-patterns/SKILL.md +710 -0
- package/skills/kotlin-testing/SKILL.md +823 -0
- package/skills/laravel-patterns/SKILL.md +414 -0
- package/skills/laravel-plugin-discovery/SKILL.md +228 -0
- package/skills/laravel-security/SKILL.md +284 -0
- package/skills/laravel-tdd/SKILL.md +282 -0
- package/skills/laravel-verification/SKILL.md +178 -0
- package/skills/lead-intelligence/SKILL.md +320 -0
- package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/skills/logistics-exception-management/SKILL.md +221 -0
- package/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/skills/manim-video/SKILL.md +88 -0
- package/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/skills/market-research/SKILL.md +74 -0
- package/skills/mcp-server-patterns/SKILL.md +68 -0
- package/skills/messages-ops/SKILL.md +103 -0
- package/skills/mle-workflow/SKILL.md +345 -0
- package/skills/motion-advanced/SKILL.md +596 -0
- package/skills/motion-foundations/SKILL.md +299 -0
- package/skills/motion-patterns/SKILL.md +435 -0
- package/skills/motion-ui/SKILL.md +574 -0
- package/skills/mysql-patterns/SKILL.md +411 -0
- package/skills/nanoclaw-repl/SKILL.md +32 -0
- package/skills/nestjs-patterns/SKILL.md +229 -0
- package/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/skills/network-config-validation/SKILL.md +210 -0
- package/skills/network-interface-health/SKILL.md +152 -0
- package/skills/nextjs-turbopack/SKILL.md +43 -0
- package/skills/nodejs-keccak256/SKILL.md +102 -0
- package/skills/nutrient-document-processing/SKILL.md +166 -0
- package/skills/nuxt4-patterns/SKILL.md +99 -0
- package/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/skills/openclaw-persona-forge/gacha.py +224 -0
- package/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/skills/opensource-pipeline/SKILL.md +254 -0
- package/skills/perl-patterns/SKILL.md +503 -0
- package/skills/perl-security/SKILL.md +502 -0
- package/skills/perl-testing/SKILL.md +474 -0
- package/skills/plan-orchestrate/SKILL.md +253 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +146 -0
- package/skills/product-capability/SKILL.md +140 -0
- package/skills/product-lens/SKILL.md +91 -0
- package/skills/production-audit/SKILL.md +206 -0
- package/skills/production-scheduling/SKILL.md +237 -0
- package/skills/project-flow-ops/SKILL.md +110 -0
- package/skills/prompt-optimizer/SKILL.md +398 -0
- package/skills/python-patterns/SKILL.md +749 -0
- package/skills/python-testing/SKILL.md +815 -0
- package/skills/pytorch-patterns/SKILL.md +395 -0
- package/skills/quality-nonconformance/SKILL.md +259 -0
- package/skills/quarkus-patterns/SKILL.md +721 -0
- package/skills/quarkus-security/SKILL.md +466 -0
- package/skills/quarkus-tdd/SKILL.md +810 -0
- package/skills/quarkus-verification/SKILL.md +478 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
- package/skills/redis-patterns/SKILL.md +402 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
- package/skills/remotion-video-creation/SKILL.md +43 -0
- package/skills/remotion-video-creation/rules/3d.md +86 -0
- package/skills/remotion-video-creation/rules/animations.md +29 -0
- package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/skills/remotion-video-creation/rules/assets.md +78 -0
- package/skills/remotion-video-creation/rules/audio.md +172 -0
- package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/skills/remotion-video-creation/rules/charts.md +58 -0
- package/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/skills/remotion-video-creation/rules/images.md +130 -0
- package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/skills/remotion-video-creation/rules/timing.md +179 -0
- package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/skills/remotion-video-creation/rules/videos.md +171 -0
- package/skills/repo-scan/SKILL.md +78 -0
- package/skills/research-ops/SKILL.md +111 -0
- package/skills/returns-reverse-logistics/SKILL.md +239 -0
- package/skills/rules-distill/SKILL.md +263 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +498 -0
- package/skills/rust-testing/SKILL.md +499 -0
- package/skills/safety-guard/SKILL.md +74 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/skills/search-first/SKILL.md +181 -0
- package/skills/security-bounty-hunter/SKILL.md +99 -0
- package/skills/security-review/SKILL.md +502 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/seo/SKILL.md +153 -0
- package/skills/skill-comply/SKILL.md +57 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +124 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +186 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +197 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-comply/tests/test_runner.py +172 -0
- package/skills/skill-scout/SKILL.md +139 -0
- package/skills/skill-stocktake/SKILL.md +193 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/social-graph-ranker/SKILL.md +153 -0
- package/skills/springboot-patterns/SKILL.md +313 -0
- package/skills/springboot-security/SKILL.md +271 -0
- package/skills/springboot-tdd/SKILL.md +157 -0
- package/skills/springboot-verification/SKILL.md +230 -0
- package/skills/strategic-compact/SKILL.md +129 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +142 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +189 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +462 -0
- package/skills/team-builder/SKILL.md +166 -0
- package/skills/terminal-ops/SKILL.md +108 -0
- package/skills/tinystruct-patterns/SKILL.md +130 -0
- package/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/skills/tinystruct-patterns/references/routing.md +57 -0
- package/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/skills/tinystruct-patterns/references/testing.md +59 -0
- package/skills/token-budget-advisor/SKILL.md +133 -0
- package/skills/ui-demo/SKILL.md +464 -0
- package/skills/ui-to-vue/SKILL.md +134 -0
- package/skills/unified-notifications-ops/SKILL.md +186 -0
- package/skills/verification-loop/SKILL.md +125 -0
- package/skills/video-editing/SKILL.md +309 -0
- package/skills/videodb/SKILL.md +373 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/vite-patterns/SKILL.md +448 -0
- package/skills/windows-desktop-e2e/SKILL.md +787 -0
- package/skills/workspace-surface-audit/SKILL.md +124 -0
- package/skills/x-api/SKILL.md +233 -0
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: content-hash-cache-pattern
|
|
3
|
+
description: Cache expensive file processing results using SHA-256 content hashes — path-independent, auto-invalidating, with service layer separation.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Content-Hash File Cache Pattern
|
|
7
|
+
|
|
8
|
+
Cache expensive file processing results (PDF parsing, text extraction, image analysis) using SHA-256 content hashes as cache keys. Unlike path-based caching, this approach survives file moves/renames and auto-invalidates when content changes.
|
|
9
|
+
|
|
10
|
+
## When to Activate
|
|
11
|
+
|
|
12
|
+
- Building file processing pipelines (PDF, images, text extraction)
|
|
13
|
+
- Processing cost is high and same files are processed repeatedly
|
|
14
|
+
- Need a `--cache/--no-cache` CLI option
|
|
15
|
+
- Want to add caching to existing pure functions without modifying them
|
|
16
|
+
|
|
17
|
+
## Core Pattern
|
|
18
|
+
|
|
19
|
+
### 1. Content-Hash Based Cache Key
|
|
20
|
+
|
|
21
|
+
Use file content (not path) as the cache key:
|
|
22
|
+
|
|
23
|
+
```python
|
|
24
|
+
import hashlib
|
|
25
|
+
from pathlib import Path
|
|
26
|
+
|
|
27
|
+
_HASH_CHUNK_SIZE = 65536 # 64KB chunks for large files
|
|
28
|
+
|
|
29
|
+
def compute_file_hash(path: Path) -> str:
|
|
30
|
+
"""SHA-256 of file contents (chunked for large files)."""
|
|
31
|
+
if not path.is_file():
|
|
32
|
+
raise FileNotFoundError(f"File not found: {path}")
|
|
33
|
+
sha256 = hashlib.sha256()
|
|
34
|
+
with open(path, "rb") as f:
|
|
35
|
+
while True:
|
|
36
|
+
chunk = f.read(_HASH_CHUNK_SIZE)
|
|
37
|
+
if not chunk:
|
|
38
|
+
break
|
|
39
|
+
sha256.update(chunk)
|
|
40
|
+
return sha256.hexdigest()
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
**Why content hash?** File rename/move = cache hit. Content change = automatic invalidation. No index file needed.
|
|
44
|
+
|
|
45
|
+
### 2. Frozen Dataclass for Cache Entry
|
|
46
|
+
|
|
47
|
+
```python
|
|
48
|
+
from dataclasses import dataclass
|
|
49
|
+
|
|
50
|
+
@dataclass(frozen=True, slots=True)
|
|
51
|
+
class CacheEntry:
|
|
52
|
+
file_hash: str
|
|
53
|
+
source_path: str
|
|
54
|
+
document: ExtractedDocument # The cached result
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
### 3. File-Based Cache Storage
|
|
58
|
+
|
|
59
|
+
Each cache entry is stored as `{hash}.json` — O(1) lookup by hash, no index file required.
|
|
60
|
+
|
|
61
|
+
```python
|
|
62
|
+
import json
|
|
63
|
+
from typing import Any
|
|
64
|
+
|
|
65
|
+
def write_cache(cache_dir: Path, entry: CacheEntry) -> None:
|
|
66
|
+
cache_dir.mkdir(parents=True, exist_ok=True)
|
|
67
|
+
cache_file = cache_dir / f"{entry.file_hash}.json"
|
|
68
|
+
data = serialize_entry(entry)
|
|
69
|
+
cache_file.write_text(json.dumps(data, ensure_ascii=False), encoding="utf-8")
|
|
70
|
+
|
|
71
|
+
def read_cache(cache_dir: Path, file_hash: str) -> CacheEntry | None:
|
|
72
|
+
cache_file = cache_dir / f"{file_hash}.json"
|
|
73
|
+
if not cache_file.is_file():
|
|
74
|
+
return None
|
|
75
|
+
try:
|
|
76
|
+
raw = cache_file.read_text(encoding="utf-8")
|
|
77
|
+
data = json.loads(raw)
|
|
78
|
+
return deserialize_entry(data)
|
|
79
|
+
except (json.JSONDecodeError, ValueError, KeyError):
|
|
80
|
+
return None # Treat corruption as cache miss
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### 4. Service Layer Wrapper (SRP)
|
|
84
|
+
|
|
85
|
+
Keep the processing function pure. Add caching as a separate service layer.
|
|
86
|
+
|
|
87
|
+
```python
|
|
88
|
+
def extract_with_cache(
|
|
89
|
+
file_path: Path,
|
|
90
|
+
*,
|
|
91
|
+
cache_enabled: bool = True,
|
|
92
|
+
cache_dir: Path = Path(".cache"),
|
|
93
|
+
) -> ExtractedDocument:
|
|
94
|
+
"""Service layer: cache check -> extraction -> cache write."""
|
|
95
|
+
if not cache_enabled:
|
|
96
|
+
return extract_text(file_path) # Pure function, no cache knowledge
|
|
97
|
+
|
|
98
|
+
file_hash = compute_file_hash(file_path)
|
|
99
|
+
|
|
100
|
+
# Check cache
|
|
101
|
+
cached = read_cache(cache_dir, file_hash)
|
|
102
|
+
if cached is not None:
|
|
103
|
+
logger.info("Cache hit: %s (hash=%s)", file_path.name, file_hash[:12])
|
|
104
|
+
return cached.document
|
|
105
|
+
|
|
106
|
+
# Cache miss -> extract -> store
|
|
107
|
+
logger.info("Cache miss: %s (hash=%s)", file_path.name, file_hash[:12])
|
|
108
|
+
doc = extract_text(file_path)
|
|
109
|
+
entry = CacheEntry(file_hash=file_hash, source_path=str(file_path), document=doc)
|
|
110
|
+
write_cache(cache_dir, entry)
|
|
111
|
+
return doc
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
## Key Design Decisions
|
|
115
|
+
|
|
116
|
+
| Decision | Rationale |
|
|
117
|
+
|----------|-----------|
|
|
118
|
+
| SHA-256 content hash | Path-independent, auto-invalidates on content change |
|
|
119
|
+
| `{hash}.json` file naming | O(1) lookup, no index file needed |
|
|
120
|
+
| Service layer wrapper | SRP: extraction stays pure, cache is a separate concern |
|
|
121
|
+
| Manual JSON serialization | Full control over frozen dataclass serialization |
|
|
122
|
+
| Corruption returns `None` | Graceful degradation, re-processes on next run |
|
|
123
|
+
| `cache_dir.mkdir(parents=True)` | Lazy directory creation on first write |
|
|
124
|
+
|
|
125
|
+
## Best Practices
|
|
126
|
+
|
|
127
|
+
- **Hash content, not paths** — paths change, content identity doesn't
|
|
128
|
+
- **Chunk large files** when hashing — avoid loading entire files into memory
|
|
129
|
+
- **Keep processing functions pure** — they should know nothing about caching
|
|
130
|
+
- **Log cache hit/miss** with truncated hashes for debugging
|
|
131
|
+
- **Handle corruption gracefully** — treat invalid cache entries as misses, never crash
|
|
132
|
+
|
|
133
|
+
## Anti-Patterns to Avoid
|
|
134
|
+
|
|
135
|
+
```python
|
|
136
|
+
# BAD: Path-based caching (breaks on file move/rename)
|
|
137
|
+
cache = {"/path/to/file.pdf": result}
|
|
138
|
+
|
|
139
|
+
# BAD: Adding cache logic inside the processing function (SRP violation)
|
|
140
|
+
def extract_text(path, *, cache_enabled=False, cache_dir=None):
|
|
141
|
+
if cache_enabled: # Now this function has two responsibilities
|
|
142
|
+
...
|
|
143
|
+
|
|
144
|
+
# BAD: Using dataclasses.asdict() with nested frozen dataclasses
|
|
145
|
+
# (can cause issues with complex nested types)
|
|
146
|
+
data = dataclasses.asdict(entry) # Use manual serialization instead
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
## When to Use
|
|
150
|
+
|
|
151
|
+
- File processing pipelines (PDF parsing, OCR, text extraction, image analysis)
|
|
152
|
+
- CLI tools that benefit from `--cache/--no-cache` options
|
|
153
|
+
- Batch processing where the same files appear across runs
|
|
154
|
+
- Adding caching to existing pure functions without modifying them
|
|
155
|
+
|
|
156
|
+
## When NOT to Use
|
|
157
|
+
|
|
158
|
+
- Data that must always be fresh (real-time feeds)
|
|
159
|
+
- Cache entries that would be extremely large (consider streaming instead)
|
|
160
|
+
- Results that depend on parameters beyond file content (e.g., different extraction configs)
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: context-budget
|
|
3
|
+
description: Audits Claude Code context window consumption across agents, skills, MCP servers, and rules. Identifies bloat, redundant components, and produces prioritized token-savings recommendations.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Context Budget
|
|
7
|
+
|
|
8
|
+
Analyze token overhead across every loaded component in a Claude Code session and surface actionable optimizations to reclaim context space.
|
|
9
|
+
|
|
10
|
+
## When to Use
|
|
11
|
+
|
|
12
|
+
- Session performance feels sluggish or output quality is degrading
|
|
13
|
+
- You've recently added many skills, agents, or MCP servers
|
|
14
|
+
- You want to know how much context headroom you actually have
|
|
15
|
+
- Planning to add more components and need to know if there's room
|
|
16
|
+
- Running `/context-budget` command (this skill backs it)
|
|
17
|
+
|
|
18
|
+
## How It Works
|
|
19
|
+
|
|
20
|
+
### Phase 1: Inventory
|
|
21
|
+
|
|
22
|
+
Scan all component directories and estimate token consumption:
|
|
23
|
+
|
|
24
|
+
**Agents** (`agents/*.md`)
|
|
25
|
+
- Count lines and tokens per file (words × 1.3)
|
|
26
|
+
- Extract `description` frontmatter length
|
|
27
|
+
- Flag: files >200 lines (heavy), description >30 words (bloated frontmatter)
|
|
28
|
+
|
|
29
|
+
**Skills** (`skills/*/SKILL.md`)
|
|
30
|
+
- Count tokens per SKILL.md
|
|
31
|
+
- Flag: files >400 lines
|
|
32
|
+
- Check for duplicate copies in `.agents/skills/` — skip identical copies to avoid double-counting
|
|
33
|
+
|
|
34
|
+
**Rules** (`rules/**/*.md`)
|
|
35
|
+
- Count tokens per file
|
|
36
|
+
- Flag: files >100 lines
|
|
37
|
+
- Detect content overlap between rule files in the same language module
|
|
38
|
+
|
|
39
|
+
**MCP Servers** (`.mcp.json` or active MCP config)
|
|
40
|
+
- Count configured servers and total tool count
|
|
41
|
+
- Estimate schema overhead at ~500 tokens per tool
|
|
42
|
+
- Flag: servers with >20 tools, servers that wrap simple CLI commands (`gh`, `git`, `npm`, `supabase`, `vercel`)
|
|
43
|
+
|
|
44
|
+
**CLAUDE.md** (project + user-level)
|
|
45
|
+
- Count tokens per file in the CLAUDE.md chain
|
|
46
|
+
- Flag: combined total >300 lines
|
|
47
|
+
|
|
48
|
+
### Phase 2: Classify
|
|
49
|
+
|
|
50
|
+
Sort every component into a bucket:
|
|
51
|
+
|
|
52
|
+
| Bucket | Criteria | Action |
|
|
53
|
+
|--------|----------|--------|
|
|
54
|
+
| **Always needed** | Referenced in CLAUDE.md, backs an active command, or matches current project type | Keep |
|
|
55
|
+
| **Sometimes needed** | Domain-specific (e.g. language patterns), not referenced in CLAUDE.md | Consider on-demand activation |
|
|
56
|
+
| **Rarely needed** | No command reference, overlapping content, or no obvious project match | Remove or lazy-load |
|
|
57
|
+
|
|
58
|
+
### Phase 3: Detect Issues
|
|
59
|
+
|
|
60
|
+
Identify the following problem patterns:
|
|
61
|
+
|
|
62
|
+
- **Bloated agent descriptions** — description >30 words in frontmatter loads into every Task tool invocation
|
|
63
|
+
- **Heavy agents** — files >200 lines inflate Task tool context on every spawn
|
|
64
|
+
- **Redundant components** — skills that duplicate agent logic, rules that duplicate CLAUDE.md
|
|
65
|
+
- **MCP over-subscription** — >10 servers, or servers wrapping CLI tools available for free
|
|
66
|
+
- **CLAUDE.md bloat** — verbose explanations, outdated sections, instructions that should be rules
|
|
67
|
+
|
|
68
|
+
### Phase 4: Report
|
|
69
|
+
|
|
70
|
+
Produce the context budget report:
|
|
71
|
+
|
|
72
|
+
```
|
|
73
|
+
Context Budget Report
|
|
74
|
+
═══════════════════════════════════════
|
|
75
|
+
|
|
76
|
+
Total estimated overhead: ~XX,XXX tokens
|
|
77
|
+
Context model: Claude Sonnet (200K window)
|
|
78
|
+
Effective available context: ~XXX,XXX tokens (XX%)
|
|
79
|
+
|
|
80
|
+
Component Breakdown:
|
|
81
|
+
┌─────────────────┬────────┬───────────┐
|
|
82
|
+
│ Component │ Count │ Tokens │
|
|
83
|
+
├─────────────────┼────────┼───────────┤
|
|
84
|
+
│ Agents │ N │ ~X,XXX │
|
|
85
|
+
│ Skills │ N │ ~X,XXX │
|
|
86
|
+
│ Rules │ N │ ~X,XXX │
|
|
87
|
+
│ MCP tools │ N │ ~XX,XXX │
|
|
88
|
+
│ CLAUDE.md │ N │ ~X,XXX │
|
|
89
|
+
└─────────────────┴────────┴───────────┘
|
|
90
|
+
|
|
91
|
+
WARNING: Issues Found (N):
|
|
92
|
+
[ranked by token savings]
|
|
93
|
+
|
|
94
|
+
Top 3 Optimizations:
|
|
95
|
+
1. [action] → save ~X,XXX tokens
|
|
96
|
+
2. [action] → save ~X,XXX tokens
|
|
97
|
+
3. [action] → save ~X,XXX tokens
|
|
98
|
+
|
|
99
|
+
Potential savings: ~XX,XXX tokens (XX% of current overhead)
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
In verbose mode, additionally output per-file token counts, line-by-line breakdown of the heaviest files, specific redundant lines between overlapping components, and MCP tool list with per-tool schema size estimates.
|
|
103
|
+
|
|
104
|
+
## Examples
|
|
105
|
+
|
|
106
|
+
**Basic audit**
|
|
107
|
+
```
|
|
108
|
+
User: /context-budget
|
|
109
|
+
Skill: Scans setup → 16 agents (12,400 tokens), 28 skills (6,200), 87 MCP tools (43,500), 2 CLAUDE.md (1,200)
|
|
110
|
+
Flags: 3 heavy agents, 14 MCP servers (3 CLI-replaceable)
|
|
111
|
+
Top saving: remove 3 MCP servers → -27,500 tokens (47% overhead reduction)
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
**Verbose mode**
|
|
115
|
+
```
|
|
116
|
+
User: /context-budget --verbose
|
|
117
|
+
Skill: Full report + per-file breakdown showing planner.md (213 lines, 1,840 tokens),
|
|
118
|
+
MCP tool list with per-tool sizes, duplicated rule lines side by side
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
**Pre-expansion check**
|
|
122
|
+
```
|
|
123
|
+
User: I want to add 5 more MCP servers, do I have room?
|
|
124
|
+
Skill: Current overhead 33% → adding 5 servers (~50 tools) would add ~25,000 tokens → pushes to 45% overhead
|
|
125
|
+
Recommendation: remove 2 CLI-replaceable servers first to stay under 40%
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
## Best Practices
|
|
129
|
+
|
|
130
|
+
- **Token estimation**: use `words × 1.3` for prose, `chars / 4` for code-heavy files
|
|
131
|
+
- **MCP is the biggest lever**: each tool schema costs ~500 tokens; a 30-tool server costs more than all your skills combined
|
|
132
|
+
- **Agent descriptions are loaded always**: even if the agent is never invoked, its description field is present in every Task tool context
|
|
133
|
+
- **Verbose mode for debugging**: use when you need to pinpoint the exact files driving overhead, not for regular audits
|
|
134
|
+
- **Audit after changes**: run after adding any agent, skill, or MCP server to catch creep early
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: continuous-agent-loop
|
|
3
|
+
description: Patterns for continuous autonomous agent loops with quality gates, evals, and recovery controls.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Continuous Agent Loop
|
|
7
|
+
|
|
8
|
+
This is the v1.8+ canonical loop skill name. It supersedes `autonomous-loops` while keeping compatibility for one release.
|
|
9
|
+
|
|
10
|
+
## Loop Selection Flow
|
|
11
|
+
|
|
12
|
+
```text
|
|
13
|
+
Start
|
|
14
|
+
|
|
|
15
|
+
+-- Need strict CI/PR control? -- yes --> continuous-pr
|
|
16
|
+
|
|
|
17
|
+
+-- Need RFC decomposition? -- yes --> rfc-dag
|
|
18
|
+
|
|
|
19
|
+
+-- Need exploratory parallel generation? -- yes --> infinite
|
|
20
|
+
|
|
|
21
|
+
+-- default --> sequential
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
## Combined Pattern
|
|
25
|
+
|
|
26
|
+
Recommended production stack:
|
|
27
|
+
1. RFC decomposition (`ralphinho-rfc-pipeline`)
|
|
28
|
+
2. quality gates (`plankton-code-quality` + `/quality-gate`)
|
|
29
|
+
3. eval loop (`eval-harness`)
|
|
30
|
+
4. session persistence (`nanoclaw-repl`)
|
|
31
|
+
|
|
32
|
+
## Failure Modes
|
|
33
|
+
|
|
34
|
+
- loop churn without measurable progress
|
|
35
|
+
- repeated retries with same root cause
|
|
36
|
+
- merge queue stalls
|
|
37
|
+
- cost drift from unbounded escalation
|
|
38
|
+
|
|
39
|
+
## Recovery
|
|
40
|
+
|
|
41
|
+
- freeze loop
|
|
42
|
+
- run `/harness-audit`
|
|
43
|
+
- reduce scope to failing unit
|
|
44
|
+
- replay with explicit acceptance criteria
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: continuous-learning
|
|
3
|
+
description: "[DEPRECATED - use continuous-learning-v2] Legacy v1 stop-hook skill extractor. v2 is a strict superset with instinct-based, project-scoped, hook-reliable learning. Do not invoke v1; route continuous learning, session learning, and pattern extraction requests to continuous-learning-v2."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Continuous Learning Skill - DEPRECATED
|
|
7
|
+
|
|
8
|
+
> **DEPRECATED 2026-04-28.** Use `continuous-learning-v2` instead. v2 is a strict superset: stop-hook observation becomes PreToolUse/PostToolUse observation, full skills become atomic instincts with confidence scoring, and global-only storage becomes project-scoped plus global promotion.
|
|
9
|
+
>
|
|
10
|
+
> This file is kept for archival reference and backward compatibility with existing installs.
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## Original v1 Documentation (archival)
|
|
15
|
+
|
|
16
|
+
Automatically evaluates Claude Code sessions on end to extract reusable patterns that can be saved as learned skills.
|
|
17
|
+
|
|
18
|
+
## When to Activate
|
|
19
|
+
|
|
20
|
+
- Setting up automatic pattern extraction from Claude Code sessions
|
|
21
|
+
- Configuring the Stop hook for session evaluation
|
|
22
|
+
- Reviewing or curating learned skills in `~/.claude/skills/learned/`
|
|
23
|
+
- Adjusting extraction thresholds or pattern categories
|
|
24
|
+
- Comparing v1 (this) vs v2 (instinct-based) approaches
|
|
25
|
+
|
|
26
|
+
## Status
|
|
27
|
+
|
|
28
|
+
This v1 skill is still supported, but `continuous-learning-v2` is the preferred path for new installs. Keep v1 when you explicitly want the simpler Stop-hook extraction flow or need compatibility with older learned-skill workflows.
|
|
29
|
+
|
|
30
|
+
## How It Works
|
|
31
|
+
|
|
32
|
+
This skill runs as a **Stop hook** at the end of each session:
|
|
33
|
+
|
|
34
|
+
1. **Session Evaluation**: Checks if session has enough messages (default: 10+)
|
|
35
|
+
2. **Pattern Detection**: Identifies extractable patterns from the session
|
|
36
|
+
3. **Skill Extraction**: Saves useful patterns to `~/.claude/skills/learned/`
|
|
37
|
+
|
|
38
|
+
## Configuration
|
|
39
|
+
|
|
40
|
+
Edit `config.json` to customize:
|
|
41
|
+
|
|
42
|
+
```json
|
|
43
|
+
{
|
|
44
|
+
"min_session_length": 10,
|
|
45
|
+
"extraction_threshold": "medium",
|
|
46
|
+
"auto_approve": false,
|
|
47
|
+
"learned_skills_path": "~/.claude/skills/learned/",
|
|
48
|
+
"patterns_to_detect": [
|
|
49
|
+
"error_resolution",
|
|
50
|
+
"user_corrections",
|
|
51
|
+
"workarounds",
|
|
52
|
+
"debugging_techniques",
|
|
53
|
+
"project_specific"
|
|
54
|
+
],
|
|
55
|
+
"ignore_patterns": [
|
|
56
|
+
"simple_typos",
|
|
57
|
+
"one_time_fixes",
|
|
58
|
+
"external_api_issues"
|
|
59
|
+
]
|
|
60
|
+
}
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Pattern Types
|
|
64
|
+
|
|
65
|
+
| Pattern | Description |
|
|
66
|
+
|---------|-------------|
|
|
67
|
+
| `error_resolution` | How specific errors were resolved |
|
|
68
|
+
| `user_corrections` | Patterns from user corrections |
|
|
69
|
+
| `workarounds` | Solutions to framework/library quirks |
|
|
70
|
+
| `debugging_techniques` | Effective debugging approaches |
|
|
71
|
+
| `project_specific` | Project-specific conventions |
|
|
72
|
+
|
|
73
|
+
## Hook Setup
|
|
74
|
+
|
|
75
|
+
Add to your `~/.claude/settings.json`:
|
|
76
|
+
|
|
77
|
+
```json
|
|
78
|
+
{
|
|
79
|
+
"hooks": {
|
|
80
|
+
"Stop": [{
|
|
81
|
+
"matcher": "*",
|
|
82
|
+
"hooks": [{
|
|
83
|
+
"type": "command",
|
|
84
|
+
"command": "~/.claude/skills/continuous-learning/evaluate-session.sh"
|
|
85
|
+
}]
|
|
86
|
+
}]
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
## Why Stop Hook?
|
|
92
|
+
|
|
93
|
+
- **Lightweight**: Runs once at session end
|
|
94
|
+
- **Non-blocking**: Doesn't add latency to every message
|
|
95
|
+
- **Complete context**: Has access to full session transcript
|
|
96
|
+
|
|
97
|
+
## Related
|
|
98
|
+
|
|
99
|
+
- `/learn` command - Manual pattern extraction mid-session
|
|
100
|
+
|
|
101
|
+
---
|
|
102
|
+
|
|
103
|
+
## Comparison Notes (Research: Jan 2025)
|
|
104
|
+
|
|
105
|
+
### vs Homunculus
|
|
106
|
+
|
|
107
|
+
Homunculus v2 takes a more sophisticated approach:
|
|
108
|
+
|
|
109
|
+
| Feature | Our Approach | Homunculus v2 |
|
|
110
|
+
|---------|--------------|---------------|
|
|
111
|
+
| Observation | Stop hook (end of session) | PreToolUse/PostToolUse hooks (100% reliable) |
|
|
112
|
+
| Analysis | Main context | Background agent (Haiku) |
|
|
113
|
+
| Granularity | Full skills | Atomic "instincts" |
|
|
114
|
+
| Confidence | None | 0.3-0.9 weighted |
|
|
115
|
+
| Evolution | Direct to skill | Instincts → cluster → skill/command/agent |
|
|
116
|
+
| Sharing | None | Export/import instincts |
|
|
117
|
+
|
|
118
|
+
**Key insight from homunculus:**
|
|
119
|
+
> "v1 relied on skills to observe. Skills are probabilistic—they fire ~50-80% of the time. v2 uses hooks for observation (100% reliable) and instincts as the atomic unit of learned behavior."
|
|
120
|
+
|
|
121
|
+
### Potential v2 Enhancements
|
|
122
|
+
|
|
123
|
+
1. **Instinct-based learning** - Smaller, atomic behaviors with confidence scoring
|
|
124
|
+
2. **Background observer** - Haiku agent analyzing in parallel
|
|
125
|
+
3. **Confidence decay** - Instincts lose confidence if contradicted
|
|
126
|
+
4. **Domain tagging** - code-style, testing, git, debugging, etc.
|
|
127
|
+
5. **Evolution path** - Cluster related instincts into skills/commands
|
|
128
|
+
|
|
129
|
+
See: `docs/continuous-learning-v2-spec.md` for full spec.
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"min_session_length": 10,
|
|
3
|
+
"extraction_threshold": "medium",
|
|
4
|
+
"auto_approve": false,
|
|
5
|
+
"learned_skills_path": "~/.claude/skills/learned/",
|
|
6
|
+
"patterns_to_detect": [
|
|
7
|
+
"error_resolution",
|
|
8
|
+
"user_corrections",
|
|
9
|
+
"workarounds",
|
|
10
|
+
"debugging_techniques",
|
|
11
|
+
"project_specific"
|
|
12
|
+
],
|
|
13
|
+
"ignore_patterns": [
|
|
14
|
+
"simple_typos",
|
|
15
|
+
"one_time_fixes",
|
|
16
|
+
"external_api_issues"
|
|
17
|
+
]
|
|
18
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Continuous Learning - Session Evaluator
|
|
3
|
+
# Runs on Stop hook to extract reusable patterns from Claude Code sessions
|
|
4
|
+
#
|
|
5
|
+
# Why Stop hook instead of UserPromptSubmit:
|
|
6
|
+
# - Stop runs once at session end (lightweight)
|
|
7
|
+
# - UserPromptSubmit runs every message (heavy, adds latency)
|
|
8
|
+
#
|
|
9
|
+
# Hook config (in ~/.claude/settings.json):
|
|
10
|
+
# {
|
|
11
|
+
# "hooks": {
|
|
12
|
+
# "Stop": [{
|
|
13
|
+
# "matcher": "*",
|
|
14
|
+
# "hooks": [{
|
|
15
|
+
# "type": "command",
|
|
16
|
+
# "command": "~/.claude/skills/continuous-learning/evaluate-session.sh"
|
|
17
|
+
# }]
|
|
18
|
+
# }]
|
|
19
|
+
# }
|
|
20
|
+
# }
|
|
21
|
+
#
|
|
22
|
+
# Patterns to detect: error_resolution, debugging_techniques, workarounds, project_specific
|
|
23
|
+
# Patterns to ignore: simple_typos, one_time_fixes, external_api_issues
|
|
24
|
+
# Extracted skills saved to: ~/.claude/skills/learned/
|
|
25
|
+
|
|
26
|
+
set -e
|
|
27
|
+
|
|
28
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
29
|
+
CONFIG_FILE="$SCRIPT_DIR/config.json"
|
|
30
|
+
LEARNED_SKILLS_PATH="${HOME}/.claude/skills/learned"
|
|
31
|
+
MIN_SESSION_LENGTH=10
|
|
32
|
+
|
|
33
|
+
# Load config if exists
|
|
34
|
+
if [ -f "$CONFIG_FILE" ]; then
|
|
35
|
+
if ! command -v jq &>/dev/null; then
|
|
36
|
+
echo "[ContinuousLearning] jq is required to parse config.json but not installed, using defaults" >&2
|
|
37
|
+
else
|
|
38
|
+
MIN_SESSION_LENGTH=$(jq -r '.min_session_length // 10' "$CONFIG_FILE")
|
|
39
|
+
LEARNED_SKILLS_PATH=$(jq -r '.learned_skills_path // "~/.claude/skills/learned/"' "$CONFIG_FILE" | sed "s|~|$HOME|")
|
|
40
|
+
fi
|
|
41
|
+
fi
|
|
42
|
+
|
|
43
|
+
# Ensure learned skills directory exists
|
|
44
|
+
mkdir -p "$LEARNED_SKILLS_PATH"
|
|
45
|
+
|
|
46
|
+
# Get transcript path from stdin JSON (Claude Code hook input)
|
|
47
|
+
# Falls back to env var for backwards compatibility
|
|
48
|
+
stdin_data=$(cat)
|
|
49
|
+
transcript_path=$(echo "$stdin_data" | grep -o '"transcript_path":"[^"]*"' | head -1 | cut -d'"' -f4)
|
|
50
|
+
if [ -z "$transcript_path" ]; then
|
|
51
|
+
transcript_path="${CLAUDE_TRANSCRIPT_PATH:-}"
|
|
52
|
+
fi
|
|
53
|
+
|
|
54
|
+
if [ -z "$transcript_path" ] || [ ! -f "$transcript_path" ]; then
|
|
55
|
+
exit 0
|
|
56
|
+
fi
|
|
57
|
+
|
|
58
|
+
# Count messages in session
|
|
59
|
+
message_count=$(grep -c '"type":"user"' "$transcript_path" 2>/dev/null || echo "0")
|
|
60
|
+
|
|
61
|
+
# Skip short sessions
|
|
62
|
+
if [ "$message_count" -lt "$MIN_SESSION_LENGTH" ]; then
|
|
63
|
+
echo "[ContinuousLearning] Session too short ($message_count messages), skipping" >&2
|
|
64
|
+
exit 0
|
|
65
|
+
fi
|
|
66
|
+
|
|
67
|
+
# Signal to Claude that session should be evaluated for extractable patterns
|
|
68
|
+
echo "[ContinuousLearning] Session has $message_count messages - evaluate for extractable patterns" >&2
|
|
69
|
+
echo "[ContinuousLearning] Save learned skills to: $LEARNED_SKILLS_PATH" >&2
|