buildanything 1.8.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (458) hide show
  1. package/.claude-plugin/marketplace.json +3 -3
  2. package/.claude-plugin/plugin.json +9 -3
  3. package/CHANGELOG.md +57 -0
  4. package/README.md +2 -2
  5. package/agents/a11y-architect.md +166 -0
  6. package/agents/business-model.md +80 -29
  7. package/agents/code-architect.md +75 -0
  8. package/agents/code-reviewer.md +255 -0
  9. package/agents/code-simplifier.md +64 -0
  10. package/agents/design-brand-guardian.md +293 -53
  11. package/agents/design-critic.md +139 -0
  12. package/agents/design-inclusive-visuals-specialist.md +6 -19
  13. package/agents/design-ui-designer.md +335 -56
  14. package/agents/design-ux-architect.md +403 -55
  15. package/agents/design-ux-researcher.md +264 -49
  16. package/agents/engineering-ai-engineer.md +26 -36
  17. package/agents/engineering-backend-architect.md +185 -36
  18. package/agents/engineering-data-engineer.md +225 -43
  19. package/agents/engineering-devops-automator.md +227 -74
  20. package/agents/engineering-frontend-developer.md +210 -34
  21. package/agents/engineering-mobile-app-builder.md +6 -1
  22. package/agents/engineering-rapid-prototyper.md +30 -9
  23. package/agents/engineering-security-engineer.md +263 -61
  24. package/agents/engineering-senior-developer.md +128 -19
  25. package/agents/engineering-sre.md +84 -0
  26. package/agents/engineering-technical-writer.md +285 -41
  27. package/agents/feature-intel.md +110 -0
  28. package/agents/ios-app-review-guardian.md +19 -2
  29. package/agents/ios-foundation-models-specialist.md +20 -2
  30. package/agents/ios-storekit-specialist.md +9 -2
  31. package/agents/ios-swift-architect.md +28 -1
  32. package/agents/ios-swift-search.md +8 -1
  33. package/agents/ios-swift-ui-design.md +33 -1
  34. package/agents/marketing-app-store-optimizer.md +246 -64
  35. package/agents/planner.md +216 -0
  36. package/agents/pr-test-analyzer.md +63 -0
  37. package/agents/product-feedback-synthesizer.md +8 -2
  38. package/agents/refactor-cleaner.md +102 -0
  39. package/agents/security-reviewer.md +128 -0
  40. package/agents/silent-failure-hunter.md +54 -0
  41. package/agents/swift-build-resolver.md +119 -0
  42. package/agents/swift-reviewer.md +112 -0
  43. package/agents/tech-feasibility.md +21 -1
  44. package/agents/testing-api-tester.md +236 -59
  45. package/agents/testing-evidence-collector.md +26 -1
  46. package/agents/testing-performance-benchmarker.md +21 -1
  47. package/agents/testing-reality-checker.md +6 -1
  48. package/agents/visual-research.md +116 -0
  49. package/bin/adapters/cycle-counter-tool.ts +155 -0
  50. package/bin/adapters/scribe-tool.ts +71 -0
  51. package/bin/adapters/state-save-tool.ts +130 -0
  52. package/bin/adapters/write-lease-tool.ts +127 -0
  53. package/bin/buildanything-runtime.js +15 -0
  54. package/bin/buildanything-runtime.ts +328 -0
  55. package/bin/setup.js +83 -8
  56. package/commands/add-feature.md +2 -0
  57. package/commands/build.md +782 -266
  58. package/commands/fix.md +1 -1
  59. package/commands/self-check.md +121 -0
  60. package/commands/setup.md +50 -9
  61. package/commands/ux-review.md +2 -2
  62. package/commands/verify.md +6 -9
  63. package/docs/migration/agents.yaml +729 -0
  64. package/docs/migration/phase-graph.yaml +1088 -0
  65. package/docs/migration/sdk-host-compat.md +18 -0
  66. package/hooks/compile-writer-owner-cache.ts +171 -0
  67. package/hooks/hooks.json +36 -0
  68. package/hooks/pre-tool-use +19 -0
  69. package/hooks/pre-tool-use.ts +776 -0
  70. package/hooks/record-mode-transitions.ts +178 -0
  71. package/hooks/session-start +71 -1
  72. package/hooks/subagent-start +17 -0
  73. package/hooks/subagent-start.ts +471 -0
  74. package/hooks/subagent-stop +17 -0
  75. package/hooks/subagent-stop.ts +153 -0
  76. package/package.json +24 -4
  77. package/protocols/architecture-schema.md +171 -0
  78. package/protocols/decision-log.md +131 -0
  79. package/protocols/ios-context.md +10 -11
  80. package/protocols/ios-phase-branches.md +208 -33
  81. package/protocols/launch-readiness.md +258 -0
  82. package/protocols/metric-loop.md +62 -2
  83. package/protocols/smoke-test.md +9 -1
  84. package/protocols/state-schema.json +388 -0
  85. package/protocols/state-schema.md +172 -0
  86. package/protocols/verify.md +62 -2
  87. package/protocols/visual-dna.md +185 -0
  88. package/protocols/web-phase-branches.md +222 -72
  89. package/skills/ios/_VENDORED.md +2 -0
  90. package/skills/ios/app-store-connect-metadata/SKILL.md +148 -0
  91. package/skills/ios/asc-privacy-manifest/SKILL.md +350 -0
  92. package/skills/ios/hig-components-content/SKILL.md +86 -0
  93. package/skills/ios/hig-components-content/references/activity-views.md +79 -0
  94. package/skills/ios/hig-components-content/references/charts.md +180 -0
  95. package/skills/ios/hig-components-content/references/collections.md +48 -0
  96. package/skills/ios/hig-components-content/references/color-wells.md +42 -0
  97. package/skills/ios/hig-components-content/references/image-views.md +82 -0
  98. package/skills/ios/hig-components-content/references/image-wells.md +34 -0
  99. package/skills/ios/hig-components-content/references/lockups.md +78 -0
  100. package/skills/ios/hig-components-content/references/web-views.md +36 -0
  101. package/skills/ios/hig-components-controls/SKILL.md +88 -0
  102. package/skills/ios/hig-components-controls/references/combo-boxes.md +40 -0
  103. package/skills/ios/hig-components-controls/references/controls.md +112 -0
  104. package/skills/ios/hig-components-controls/references/gauges.md +74 -0
  105. package/skills/ios/hig-components-controls/references/labels.md +92 -0
  106. package/skills/ios/hig-components-controls/references/pickers.md +128 -0
  107. package/skills/ios/hig-components-controls/references/rating-indicators.md +38 -0
  108. package/skills/ios/hig-components-controls/references/segmented-controls.md +94 -0
  109. package/skills/ios/hig-components-controls/references/sliders.md +92 -0
  110. package/skills/ios/hig-components-controls/references/steppers.md +40 -0
  111. package/skills/ios/hig-components-controls/references/text-fields.md +88 -0
  112. package/skills/ios/hig-components-controls/references/text-views.md +56 -0
  113. package/skills/ios/hig-components-controls/references/toggles.md +127 -0
  114. package/skills/ios/hig-components-controls/references/token-fields.md +48 -0
  115. package/skills/ios/hig-components-controls/references/virtual-keyboards.md +156 -0
  116. package/skills/ios/hig-components-dialogs/SKILL.md +76 -0
  117. package/skills/ios/hig-components-dialogs/references/action-sheets.md +74 -0
  118. package/skills/ios/hig-components-dialogs/references/alerts.md +158 -0
  119. package/skills/ios/hig-components-dialogs/references/digit-entry-views.md +32 -0
  120. package/skills/ios/hig-components-dialogs/references/popovers.md +81 -0
  121. package/skills/ios/hig-components-dialogs/references/sheets.md +157 -0
  122. package/skills/ios/hig-components-layout/SKILL.md +99 -0
  123. package/skills/ios/hig-components-layout/references/boxes.md +48 -0
  124. package/skills/ios/hig-components-layout/references/column-views.md +44 -0
  125. package/skills/ios/hig-components-layout/references/lists-and-tables.md +99 -0
  126. package/skills/ios/hig-components-layout/references/ornaments.md +56 -0
  127. package/skills/ios/hig-components-layout/references/outline-views.md +64 -0
  128. package/skills/ios/hig-components-layout/references/panels.md +75 -0
  129. package/skills/ios/hig-components-layout/references/scroll-views.md +123 -0
  130. package/skills/ios/hig-components-layout/references/sidebars.md +109 -0
  131. package/skills/ios/hig-components-layout/references/split-views.md +110 -0
  132. package/skills/ios/hig-components-layout/references/tab-bars.md +173 -0
  133. package/skills/ios/hig-components-layout/references/tab-views.md +68 -0
  134. package/skills/ios/hig-components-layout/references/windows.md +188 -0
  135. package/skills/ios/hig-components-menus/SKILL.md +81 -0
  136. package/skills/ios/hig-components-menus/references/action-button.md +61 -0
  137. package/skills/ios/hig-components-menus/references/buttons.md +261 -0
  138. package/skills/ios/hig-components-menus/references/context-menus.md +105 -0
  139. package/skills/ios/hig-components-menus/references/disclosure-controls.md +84 -0
  140. package/skills/ios/hig-components-menus/references/dock-menus.md +40 -0
  141. package/skills/ios/hig-components-menus/references/edit-menus.md +88 -0
  142. package/skills/ios/hig-components-menus/references/menus.md +171 -0
  143. package/skills/ios/hig-components-menus/references/pop-up-buttons.md +70 -0
  144. package/skills/ios/hig-components-menus/references/pull-down-buttons.md +77 -0
  145. package/skills/ios/hig-components-menus/references/the-menu-bar.md +303 -0
  146. package/skills/ios/hig-components-menus/references/toolbars.md +256 -0
  147. package/skills/ios/hig-components-search/SKILL.md +68 -0
  148. package/skills/ios/hig-components-search/references/page-controls.md +120 -0
  149. package/skills/ios/hig-components-search/references/path-controls.md +40 -0
  150. package/skills/ios/hig-components-search/references/search-fields.md +189 -0
  151. package/skills/ios/hig-components-status/SKILL.md +80 -0
  152. package/skills/ios/hig-components-status/references/activity-rings.md +105 -0
  153. package/skills/ios/hig-components-status/references/progress-indicators.md +116 -0
  154. package/skills/ios/hig-components-status/references/status-bars.md +38 -0
  155. package/skills/ios/hig-components-system/SKILL.md +88 -0
  156. package/skills/ios/hig-components-system/references/app-clips.md +387 -0
  157. package/skills/ios/hig-components-system/references/app-shortcuts.md +114 -0
  158. package/skills/ios/hig-components-system/references/complications.md +425 -0
  159. package/skills/ios/hig-components-system/references/home-screen-quick-actions.md +42 -0
  160. package/skills/ios/hig-components-system/references/live-activities.md +442 -0
  161. package/skills/ios/hig-components-system/references/notifications.md +153 -0
  162. package/skills/ios/hig-components-system/references/top-shelf.md +135 -0
  163. package/skills/ios/hig-components-system/references/watch-faces.md +40 -0
  164. package/skills/ios/hig-components-system/references/widgets.md +517 -0
  165. package/skills/ios/hig-foundations/SKILL.md +98 -0
  166. package/skills/ios/hig-foundations/references/accessibility.md +291 -0
  167. package/skills/ios/hig-foundations/references/app-icons.md +210 -0
  168. package/skills/ios/hig-foundations/references/branding.md +44 -0
  169. package/skills/ios/hig-foundations/references/color.md +274 -0
  170. package/skills/ios/hig-foundations/references/dark-mode.md +116 -0
  171. package/skills/ios/hig-foundations/references/icons.md +263 -0
  172. package/skills/ios/hig-foundations/references/images.md +176 -0
  173. package/skills/ios/hig-foundations/references/immersive-experiences.md +174 -0
  174. package/skills/ios/hig-foundations/references/inclusion.md +189 -0
  175. package/skills/ios/hig-foundations/references/layout.md +425 -0
  176. package/skills/ios/hig-foundations/references/materials.md +238 -0
  177. package/skills/ios/hig-foundations/references/motion.md +103 -0
  178. package/skills/ios/hig-foundations/references/privacy.md +231 -0
  179. package/skills/ios/hig-foundations/references/right-to-left.md +206 -0
  180. package/skills/ios/hig-foundations/references/sf-symbols.md +310 -0
  181. package/skills/ios/hig-foundations/references/spatial-layout.md +142 -0
  182. package/skills/ios/hig-foundations/references/typography.md +1146 -0
  183. package/skills/ios/hig-foundations/references/writing.md +91 -0
  184. package/skills/ios/hig-inputs/SKILL.md +94 -0
  185. package/skills/ios/hig-inputs/references/apple-pencil-and-scribble.md +148 -0
  186. package/skills/ios/hig-inputs/references/camera-control.md +107 -0
  187. package/skills/ios/hig-inputs/references/digital-crown.md +83 -0
  188. package/skills/ios/hig-inputs/references/eyes.md +120 -0
  189. package/skills/ios/hig-inputs/references/focus-and-selection.md +120 -0
  190. package/skills/ios/hig-inputs/references/game-controls.md +156 -0
  191. package/skills/ios/hig-inputs/references/gestures.md +208 -0
  192. package/skills/ios/hig-inputs/references/gyro-and-accelerometer.md +40 -0
  193. package/skills/ios/hig-inputs/references/keyboards.md +234 -0
  194. package/skills/ios/hig-inputs/references/nearby-interactions.md +70 -0
  195. package/skills/ios/hig-inputs/references/pointing-devices.md +237 -0
  196. package/skills/ios/hig-inputs/references/remotes.md +67 -0
  197. package/skills/ios/hig-inputs/references/spatial-interactions.md +70 -0
  198. package/skills/ios/hig-patterns/SKILL.md +104 -0
  199. package/skills/ios/hig-patterns/references/charting-data.md +81 -0
  200. package/skills/ios/hig-patterns/references/collaboration-and-sharing.md +86 -0
  201. package/skills/ios/hig-patterns/references/drag-and-drop.md +134 -0
  202. package/skills/ios/hig-patterns/references/entering-data.md +69 -0
  203. package/skills/ios/hig-patterns/references/feedback.md +67 -0
  204. package/skills/ios/hig-patterns/references/file-management.md +135 -0
  205. package/skills/ios/hig-patterns/references/going-full-screen.md +79 -0
  206. package/skills/ios/hig-patterns/references/launching.md +81 -0
  207. package/skills/ios/hig-patterns/references/live-viewing-apps.md +79 -0
  208. package/skills/ios/hig-patterns/references/loading.md +59 -0
  209. package/skills/ios/hig-patterns/references/managing-accounts.md +107 -0
  210. package/skills/ios/hig-patterns/references/managing-notifications.md +99 -0
  211. package/skills/ios/hig-patterns/references/modality.md +82 -0
  212. package/skills/ios/hig-patterns/references/multitasking.md +131 -0
  213. package/skills/ios/hig-patterns/references/offering-help.md +117 -0
  214. package/skills/ios/hig-patterns/references/onboarding.md +69 -0
  215. package/skills/ios/hig-patterns/references/playing-audio.md +124 -0
  216. package/skills/ios/hig-patterns/references/playing-haptics.md +280 -0
  217. package/skills/ios/hig-patterns/references/playing-video.md +180 -0
  218. package/skills/ios/hig-patterns/references/printing.md +50 -0
  219. package/skills/ios/hig-patterns/references/ratings-and-reviews.md +48 -0
  220. package/skills/ios/hig-patterns/references/searching.md +70 -0
  221. package/skills/ios/hig-patterns/references/settings.md +84 -0
  222. package/skills/ios/hig-patterns/references/undo-and-redo.md +58 -0
  223. package/skills/ios/hig-patterns/references/workouts.md +76 -0
  224. package/skills/ios/hig-platforms/SKILL.md +84 -0
  225. package/skills/ios/hig-platforms/references/designing-for-games.md +159 -0
  226. package/skills/ios/hig-platforms/references/designing-for-ios.md +66 -0
  227. package/skills/ios/hig-platforms/references/designing-for-ipados.md +64 -0
  228. package/skills/ios/hig-platforms/references/designing-for-macos.md +70 -0
  229. package/skills/ios/hig-platforms/references/designing-for-tvos.md +68 -0
  230. package/skills/ios/hig-platforms/references/designing-for-visionos.md +85 -0
  231. package/skills/ios/hig-platforms/references/designing-for-watchos.md +74 -0
  232. package/skills/ios/hig-project-context/SKILL.md +133 -0
  233. package/skills/ios/hig-technologies/SKILL.md +107 -0
  234. package/skills/ios/hig-technologies/references/airplay.md +125 -0
  235. package/skills/ios/hig-technologies/references/always-on.md +62 -0
  236. package/skills/ios/hig-technologies/references/apple-pay.md +441 -0
  237. package/skills/ios/hig-technologies/references/augmented-reality.md +247 -0
  238. package/skills/ios/hig-technologies/references/carekit.md +224 -0
  239. package/skills/ios/hig-technologies/references/carplay.md +119 -0
  240. package/skills/ios/hig-technologies/references/game-center.md +343 -0
  241. package/skills/ios/hig-technologies/references/generative-ai.md +110 -0
  242. package/skills/ios/hig-technologies/references/healthkit.md +120 -0
  243. package/skills/ios/hig-technologies/references/homekit.md +343 -0
  244. package/skills/ios/hig-technologies/references/icloud.md +52 -0
  245. package/skills/ios/hig-technologies/references/id-verifier.md +73 -0
  246. package/skills/ios/hig-technologies/references/imessage-apps-and-stickers.md +105 -0
  247. package/skills/ios/hig-technologies/references/in-app-purchase.md +263 -0
  248. package/skills/ios/hig-technologies/references/live-photos.md +54 -0
  249. package/skills/ios/hig-technologies/references/mac-catalyst.md +216 -0
  250. package/skills/ios/hig-technologies/references/machine-learning.md +394 -0
  251. package/skills/ios/hig-technologies/references/maps.md +221 -0
  252. package/skills/ios/hig-technologies/references/nfc.md +51 -0
  253. package/skills/ios/hig-technologies/references/photo-editing.md +40 -0
  254. package/skills/ios/hig-technologies/references/researchkit.md +134 -0
  255. package/skills/ios/hig-technologies/references/shareplay.md +142 -0
  256. package/skills/ios/hig-technologies/references/shazamkit.md +47 -0
  257. package/skills/ios/hig-technologies/references/sign-in-with-apple.md +288 -0
  258. package/skills/ios/hig-technologies/references/siri.md +523 -0
  259. package/skills/ios/hig-technologies/references/tap-to-pay-on-iphone.md +208 -0
  260. package/skills/ios/hig-technologies/references/voiceover.md +90 -0
  261. package/skills/ios/hig-technologies/references/wallet.md +420 -0
  262. package/skills/ios/ios-bootstrap/SKILL.md +16 -7
  263. package/skills/ios/swift-actor-persistence/SKILL.md +143 -0
  264. package/skills/ios/swift-concurrency-6-2/SKILL.md +216 -0
  265. package/skills/ios/swift-protocol-di-testing/SKILL.md +190 -0
  266. package/skills/ios/swiftui-design-tokens/SKILL.md +475 -0
  267. package/skills/ios/writing-for-interfaces/SKILL.md +75 -0
  268. package/skills/web/accessibility/SKILL.md +146 -0
  269. package/skills/web/aceternity-ui/SKILL.md +719 -0
  270. package/skills/web/aceternity-ui/metadata.json +10 -0
  271. package/skills/web/api-design/SKILL.md +523 -0
  272. package/skills/web/chart-accessibility/SKILL.md +332 -0
  273. package/skills/web/composition-patterns/AGENTS.md +946 -0
  274. package/skills/web/composition-patterns/README.md +60 -0
  275. package/skills/web/composition-patterns/SKILL.md +89 -0
  276. package/skills/web/composition-patterns/metadata.json +11 -0
  277. package/skills/web/composition-patterns/rules/_sections.md +29 -0
  278. package/skills/web/composition-patterns/rules/_template.md +24 -0
  279. package/skills/web/composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
  280. package/skills/web/composition-patterns/rules/architecture-compound-components.md +112 -0
  281. package/skills/web/composition-patterns/rules/patterns-children-over-render-props.md +87 -0
  282. package/skills/web/composition-patterns/rules/patterns-explicit-variants.md +100 -0
  283. package/skills/web/composition-patterns/rules/react19-no-forwardref.md +42 -0
  284. package/skills/web/composition-patterns/rules/state-context-interface.md +191 -0
  285. package/skills/web/composition-patterns/rules/state-decouple-implementation.md +113 -0
  286. package/skills/web/composition-patterns/rules/state-lift-state.md +125 -0
  287. package/skills/web/cost-aware-llm-pipeline/SKILL.md +183 -0
  288. package/skills/web/database-migrations/SKILL.md +429 -0
  289. package/skills/web/deployment-patterns/SKILL.md +427 -0
  290. package/skills/web/docker-patterns/SKILL.md +364 -0
  291. package/skills/web/e2e-testing/SKILL.md +326 -0
  292. package/skills/web/lighthouse-ci/SKILL.md +361 -0
  293. package/skills/web/mcp-server-patterns/SKILL.md +69 -0
  294. package/skills/web/next-best-practices/SKILL.md +153 -0
  295. package/skills/web/next-best-practices/async-patterns.md +87 -0
  296. package/skills/web/next-best-practices/bundling.md +180 -0
  297. package/skills/web/next-best-practices/data-patterns.md +297 -0
  298. package/skills/web/next-best-practices/debug-tricks.md +105 -0
  299. package/skills/web/next-best-practices/directives.md +73 -0
  300. package/skills/web/next-best-practices/error-handling.md +227 -0
  301. package/skills/web/next-best-practices/file-conventions.md +140 -0
  302. package/skills/web/next-best-practices/font.md +245 -0
  303. package/skills/web/next-best-practices/functions.md +108 -0
  304. package/skills/web/next-best-practices/hydration-error.md +91 -0
  305. package/skills/web/next-best-practices/image.md +173 -0
  306. package/skills/web/next-best-practices/metadata.md +301 -0
  307. package/skills/web/next-best-practices/parallel-routes.md +287 -0
  308. package/skills/web/next-best-practices/route-handlers.md +146 -0
  309. package/skills/web/next-best-practices/rsc-boundaries.md +159 -0
  310. package/skills/web/next-best-practices/runtime-selection.md +39 -0
  311. package/skills/web/next-best-practices/scripts.md +141 -0
  312. package/skills/web/next-best-practices/self-hosting.md +371 -0
  313. package/skills/web/next-best-practices/suspense-boundaries.md +67 -0
  314. package/skills/web/next-cache-components/SKILL.md +411 -0
  315. package/skills/web/postgres-best-practices/SKILL.md +14 -0
  316. package/skills/web/postgres-best-practices/references/schema-design.md +9 -0
  317. package/skills/web/react-best-practices/AGENTS.md +3810 -0
  318. package/skills/web/react-best-practices/README.md +123 -0
  319. package/skills/web/react-best-practices/SKILL.md +149 -0
  320. package/skills/web/react-best-practices/metadata.json +15 -0
  321. package/skills/web/react-best-practices/rules/_sections.md +46 -0
  322. package/skills/web/react-best-practices/rules/_template.md +28 -0
  323. package/skills/web/react-best-practices/rules/advanced-effect-event-deps.md +56 -0
  324. package/skills/web/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  325. package/skills/web/react-best-practices/rules/advanced-init-once.md +42 -0
  326. package/skills/web/react-best-practices/rules/advanced-use-latest.md +39 -0
  327. package/skills/web/react-best-practices/rules/async-api-routes.md +38 -0
  328. package/skills/web/react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
  329. package/skills/web/react-best-practices/rules/async-defer-await.md +82 -0
  330. package/skills/web/react-best-practices/rules/async-dependencies.md +51 -0
  331. package/skills/web/react-best-practices/rules/async-parallel.md +28 -0
  332. package/skills/web/react-best-practices/rules/async-suspense-boundaries.md +99 -0
  333. package/skills/web/react-best-practices/rules/bundle-analyzable-paths.md +63 -0
  334. package/skills/web/react-best-practices/rules/bundle-barrel-imports.md +60 -0
  335. package/skills/web/react-best-practices/rules/bundle-conditional.md +31 -0
  336. package/skills/web/react-best-practices/rules/bundle-defer-third-party.md +49 -0
  337. package/skills/web/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  338. package/skills/web/react-best-practices/rules/bundle-preload.md +50 -0
  339. package/skills/web/react-best-practices/rules/client-event-listeners.md +74 -0
  340. package/skills/web/react-best-practices/rules/client-localstorage-schema.md +71 -0
  341. package/skills/web/react-best-practices/rules/client-passive-event-listeners.md +48 -0
  342. package/skills/web/react-best-practices/rules/client-swr-dedup.md +56 -0
  343. package/skills/web/react-best-practices/rules/js-batch-dom-css.md +107 -0
  344. package/skills/web/react-best-practices/rules/js-cache-function-results.md +80 -0
  345. package/skills/web/react-best-practices/rules/js-cache-property-access.md +28 -0
  346. package/skills/web/react-best-practices/rules/js-cache-storage.md +70 -0
  347. package/skills/web/react-best-practices/rules/js-combine-iterations.md +32 -0
  348. package/skills/web/react-best-practices/rules/js-early-exit.md +50 -0
  349. package/skills/web/react-best-practices/rules/js-flatmap-filter.md +60 -0
  350. package/skills/web/react-best-practices/rules/js-hoist-regexp.md +45 -0
  351. package/skills/web/react-best-practices/rules/js-index-maps.md +37 -0
  352. package/skills/web/react-best-practices/rules/js-length-check-first.md +49 -0
  353. package/skills/web/react-best-practices/rules/js-min-max-loop.md +82 -0
  354. package/skills/web/react-best-practices/rules/js-request-idle-callback.md +105 -0
  355. package/skills/web/react-best-practices/rules/js-set-map-lookups.md +24 -0
  356. package/skills/web/react-best-practices/rules/js-tosorted-immutable.md +57 -0
  357. package/skills/web/react-best-practices/rules/rendering-activity.md +26 -0
  358. package/skills/web/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  359. package/skills/web/react-best-practices/rules/rendering-conditional-render.md +40 -0
  360. package/skills/web/react-best-practices/rules/rendering-content-visibility.md +38 -0
  361. package/skills/web/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  362. package/skills/web/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  363. package/skills/web/react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  364. package/skills/web/react-best-practices/rules/rendering-resource-hints.md +85 -0
  365. package/skills/web/react-best-practices/rules/rendering-script-defer-async.md +68 -0
  366. package/skills/web/react-best-practices/rules/rendering-svg-precision.md +28 -0
  367. package/skills/web/react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  368. package/skills/web/react-best-practices/rules/rerender-defer-reads.md +39 -0
  369. package/skills/web/react-best-practices/rules/rerender-dependencies.md +45 -0
  370. package/skills/web/react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  371. package/skills/web/react-best-practices/rules/rerender-derived-state.md +29 -0
  372. package/skills/web/react-best-practices/rules/rerender-functional-setstate.md +74 -0
  373. package/skills/web/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  374. package/skills/web/react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  375. package/skills/web/react-best-practices/rules/rerender-memo.md +44 -0
  376. package/skills/web/react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  377. package/skills/web/react-best-practices/rules/rerender-no-inline-components.md +82 -0
  378. package/skills/web/react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  379. package/skills/web/react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
  380. package/skills/web/react-best-practices/rules/rerender-transitions.md +40 -0
  381. package/skills/web/react-best-practices/rules/rerender-use-deferred-value.md +59 -0
  382. package/skills/web/react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  383. package/skills/web/react-best-practices/rules/server-after-nonblocking.md +73 -0
  384. package/skills/web/react-best-practices/rules/server-auth-actions.md +96 -0
  385. package/skills/web/react-best-practices/rules/server-cache-lru.md +41 -0
  386. package/skills/web/react-best-practices/rules/server-cache-react.md +76 -0
  387. package/skills/web/react-best-practices/rules/server-dedup-props.md +65 -0
  388. package/skills/web/react-best-practices/rules/server-hoist-static-io.md +149 -0
  389. package/skills/web/react-best-practices/rules/server-no-shared-module-state.md +50 -0
  390. package/skills/web/react-best-practices/rules/server-parallel-fetching.md +83 -0
  391. package/skills/web/react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
  392. package/skills/web/react-best-practices/rules/server-serialization.md +38 -0
  393. package/skills/web/seo/SKILL.md +154 -0
  394. package/skills/web/web-design-guidelines/SKILL.md +39 -0
  395. package/skills/web/zap-scan-config/SKILL.md +444 -0
  396. package/skills/web/zap-scan-config/assets/.gitkeep +9 -0
  397. package/skills/web/zap-scan-config/assets/github_action.yml +207 -0
  398. package/skills/web/zap-scan-config/assets/gitlab_ci.yml +226 -0
  399. package/skills/web/zap-scan-config/assets/zap_automation.yaml +196 -0
  400. package/skills/web/zap-scan-config/assets/zap_context.xml +192 -0
  401. package/skills/web/zap-scan-config/references/EXAMPLE.md +40 -0
  402. package/skills/web/zap-scan-config/references/api_testing_guide.md +475 -0
  403. package/skills/web/zap-scan-config/references/authentication_guide.md +431 -0
  404. package/skills/web/zap-scan-config/references/false_positive_handling.md +427 -0
  405. package/skills/web/zap-scan-config/references/owasp_mapping.md +255 -0
  406. package/src/lrr/aggregator.ts +80 -0
  407. package/src/orchestrator/hooks/context-header.ts +95 -0
  408. package/src/orchestrator/hooks/token-accounting-emitter.ts +77 -0
  409. package/src/orchestrator/hooks/token-accounting.ts +101 -0
  410. package/src/orchestrator/mcp/cycle-counter.ts +129 -0
  411. package/src/orchestrator/mcp/scribe.ts +283 -0
  412. package/src/orchestrator/mcp/state-save.ts +149 -0
  413. package/src/orchestrator/mcp/write-lease.ts +167 -0
  414. package/src/orchestrator/phase4-shared-context.ts +41 -0
  415. package/src/orchestrator/schemas/backward-edge.ts +46 -0
  416. package/agents/agentic-identity-trust.md +0 -121
  417. package/agents/data-consolidation-agent.md +0 -39
  418. package/agents/design-image-prompt-engineer.md +0 -105
  419. package/agents/design-visual-storyteller.md +0 -147
  420. package/agents/design-whimsy-injector.md +0 -89
  421. package/agents/engineering-autonomous-optimization-architect.md +0 -105
  422. package/agents/market-intel.md +0 -35
  423. package/agents/marketing-instagram-curator.md +0 -111
  424. package/agents/marketing-reddit-community-builder.md +0 -121
  425. package/agents/marketing-social-media-strategist.md +0 -74
  426. package/agents/marketing-tiktok-strategist.md +0 -123
  427. package/agents/marketing-twitter-engager.md +0 -124
  428. package/agents/marketing-wechat-official-account.md +0 -143
  429. package/agents/marketing-xiaohongshu-specialist.md +0 -136
  430. package/agents/marketing-zhihu-strategist.md +0 -160
  431. package/agents/product-behavioral-nudge-engine.md +0 -78
  432. package/agents/project-management-experiment-tracker.md +0 -102
  433. package/agents/report-distribution-agent.md +0 -43
  434. package/agents/risk-analysis.md +0 -45
  435. package/agents/sales-data-extraction-agent.md +0 -46
  436. package/agents/specialized-cultural-intelligence-strategist.md +0 -65
  437. package/agents/specialized-developer-advocate.md +0 -146
  438. package/agents/support-analytics-reporter.md +0 -133
  439. package/agents/support-executive-summary-generator.md +0 -64
  440. package/agents/support-finance-tracker.md +0 -145
  441. package/agents/support-legal-compliance-checker.md +0 -129
  442. package/agents/support-support-responder.md +0 -91
  443. package/agents/testing-accessibility-auditor.md +0 -110
  444. package/agents/testing-test-results-analyzer.md +0 -97
  445. package/agents/testing-tool-evaluator.md +0 -76
  446. package/agents/testing-workflow-optimizer.md +0 -99
  447. package/agents/user-research.md +0 -40
  448. package/protocols/brainstorm.md +0 -99
  449. package/protocols/design.md +0 -269
  450. package/protocols/planning.md +0 -87
  451. package/skills/ios/ios-hig/SKILL.md +0 -41
  452. package/skills/ios/ios-hig/references/accessibility.md +0 -81
  453. package/skills/ios/ios-hig/references/content.md +0 -142
  454. package/skills/ios/ios-hig/references/feedback.md +0 -123
  455. package/skills/ios/ios-hig/references/interaction.md +0 -199
  456. package/skills/ios/ios-hig/references/performance-platform.md +0 -129
  457. package/skills/ios/ios-hig/references/privacy-permissions.md +0 -181
  458. package/skills/ios/ios-hig/references/visual-design.md +0 -84
@@ -0,0 +1,191 @@
1
+ ---
2
+ title: Define Generic Context Interfaces for Dependency Injection
3
+ impact: HIGH
4
+ impactDescription: enables dependency-injectable state across use-cases
5
+ tags: composition, context, state, typescript, dependency-injection
6
+ ---
7
+
8
+ ## Define Generic Context Interfaces for Dependency Injection
9
+
10
+ Define a **generic interface** for your component context with three parts:
11
+ `state`, `actions`, and `meta`. This interface is a contract that any provider
12
+ can implement—enabling the same UI components to work with completely different
13
+ state implementations.
14
+
15
+ **Core principle:** Lift state, compose internals, make state
16
+ dependency-injectable.
17
+
18
+ **Incorrect (UI coupled to specific state implementation):**
19
+
20
+ ```tsx
21
+ function ComposerInput() {
22
+ // Tightly coupled to a specific hook
23
+ const { input, setInput } = useChannelComposerState()
24
+ return <TextInput value={input} onChangeText={setInput} />
25
+ }
26
+ ```
27
+
28
+ **Correct (generic interface enables dependency injection):**
29
+
30
+ ```tsx
31
+ // Define a GENERIC interface that any provider can implement
32
+ interface ComposerState {
33
+ input: string
34
+ attachments: Attachment[]
35
+ isSubmitting: boolean
36
+ }
37
+
38
+ interface ComposerActions {
39
+ update: (updater: (state: ComposerState) => ComposerState) => void
40
+ submit: () => void
41
+ }
42
+
43
+ interface ComposerMeta {
44
+ inputRef: React.RefObject<TextInput>
45
+ }
46
+
47
+ interface ComposerContextValue {
48
+ state: ComposerState
49
+ actions: ComposerActions
50
+ meta: ComposerMeta
51
+ }
52
+
53
+ const ComposerContext = createContext<ComposerContextValue | null>(null)
54
+ ```
55
+
56
+ **UI components consume the interface, not the implementation:**
57
+
58
+ ```tsx
59
+ function ComposerInput() {
60
+ const {
61
+ state,
62
+ actions: { update },
63
+ meta,
64
+ } = use(ComposerContext)
65
+
66
+ // This component works with ANY provider that implements the interface
67
+ return (
68
+ <TextInput
69
+ ref={meta.inputRef}
70
+ value={state.input}
71
+ onChangeText={(text) => update((s) => ({ ...s, input: text }))}
72
+ />
73
+ )
74
+ }
75
+ ```
76
+
77
+ **Different providers implement the same interface:**
78
+
79
+ ```tsx
80
+ // Provider A: Local state for ephemeral forms
81
+ function ForwardMessageProvider({ children }: { children: React.ReactNode }) {
82
+ const [state, setState] = useState(initialState)
83
+ const inputRef = useRef(null)
84
+ const submit = useForwardMessage()
85
+
86
+ return (
87
+ <ComposerContext
88
+ value={{
89
+ state,
90
+ actions: { update: setState, submit },
91
+ meta: { inputRef },
92
+ }}
93
+ >
94
+ {children}
95
+ </ComposerContext>
96
+ )
97
+ }
98
+
99
+ // Provider B: Global synced state for channels
100
+ function ChannelProvider({ channelId, children }: Props) {
101
+ const { state, update, submit } = useGlobalChannel(channelId)
102
+ const inputRef = useRef(null)
103
+
104
+ return (
105
+ <ComposerContext
106
+ value={{
107
+ state,
108
+ actions: { update, submit },
109
+ meta: { inputRef },
110
+ }}
111
+ >
112
+ {children}
113
+ </ComposerContext>
114
+ )
115
+ }
116
+ ```
117
+
118
+ **The same composed UI works with both:**
119
+
120
+ ```tsx
121
+ // Works with ForwardMessageProvider (local state)
122
+ <ForwardMessageProvider>
123
+ <Composer.Frame>
124
+ <Composer.Input />
125
+ <Composer.Submit />
126
+ </Composer.Frame>
127
+ </ForwardMessageProvider>
128
+
129
+ // Works with ChannelProvider (global synced state)
130
+ <ChannelProvider channelId="abc">
131
+ <Composer.Frame>
132
+ <Composer.Input />
133
+ <Composer.Submit />
134
+ </Composer.Frame>
135
+ </ChannelProvider>
136
+ ```
137
+
138
+ **Custom UI outside the component can access state and actions:**
139
+
140
+ The provider boundary is what matters—not the visual nesting. Components that
141
+ need shared state don't have to be inside the `Composer.Frame`. They just need
142
+ to be within the provider.
143
+
144
+ ```tsx
145
+ function ForwardMessageDialog() {
146
+ return (
147
+ <ForwardMessageProvider>
148
+ <Dialog>
149
+ {/* The composer UI */}
150
+ <Composer.Frame>
151
+ <Composer.Input placeholder="Add a message, if you'd like." />
152
+ <Composer.Footer>
153
+ <Composer.Formatting />
154
+ <Composer.Emojis />
155
+ </Composer.Footer>
156
+ </Composer.Frame>
157
+
158
+ {/* Custom UI OUTSIDE the composer, but INSIDE the provider */}
159
+ <MessagePreview />
160
+
161
+ {/* Actions at the bottom of the dialog */}
162
+ <DialogActions>
163
+ <CancelButton />
164
+ <ForwardButton />
165
+ </DialogActions>
166
+ </Dialog>
167
+ </ForwardMessageProvider>
168
+ )
169
+ }
170
+
171
+ // This button lives OUTSIDE Composer.Frame but can still submit based on its context!
172
+ function ForwardButton() {
173
+ const {
174
+ actions: { submit },
175
+ } = use(ComposerContext)
176
+ return <Button onPress={submit}>Forward</Button>
177
+ }
178
+
179
+ // This preview lives OUTSIDE Composer.Frame but can read composer's state!
180
+ function MessagePreview() {
181
+ const { state } = use(ComposerContext)
182
+ return <Preview message={state.input} attachments={state.attachments} />
183
+ }
184
+ ```
185
+
186
+ The `ForwardButton` and `MessagePreview` are not visually inside the composer
187
+ box, but they can still access its state and actions. This is the power of
188
+ lifting state into providers.
189
+
190
+ The UI is reusable bits you compose together. The state is dependency-injected
191
+ by the provider. Swap the provider, keep the UI.
@@ -0,0 +1,113 @@
1
+ ---
2
+ title: Decouple State Management from UI
3
+ impact: MEDIUM
4
+ impactDescription: enables swapping state implementations without changing UI
5
+ tags: composition, state, architecture
6
+ ---
7
+
8
+ ## Decouple State Management from UI
9
+
10
+ The provider component should be the only place that knows how state is managed.
11
+ UI components consume the context interface—they don't know if state comes from
12
+ useState, Zustand, or a server sync.
13
+
14
+ **Incorrect (UI coupled to state implementation):**
15
+
16
+ ```tsx
17
+ function ChannelComposer({ channelId }: { channelId: string }) {
18
+ // UI component knows about global state implementation
19
+ const state = useGlobalChannelState(channelId)
20
+ const { submit, updateInput } = useChannelSync(channelId)
21
+
22
+ return (
23
+ <Composer.Frame>
24
+ <Composer.Input
25
+ value={state.input}
26
+ onChange={(text) => sync.updateInput(text)}
27
+ />
28
+ <Composer.Submit onPress={() => sync.submit()} />
29
+ </Composer.Frame>
30
+ )
31
+ }
32
+ ```
33
+
34
+ **Correct (state management isolated in provider):**
35
+
36
+ ```tsx
37
+ // Provider handles all state management details
38
+ function ChannelProvider({
39
+ channelId,
40
+ children,
41
+ }: {
42
+ channelId: string
43
+ children: React.ReactNode
44
+ }) {
45
+ const { state, update, submit } = useGlobalChannel(channelId)
46
+ const inputRef = useRef(null)
47
+
48
+ return (
49
+ <Composer.Provider
50
+ state={state}
51
+ actions={{ update, submit }}
52
+ meta={{ inputRef }}
53
+ >
54
+ {children}
55
+ </Composer.Provider>
56
+ )
57
+ }
58
+
59
+ // UI component only knows about the context interface
60
+ function ChannelComposer() {
61
+ return (
62
+ <Composer.Frame>
63
+ <Composer.Header />
64
+ <Composer.Input />
65
+ <Composer.Footer>
66
+ <Composer.Submit />
67
+ </Composer.Footer>
68
+ </Composer.Frame>
69
+ )
70
+ }
71
+
72
+ // Usage
73
+ function Channel({ channelId }: { channelId: string }) {
74
+ return (
75
+ <ChannelProvider channelId={channelId}>
76
+ <ChannelComposer />
77
+ </ChannelProvider>
78
+ )
79
+ }
80
+ ```
81
+
82
+ **Different providers, same UI:**
83
+
84
+ ```tsx
85
+ // Local state for ephemeral forms
86
+ function ForwardMessageProvider({ children }) {
87
+ const [state, setState] = useState(initialState)
88
+ const forwardMessage = useForwardMessage()
89
+
90
+ return (
91
+ <Composer.Provider
92
+ state={state}
93
+ actions={{ update: setState, submit: forwardMessage }}
94
+ >
95
+ {children}
96
+ </Composer.Provider>
97
+ )
98
+ }
99
+
100
+ // Global synced state for channels
101
+ function ChannelProvider({ channelId, children }) {
102
+ const { state, update, submit } = useGlobalChannel(channelId)
103
+
104
+ return (
105
+ <Composer.Provider state={state} actions={{ update, submit }}>
106
+ {children}
107
+ </Composer.Provider>
108
+ )
109
+ }
110
+ ```
111
+
112
+ The same `Composer.Input` component works with both providers because it only
113
+ depends on the context interface, not the implementation.
@@ -0,0 +1,125 @@
1
+ ---
2
+ title: Lift State into Provider Components
3
+ impact: HIGH
4
+ impactDescription: enables state sharing outside component boundaries
5
+ tags: composition, state, context, providers
6
+ ---
7
+
8
+ ## Lift State into Provider Components
9
+
10
+ Move state management into dedicated provider components. This allows sibling
11
+ components outside the main UI to access and modify state without prop drilling
12
+ or awkward refs.
13
+
14
+ **Incorrect (state trapped inside component):**
15
+
16
+ ```tsx
17
+ function ForwardMessageComposer() {
18
+ const [state, setState] = useState(initialState)
19
+ const forwardMessage = useForwardMessage()
20
+
21
+ return (
22
+ <Composer.Frame>
23
+ <Composer.Input />
24
+ <Composer.Footer />
25
+ </Composer.Frame>
26
+ )
27
+ }
28
+
29
+ // Problem: How does this button access composer state?
30
+ function ForwardMessageDialog() {
31
+ return (
32
+ <Dialog>
33
+ <ForwardMessageComposer />
34
+ <MessagePreview /> {/* Needs composer state */}
35
+ <DialogActions>
36
+ <CancelButton />
37
+ <ForwardButton /> {/* Needs to call submit */}
38
+ </DialogActions>
39
+ </Dialog>
40
+ )
41
+ }
42
+ ```
43
+
44
+ **Incorrect (useEffect to sync state up):**
45
+
46
+ ```tsx
47
+ function ForwardMessageDialog() {
48
+ const [input, setInput] = useState('')
49
+ return (
50
+ <Dialog>
51
+ <ForwardMessageComposer onInputChange={setInput} />
52
+ <MessagePreview input={input} />
53
+ </Dialog>
54
+ )
55
+ }
56
+
57
+ function ForwardMessageComposer({ onInputChange }) {
58
+ const [state, setState] = useState(initialState)
59
+ useEffect(() => {
60
+ onInputChange(state.input) // Sync on every change 😬
61
+ }, [state.input])
62
+ }
63
+ ```
64
+
65
+ **Incorrect (reading state from ref on submit):**
66
+
67
+ ```tsx
68
+ function ForwardMessageDialog() {
69
+ const stateRef = useRef(null)
70
+ return (
71
+ <Dialog>
72
+ <ForwardMessageComposer stateRef={stateRef} />
73
+ <ForwardButton onPress={() => submit(stateRef.current)} />
74
+ </Dialog>
75
+ )
76
+ }
77
+ ```
78
+
79
+ **Correct (state lifted to provider):**
80
+
81
+ ```tsx
82
+ function ForwardMessageProvider({ children }: { children: React.ReactNode }) {
83
+ const [state, setState] = useState(initialState)
84
+ const forwardMessage = useForwardMessage()
85
+ const inputRef = useRef(null)
86
+
87
+ return (
88
+ <Composer.Provider
89
+ state={state}
90
+ actions={{ update: setState, submit: forwardMessage }}
91
+ meta={{ inputRef }}
92
+ >
93
+ {children}
94
+ </Composer.Provider>
95
+ )
96
+ }
97
+
98
+ function ForwardMessageDialog() {
99
+ return (
100
+ <ForwardMessageProvider>
101
+ <Dialog>
102
+ <ForwardMessageComposer />
103
+ <MessagePreview /> {/* Custom components can access state and actions */}
104
+ <DialogActions>
105
+ <CancelButton />
106
+ <ForwardButton /> {/* Custom components can access state and actions */}
107
+ </DialogActions>
108
+ </Dialog>
109
+ </ForwardMessageProvider>
110
+ )
111
+ }
112
+
113
+ function ForwardButton() {
114
+ const { actions } = use(Composer.Context)
115
+ return <Button onPress={actions.submit}>Forward</Button>
116
+ }
117
+ ```
118
+
119
+ The ForwardButton lives outside the Composer.Frame but still has access to the
120
+ submit action because it's within the provider. Even though it's a one-off
121
+ component, it can still access the composer's state and actions from outside the
122
+ UI itself.
123
+
124
+ **Key insight:** Components that need shared state don't have to be visually
125
+ nested inside each other—they just need to be within the same provider.
@@ -0,0 +1,183 @@
1
+ ---
2
+ name: cost-aware-llm-pipeline
3
+ description: Cost optimization patterns for LLM API usage — model routing by task complexity, budget tracking, retry logic, and prompt caching.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Cost-Aware LLM Pipeline
8
+
9
+ Patterns for controlling LLM API costs while maintaining quality. Combines model routing, budget tracking, retry logic, and prompt caching into a composable pipeline.
10
+
11
+ ## When to Activate
12
+
13
+ - Building applications that call LLM APIs (Claude, GPT, etc.)
14
+ - Processing batches of items with varying complexity
15
+ - Need to stay within a budget for API spend
16
+ - Optimizing cost without sacrificing quality on complex tasks
17
+
18
+ ## Core Concepts
19
+
20
+ ### 1. Model Routing by Task Complexity
21
+
22
+ Automatically select cheaper models for simple tasks, reserving expensive models for complex ones.
23
+
24
+ ```python
25
+ MODEL_SONNET = "claude-sonnet-4-6"
26
+ MODEL_HAIKU = "claude-haiku-4-5-20251001"
27
+
28
+ _SONNET_TEXT_THRESHOLD = 10_000 # chars
29
+ _SONNET_ITEM_THRESHOLD = 30 # items
30
+
31
+ def select_model(
32
+ text_length: int,
33
+ item_count: int,
34
+ force_model: str | None = None,
35
+ ) -> str:
36
+ """Select model based on task complexity."""
37
+ if force_model is not None:
38
+ return force_model
39
+ if text_length >= _SONNET_TEXT_THRESHOLD or item_count >= _SONNET_ITEM_THRESHOLD:
40
+ return MODEL_SONNET # Complex task
41
+ return MODEL_HAIKU # Simple task (3-4x cheaper)
42
+ ```
43
+
44
+ ### 2. Immutable Cost Tracking
45
+
46
+ Track cumulative spend with frozen dataclasses. Each API call returns a new tracker — never mutates state.
47
+
48
+ ```python
49
+ from dataclasses import dataclass
50
+
51
+ @dataclass(frozen=True, slots=True)
52
+ class CostRecord:
53
+ model: str
54
+ input_tokens: int
55
+ output_tokens: int
56
+ cost_usd: float
57
+
58
+ @dataclass(frozen=True, slots=True)
59
+ class CostTracker:
60
+ budget_limit: float = 1.00
61
+ records: tuple[CostRecord, ...] = ()
62
+
63
+ def add(self, record: CostRecord) -> "CostTracker":
64
+ """Return new tracker with added record (never mutates self)."""
65
+ return CostTracker(
66
+ budget_limit=self.budget_limit,
67
+ records=(*self.records, record),
68
+ )
69
+
70
+ @property
71
+ def total_cost(self) -> float:
72
+ return sum(r.cost_usd for r in self.records)
73
+
74
+ @property
75
+ def over_budget(self) -> bool:
76
+ return self.total_cost > self.budget_limit
77
+ ```
78
+
79
+ ### 3. Narrow Retry Logic
80
+
81
+ Retry only on transient errors. Fail fast on authentication or bad request errors.
82
+
83
+ ```python
84
+ from anthropic import (
85
+ APIConnectionError,
86
+ InternalServerError,
87
+ RateLimitError,
88
+ )
89
+
90
+ _RETRYABLE_ERRORS = (APIConnectionError, RateLimitError, InternalServerError)
91
+ _MAX_RETRIES = 3
92
+
93
+ def call_with_retry(func, *, max_retries: int = _MAX_RETRIES):
94
+ """Retry only on transient errors, fail fast on others."""
95
+ for attempt in range(max_retries):
96
+ try:
97
+ return func()
98
+ except _RETRYABLE_ERRORS:
99
+ if attempt == max_retries - 1:
100
+ raise
101
+ time.sleep(2 ** attempt) # Exponential backoff
102
+ # AuthenticationError, BadRequestError etc. → raise immediately
103
+ ```
104
+
105
+ ### 4. Prompt Caching
106
+
107
+ Cache long system prompts to avoid resending them on every request.
108
+
109
+ ```python
110
+ messages = [
111
+ {
112
+ "role": "user",
113
+ "content": [
114
+ {
115
+ "type": "text",
116
+ "text": system_prompt,
117
+ "cache_control": {"type": "ephemeral"}, # Cache this
118
+ },
119
+ {
120
+ "type": "text",
121
+ "text": user_input, # Variable part
122
+ },
123
+ ],
124
+ }
125
+ ]
126
+ ```
127
+
128
+ ## Composition
129
+
130
+ Combine all four techniques in a single pipeline function:
131
+
132
+ ```python
133
+ def process(text: str, config: Config, tracker: CostTracker) -> tuple[Result, CostTracker]:
134
+ # 1. Route model
135
+ model = select_model(len(text), estimated_items, config.force_model)
136
+
137
+ # 2. Check budget
138
+ if tracker.over_budget:
139
+ raise BudgetExceededError(tracker.total_cost, tracker.budget_limit)
140
+
141
+ # 3. Call with retry + caching
142
+ response = call_with_retry(lambda: client.messages.create(
143
+ model=model,
144
+ messages=build_cached_messages(system_prompt, text),
145
+ ))
146
+
147
+ # 4. Track cost (immutable)
148
+ record = CostRecord(model=model, input_tokens=..., output_tokens=..., cost_usd=...)
149
+ tracker = tracker.add(record)
150
+
151
+ return parse_result(response), tracker
152
+ ```
153
+
154
+ ## Pricing Reference (2025-2026)
155
+
156
+ | Model | Input ($/1M tokens) | Output ($/1M tokens) | Relative Cost |
157
+ |-------|---------------------|----------------------|---------------|
158
+ | Haiku 4.5 | $0.80 | $4.00 | 1x |
159
+ | Sonnet 4.6 | $3.00 | $15.00 | ~4x |
160
+ | Opus 4.5 | $15.00 | $75.00 | ~19x |
161
+
162
+ ## Best Practices
163
+
164
+ - **Start with the cheapest model** and only route to expensive models when complexity thresholds are met
165
+ - **Set explicit budget limits** before processing batches — fail early rather than overspend
166
+ - **Log model selection decisions** so you can tune thresholds based on real data
167
+ - **Use prompt caching** for system prompts over 1024 tokens — saves both cost and latency
168
+ - **Never retry on authentication or validation errors** — only transient failures (network, rate limit, server error)
169
+
170
+ ## Anti-Patterns to Avoid
171
+
172
+ - Using the most expensive model for all requests regardless of complexity
173
+ - Retrying on all errors (wastes budget on permanent failures)
174
+ - Mutating cost tracking state (makes debugging and auditing difficult)
175
+ - Hardcoding model names throughout the codebase (use constants or config)
176
+ - Ignoring prompt caching for repetitive system prompts
177
+
178
+ ## When to Use
179
+
180
+ - Any application calling Claude, OpenAI, or similar LLM APIs
181
+ - Batch processing pipelines where cost adds up quickly
182
+ - Multi-model architectures that need intelligent routing
183
+ - Production systems that need budget guardrails