buildanything 1.7.1 → 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.
- package/.claude-plugin/marketplace.json +3 -3
- package/.claude-plugin/plugin.json +9 -3
- package/CHANGELOG.md +112 -0
- package/README.md +2 -2
- package/agents/a11y-architect.md +166 -0
- package/agents/business-model.md +80 -29
- package/agents/code-architect.md +75 -0
- package/agents/code-reviewer.md +255 -0
- package/agents/code-simplifier.md +64 -0
- package/agents/design-brand-guardian.md +293 -53
- package/agents/design-critic.md +139 -0
- package/agents/design-inclusive-visuals-specialist.md +6 -19
- package/agents/design-ui-designer.md +335 -56
- package/agents/design-ux-architect.md +403 -55
- package/agents/design-ux-researcher.md +264 -49
- package/agents/engineering-ai-engineer.md +26 -36
- package/agents/engineering-backend-architect.md +185 -36
- package/agents/engineering-data-engineer.md +225 -43
- package/agents/engineering-devops-automator.md +227 -74
- package/agents/engineering-frontend-developer.md +210 -34
- package/agents/engineering-mobile-app-builder.md +6 -1
- package/agents/engineering-rapid-prototyper.md +30 -9
- package/agents/engineering-security-engineer.md +263 -61
- package/agents/engineering-senior-developer.md +128 -19
- package/agents/engineering-sre.md +84 -0
- package/agents/engineering-technical-writer.md +285 -41
- package/agents/feature-intel.md +110 -0
- package/agents/ios-app-review-guardian.md +66 -0
- package/agents/ios-foundation-models-specialist.md +64 -0
- package/agents/ios-storekit-specialist.md +59 -0
- package/agents/ios-swift-architect.md +129 -0
- package/agents/ios-swift-search.md +137 -0
- package/agents/ios-swift-ui-design.md +136 -0
- package/agents/marketing-app-store-optimizer.md +246 -64
- package/agents/planner.md +216 -0
- package/agents/pr-test-analyzer.md +63 -0
- package/agents/product-feedback-synthesizer.md +8 -2
- package/agents/refactor-cleaner.md +102 -0
- package/agents/security-reviewer.md +128 -0
- package/agents/silent-failure-hunter.md +54 -0
- package/agents/swift-build-resolver.md +119 -0
- package/agents/swift-reviewer.md +112 -0
- package/agents/tech-feasibility.md +21 -1
- package/agents/testing-api-tester.md +236 -59
- package/agents/testing-evidence-collector.md +26 -1
- package/agents/testing-performance-benchmarker.md +21 -1
- package/agents/testing-reality-checker.md +6 -1
- package/agents/visual-research.md +116 -0
- package/bin/adapters/cycle-counter-tool.ts +155 -0
- package/bin/adapters/scribe-tool.ts +71 -0
- package/bin/adapters/state-save-tool.ts +130 -0
- package/bin/adapters/write-lease-tool.ts +127 -0
- package/bin/buildanything-runtime.js +15 -0
- package/bin/buildanything-runtime.ts +328 -0
- package/bin/setup.js +83 -8
- package/commands/add-feature.md +2 -0
- package/commands/build.md +752 -332
- package/commands/fix.md +65 -0
- package/commands/self-check.md +121 -0
- package/commands/setup.md +114 -0
- package/commands/ux-review.md +63 -0
- package/commands/verify.md +69 -0
- package/docs/migration/agents.yaml +729 -0
- package/docs/migration/phase-graph.yaml +1088 -0
- package/docs/migration/sdk-host-compat.md +18 -0
- package/hooks/compile-writer-owner-cache.ts +171 -0
- package/hooks/hooks.json +36 -0
- package/hooks/pre-tool-use +19 -0
- package/hooks/pre-tool-use.ts +776 -0
- package/hooks/record-mode-transitions.ts +178 -0
- package/hooks/session-start +89 -2
- package/hooks/subagent-start +17 -0
- package/hooks/subagent-start.ts +471 -0
- package/hooks/subagent-stop +17 -0
- package/hooks/subagent-stop.ts +153 -0
- package/package.json +28 -5
- package/protocols/architecture-schema.md +171 -0
- package/protocols/build-fix.md +52 -0
- package/protocols/cleanup.md +54 -0
- package/protocols/decision-log.md +131 -0
- package/protocols/eval-harness.md +61 -0
- package/protocols/fake-data-detector.md +64 -0
- package/protocols/ios-context.md +234 -0
- package/protocols/ios-frameworks-map.md +323 -0
- package/protocols/ios-phase-branches.md +337 -0
- package/protocols/ios-preflight.md +27 -0
- package/protocols/launch-readiness.md +258 -0
- package/protocols/metric-loop.md +153 -0
- package/protocols/smoke-test.md +118 -0
- package/protocols/state-schema.json +388 -0
- package/protocols/state-schema.md +172 -0
- package/protocols/verify.md +127 -0
- package/protocols/visual-dna.md +185 -0
- package/protocols/web-phase-branches.md +351 -0
- package/skills/ios/_VENDORED.md +62 -0
- package/skills/ios/activitykit/LICENSE +131 -0
- package/skills/ios/activitykit/SKILL.md +505 -0
- package/skills/ios/activitykit/references/activitykit-patterns.md +868 -0
- package/skills/ios/app-intents/LICENSE +131 -0
- package/skills/ios/app-intents/SKILL.md +494 -0
- package/skills/ios/app-intents/references/appintents-advanced.md +1076 -0
- package/skills/ios/app-store-connect-metadata/SKILL.md +148 -0
- package/skills/ios/apple-on-device-ai/LICENSE +131 -0
- package/skills/ios/apple-on-device-ai/SKILL.md +505 -0
- package/skills/ios/apple-on-device-ai/references/coreml-conversion.md +425 -0
- package/skills/ios/apple-on-device-ai/references/coreml-optimization.md +344 -0
- package/skills/ios/apple-on-device-ai/references/foundation-models.md +508 -0
- package/skills/ios/apple-on-device-ai/references/mlx-swift.md +285 -0
- package/skills/ios/asc-privacy-manifest/SKILL.md +350 -0
- package/skills/ios/hig-components-content/SKILL.md +86 -0
- package/skills/ios/hig-components-content/references/activity-views.md +79 -0
- package/skills/ios/hig-components-content/references/charts.md +180 -0
- package/skills/ios/hig-components-content/references/collections.md +48 -0
- package/skills/ios/hig-components-content/references/color-wells.md +42 -0
- package/skills/ios/hig-components-content/references/image-views.md +82 -0
- package/skills/ios/hig-components-content/references/image-wells.md +34 -0
- package/skills/ios/hig-components-content/references/lockups.md +78 -0
- package/skills/ios/hig-components-content/references/web-views.md +36 -0
- package/skills/ios/hig-components-controls/SKILL.md +88 -0
- package/skills/ios/hig-components-controls/references/combo-boxes.md +40 -0
- package/skills/ios/hig-components-controls/references/controls.md +112 -0
- package/skills/ios/hig-components-controls/references/gauges.md +74 -0
- package/skills/ios/hig-components-controls/references/labels.md +92 -0
- package/skills/ios/hig-components-controls/references/pickers.md +128 -0
- package/skills/ios/hig-components-controls/references/rating-indicators.md +38 -0
- package/skills/ios/hig-components-controls/references/segmented-controls.md +94 -0
- package/skills/ios/hig-components-controls/references/sliders.md +92 -0
- package/skills/ios/hig-components-controls/references/steppers.md +40 -0
- package/skills/ios/hig-components-controls/references/text-fields.md +88 -0
- package/skills/ios/hig-components-controls/references/text-views.md +56 -0
- package/skills/ios/hig-components-controls/references/toggles.md +127 -0
- package/skills/ios/hig-components-controls/references/token-fields.md +48 -0
- package/skills/ios/hig-components-controls/references/virtual-keyboards.md +156 -0
- package/skills/ios/hig-components-dialogs/SKILL.md +76 -0
- package/skills/ios/hig-components-dialogs/references/action-sheets.md +74 -0
- package/skills/ios/hig-components-dialogs/references/alerts.md +158 -0
- package/skills/ios/hig-components-dialogs/references/digit-entry-views.md +32 -0
- package/skills/ios/hig-components-dialogs/references/popovers.md +81 -0
- package/skills/ios/hig-components-dialogs/references/sheets.md +157 -0
- package/skills/ios/hig-components-layout/SKILL.md +99 -0
- package/skills/ios/hig-components-layout/references/boxes.md +48 -0
- package/skills/ios/hig-components-layout/references/column-views.md +44 -0
- package/skills/ios/hig-components-layout/references/lists-and-tables.md +99 -0
- package/skills/ios/hig-components-layout/references/ornaments.md +56 -0
- package/skills/ios/hig-components-layout/references/outline-views.md +64 -0
- package/skills/ios/hig-components-layout/references/panels.md +75 -0
- package/skills/ios/hig-components-layout/references/scroll-views.md +123 -0
- package/skills/ios/hig-components-layout/references/sidebars.md +109 -0
- package/skills/ios/hig-components-layout/references/split-views.md +110 -0
- package/skills/ios/hig-components-layout/references/tab-bars.md +173 -0
- package/skills/ios/hig-components-layout/references/tab-views.md +68 -0
- package/skills/ios/hig-components-layout/references/windows.md +188 -0
- package/skills/ios/hig-components-menus/SKILL.md +81 -0
- package/skills/ios/hig-components-menus/references/action-button.md +61 -0
- package/skills/ios/hig-components-menus/references/buttons.md +261 -0
- package/skills/ios/hig-components-menus/references/context-menus.md +105 -0
- package/skills/ios/hig-components-menus/references/disclosure-controls.md +84 -0
- package/skills/ios/hig-components-menus/references/dock-menus.md +40 -0
- package/skills/ios/hig-components-menus/references/edit-menus.md +88 -0
- package/skills/ios/hig-components-menus/references/menus.md +171 -0
- package/skills/ios/hig-components-menus/references/pop-up-buttons.md +70 -0
- package/skills/ios/hig-components-menus/references/pull-down-buttons.md +77 -0
- package/skills/ios/hig-components-menus/references/the-menu-bar.md +303 -0
- package/skills/ios/hig-components-menus/references/toolbars.md +256 -0
- package/skills/ios/hig-components-search/SKILL.md +68 -0
- package/skills/ios/hig-components-search/references/page-controls.md +120 -0
- package/skills/ios/hig-components-search/references/path-controls.md +40 -0
- package/skills/ios/hig-components-search/references/search-fields.md +189 -0
- package/skills/ios/hig-components-status/SKILL.md +80 -0
- package/skills/ios/hig-components-status/references/activity-rings.md +105 -0
- package/skills/ios/hig-components-status/references/progress-indicators.md +116 -0
- package/skills/ios/hig-components-status/references/status-bars.md +38 -0
- package/skills/ios/hig-components-system/SKILL.md +88 -0
- package/skills/ios/hig-components-system/references/app-clips.md +387 -0
- package/skills/ios/hig-components-system/references/app-shortcuts.md +114 -0
- package/skills/ios/hig-components-system/references/complications.md +425 -0
- package/skills/ios/hig-components-system/references/home-screen-quick-actions.md +42 -0
- package/skills/ios/hig-components-system/references/live-activities.md +442 -0
- package/skills/ios/hig-components-system/references/notifications.md +153 -0
- package/skills/ios/hig-components-system/references/top-shelf.md +135 -0
- package/skills/ios/hig-components-system/references/watch-faces.md +40 -0
- package/skills/ios/hig-components-system/references/widgets.md +517 -0
- package/skills/ios/hig-foundations/SKILL.md +98 -0
- package/skills/ios/hig-foundations/references/accessibility.md +291 -0
- package/skills/ios/hig-foundations/references/app-icons.md +210 -0
- package/skills/ios/hig-foundations/references/branding.md +44 -0
- package/skills/ios/hig-foundations/references/color.md +274 -0
- package/skills/ios/hig-foundations/references/dark-mode.md +116 -0
- package/skills/ios/hig-foundations/references/icons.md +263 -0
- package/skills/ios/hig-foundations/references/images.md +176 -0
- package/skills/ios/hig-foundations/references/immersive-experiences.md +174 -0
- package/skills/ios/hig-foundations/references/inclusion.md +189 -0
- package/skills/ios/hig-foundations/references/layout.md +425 -0
- package/skills/ios/hig-foundations/references/materials.md +238 -0
- package/skills/ios/hig-foundations/references/motion.md +103 -0
- package/skills/ios/hig-foundations/references/privacy.md +231 -0
- package/skills/ios/hig-foundations/references/right-to-left.md +206 -0
- package/skills/ios/hig-foundations/references/sf-symbols.md +310 -0
- package/skills/ios/hig-foundations/references/spatial-layout.md +142 -0
- package/skills/ios/hig-foundations/references/typography.md +1146 -0
- package/skills/ios/hig-foundations/references/writing.md +91 -0
- package/skills/ios/hig-inputs/SKILL.md +94 -0
- package/skills/ios/hig-inputs/references/apple-pencil-and-scribble.md +148 -0
- package/skills/ios/hig-inputs/references/camera-control.md +107 -0
- package/skills/ios/hig-inputs/references/digital-crown.md +83 -0
- package/skills/ios/hig-inputs/references/eyes.md +120 -0
- package/skills/ios/hig-inputs/references/focus-and-selection.md +120 -0
- package/skills/ios/hig-inputs/references/game-controls.md +156 -0
- package/skills/ios/hig-inputs/references/gestures.md +208 -0
- package/skills/ios/hig-inputs/references/gyro-and-accelerometer.md +40 -0
- package/skills/ios/hig-inputs/references/keyboards.md +234 -0
- package/skills/ios/hig-inputs/references/nearby-interactions.md +70 -0
- package/skills/ios/hig-inputs/references/pointing-devices.md +237 -0
- package/skills/ios/hig-inputs/references/remotes.md +67 -0
- package/skills/ios/hig-inputs/references/spatial-interactions.md +70 -0
- package/skills/ios/hig-patterns/SKILL.md +104 -0
- package/skills/ios/hig-patterns/references/charting-data.md +81 -0
- package/skills/ios/hig-patterns/references/collaboration-and-sharing.md +86 -0
- package/skills/ios/hig-patterns/references/drag-and-drop.md +134 -0
- package/skills/ios/hig-patterns/references/entering-data.md +69 -0
- package/skills/ios/hig-patterns/references/feedback.md +67 -0
- package/skills/ios/hig-patterns/references/file-management.md +135 -0
- package/skills/ios/hig-patterns/references/going-full-screen.md +79 -0
- package/skills/ios/hig-patterns/references/launching.md +81 -0
- package/skills/ios/hig-patterns/references/live-viewing-apps.md +79 -0
- package/skills/ios/hig-patterns/references/loading.md +59 -0
- package/skills/ios/hig-patterns/references/managing-accounts.md +107 -0
- package/skills/ios/hig-patterns/references/managing-notifications.md +99 -0
- package/skills/ios/hig-patterns/references/modality.md +82 -0
- package/skills/ios/hig-patterns/references/multitasking.md +131 -0
- package/skills/ios/hig-patterns/references/offering-help.md +117 -0
- package/skills/ios/hig-patterns/references/onboarding.md +69 -0
- package/skills/ios/hig-patterns/references/playing-audio.md +124 -0
- package/skills/ios/hig-patterns/references/playing-haptics.md +280 -0
- package/skills/ios/hig-patterns/references/playing-video.md +180 -0
- package/skills/ios/hig-patterns/references/printing.md +50 -0
- package/skills/ios/hig-patterns/references/ratings-and-reviews.md +48 -0
- package/skills/ios/hig-patterns/references/searching.md +70 -0
- package/skills/ios/hig-patterns/references/settings.md +84 -0
- package/skills/ios/hig-patterns/references/undo-and-redo.md +58 -0
- package/skills/ios/hig-patterns/references/workouts.md +76 -0
- package/skills/ios/hig-platforms/SKILL.md +84 -0
- package/skills/ios/hig-platforms/references/designing-for-games.md +159 -0
- package/skills/ios/hig-platforms/references/designing-for-ios.md +66 -0
- package/skills/ios/hig-platforms/references/designing-for-ipados.md +64 -0
- package/skills/ios/hig-platforms/references/designing-for-macos.md +70 -0
- package/skills/ios/hig-platforms/references/designing-for-tvos.md +68 -0
- package/skills/ios/hig-platforms/references/designing-for-visionos.md +85 -0
- package/skills/ios/hig-platforms/references/designing-for-watchos.md +74 -0
- package/skills/ios/hig-project-context/SKILL.md +133 -0
- package/skills/ios/hig-technologies/SKILL.md +107 -0
- package/skills/ios/hig-technologies/references/airplay.md +125 -0
- package/skills/ios/hig-technologies/references/always-on.md +62 -0
- package/skills/ios/hig-technologies/references/apple-pay.md +441 -0
- package/skills/ios/hig-technologies/references/augmented-reality.md +247 -0
- package/skills/ios/hig-technologies/references/carekit.md +224 -0
- package/skills/ios/hig-technologies/references/carplay.md +119 -0
- package/skills/ios/hig-technologies/references/game-center.md +343 -0
- package/skills/ios/hig-technologies/references/generative-ai.md +110 -0
- package/skills/ios/hig-technologies/references/healthkit.md +120 -0
- package/skills/ios/hig-technologies/references/homekit.md +343 -0
- package/skills/ios/hig-technologies/references/icloud.md +52 -0
- package/skills/ios/hig-technologies/references/id-verifier.md +73 -0
- package/skills/ios/hig-technologies/references/imessage-apps-and-stickers.md +105 -0
- package/skills/ios/hig-technologies/references/in-app-purchase.md +263 -0
- package/skills/ios/hig-technologies/references/live-photos.md +54 -0
- package/skills/ios/hig-technologies/references/mac-catalyst.md +216 -0
- package/skills/ios/hig-technologies/references/machine-learning.md +394 -0
- package/skills/ios/hig-technologies/references/maps.md +221 -0
- package/skills/ios/hig-technologies/references/nfc.md +51 -0
- package/skills/ios/hig-technologies/references/photo-editing.md +40 -0
- package/skills/ios/hig-technologies/references/researchkit.md +134 -0
- package/skills/ios/hig-technologies/references/shareplay.md +142 -0
- package/skills/ios/hig-technologies/references/shazamkit.md +47 -0
- package/skills/ios/hig-technologies/references/sign-in-with-apple.md +288 -0
- package/skills/ios/hig-technologies/references/siri.md +523 -0
- package/skills/ios/hig-technologies/references/tap-to-pay-on-iphone.md +208 -0
- package/skills/ios/hig-technologies/references/voiceover.md +90 -0
- package/skills/ios/hig-technologies/references/wallet.md +420 -0
- package/skills/ios/ios-26-platform/SKILL.md +53 -0
- package/skills/ios/ios-26-platform/references/automatic-adoption.md +161 -0
- package/skills/ios/ios-26-platform/references/backward-compat.md +238 -0
- package/skills/ios/ios-26-platform/references/liquid-glass.md +255 -0
- package/skills/ios/ios-26-platform/references/swiftui-apis.md +277 -0
- package/skills/ios/ios-26-platform/references/toolbar-navigation.md +250 -0
- package/skills/ios/ios-bootstrap/SKILL.md +107 -0
- package/skills/ios/ios-bootstrap/references/apple-docs-mcp-config.md +28 -0
- package/skills/ios/ios-bootstrap/references/new-project-dialog.md +41 -0
- package/skills/ios/ios-bootstrap/references/xcode-mcp-config.md +29 -0
- package/skills/ios/ios-debugger-agent/LICENSE +21 -0
- package/skills/ios/ios-debugger-agent/SKILL.md +58 -0
- package/skills/ios/ios-debugger-agent/agents/openai.yaml +4 -0
- package/skills/ios/ios-entitlements-generator/SKILL.md +47 -0
- package/skills/ios/ios-info-plist-hardening/SKILL.md +130 -0
- package/skills/ios/ios-maestro-flow-author/SKILL.md +68 -0
- package/skills/ios/ios-maestro-flow-author/references/input-and-scroll.yaml +17 -0
- package/skills/ios/ios-maestro-flow-author/references/modal-and-dismiss.yaml +14 -0
- package/skills/ios/ios-maestro-flow-author/references/onboarding-flow.yaml +16 -0
- package/skills/ios/ios-maestro-flow-author/references/tab-navigation.yaml +13 -0
- package/skills/ios/ios-maestro-flow-author/references/tap-and-assert.yaml +9 -0
- package/skills/ios/swift-accessibility/LICENSE +21 -0
- package/skills/ios/swift-accessibility/SKILL.md +371 -0
- package/skills/ios/swift-accessibility/examples/before-after-appkit.md +446 -0
- package/skills/ios/swift-accessibility/examples/before-after-swiftui.md +441 -0
- package/skills/ios/swift-accessibility/examples/before-after-uikit.md +464 -0
- package/skills/ios/swift-accessibility/references/assistive-access.md +441 -0
- package/skills/ios/swift-accessibility/references/display-settings.md +491 -0
- package/skills/ios/swift-accessibility/references/dynamic-type.md +420 -0
- package/skills/ios/swift-accessibility/references/media-accessibility.md +421 -0
- package/skills/ios/swift-accessibility/references/motor-input.md +393 -0
- package/skills/ios/swift-accessibility/references/nutrition-labels.md +362 -0
- package/skills/ios/swift-accessibility/references/platform-specifics.md +515 -0
- package/skills/ios/swift-accessibility/references/semantic-structure.md +585 -0
- package/skills/ios/swift-accessibility/references/testing-auditing.md +507 -0
- package/skills/ios/swift-accessibility/references/voice-control.md +317 -0
- package/skills/ios/swift-accessibility/references/voiceover-swiftui.md +584 -0
- package/skills/ios/swift-accessibility/references/voiceover-uikit.md +519 -0
- package/skills/ios/swift-accessibility/references/wcag-mapping.md +167 -0
- package/skills/ios/swift-accessibility/resources/audit-template.swift +128 -0
- package/skills/ios/swift-accessibility/resources/qa-checklist.md +258 -0
- package/skills/ios/swift-actor-persistence/SKILL.md +143 -0
- package/skills/ios/swift-concurrency/LICENSE +21 -0
- package/skills/ios/swift-concurrency/SKILL.md +171 -0
- package/skills/ios/swift-concurrency/references/_index.md +50 -0
- package/skills/ios/swift-concurrency/references/actors.md +660 -0
- package/skills/ios/swift-concurrency/references/async-algorithms.md +847 -0
- package/skills/ios/swift-concurrency/references/async-await-basics.md +266 -0
- package/skills/ios/swift-concurrency/references/async-sequences.md +710 -0
- package/skills/ios/swift-concurrency/references/core-data.md +560 -0
- package/skills/ios/swift-concurrency/references/glossary.md +135 -0
- package/skills/ios/swift-concurrency/references/linting.md +155 -0
- package/skills/ios/swift-concurrency/references/memory-management.md +569 -0
- package/skills/ios/swift-concurrency/references/migration.md +1104 -0
- package/skills/ios/swift-concurrency/references/performance.md +593 -0
- package/skills/ios/swift-concurrency/references/sendable.md +598 -0
- package/skills/ios/swift-concurrency/references/tasks.md +636 -0
- package/skills/ios/swift-concurrency/references/testing.md +592 -0
- package/skills/ios/swift-concurrency/references/threading.md +495 -0
- package/skills/ios/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/ios/swift-protocol-di-testing/SKILL.md +190 -0
- package/skills/ios/swift-security-expert/LICENSE +21 -0
- package/skills/ios/swift-security-expert/SKILL.md +470 -0
- package/skills/ios/swift-security-expert/references/biometric-authentication.md +565 -0
- package/skills/ios/swift-security-expert/references/certificate-trust.md +592 -0
- package/skills/ios/swift-security-expert/references/common-anti-patterns.md +690 -0
- package/skills/ios/swift-security-expert/references/compliance-owasp-mapping.md +537 -0
- package/skills/ios/swift-security-expert/references/credential-storage-patterns.md +721 -0
- package/skills/ios/swift-security-expert/references/cryptokit-public-key.md +505 -0
- package/skills/ios/swift-security-expert/references/cryptokit-symmetric.md +497 -0
- package/skills/ios/swift-security-expert/references/keychain-access-control.md +508 -0
- package/skills/ios/swift-security-expert/references/keychain-fundamentals.md +596 -0
- package/skills/ios/swift-security-expert/references/keychain-item-classes.md +476 -0
- package/skills/ios/swift-security-expert/references/keychain-sharing.md +458 -0
- package/skills/ios/swift-security-expert/references/migration-legacy-stores.md +727 -0
- package/skills/ios/swift-security-expert/references/secure-enclave.md +539 -0
- package/skills/ios/swift-security-expert/references/testing-security-code.md +781 -0
- package/skills/ios/swift-testing-expert/LICENSE +21 -0
- package/skills/ios/swift-testing-expert/SKILL.md +79 -0
- package/skills/ios/swift-testing-expert/references/_index.md +12 -0
- package/skills/ios/swift-testing-expert/references/async-testing-and-waiting.md +127 -0
- package/skills/ios/swift-testing-expert/references/expectations.md +145 -0
- package/skills/ios/swift-testing-expert/references/fundamentals.md +141 -0
- package/skills/ios/swift-testing-expert/references/migration-from-xctest.md +127 -0
- package/skills/ios/swift-testing-expert/references/parallelization-and-isolation.md +95 -0
- package/skills/ios/swift-testing-expert/references/parameterized-testing.md +284 -0
- package/skills/ios/swift-testing-expert/references/performance-and-best-practices.md +187 -0
- package/skills/ios/swift-testing-expert/references/traits-and-tags.md +114 -0
- package/skills/ios/swift-testing-expert/references/xcode-workflows.md +70 -0
- package/skills/ios/swiftdata-pro/LICENSE +21 -0
- package/skills/ios/swiftdata-pro/SKILL.md +102 -0
- package/skills/ios/swiftdata-pro/agents/openai.yaml +10 -0
- package/skills/ios/swiftdata-pro/assets/swiftdata-pro-icon.png +0 -0
- package/skills/ios/swiftdata-pro/assets/swiftdata-pro-icon.svg +29 -0
- package/skills/ios/swiftdata-pro/references/class-inheritance.md +104 -0
- package/skills/ios/swiftdata-pro/references/cloudkit.md +10 -0
- package/skills/ios/swiftdata-pro/references/core-rules.md +20 -0
- package/skills/ios/swiftdata-pro/references/indexing.md +27 -0
- package/skills/ios/swiftdata-pro/references/predicates.md +73 -0
- package/skills/ios/swiftui-design-principles/AGENTS.md +21 -0
- package/skills/ios/swiftui-design-principles/LICENSE +21 -0
- package/skills/ios/swiftui-design-principles/README.md +41 -0
- package/skills/ios/swiftui-design-principles/SKILL.md +605 -0
- package/skills/ios/swiftui-design-principles/metadata.json +10 -0
- package/skills/ios/swiftui-design-tokens/SKILL.md +475 -0
- package/skills/ios/swiftui-liquid-glass/LICENSE +21 -0
- package/skills/ios/swiftui-liquid-glass/SKILL.md +95 -0
- package/skills/ios/swiftui-liquid-glass/agents/openai.yaml +4 -0
- package/skills/ios/swiftui-liquid-glass/references/liquid-glass.md +280 -0
- package/skills/ios/swiftui-performance-audit/LICENSE +21 -0
- package/skills/ios/swiftui-performance-audit/SKILL.md +111 -0
- package/skills/ios/swiftui-performance-audit/agents/openai.yaml +4 -0
- package/skills/ios/swiftui-performance-audit/references/code-smells.md +150 -0
- package/skills/ios/swiftui-performance-audit/references/demystify-swiftui-performance-wwdc23.md +46 -0
- package/skills/ios/swiftui-performance-audit/references/optimizing-swiftui-performance-instruments.md +29 -0
- package/skills/ios/swiftui-performance-audit/references/profiling-intake.md +44 -0
- package/skills/ios/swiftui-performance-audit/references/report-template.md +47 -0
- package/skills/ios/swiftui-performance-audit/references/understanding-hangs-in-your-app.md +33 -0
- package/skills/ios/swiftui-performance-audit/references/understanding-improving-swiftui-performance.md +52 -0
- package/skills/ios/swiftui-pro/LICENSE +21 -0
- package/skills/ios/swiftui-pro/SKILL.md +108 -0
- package/skills/ios/swiftui-pro/agents/openai.yaml +10 -0
- package/skills/ios/swiftui-pro/assets/swiftui-pro-icon.png +0 -0
- package/skills/ios/swiftui-pro/assets/swiftui-pro-icon.svg +29 -0
- package/skills/ios/swiftui-pro/references/accessibility.md +13 -0
- package/skills/ios/swiftui-pro/references/api.md +39 -0
- package/skills/ios/swiftui-pro/references/data.md +43 -0
- package/skills/ios/swiftui-pro/references/design.md +31 -0
- package/skills/ios/swiftui-pro/references/hygiene.md +9 -0
- package/skills/ios/swiftui-pro/references/navigation.md +14 -0
- package/skills/ios/swiftui-pro/references/performance.md +46 -0
- package/skills/ios/swiftui-pro/references/swift.md +56 -0
- package/skills/ios/swiftui-pro/references/views.md +35 -0
- package/skills/ios/swiftui-ui-patterns/LICENSE +21 -0
- package/skills/ios/swiftui-ui-patterns/SKILL.md +100 -0
- package/skills/ios/swiftui-ui-patterns/agents/openai.yaml +4 -0
- package/skills/ios/swiftui-ui-patterns/references/app-wiring.md +201 -0
- package/skills/ios/swiftui-ui-patterns/references/async-state.md +96 -0
- package/skills/ios/swiftui-ui-patterns/references/components-index.md +50 -0
- package/skills/ios/swiftui-ui-patterns/references/controls.md +57 -0
- package/skills/ios/swiftui-ui-patterns/references/deeplinks.md +66 -0
- package/skills/ios/swiftui-ui-patterns/references/focus.md +90 -0
- package/skills/ios/swiftui-ui-patterns/references/form.md +97 -0
- package/skills/ios/swiftui-ui-patterns/references/grids.md +71 -0
- package/skills/ios/swiftui-ui-patterns/references/haptics.md +71 -0
- package/skills/ios/swiftui-ui-patterns/references/input-toolbar.md +51 -0
- package/skills/ios/swiftui-ui-patterns/references/lightweight-clients.md +93 -0
- package/skills/ios/swiftui-ui-patterns/references/list.md +86 -0
- package/skills/ios/swiftui-ui-patterns/references/loading-placeholders.md +38 -0
- package/skills/ios/swiftui-ui-patterns/references/macos-settings.md +71 -0
- package/skills/ios/swiftui-ui-patterns/references/matched-transitions.md +59 -0
- package/skills/ios/swiftui-ui-patterns/references/media.md +73 -0
- package/skills/ios/swiftui-ui-patterns/references/menu-bar.md +101 -0
- package/skills/ios/swiftui-ui-patterns/references/navigationstack.md +159 -0
- package/skills/ios/swiftui-ui-patterns/references/overlay.md +45 -0
- package/skills/ios/swiftui-ui-patterns/references/performance.md +62 -0
- package/skills/ios/swiftui-ui-patterns/references/previews.md +48 -0
- package/skills/ios/swiftui-ui-patterns/references/scroll-reveal.md +133 -0
- package/skills/ios/swiftui-ui-patterns/references/scrollview.md +87 -0
- package/skills/ios/swiftui-ui-patterns/references/searchable.md +71 -0
- package/skills/ios/swiftui-ui-patterns/references/sheets.md +155 -0
- package/skills/ios/swiftui-ui-patterns/references/split-views.md +72 -0
- package/skills/ios/swiftui-ui-patterns/references/tabview.md +114 -0
- package/skills/ios/swiftui-ui-patterns/references/theming.md +71 -0
- package/skills/ios/swiftui-ui-patterns/references/title-menus.md +93 -0
- package/skills/ios/swiftui-ui-patterns/references/top-bar.md +49 -0
- package/skills/ios/swiftui-view-refactor/LICENSE +21 -0
- package/skills/ios/swiftui-view-refactor/SKILL.md +207 -0
- package/skills/ios/swiftui-view-refactor/agents/openai.yaml +4 -0
- package/skills/ios/swiftui-view-refactor/references/mv-patterns.md +161 -0
- package/skills/ios/widgetkit/LICENSE +131 -0
- package/skills/ios/widgetkit/SKILL.md +502 -0
- package/skills/ios/widgetkit/references/widgetkit-advanced.md +871 -0
- package/skills/ios/writing-for-interfaces/SKILL.md +75 -0
- package/skills/web/accessibility/SKILL.md +146 -0
- package/skills/web/aceternity-ui/SKILL.md +719 -0
- package/skills/web/aceternity-ui/metadata.json +10 -0
- package/skills/web/api-design/SKILL.md +523 -0
- package/skills/web/chart-accessibility/SKILL.md +332 -0
- package/skills/web/composition-patterns/AGENTS.md +946 -0
- package/skills/web/composition-patterns/README.md +60 -0
- package/skills/web/composition-patterns/SKILL.md +89 -0
- package/skills/web/composition-patterns/metadata.json +11 -0
- package/skills/web/composition-patterns/rules/_sections.md +29 -0
- package/skills/web/composition-patterns/rules/_template.md +24 -0
- package/skills/web/composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
- package/skills/web/composition-patterns/rules/architecture-compound-components.md +112 -0
- package/skills/web/composition-patterns/rules/patterns-children-over-render-props.md +87 -0
- package/skills/web/composition-patterns/rules/patterns-explicit-variants.md +100 -0
- package/skills/web/composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/skills/web/composition-patterns/rules/state-context-interface.md +191 -0
- package/skills/web/composition-patterns/rules/state-decouple-implementation.md +113 -0
- package/skills/web/composition-patterns/rules/state-lift-state.md +125 -0
- package/skills/web/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/skills/web/database-migrations/SKILL.md +429 -0
- package/skills/web/deployment-patterns/SKILL.md +427 -0
- package/skills/web/docker-patterns/SKILL.md +364 -0
- package/skills/web/e2e-testing/SKILL.md +326 -0
- package/skills/web/lighthouse-ci/SKILL.md +361 -0
- package/skills/web/mcp-server-patterns/SKILL.md +69 -0
- package/skills/web/next-best-practices/SKILL.md +153 -0
- package/skills/web/next-best-practices/async-patterns.md +87 -0
- package/skills/web/next-best-practices/bundling.md +180 -0
- package/skills/web/next-best-practices/data-patterns.md +297 -0
- package/skills/web/next-best-practices/debug-tricks.md +105 -0
- package/skills/web/next-best-practices/directives.md +73 -0
- package/skills/web/next-best-practices/error-handling.md +227 -0
- package/skills/web/next-best-practices/file-conventions.md +140 -0
- package/skills/web/next-best-practices/font.md +245 -0
- package/skills/web/next-best-practices/functions.md +108 -0
- package/skills/web/next-best-practices/hydration-error.md +91 -0
- package/skills/web/next-best-practices/image.md +173 -0
- package/skills/web/next-best-practices/metadata.md +301 -0
- package/skills/web/next-best-practices/parallel-routes.md +287 -0
- package/skills/web/next-best-practices/route-handlers.md +146 -0
- package/skills/web/next-best-practices/rsc-boundaries.md +159 -0
- package/skills/web/next-best-practices/runtime-selection.md +39 -0
- package/skills/web/next-best-practices/scripts.md +141 -0
- package/skills/web/next-best-practices/self-hosting.md +371 -0
- package/skills/web/next-best-practices/suspense-boundaries.md +67 -0
- package/skills/web/next-cache-components/SKILL.md +411 -0
- package/skills/web/postgres-best-practices/SKILL.md +14 -0
- package/skills/web/postgres-best-practices/references/schema-design.md +9 -0
- package/skills/web/react-best-practices/AGENTS.md +3810 -0
- package/skills/web/react-best-practices/README.md +123 -0
- package/skills/web/react-best-practices/SKILL.md +149 -0
- package/skills/web/react-best-practices/metadata.json +15 -0
- package/skills/web/react-best-practices/rules/_sections.md +46 -0
- package/skills/web/react-best-practices/rules/_template.md +28 -0
- package/skills/web/react-best-practices/rules/advanced-effect-event-deps.md +56 -0
- package/skills/web/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/skills/web/react-best-practices/rules/advanced-init-once.md +42 -0
- package/skills/web/react-best-practices/rules/advanced-use-latest.md +39 -0
- package/skills/web/react-best-practices/rules/async-api-routes.md +38 -0
- package/skills/web/react-best-practices/rules/async-cheap-condition-before-await.md +37 -0
- package/skills/web/react-best-practices/rules/async-defer-await.md +82 -0
- package/skills/web/react-best-practices/rules/async-dependencies.md +51 -0
- package/skills/web/react-best-practices/rules/async-parallel.md +28 -0
- package/skills/web/react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/skills/web/react-best-practices/rules/bundle-analyzable-paths.md +63 -0
- package/skills/web/react-best-practices/rules/bundle-barrel-imports.md +60 -0
- package/skills/web/react-best-practices/rules/bundle-conditional.md +31 -0
- package/skills/web/react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/skills/web/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/skills/web/react-best-practices/rules/bundle-preload.md +50 -0
- package/skills/web/react-best-practices/rules/client-event-listeners.md +74 -0
- package/skills/web/react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/skills/web/react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/skills/web/react-best-practices/rules/client-swr-dedup.md +56 -0
- package/skills/web/react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/skills/web/react-best-practices/rules/js-cache-function-results.md +80 -0
- package/skills/web/react-best-practices/rules/js-cache-property-access.md +28 -0
- package/skills/web/react-best-practices/rules/js-cache-storage.md +70 -0
- package/skills/web/react-best-practices/rules/js-combine-iterations.md +32 -0
- package/skills/web/react-best-practices/rules/js-early-exit.md +50 -0
- package/skills/web/react-best-practices/rules/js-flatmap-filter.md +60 -0
- package/skills/web/react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/skills/web/react-best-practices/rules/js-index-maps.md +37 -0
- package/skills/web/react-best-practices/rules/js-length-check-first.md +49 -0
- package/skills/web/react-best-practices/rules/js-min-max-loop.md +82 -0
- package/skills/web/react-best-practices/rules/js-request-idle-callback.md +105 -0
- package/skills/web/react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/skills/web/react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/skills/web/react-best-practices/rules/rendering-activity.md +26 -0
- package/skills/web/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/skills/web/react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/skills/web/react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/skills/web/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/skills/web/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/skills/web/react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/skills/web/react-best-practices/rules/rendering-resource-hints.md +85 -0
- package/skills/web/react-best-practices/rules/rendering-script-defer-async.md +68 -0
- package/skills/web/react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/skills/web/react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/skills/web/react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/skills/web/react-best-practices/rules/rerender-dependencies.md +45 -0
- package/skills/web/react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/skills/web/react-best-practices/rules/rerender-derived-state.md +29 -0
- package/skills/web/react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/skills/web/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/skills/web/react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/skills/web/react-best-practices/rules/rerender-memo.md +44 -0
- package/skills/web/react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/skills/web/react-best-practices/rules/rerender-no-inline-components.md +82 -0
- package/skills/web/react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/skills/web/react-best-practices/rules/rerender-split-combined-hooks.md +64 -0
- package/skills/web/react-best-practices/rules/rerender-transitions.md +40 -0
- package/skills/web/react-best-practices/rules/rerender-use-deferred-value.md +59 -0
- package/skills/web/react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/skills/web/react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/skills/web/react-best-practices/rules/server-auth-actions.md +96 -0
- package/skills/web/react-best-practices/rules/server-cache-lru.md +41 -0
- package/skills/web/react-best-practices/rules/server-cache-react.md +76 -0
- package/skills/web/react-best-practices/rules/server-dedup-props.md +65 -0
- package/skills/web/react-best-practices/rules/server-hoist-static-io.md +149 -0
- package/skills/web/react-best-practices/rules/server-no-shared-module-state.md +50 -0
- package/skills/web/react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/skills/web/react-best-practices/rules/server-parallel-nested-fetching.md +34 -0
- package/skills/web/react-best-practices/rules/server-serialization.md +38 -0
- package/skills/web/seo/SKILL.md +154 -0
- package/skills/web/web-design-guidelines/SKILL.md +39 -0
- package/skills/web/zap-scan-config/SKILL.md +444 -0
- package/skills/web/zap-scan-config/assets/.gitkeep +9 -0
- package/skills/web/zap-scan-config/assets/github_action.yml +207 -0
- package/skills/web/zap-scan-config/assets/gitlab_ci.yml +226 -0
- package/skills/web/zap-scan-config/assets/zap_automation.yaml +196 -0
- package/skills/web/zap-scan-config/assets/zap_context.xml +192 -0
- package/skills/web/zap-scan-config/references/EXAMPLE.md +40 -0
- package/skills/web/zap-scan-config/references/api_testing_guide.md +475 -0
- package/skills/web/zap-scan-config/references/authentication_guide.md +431 -0
- package/skills/web/zap-scan-config/references/false_positive_handling.md +427 -0
- package/skills/web/zap-scan-config/references/owasp_mapping.md +255 -0
- package/src/lrr/aggregator.ts +80 -0
- package/src/orchestrator/hooks/context-header.ts +95 -0
- package/src/orchestrator/hooks/token-accounting-emitter.ts +77 -0
- package/src/orchestrator/hooks/token-accounting.ts +101 -0
- package/src/orchestrator/mcp/cycle-counter.ts +129 -0
- package/src/orchestrator/mcp/scribe.ts +283 -0
- package/src/orchestrator/mcp/state-save.ts +149 -0
- package/src/orchestrator/mcp/write-lease.ts +167 -0
- package/src/orchestrator/phase4-shared-context.ts +41 -0
- package/src/orchestrator/schemas/backward-edge.ts +46 -0
- package/agents/agentic-identity-trust.md +0 -121
- package/agents/data-consolidation-agent.md +0 -39
- package/agents/design-image-prompt-engineer.md +0 -105
- package/agents/design-visual-storyteller.md +0 -147
- package/agents/design-whimsy-injector.md +0 -89
- package/agents/engineering-autonomous-optimization-architect.md +0 -105
- package/agents/market-intel.md +0 -35
- package/agents/marketing-instagram-curator.md +0 -111
- package/agents/marketing-reddit-community-builder.md +0 -121
- package/agents/marketing-social-media-strategist.md +0 -74
- package/agents/marketing-tiktok-strategist.md +0 -123
- package/agents/marketing-twitter-engager.md +0 -124
- package/agents/marketing-wechat-official-account.md +0 -143
- package/agents/marketing-xiaohongshu-specialist.md +0 -136
- package/agents/marketing-zhihu-strategist.md +0 -160
- package/agents/product-behavioral-nudge-engine.md +0 -78
- package/agents/project-management-experiment-tracker.md +0 -102
- package/agents/report-distribution-agent.md +0 -43
- package/agents/risk-analysis.md +0 -45
- package/agents/sales-data-extraction-agent.md +0 -46
- package/agents/specialized-cultural-intelligence-strategist.md +0 -65
- package/agents/specialized-developer-advocate.md +0 -146
- package/agents/support-analytics-reporter.md +0 -133
- package/agents/support-executive-summary-generator.md +0 -64
- package/agents/support-finance-tracker.md +0 -145
- package/agents/support-legal-compliance-checker.md +0 -129
- package/agents/support-support-responder.md +0 -91
- package/agents/testing-accessibility-auditor.md +0 -110
- package/agents/testing-test-results-analyzer.md +0 -97
- package/agents/testing-tool-evaluator.md +0 -76
- package/agents/testing-workflow-optimizer.md +0 -99
- package/agents/user-research.md +0 -40
|
@@ -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
|