@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.
Files changed (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. 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