arboris-cli 1.0.0 → 1.1.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 (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,359 @@
1
+ #!/usr/bin/env bash
2
+ # Continuous Learning v2 - Observer background loop
3
+ #
4
+ # Fix for #521: Added re-entrancy guard, cooldown throttle, and
5
+ # tail-based sampling to prevent memory explosion from runaway
6
+ # parallel Claude analysis processes.
7
+
8
+ set +e
9
+ unset CLAUDECODE
10
+
11
+ SLEEP_PID=""
12
+ USR1_FIRED=0
13
+ PENDING_ANALYSIS=0
14
+ ANALYZING=0
15
+ LAST_ANALYSIS_EPOCH=0
16
+ # Minimum seconds between analyses (prevents rapid re-triggering)
17
+ ANALYSIS_COOLDOWN="${ECC_OBSERVER_ANALYSIS_COOLDOWN:-60}"
18
+ IDLE_TIMEOUT_SECONDS="${ECC_OBSERVER_IDLE_TIMEOUT_SECONDS:-1800}"
19
+ SESSION_LEASE_DIR="${PROJECT_DIR}/.observer-sessions"
20
+ ACTIVITY_FILE="${PROJECT_DIR}/.observer-last-activity"
21
+
22
+ # Resolve this script's own directory so sibling scripts (session-guardian.sh)
23
+ # and relative helpers (../scripts/instinct-cli.py) resolve correctly whether
24
+ # this file is executed or sourced. $0 is the *caller* when sourced, so prefer
25
+ # ${BASH_SOURCE[0]}, which always points at this file (#2370).
26
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
27
+
28
+ cleanup() {
29
+ [ -n "$SLEEP_PID" ] && kill "$SLEEP_PID" 2>/dev/null
30
+ if [ -f "$PID_FILE" ] && [ "$(cat "$PID_FILE" 2>/dev/null)" = "$$" ]; then
31
+ rm -f "$PID_FILE"
32
+ fi
33
+ exit 0
34
+ }
35
+ trap cleanup TERM INT
36
+
37
+ file_mtime_epoch() {
38
+ local file="$1"
39
+ if [ ! -f "$file" ]; then
40
+ printf '0\n'
41
+ return
42
+ fi
43
+
44
+ if stat -c %Y "$file" >/dev/null 2>&1; then
45
+ stat -c %Y "$file" 2>/dev/null || printf '0\n'
46
+ return
47
+ fi
48
+
49
+ if stat -f %m "$file" >/dev/null 2>&1; then
50
+ stat -f %m "$file" 2>/dev/null || printf '0\n'
51
+ return
52
+ fi
53
+
54
+ printf '0\n'
55
+ }
56
+
57
+ has_active_session_leases() {
58
+ if [ ! -d "$SESSION_LEASE_DIR" ]; then
59
+ return 1
60
+ fi
61
+
62
+ find "$SESSION_LEASE_DIR" -type f -name '*.json' -print -quit 2>/dev/null | grep -q .
63
+ }
64
+
65
+ latest_activity_epoch() {
66
+ local observations_epoch activity_epoch
67
+ observations_epoch="$(file_mtime_epoch "$OBSERVATIONS_FILE")"
68
+ activity_epoch="$(file_mtime_epoch "$ACTIVITY_FILE")"
69
+
70
+ if [ "$activity_epoch" -gt "$observations_epoch" ] 2>/dev/null; then
71
+ printf '%s\n' "$activity_epoch"
72
+ else
73
+ printf '%s\n' "$observations_epoch"
74
+ fi
75
+ }
76
+
77
+ exit_if_idle_without_sessions() {
78
+ if has_active_session_leases; then
79
+ return
80
+ fi
81
+
82
+ local last_activity now_epoch idle_for
83
+ last_activity="$(latest_activity_epoch)"
84
+ now_epoch="$(date +%s)"
85
+ idle_for=$(( now_epoch - last_activity ))
86
+
87
+ if [ "$last_activity" -eq 0 ] || [ "$idle_for" -ge "$IDLE_TIMEOUT_SECONDS" ]; then
88
+ echo "[$(date)] Observer idle without active session leases for ${idle_for}s; exiting" >> "$LOG_FILE"
89
+ cleanup
90
+ fi
91
+ }
92
+
93
+ wait_for_claude_analysis() {
94
+ local child_pid="$1"
95
+ local wait_status=0
96
+
97
+ while true; do
98
+ wait "$child_pid"
99
+ wait_status=$?
100
+
101
+ if [ "$wait_status" -eq 0 ]; then
102
+ return 0
103
+ fi
104
+
105
+ # SIGUSR1 can interrupt wait while the Claude child is still running.
106
+ # Re-wait in that case so a signal is not logged as a false child failure.
107
+ if kill -0 "$child_pid" 2>/dev/null; then
108
+ continue
109
+ fi
110
+
111
+ return "$wait_status"
112
+ done
113
+ }
114
+
115
+ analyze_observations() {
116
+ if [ ! -f "$OBSERVATIONS_FILE" ]; then
117
+ return
118
+ fi
119
+
120
+ obs_count=$(wc -l < "$OBSERVATIONS_FILE" 2>/dev/null || echo 0)
121
+ if [ "$obs_count" -lt "$MIN_OBSERVATIONS" ]; then
122
+ return
123
+ fi
124
+
125
+ echo "[$(date)] Analyzing $obs_count observations for project ${PROJECT_NAME}..." >> "$LOG_FILE"
126
+
127
+ if [ "${CLV2_IS_WINDOWS:-false}" = "true" ] && [ "${ECC_OBSERVER_ALLOW_WINDOWS:-false}" != "true" ]; then
128
+ echo "[$(date)] Skipping claude analysis on Windows due to known non-interactive hang issue (#295). Set ECC_OBSERVER_ALLOW_WINDOWS=true to override." >> "$LOG_FILE"
129
+ return
130
+ fi
131
+
132
+ if ! command -v claude >/dev/null 2>&1; then
133
+ echo "[$(date)] claude CLI not found, skipping analysis" >> "$LOG_FILE"
134
+ return
135
+ fi
136
+
137
+ # session-guardian: gate observer cycle (active hours, cooldown, idle detection)
138
+ if ! bash "${SCRIPT_DIR}/session-guardian.sh"; then
139
+ echo "[$(date)] Observer cycle skipped by session-guardian" >> "$LOG_FILE"
140
+ return
141
+ fi
142
+
143
+ # Sample recent observations instead of loading the entire file (#521).
144
+ # This prevents multi-MB payloads from being passed to the LLM.
145
+ MAX_ANALYSIS_LINES="${ECC_OBSERVER_MAX_ANALYSIS_LINES:-500}"
146
+ observer_tmp_dir="${PROJECT_DIR}/.observer-tmp"
147
+ mkdir -p "$observer_tmp_dir"
148
+ analysis_file="$(mktemp "${observer_tmp_dir}/ecc-observer-analysis.XXXXXX.jsonl")"
149
+ tail -n "$MAX_ANALYSIS_LINES" "$OBSERVATIONS_FILE" > "$analysis_file"
150
+ analysis_count=$(wc -l < "$analysis_file" 2>/dev/null || echo 0)
151
+ echo "[$(date)] Using last $analysis_count of $obs_count observations for analysis" >> "$LOG_FILE"
152
+
153
+ # Use relative path from PROJECT_DIR for cross-platform compatibility (#842).
154
+ # On Windows (Git Bash/MSYS2), absolute paths from mktemp may use MSYS-style
155
+ # prefixes (e.g. /c/Users/...) that the Claude subprocess cannot resolve.
156
+ analysis_relpath=".observer-tmp/$(basename "$analysis_file")"
157
+
158
+ prompt_file="$(mktemp "${observer_tmp_dir}/ecc-observer-prompt.XXXXXX")"
159
+ cat > "$prompt_file" <<PROMPT
160
+ IMPORTANT: You are running in non-interactive --print mode. You MUST use the Write tool directly to create files. Do NOT ask for permission, do NOT ask for confirmation, do NOT output summaries instead of writing. Just read, analyze, and write.
161
+
162
+ Read ${analysis_relpath} and identify patterns for the project ${PROJECT_NAME} (user corrections, error resolutions, repeated workflows, tool preferences).
163
+ If you find 3+ occurrences of the same pattern, you MUST write an instinct file directly to ${INSTINCTS_DIR}/<id>.md using the Write tool.
164
+ Do NOT ask for permission to write files, do NOT describe what you would write, and do NOT stop at analysis when a qualifying pattern exists.
165
+
166
+ CRITICAL: Every instinct file MUST use this exact format:
167
+
168
+ ---
169
+ id: kebab-case-name
170
+ trigger: when <specific condition>
171
+ confidence: <0.3-0.85 based on frequency: 3-5 times=0.5, 6-10=0.7, 11+=0.85>
172
+ domain: <one of: code-style, testing, git, debugging, workflow, file-patterns>
173
+ source: session-observation
174
+ scope: project
175
+ project_id: ${PROJECT_ID}
176
+ project_name: ${PROJECT_NAME}
177
+ ---
178
+
179
+ # Title
180
+
181
+ ## Action
182
+ <what to do, one clear sentence>
183
+
184
+ ## Evidence
185
+ - Observed N times in session <id>
186
+ - Pattern: <description>
187
+ - Last observed: <date>
188
+
189
+ Rules:
190
+ - Be conservative, only clear patterns with 3+ observations
191
+ - Use narrow, specific triggers
192
+ - Never include actual code snippets, only describe patterns
193
+ - When a qualifying pattern exists, write or update the instinct file in this run instead of asking for confirmation
194
+ - If a similar instinct already exists in ${INSTINCTS_DIR}/, update it instead of creating a duplicate
195
+ - The YAML frontmatter (between --- markers) with id field is MANDATORY
196
+ - If a pattern seems universal (not project-specific), set scope to global instead of project
197
+ - Examples of global patterns: always validate user input, prefer explicit error handling
198
+ - Examples of project patterns: use React functional components, follow Django REST framework conventions
199
+ PROMPT
200
+
201
+ # Read the prompt into memory before the Claude subprocess is spawned.
202
+ # On Windows/MSYS2, the mktemp path can differ from the shell's later path
203
+ # resolution, so relying on cat "$prompt_file" inside the claude invocation
204
+ # can fail even though the file was created successfully.
205
+ prompt_content="$(cat "$prompt_file" 2>/dev/null || true)"
206
+ rm -f "$prompt_file"
207
+ if [ -z "$prompt_content" ]; then
208
+ echo "[$(date)] Failed to load observer prompt content, skipping analysis" >> "$LOG_FILE"
209
+ rm -f "$analysis_file"
210
+ return
211
+ fi
212
+
213
+ timeout_seconds="${ECC_OBSERVER_TIMEOUT_SECONDS:-120}"
214
+ # Auto-scale max_turns proportional to analysis batch size when not explicitly set.
215
+ # The old hardcoded default of 20 is insufficient for the 500-line MAX_ANALYSIS_LINES
216
+ # default: Claude hits --max-turns before it can write all discovered instinct files.
217
+ # Formula: 1 turn per 10 analysis lines, floor 20, cap 100. (#2035)
218
+ if [ -n "${ECC_OBSERVER_MAX_TURNS:-}" ]; then
219
+ max_turns="${ECC_OBSERVER_MAX_TURNS}"
220
+ else
221
+ max_turns=$(( analysis_count / 10 ))
222
+ if [ "$max_turns" -lt 20 ]; then max_turns=20; fi
223
+ if [ "$max_turns" -gt 100 ]; then max_turns=100; fi
224
+ fi
225
+ exit_code=0
226
+
227
+ # Sanitize max_turns. The auto-scaled path above always yields a valid value >=20,
228
+ # but an explicit ECC_OBSERVER_MAX_TURNS override may be non-numeric, empty, or too
229
+ # small, so guard here and fall back to the safe default of 20.
230
+ case "$max_turns" in
231
+ ''|*[!0-9]*)
232
+ max_turns=20
233
+ ;;
234
+ esac
235
+
236
+ if [ "$max_turns" -lt 4 ]; then
237
+ max_turns=20
238
+ fi
239
+
240
+ # Ensure CWD is PROJECT_DIR so the relative analysis_relpath resolves correctly
241
+ # on all platforms, not just when the observer happens to be launched from the project root.
242
+ cd "$PROJECT_DIR" || { echo "[$(date)] Failed to cd to PROJECT_DIR ($PROJECT_DIR), skipping analysis" >> "$LOG_FILE"; rm -f "$analysis_file"; return; }
243
+
244
+ # Prevent observe.sh from recording this automated observer session as observations.
245
+ # Pass prompt via -p flag instead of stdin redirect for Windows compatibility (#842).
246
+ # prompt_content is already loaded in-memory so this no longer depends on the
247
+ # mktemp absolute path continuing to resolve after cwd changes (#1296).
248
+ # Model is configurable via ECC_OBSERVER_MODEL (defaults to haiku for cost efficiency);
249
+ # e.g. ECC_OBSERVER_MODEL=opus for higher-quality instinct extraction. Heavier models are
250
+ # slower — consider raising ECC_OBSERVER_TIMEOUT_SECONDS (default 120s) so the watchdog
251
+ # doesn't kill the analysis mid-run.
252
+ ECC_SKIP_OBSERVE=1 ECC_HOOK_PROFILE=minimal claude --model "${ECC_OBSERVER_MODEL:-haiku}" --max-turns "$max_turns" --print \
253
+ --allowedTools "Read,Write" \
254
+ -p "$prompt_content" >> "$LOG_FILE" 2>&1 &
255
+ claude_pid=$!
256
+
257
+ (
258
+ sleep "$timeout_seconds"
259
+ if kill -0 "$claude_pid" 2>/dev/null; then
260
+ echo "[$(date)] Claude analysis timed out after ${timeout_seconds}s; terminating process" >> "$LOG_FILE"
261
+ kill "$claude_pid" 2>/dev/null || true
262
+ fi
263
+ ) &
264
+ watchdog_pid=$!
265
+
266
+ wait_for_claude_analysis "$claude_pid"
267
+ exit_code=$?
268
+ kill "$watchdog_pid" 2>/dev/null || true
269
+ rm -f "$analysis_file"
270
+
271
+ if [ "$exit_code" -ne 0 ]; then
272
+ echo "[$(date)] Claude analysis failed (exit $exit_code); retaining observations for retry" >> "$LOG_FILE"
273
+ return
274
+ fi
275
+
276
+ # Archive observations only after a successful analysis. A transient
277
+ # failure (timeout, non-zero exit, rate limit) must not discard the batch
278
+ # before it has been turned into instincts, since the analyzer only ever
279
+ # reads the live observations file (#2370).
280
+ if [ -f "$OBSERVATIONS_FILE" ]; then
281
+ archive_dir="${PROJECT_DIR}/observations.archive"
282
+ mkdir -p "$archive_dir"
283
+ mv "$OBSERVATIONS_FILE" "$archive_dir/processed-$(date +%Y%m%d-%H%M%S)-$$.jsonl" 2>/dev/null || true
284
+ fi
285
+ }
286
+
287
+ on_usr1() {
288
+ [ -n "$SLEEP_PID" ] && kill "$SLEEP_PID" 2>/dev/null
289
+ SLEEP_PID=""
290
+
291
+ # Re-entrancy guard: defer the nudge so the main loop runs a follow-up
292
+ # analysis immediately after the current analysis finishes.
293
+ if [ "$ANALYZING" -eq 1 ]; then
294
+ PENDING_ANALYSIS=1
295
+ echo "[$(date)] Analysis already in progress, deferring signal" >> "$LOG_FILE"
296
+ return
297
+ fi
298
+
299
+ USR1_FIRED=1
300
+
301
+ # Cooldown: skip if last analysis was too recent (#521)
302
+ now_epoch=$(date +%s)
303
+ elapsed=$(( now_epoch - LAST_ANALYSIS_EPOCH ))
304
+ if [ "$elapsed" -lt "$ANALYSIS_COOLDOWN" ]; then
305
+ echo "[$(date)] Analysis cooldown active (${elapsed}s < ${ANALYSIS_COOLDOWN}s), skipping" >> "$LOG_FILE"
306
+ return
307
+ fi
308
+
309
+ ANALYZING=1
310
+ analyze_observations
311
+ LAST_ANALYSIS_EPOCH=$(date +%s)
312
+ ANALYZING=0
313
+ }
314
+ trap on_usr1 USR1
315
+
316
+ # When this file is sourced (e.g. by tests/hooks/observer-loop-archive.test.js)
317
+ # rather than executed, stop here so callers can invoke individual functions
318
+ # such as analyze_observations without starting the observer loop. The only
319
+ # production caller (start-observer.sh) executes the script, so $0 equals
320
+ # BASH_SOURCE[0] there and this guard is a no-op (#2370).
321
+ if [ "${BASH_SOURCE[0]}" != "${0}" ]; then
322
+ return 0 2>/dev/null || true
323
+ fi
324
+
325
+ echo "$$" > "$PID_FILE"
326
+ echo "[$(date)] Observer started for ${PROJECT_NAME} (PID: $$)" >> "$LOG_FILE"
327
+
328
+ # Prune expired pending instincts before analysis (SCRIPT_DIR resolved at top
329
+ # via ${BASH_SOURCE[0]} so it is correct under both execution and sourcing).
330
+ "${CLV2_PYTHON_CMD:-python3}" "${SCRIPT_DIR}/../scripts/instinct-cli.py" prune --quiet >> "$LOG_FILE" 2>&1 || echo "[$(date)] Warning: instinct prune failed (non-fatal)" >> "$LOG_FILE"
331
+
332
+ while true; do
333
+ exit_if_idle_without_sessions
334
+
335
+ if [ "$PENDING_ANALYSIS" -eq 1 ]; then
336
+ PENDING_ANALYSIS=0
337
+ USR1_FIRED=0
338
+ ANALYZING=1
339
+ analyze_observations
340
+ LAST_ANALYSIS_EPOCH=$(date +%s)
341
+ ANALYZING=0
342
+ continue
343
+ fi
344
+
345
+ sleep "$OBSERVER_INTERVAL_SECONDS" &
346
+ SLEEP_PID=$!
347
+ wait "$SLEEP_PID" 2>/dev/null
348
+ SLEEP_PID=""
349
+
350
+ exit_if_idle_without_sessions
351
+ if [ "$USR1_FIRED" -eq 1 ]; then
352
+ USR1_FIRED=0
353
+ else
354
+ ANALYZING=1
355
+ analyze_observations
356
+ LAST_ANALYSIS_EPOCH=$(date +%s)
357
+ ANALYZING=0
358
+ fi
359
+ done
@@ -0,0 +1,189 @@
1
+ ---
2
+ name: observer
3
+ description: Background agent that analyzes session observations to detect patterns and create instincts. Uses Haiku for cost-efficiency. v2.1 adds project-scoped instincts.
4
+ model: haiku
5
+ ---
6
+
7
+ # Observer Agent
8
+
9
+ A background agent that analyzes observations from Claude Code sessions to detect patterns and create instincts.
10
+
11
+ ## When to Run
12
+
13
+ - After enough observations accumulate (configurable, default 20)
14
+ - On a scheduled interval (configurable, default 5 minutes)
15
+ - When triggered on demand via SIGUSR1 to the observer process
16
+
17
+ ## Input
18
+
19
+ Reads observations from the **project-scoped** observations file:
20
+ - Project: `${XDG_DATA_HOME:-~/.local/share}/ecc-homunculus/projects/<project-hash>/observations.jsonl`
21
+ - Global fallback: `${XDG_DATA_HOME:-~/.local/share}/ecc-homunculus/observations.jsonl`
22
+
23
+ ```jsonl
24
+ {"timestamp":"2025-01-22T10:30:00Z","event":"tool_start","session":"abc123","tool":"Edit","input":"...","project_id":"a1b2c3d4e5f6","project_name":"my-react-app"}
25
+ {"timestamp":"2025-01-22T10:30:01Z","event":"tool_complete","session":"abc123","tool":"Edit","output":"...","project_id":"a1b2c3d4e5f6","project_name":"my-react-app"}
26
+ {"timestamp":"2025-01-22T10:30:05Z","event":"tool_start","session":"abc123","tool":"Bash","input":"npm test","project_id":"a1b2c3d4e5f6","project_name":"my-react-app"}
27
+ {"timestamp":"2025-01-22T10:30:10Z","event":"tool_complete","session":"abc123","tool":"Bash","output":"All tests pass","project_id":"a1b2c3d4e5f6","project_name":"my-react-app"}
28
+ ```
29
+
30
+ ## Pattern Detection
31
+
32
+ Look for these patterns in observations:
33
+
34
+ ### 1. User Corrections
35
+ When a user's follow-up message corrects Claude's previous action:
36
+ - "No, use X instead of Y"
37
+ - "Actually, I meant..."
38
+ - Immediate undo/redo patterns
39
+
40
+ → Create instinct: "When doing X, prefer Y"
41
+
42
+ ### 2. Error Resolutions
43
+ When an error is followed by a fix:
44
+ - Tool output contains error
45
+ - Next few tool calls fix it
46
+ - Same error type resolved similarly multiple times
47
+
48
+ → Create instinct: "When encountering error X, try Y"
49
+
50
+ ### 3. Repeated Workflows
51
+ When the same sequence of tools is used multiple times:
52
+ - Same tool sequence with similar inputs
53
+ - File patterns that change together
54
+ - Time-clustered operations
55
+
56
+ → Create workflow instinct: "When doing X, follow steps Y, Z, W"
57
+
58
+ ### 4. Tool Preferences
59
+ When certain tools are consistently preferred:
60
+ - Always uses Grep before Edit
61
+ - Prefers Read over Bash cat
62
+ - Uses specific Bash commands for certain tasks
63
+
64
+ → Create instinct: "When needing X, use tool Y"
65
+
66
+ ## Output
67
+
68
+ Creates/updates instincts in the **project-scoped** instincts directory:
69
+ - Project: `${XDG_DATA_HOME:-~/.local/share}/ecc-homunculus/projects/<project-hash>/instincts/personal/`
70
+ - Global: `${XDG_DATA_HOME:-~/.local/share}/ecc-homunculus/instincts/personal/` (for universal patterns)
71
+
72
+ ### Project-Scoped Instinct (default)
73
+
74
+ ```yaml
75
+ ---
76
+ id: use-react-hooks-pattern
77
+ trigger: "when creating React components"
78
+ confidence: 0.65
79
+ domain: "code-style"
80
+ source: "session-observation"
81
+ scope: project
82
+ project_id: "a1b2c3d4e5f6"
83
+ project_name: "my-react-app"
84
+ ---
85
+
86
+ # Use React Hooks Pattern
87
+
88
+ ## Action
89
+ Always use functional components with hooks instead of class components.
90
+
91
+ ## Evidence
92
+ - Observed 8 times in session abc123
93
+ - Pattern: All new components use useState/useEffect
94
+ - Last observed: 2025-01-22
95
+ ```
96
+
97
+ ### Global Instinct (universal patterns)
98
+
99
+ ```yaml
100
+ ---
101
+ id: always-validate-user-input
102
+ trigger: "when handling user input"
103
+ confidence: 0.75
104
+ domain: "security"
105
+ source: "session-observation"
106
+ scope: global
107
+ ---
108
+
109
+ # Always Validate User Input
110
+
111
+ ## Action
112
+ Validate and sanitize all user input before processing.
113
+
114
+ ## Evidence
115
+ - Observed across 3 different projects
116
+ - Pattern: User consistently adds input validation
117
+ - Last observed: 2025-01-22
118
+ ```
119
+
120
+ ## Scope Decision Guide
121
+
122
+ When creating instincts, determine scope based on these heuristics:
123
+
124
+ > **Scope Decision Guide** – See the canonical table in `skills/continuous-learning-v2/SKILL.md` (lines 271‑282).
125
+
126
+ **When in doubt, default to `scope: project`** — it's safer to be project-specific and promote later than to contaminate the global space.
127
+
128
+ ## Confidence Calculation
129
+
130
+ Initial confidence based on observation frequency:
131
+ - 1-2 observations: 0.3 (tentative)
132
+ - 3-5 observations: 0.5 (moderate)
133
+ - 6-10 observations: 0.7 (strong)
134
+ - 11+ observations: 0.85 (very strong)
135
+
136
+ Confidence adjusts over time:
137
+ - +0.05 for each confirming observation
138
+ - -0.1 for each contradicting observation
139
+ - -0.02 per week without observation (decay)
140
+
141
+ ## Instinct Promotion (Project → Global)
142
+
143
+ An instinct should be promoted from project-scoped to global when:
144
+ 1. The **same pattern** (by id or similar trigger) exists in **2+ different projects**
145
+ 2. Each instance has confidence **>= 0.8**
146
+ 3. The domain is in the global-friendly list (security, general-best-practices, workflow)
147
+
148
+ Promotion is handled by the `instinct-cli.py promote` command or the `/evolve` analysis.
149
+
150
+ ## Important Guidelines
151
+
152
+ 1. **Be Conservative**: Only create instincts for clear patterns (3+ observations)
153
+ 2. **Be Specific**: Narrow triggers are better than broad ones
154
+ 3. **Track Evidence**: Always include what observations led to the instinct
155
+ 4. **Respect Privacy**: Never include actual code snippets, only patterns
156
+ 5. **Merge Similar**: If a new instinct is similar to existing, update rather than duplicate
157
+ 6. **Default to Project Scope**: Unless the pattern is clearly universal, make it project-scoped
158
+ 7. **Include Project Context**: Always set `project_id` and `project_name` for project-scoped instincts
159
+
160
+ ## Example Analysis Session
161
+
162
+ Given observations:
163
+ ```jsonl
164
+ {"event":"tool_start","tool":"Grep","input":"pattern: useState","project_id":"a1b2c3","project_name":"my-app"}
165
+ {"event":"tool_complete","tool":"Grep","output":"Found in 3 files","project_id":"a1b2c3","project_name":"my-app"}
166
+ {"event":"tool_start","tool":"Read","input":"src/hooks/useAuth.ts","project_id":"a1b2c3","project_name":"my-app"}
167
+ {"event":"tool_complete","tool":"Read","output":"[file content]","project_id":"a1b2c3","project_name":"my-app"}
168
+ {"event":"tool_start","tool":"Edit","input":"src/hooks/useAuth.ts...","project_id":"a1b2c3","project_name":"my-app"}
169
+ ```
170
+
171
+ Analysis:
172
+ - Detected workflow: Grep → Read → Edit
173
+ - Frequency: Seen 5 times this session
174
+ - **Scope decision**: This is a general workflow pattern (not project-specific) → **global**
175
+ - Create instinct:
176
+ - trigger: "when modifying code"
177
+ - action: "Search with Grep, confirm with Read, then Edit"
178
+ - confidence: 0.6
179
+ - domain: "workflow"
180
+ - scope: "global"
181
+
182
+ ## Integration with Skill Creator
183
+
184
+ When instincts are imported from Skill Creator (repo analysis), they have:
185
+ - `source: "repo-analysis"`
186
+ - `source_repo: "https://github.com/..."`
187
+ - `scope: "project"` (since they come from a specific repo)
188
+
189
+ These should be treated as team/project conventions with higher initial confidence (0.7+).