@stella-studio/ck 1.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/.agents/skills/find-skills/SKILL.md +133 -0
- package/.claude/.ck.json +60 -0
- package/.claude/.ckignore +27 -0
- package/.claude/.env.example +100 -0
- package/.claude/.mcp.json.example +23 -0
- package/.claude/agents/brainstormer.md +113 -0
- package/.claude/agents/code-reviewer.md +131 -0
- package/.claude/agents/code-simplifier.md +42 -0
- package/.claude/agents/debugger.md +137 -0
- package/.claude/agents/docs-manager.md +208 -0
- package/.claude/agents/fullstack-developer.md +95 -0
- package/.claude/agents/git-manager.md +9 -0
- package/.claude/agents/journal-writer.md +113 -0
- package/.claude/agents/mcp-manager.md +97 -0
- package/.claude/agents/planner.md +108 -0
- package/.claude/agents/project-manager.md +125 -0
- package/.claude/agents/researcher.md +38 -0
- package/.claude/agents/tester.md +105 -0
- package/.claude/agents/ui-ux-designer.md +236 -0
- package/.claude/commands/ask.md +56 -0
- package/.claude/commands/bootstrap/auto/fast.md +111 -0
- package/.claude/commands/bootstrap/auto/parallel.md +66 -0
- package/.claude/commands/bootstrap/auto.md +115 -0
- package/.claude/commands/bootstrap.md +137 -0
- package/.claude/commands/ck-help.md +129 -0
- package/.claude/commands/coding-level.md +48 -0
- package/.claude/commands/docs/init.md +38 -0
- package/.claude/commands/docs/summarize.md +22 -0
- package/.claude/commands/docs/update.md +76 -0
- package/.claude/commands/journal.md +7 -0
- package/.claude/commands/kanban.md +99 -0
- package/.claude/commands/plan/archive.md +57 -0
- package/.claude/commands/plan/ci.md +33 -0
- package/.claude/commands/plan/cro.md +69 -0
- package/.claude/commands/plan/fast.md +82 -0
- package/.claude/commands/plan/hard.md +108 -0
- package/.claude/commands/plan/parallel.md +145 -0
- package/.claude/commands/plan/two.md +61 -0
- package/.claude/commands/plan/validate.md +188 -0
- package/.claude/commands/plan.md +30 -0
- package/.claude/commands/preview.md +280 -0
- package/.claude/commands/review/codebase/parallel.md +122 -0
- package/.claude/commands/review/codebase.md +49 -0
- package/.claude/commands/test/ui.md +92 -0
- package/.claude/commands/test.md +8 -0
- package/.claude/commands/use-mcp.md +38 -0
- package/.claude/commands/watzup.md +8 -0
- package/.claude/commands/worktree.md +109 -0
- package/.claude/commands-archived/code/auto.md +203 -0
- package/.claude/commands-archived/code/no-test.md +174 -0
- package/.claude/commands-archived/code/parallel.md +100 -0
- package/.claude/commands-archived/code.md +205 -0
- package/.claude/commands-archived/content/cro.md +43 -0
- package/.claude/commands-archived/content/enhance.md +14 -0
- package/.claude/commands-archived/content/fast.md +13 -0
- package/.claude/commands-archived/content/good.md +16 -0
- package/.claude/commands-archived/cook/auto/fast.md +26 -0
- package/.claude/commands-archived/cook/auto/parallel.md +49 -0
- package/.claude/commands-archived/cook/auto.md +15 -0
- package/.claude/commands-archived/cook.md +105 -0
- package/.claude/commands-archived/debug.md +13 -0
- package/.claude/commands-archived/design/3d.md +83 -0
- package/.claude/commands-archived/design/describe.md +23 -0
- package/.claude/commands-archived/design/fast.md +31 -0
- package/.claude/commands-archived/design/good.md +35 -0
- package/.claude/commands-archived/design/screenshot.md +34 -0
- package/.claude/commands-archived/design/video.md +34 -0
- package/.claude/commands-archived/fix/ci.md +17 -0
- package/.claude/commands-archived/fix/fast.md +19 -0
- package/.claude/commands-archived/fix/hard.md +39 -0
- package/.claude/commands-archived/fix/logs.md +26 -0
- package/.claude/commands-archived/fix/parallel.md +54 -0
- package/.claude/commands-archived/fix/test.md +20 -0
- package/.claude/commands-archived/fix/types.md +9 -0
- package/.claude/commands-archived/fix/ui.md +48 -0
- package/.claude/commands-archived/fix.md +43 -0
- package/.claude/commands-archived/scout/ext.md +39 -0
- package/.claude/commands-archived/scout.md +28 -0
- package/.claude/commands-archived/skill/add.md +36 -0
- package/.claude/commands-archived/skill/create.md +29 -0
- package/.claude/commands-archived/skill/fix-logs.md +22 -0
- package/.claude/commands-archived/skill/optimize/auto.md +25 -0
- package/.claude/commands-archived/skill/optimize.md +34 -0
- package/.claude/commands-archived/skill/plan.md +45 -0
- package/.claude/commands-archived/skill/update.md +36 -0
- package/.claude/hooks/__tests__/ck-config-utils.test.cjs +557 -0
- package/.claude/hooks/__tests__/descriptive-name.test.cjs +292 -0
- package/.claude/hooks/__tests__/dev-rules-reminder.test.cjs +336 -0
- package/.claude/hooks/__tests__/integration/path-resolution.test.cjs +319 -0
- package/.claude/hooks/__tests__/privacy-block.test.cjs +273 -0
- package/.claude/hooks/__tests__/session-init.test.cjs +308 -0
- package/.claude/hooks/__tests__/skill-dedup.test.cjs +527 -0
- package/.claude/hooks/__tests__/subagent-init.test.cjs +622 -0
- package/.claude/hooks/cook-after-plan-reminder.cjs +58 -0
- package/.claude/hooks/descriptive-name.cjs +33 -0
- package/.claude/hooks/dev-rules-reminder.cjs +58 -0
- package/.claude/hooks/docs/README.md +179 -0
- package/.claude/hooks/lib/__tests__/README.md +240 -0
- package/.claude/hooks/lib/__tests__/ck-config-utils.test.cjs +781 -0
- package/.claude/hooks/lib/__tests__/context-builder.test.cjs +450 -0
- package/.claude/hooks/lib/__tests__/statusline-integration.test.cjs +678 -0
- package/.claude/hooks/lib/__tests__/statusline.test.cjs +689 -0
- package/.claude/hooks/lib/ck-config-utils.cjs +829 -0
- package/.claude/hooks/lib/colors.cjs +95 -0
- package/.claude/hooks/lib/config-counter.cjs +103 -0
- package/.claude/hooks/lib/context-builder.cjs +612 -0
- package/.claude/hooks/lib/privacy-checker.cjs +297 -0
- package/.claude/hooks/lib/project-detector.cjs +430 -0
- package/.claude/hooks/lib/scout-checker.cjs +191 -0
- package/.claude/hooks/lib/transcript-parser.cjs +181 -0
- package/.claude/hooks/notifications/.env.example +21 -0
- package/.claude/hooks/notifications/discord_notify.sh +234 -0
- package/.claude/hooks/notifications/docs/discord-hook-setup.md +461 -0
- package/.claude/hooks/notifications/docs/slack-hook-setup.md +118 -0
- package/.claude/hooks/notifications/docs/telegram-hook-setup.md +813 -0
- package/.claude/hooks/notifications/lib/env-loader.cjs +105 -0
- package/.claude/hooks/notifications/lib/sender.cjs +128 -0
- package/.claude/hooks/notifications/notify.cjs +156 -0
- package/.claude/hooks/notifications/providers/discord.cjs +197 -0
- package/.claude/hooks/notifications/providers/slack.cjs +111 -0
- package/.claude/hooks/notifications/providers/telegram.cjs +109 -0
- package/.claude/hooks/notifications/send-discord.sh +75 -0
- package/.claude/hooks/notifications/telegram_notify.sh +137 -0
- package/.claude/hooks/post-edit-simplify-reminder.cjs +138 -0
- package/.claude/hooks/privacy-block.cjs +151 -0
- package/.claude/hooks/scout-block/broad-pattern-detector.cjs +260 -0
- package/.claude/hooks/scout-block/error-formatter.cjs +156 -0
- package/.claude/hooks/scout-block/path-extractor.cjs +265 -0
- package/.claude/hooks/scout-block/pattern-matcher.cjs +184 -0
- package/.claude/hooks/scout-block/tests/test-broad-pattern-detector.cjs +165 -0
- package/.claude/hooks/scout-block/tests/test-build-command-allowlist.cjs +137 -0
- package/.claude/hooks/scout-block/tests/test-error-formatter.cjs +109 -0
- package/.claude/hooks/scout-block/tests/test-full-flow-edge-cases.cjs +75 -0
- package/.claude/hooks/scout-block/tests/test-monorepo-scenarios.cjs +225 -0
- package/.claude/hooks/scout-block/tests/test-path-extractor.cjs +138 -0
- package/.claude/hooks/scout-block/tests/test-pattern-matcher.cjs +64 -0
- package/.claude/hooks/scout-block/vendor/ignore.cjs +627 -0
- package/.claude/hooks/scout-block.cjs +123 -0
- package/.claude/hooks/session-init.cjs +299 -0
- package/.claude/hooks/skill-dedup.cjs +254 -0
- package/.claude/hooks/subagent-init.cjs +189 -0
- package/.claude/hooks/tests/test-ckignore.cjs +194 -0
- package/.claude/hooks/tests/test-modularization-hook.cjs +126 -0
- package/.claude/hooks/tests/test-privacy-block.cjs +298 -0
- package/.claude/hooks/tests/test-scout-block.cjs +288 -0
- package/.claude/hooks/usage-context-awareness.cjs +165 -0
- package/.claude/metadata.json +44 -0
- package/.claude/output-styles/coding-level-0-eli5.md +103 -0
- package/.claude/output-styles/coding-level-1-junior.md +124 -0
- package/.claude/output-styles/coding-level-2-mid.md +146 -0
- package/.claude/output-styles/coding-level-3-senior.md +148 -0
- package/.claude/output-styles/coding-level-4-lead.md +159 -0
- package/.claude/output-styles/coding-level-5-god.md +91 -0
- package/.claude/rules/development-rules.md +52 -0
- package/.claude/rules/documentation-management.md +121 -0
- package/.claude/rules/orchestration-protocol.md +36 -0
- package/.claude/rules/primary-workflow.md +57 -0
- package/.claude/schemas/ck-config.schema.json +381 -0
- package/.claude/scripts/README.md +153 -0
- package/.claude/scripts/ck-help.py +1088 -0
- package/.claude/scripts/commands_data.yaml +363 -0
- package/.claude/scripts/fix-shebang-permissions.sh +50 -0
- package/.claude/scripts/requirements.txt +1 -0
- package/.claude/scripts/resolve_env.py +329 -0
- package/.claude/scripts/scan_commands.py +98 -0
- package/.claude/scripts/scan_skills.py +186 -0
- package/.claude/scripts/set-active-plan.cjs +50 -0
- package/.claude/scripts/skills_data.yaml +370 -0
- package/.claude/scripts/test-ck-help.py +218 -0
- package/.claude/scripts/test_ck_help.py +420 -0
- package/.claude/scripts/test_ck_help_integration.py +127 -0
- package/.claude/scripts/validate-docs.cjs +342 -0
- package/.claude/scripts/win_compat.py +57 -0
- package/.claude/scripts/worktree.cjs +825 -0
- package/.claude/scripts/worktree.test.cjs +770 -0
- package/.claude/settings.json +102 -0
- package/.claude/skills/.env.example +101 -0
- package/.claude/skills/INSTALLATION.md +360 -0
- package/.claude/skills/README.md +149 -0
- package/.claude/skills/THIRD_PARTY_NOTICES.md +405 -0
- package/.claude/skills/agent-browser/SKILL.md +293 -0
- package/.claude/skills/agent-browser/references/.gitkeep +0 -0
- package/.claude/skills/agent-browser/references/agent-browser-vs-chrome-devtools.md +112 -0
- package/.claude/skills/agent-browser/references/browserbase-cloud-setup.md +161 -0
- package/.claude/skills/agent_skills_spec.md +55 -0
- package/.claude/skills/ai-artist/SKILL.md +121 -0
- package/.claude/skills/ai-artist/data/awesome-prompts.csv +3592 -0
- package/.claude/skills/ai-artist/data/lighting.csv +19 -0
- package/.claude/skills/ai-artist/data/nano-banana-templates.csv +17 -0
- package/.claude/skills/ai-artist/data/platforms.csv +11 -0
- package/.claude/skills/ai-artist/data/styles.csv +26 -0
- package/.claude/skills/ai-artist/data/techniques.csv +19 -0
- package/.claude/skills/ai-artist/data/use-cases.csv +16 -0
- package/.claude/skills/ai-artist/references/advanced-techniques.md +184 -0
- package/.claude/skills/ai-artist/references/awesome-nano-banana-pro-prompts.md +8575 -0
- package/.claude/skills/ai-artist/references/domain-code.md +66 -0
- package/.claude/skills/ai-artist/references/domain-data.md +72 -0
- package/.claude/skills/ai-artist/references/domain-marketing.md +66 -0
- package/.claude/skills/ai-artist/references/domain-patterns.md +33 -0
- package/.claude/skills/ai-artist/references/domain-writing.md +68 -0
- package/.claude/skills/ai-artist/references/image-prompting.md +141 -0
- package/.claude/skills/ai-artist/references/llm-prompting.md +165 -0
- package/.claude/skills/ai-artist/references/nano-banana.md +136 -0
- package/.claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
- package/.claude/skills/ai-artist/references/validation-workflow.md +117 -0
- package/.claude/skills/ai-artist/scripts/core.py +197 -0
- package/.claude/skills/ai-artist/scripts/extract_prompts.py +102 -0
- package/.claude/skills/ai-artist/scripts/generate.py +370 -0
- package/.claude/skills/ai-artist/scripts/search.py +147 -0
- package/.claude/skills/ai-multimodal/.env.example +204 -0
- package/.claude/skills/ai-multimodal/SKILL.md +109 -0
- package/.claude/skills/ai-multimodal/references/audio-processing.md +387 -0
- package/.claude/skills/ai-multimodal/references/image-generation.md +939 -0
- package/.claude/skills/ai-multimodal/references/music-generation.md +311 -0
- package/.claude/skills/ai-multimodal/references/video-analysis.md +515 -0
- package/.claude/skills/ai-multimodal/references/video-generation.md +457 -0
- package/.claude/skills/ai-multimodal/references/vision-understanding.md +492 -0
- package/.claude/skills/ai-multimodal/scripts/.coverage +0 -0
- package/.claude/skills/ai-multimodal/scripts/check_setup.py +315 -0
- package/.claude/skills/ai-multimodal/scripts/document_converter.py +395 -0
- package/.claude/skills/ai-multimodal/scripts/gemini_batch_process.py +1185 -0
- package/.claude/skills/ai-multimodal/scripts/media_optimizer.py +506 -0
- package/.claude/skills/ai-multimodal/scripts/requirements.txt +26 -0
- package/.claude/skills/ai-multimodal/scripts/tests/.coverage +0 -0
- package/.claude/skills/ai-multimodal/scripts/tests/requirements.txt +20 -0
- package/.claude/skills/ai-multimodal/scripts/tests/test_document_converter.py +74 -0
- package/.claude/skills/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -0
- package/.claude/skills/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -0
- package/.claude/skills/backend-development/SKILL.md +95 -0
- package/.claude/skills/backend-development/references/backend-api-design.md +495 -0
- package/.claude/skills/backend-development/references/backend-architecture.md +454 -0
- package/.claude/skills/backend-development/references/backend-authentication.md +338 -0
- package/.claude/skills/backend-development/references/backend-code-quality.md +659 -0
- package/.claude/skills/backend-development/references/backend-debugging.md +904 -0
- package/.claude/skills/backend-development/references/backend-devops.md +494 -0
- package/.claude/skills/backend-development/references/backend-mindset.md +387 -0
- package/.claude/skills/backend-development/references/backend-performance.md +397 -0
- package/.claude/skills/backend-development/references/backend-security.md +290 -0
- package/.claude/skills/backend-development/references/backend-technologies.md +256 -0
- package/.claude/skills/backend-development/references/backend-testing.md +429 -0
- package/.claude/skills/better-auth/SKILL.md +204 -0
- package/.claude/skills/better-auth/references/advanced-features.md +553 -0
- package/.claude/skills/better-auth/references/database-integration.md +577 -0
- package/.claude/skills/better-auth/references/email-password-auth.md +416 -0
- package/.claude/skills/better-auth/references/oauth-providers.md +430 -0
- package/.claude/skills/better-auth/scripts/.coverage +0 -0
- package/.claude/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/.claude/skills/better-auth/scripts/requirements.txt +15 -0
- package/.claude/skills/better-auth/scripts/tests/.coverage +0 -0
- package/.claude/skills/better-auth/scripts/tests/test_better_auth_init.py +421 -0
- package/.claude/skills/brainstorm/SKILL.md +76 -0
- package/.claude/skills/chrome-devtools/SKILL.md +587 -0
- package/.claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
- package/.claude/skills/chrome-devtools/references/performance-guide.md +940 -0
- package/.claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
- package/.claude/skills/chrome-devtools/scripts/README.md +290 -0
- package/.claude/skills/chrome-devtools/scripts/__tests__/error-handling.test.js +102 -0
- package/.claude/skills/chrome-devtools/scripts/__tests__/selector.test.js +210 -0
- package/.claude/skills/chrome-devtools/scripts/aria-snapshot.js +363 -0
- package/.claude/skills/chrome-devtools/scripts/click.js +84 -0
- package/.claude/skills/chrome-devtools/scripts/connect-chrome.js +146 -0
- package/.claude/skills/chrome-devtools/scripts/console.js +81 -0
- package/.claude/skills/chrome-devtools/scripts/evaluate.js +55 -0
- package/.claude/skills/chrome-devtools/scripts/fill.js +77 -0
- package/.claude/skills/chrome-devtools/scripts/import-cookies.js +205 -0
- package/.claude/skills/chrome-devtools/scripts/inject-auth.js +230 -0
- package/.claude/skills/chrome-devtools/scripts/install-deps.sh +181 -0
- package/.claude/skills/chrome-devtools/scripts/install.sh +83 -0
- package/.claude/skills/chrome-devtools/scripts/lib/browser.js +341 -0
- package/.claude/skills/chrome-devtools/scripts/lib/selector.js +178 -0
- package/.claude/skills/chrome-devtools/scripts/navigate.js +66 -0
- package/.claude/skills/chrome-devtools/scripts/network.js +108 -0
- package/.claude/skills/chrome-devtools/scripts/package.json +16 -0
- package/.claude/skills/chrome-devtools/scripts/performance.js +151 -0
- package/.claude/skills/chrome-devtools/scripts/screenshot.js +199 -0
- package/.claude/skills/chrome-devtools/scripts/select-ref.js +132 -0
- package/.claude/skills/chrome-devtools/scripts/snapshot.js +136 -0
- package/.claude/skills/chrome-devtools/scripts/ws-debug.js +44 -0
- package/.claude/skills/chrome-devtools/scripts/ws-full-debug.js +107 -0
- package/.claude/skills/code-review/SKILL.md +106 -0
- package/.claude/skills/code-review/references/code-review-reception.md +113 -0
- package/.claude/skills/code-review/references/edge-case-scouting.md +119 -0
- package/.claude/skills/code-review/references/requesting-code-review.md +116 -0
- package/.claude/skills/code-review/references/verification-before-completion.md +139 -0
- package/.claude/skills/common/README.md +120 -0
- package/.claude/skills/common/api_key_helper.py +411 -0
- package/.claude/skills/common/api_key_rotator.py +248 -0
- package/.claude/skills/context-engineering/SKILL.md +107 -0
- package/.claude/skills/context-engineering/references/context-compression.md +84 -0
- package/.claude/skills/context-engineering/references/context-degradation.md +93 -0
- package/.claude/skills/context-engineering/references/context-fundamentals.md +75 -0
- package/.claude/skills/context-engineering/references/context-optimization.md +82 -0
- package/.claude/skills/context-engineering/references/evaluation.md +89 -0
- package/.claude/skills/context-engineering/references/memory-systems.md +88 -0
- package/.claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
- package/.claude/skills/context-engineering/references/project-development.md +97 -0
- package/.claude/skills/context-engineering/references/runtime-awareness.md +202 -0
- package/.claude/skills/context-engineering/references/tool-design.md +86 -0
- package/.claude/skills/context-engineering/scripts/compression_evaluator.py +349 -0
- package/.claude/skills/context-engineering/scripts/context_analyzer.py +317 -0
- package/.claude/skills/context-engineering/scripts/tests/test_edge_cases.py +246 -0
- package/.claude/skills/cook/README.md +86 -0
- package/.claude/skills/cook/SKILL.md +112 -0
- package/.claude/skills/cook/references/intent-detection.md +101 -0
- package/.claude/skills/cook/references/review-cycle.md +75 -0
- package/.claude/skills/cook/references/subagent-patterns.md +75 -0
- package/.claude/skills/cook/references/workflow-steps.md +166 -0
- package/.claude/skills/copywriting/SKILL.md +93 -0
- package/.claude/skills/copywriting/references/copy-formulas.md +150 -0
- package/.claude/skills/copywriting/references/cta-patterns.md +168 -0
- package/.claude/skills/copywriting/references/email-copy.md +193 -0
- package/.claude/skills/copywriting/references/headline-templates.md +140 -0
- package/.claude/skills/copywriting/references/landing-page-copy.md +175 -0
- package/.claude/skills/copywriting/references/power-words.md +189 -0
- package/.claude/skills/copywriting/references/social-media-copy.md +222 -0
- package/.claude/skills/copywriting/references/workflow-cro.md +54 -0
- package/.claude/skills/copywriting/references/workflow-enhance.md +32 -0
- package/.claude/skills/copywriting/references/workflow-fast.md +29 -0
- package/.claude/skills/copywriting/references/workflow-good.md +39 -0
- package/.claude/skills/copywriting/references/writing-styles.md +247 -0
- package/.claude/skills/copywriting/scripts/extract-writing-styles.py +308 -0
- package/.claude/skills/copywriting/templates/copy-brief.md +49 -0
- package/.claude/skills/databases/SKILL.md +83 -0
- package/.claude/skills/databases/analytics.md +198 -0
- package/.claude/skills/databases/db-design.md +188 -0
- package/.claude/skills/databases/incremental-etl.md +213 -0
- package/.claude/skills/databases/references/mongodb-aggregation.md +447 -0
- package/.claude/skills/databases/references/mongodb-atlas.md +465 -0
- package/.claude/skills/databases/references/mongodb-crud.md +408 -0
- package/.claude/skills/databases/references/mongodb-indexing.md +442 -0
- package/.claude/skills/databases/references/postgresql-administration.md +594 -0
- package/.claude/skills/databases/references/postgresql-performance.md +527 -0
- package/.claude/skills/databases/references/postgresql-psql-cli.md +467 -0
- package/.claude/skills/databases/references/postgresql-queries.md +475 -0
- package/.claude/skills/databases/scripts/.coverage +0 -0
- package/.claude/skills/databases/scripts/db_backup.py +502 -0
- package/.claude/skills/databases/scripts/db_migrate.py +426 -0
- package/.claude/skills/databases/scripts/db_performance_check.py +457 -0
- package/.claude/skills/databases/scripts/requirements.txt +20 -0
- package/.claude/skills/databases/scripts/tests/coverage-db.json +1 -0
- package/.claude/skills/databases/scripts/tests/requirements.txt +4 -0
- package/.claude/skills/databases/scripts/tests/test_db_backup.py +340 -0
- package/.claude/skills/databases/scripts/tests/test_db_migrate.py +277 -0
- package/.claude/skills/databases/scripts/tests/test_db_performance_check.py +370 -0
- package/.claude/skills/databases/stacks/bigquery.md +231 -0
- package/.claude/skills/databases/stacks/d1_cloudflare.md +137 -0
- package/.claude/skills/databases/stacks/mysql.md +216 -0
- package/.claude/skills/databases/stacks/postgres.md +235 -0
- package/.claude/skills/databases/stacks/sqlite.md +244 -0
- package/.claude/skills/databases/transactional.md +176 -0
- package/.claude/skills/debug/SKILL.md +84 -0
- package/.claude/skills/debug/references/defense-in-depth.md +124 -0
- package/.claude/skills/debug/references/root-cause-tracing.md +122 -0
- package/.claude/skills/debug/references/systematic-debugging.md +102 -0
- package/.claude/skills/debug/references/verification.md +123 -0
- package/.claude/skills/debug/scripts/find-polluter.sh +63 -0
- package/.claude/skills/debug/scripts/find-polluter.test.md +102 -0
- package/.claude/skills/devops/.env.example +76 -0
- package/.claude/skills/devops/SKILL.md +96 -0
- package/.claude/skills/devops/references/browser-rendering.md +305 -0
- package/.claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
- package/.claude/skills/devops/references/cloudflare-platform.md +271 -0
- package/.claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
- package/.claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
- package/.claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
- package/.claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
- package/.claude/skills/devops/references/docker-basics.md +297 -0
- package/.claude/skills/devops/references/docker-compose.md +292 -0
- package/.claude/skills/devops/references/gcloud-platform.md +297 -0
- package/.claude/skills/devops/references/gcloud-services.md +304 -0
- package/.claude/skills/devops/references/kubernetes-basics.md +99 -0
- package/.claude/skills/devops/references/kubernetes-helm-advanced.md +75 -0
- package/.claude/skills/devops/references/kubernetes-helm.md +81 -0
- package/.claude/skills/devops/references/kubernetes-kubectl.md +74 -0
- package/.claude/skills/devops/references/kubernetes-security-advanced.md +98 -0
- package/.claude/skills/devops/references/kubernetes-security.md +95 -0
- package/.claude/skills/devops/references/kubernetes-troubleshooting-advanced.md +74 -0
- package/.claude/skills/devops/references/kubernetes-troubleshooting.md +49 -0
- package/.claude/skills/devops/references/kubernetes-workflows-advanced.md +75 -0
- package/.claude/skills/devops/references/kubernetes-workflows.md +78 -0
- package/.claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
- package/.claude/skills/devops/scripts/docker_optimize.py +332 -0
- package/.claude/skills/devops/scripts/requirements.txt +20 -0
- package/.claude/skills/devops/scripts/tests/requirements.txt +3 -0
- package/.claude/skills/devops/scripts/tests/test_cloudflare_deploy.py +285 -0
- package/.claude/skills/devops/scripts/tests/test_docker_optimize.py +436 -0
- package/.claude/skills/docs-seeker/.env.example +15 -0
- package/.claude/skills/docs-seeker/SKILL.md +97 -0
- package/.claude/skills/docs-seeker/package.json +25 -0
- package/.claude/skills/docs-seeker/references/advanced.md +79 -0
- package/.claude/skills/docs-seeker/references/context7-patterns.md +68 -0
- package/.claude/skills/docs-seeker/references/errors.md +68 -0
- package/.claude/skills/docs-seeker/scripts/analyze-llms-txt.js +211 -0
- package/.claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
- package/.claude/skills/docs-seeker/scripts/fetch-docs.js +213 -0
- package/.claude/skills/docs-seeker/scripts/tests/run-tests.js +72 -0
- package/.claude/skills/docs-seeker/scripts/tests/test-analyze-llms.js +119 -0
- package/.claude/skills/docs-seeker/scripts/tests/test-detect-topic.js +112 -0
- package/.claude/skills/docs-seeker/scripts/tests/test-fetch-docs.js +84 -0
- package/.claude/skills/docs-seeker/scripts/utils/env-loader.js +94 -0
- package/.claude/skills/docs-seeker/workflows/library-search.md +87 -0
- package/.claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
- package/.claude/skills/docs-seeker/workflows/topic-search.md +77 -0
- package/.claude/skills/document-skills/docx/LICENSE.txt +30 -0
- package/.claude/skills/document-skills/docx/SKILL.md +197 -0
- package/.claude/skills/document-skills/docx/docx-js.md +350 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.claude/skills/document-skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/pack.py +159 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/unpack.py +29 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validate.py +69 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validation/__init__.py +15 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validation/base.py +951 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validation/docx.py +274 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validation/pptx.py +315 -0
- package/.claude/skills/document-skills/docx/ooxml/scripts/validation/redlining.py +279 -0
- package/.claude/skills/document-skills/docx/ooxml.md +610 -0
- package/.claude/skills/document-skills/docx/scripts/__init__.py +1 -0
- package/.claude/skills/document-skills/docx/scripts/document.py +1276 -0
- package/.claude/skills/document-skills/docx/scripts/templates/comments.xml +3 -0
- package/.claude/skills/document-skills/docx/scripts/templates/commentsExtended.xml +3 -0
- package/.claude/skills/document-skills/docx/scripts/templates/commentsExtensible.xml +3 -0
- package/.claude/skills/document-skills/docx/scripts/templates/commentsIds.xml +3 -0
- package/.claude/skills/document-skills/docx/scripts/templates/people.xml +3 -0
- package/.claude/skills/document-skills/docx/scripts/utilities.py +374 -0
- package/.claude/skills/document-skills/pdf/LICENSE.txt +30 -0
- package/.claude/skills/document-skills/pdf/SKILL.md +294 -0
- package/.claude/skills/document-skills/pdf/forms.md +205 -0
- package/.claude/skills/document-skills/pdf/reference.md +612 -0
- package/.claude/skills/document-skills/pdf/scripts/check_bounding_boxes.py +70 -0
- package/.claude/skills/document-skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
- package/.claude/skills/document-skills/pdf/scripts/check_fillable_fields.py +12 -0
- package/.claude/skills/document-skills/pdf/scripts/convert_pdf_to_images.py +35 -0
- package/.claude/skills/document-skills/pdf/scripts/create_validation_image.py +41 -0
- package/.claude/skills/document-skills/pdf/scripts/extract_form_field_info.py +152 -0
- package/.claude/skills/document-skills/pdf/scripts/fill_fillable_fields.py +114 -0
- package/.claude/skills/document-skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
- package/.claude/skills/document-skills/pptx/LICENSE.txt +30 -0
- package/.claude/skills/document-skills/pptx/SKILL.md +484 -0
- package/.claude/skills/document-skills/pptx/html2pptx.md +625 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/.claude/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/pack.py +159 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/unpack.py +29 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validate.py +69 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validation/base.py +951 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validation/docx.py +274 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
- package/.claude/skills/document-skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
- package/.claude/skills/document-skills/pptx/ooxml.md +427 -0
- package/.claude/skills/document-skills/pptx/scripts/html2pptx.js +979 -0
- package/.claude/skills/document-skills/pptx/scripts/inventory.py +1020 -0
- package/.claude/skills/document-skills/pptx/scripts/rearrange.py +231 -0
- package/.claude/skills/document-skills/pptx/scripts/replace.py +385 -0
- package/.claude/skills/document-skills/pptx/scripts/thumbnail.py +450 -0
- package/.claude/skills/document-skills/xlsx/LICENSE.txt +30 -0
- package/.claude/skills/document-skills/xlsx/SKILL.md +289 -0
- package/.claude/skills/document-skills/xlsx/recalc.py +191 -0
- package/.claude/skills/find-skills/SKILL.md +133 -0
- package/.claude/skills/fix/SKILL.md +104 -0
- package/.claude/skills/fix/references/complexity-assessment.md +64 -0
- package/.claude/skills/fix/references/mode-selection.md +46 -0
- package/.claude/skills/fix/references/parallel-exploration.md +77 -0
- package/.claude/skills/fix/references/review-cycle.md +77 -0
- package/.claude/skills/fix/references/skill-activation-matrix.md +65 -0
- package/.claude/skills/fix/references/workflow-ci.md +28 -0
- package/.claude/skills/fix/references/workflow-deep.md +91 -0
- package/.claude/skills/fix/references/workflow-logs.md +36 -0
- package/.claude/skills/fix/references/workflow-quick.md +59 -0
- package/.claude/skills/fix/references/workflow-standard.md +86 -0
- package/.claude/skills/fix/references/workflow-test.md +36 -0
- package/.claude/skills/fix/references/workflow-types.md +33 -0
- package/.claude/skills/fix/references/workflow-ui.md +37 -0
- package/.claude/skills/frontend-design/SKILL.md +78 -0
- package/.claude/skills/frontend-design/references/ai-multimodal-overview.md +165 -0
- package/.claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
- package/.claude/skills/frontend-design/references/analysis-prompts.md +141 -0
- package/.claude/skills/frontend-design/references/analysis-techniques.md +118 -0
- package/.claude/skills/frontend-design/references/animejs.md +396 -0
- package/.claude/skills/frontend-design/references/asset-generation.md +337 -0
- package/.claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
- package/.claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
- package/.claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
- package/.claude/skills/frontend-design/references/extraction-prompts.md +127 -0
- package/.claude/skills/frontend-design/references/technical-accessibility.md +119 -0
- package/.claude/skills/frontend-design/references/technical-best-practices.md +97 -0
- package/.claude/skills/frontend-design/references/technical-optimization.md +44 -0
- package/.claude/skills/frontend-design/references/technical-overview.md +90 -0
- package/.claude/skills/frontend-design/references/technical-workflows.md +150 -0
- package/.claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
- package/.claude/skills/frontend-design/references/workflow-3d.md +102 -0
- package/.claude/skills/frontend-design/references/workflow-describe.md +87 -0
- package/.claude/skills/frontend-design/references/workflow-immersive.md +87 -0
- package/.claude/skills/frontend-design/references/workflow-quick.md +57 -0
- package/.claude/skills/frontend-design/references/workflow-screenshot.md +63 -0
- package/.claude/skills/frontend-design/references/workflow-video.md +74 -0
- package/.claude/skills/frontend-development/SKILL.md +399 -0
- package/.claude/skills/frontend-development/resources/common-patterns.md +331 -0
- package/.claude/skills/frontend-development/resources/complete-examples.md +872 -0
- package/.claude/skills/frontend-development/resources/component-patterns.md +502 -0
- package/.claude/skills/frontend-development/resources/data-fetching.md +767 -0
- package/.claude/skills/frontend-development/resources/file-organization.md +502 -0
- package/.claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
- package/.claude/skills/frontend-development/resources/performance.md +406 -0
- package/.claude/skills/frontend-development/resources/routing-guide.md +364 -0
- package/.claude/skills/frontend-development/resources/styling-guide.md +428 -0
- package/.claude/skills/frontend-development/resources/typescript-standards.md +418 -0
- package/.claude/skills/git/SKILL.md +100 -0
- package/.claude/skills/git/references/branch-management.md +88 -0
- package/.claude/skills/git/references/commit-standards.md +46 -0
- package/.claude/skills/git/references/gh-cli-guide.md +109 -0
- package/.claude/skills/git/references/safety-protocols.md +69 -0
- package/.claude/skills/git/references/workflow-commit.md +58 -0
- package/.claude/skills/git/references/workflow-merge.md +48 -0
- package/.claude/skills/git/references/workflow-pr.md +58 -0
- package/.claude/skills/git/references/workflow-push.md +52 -0
- package/.claude/skills/gkg/SKILL.md +90 -0
- package/.claude/skills/gkg/references/cli-commands.md +106 -0
- package/.claude/skills/gkg/references/http-api.md +102 -0
- package/.claude/skills/gkg/references/language-support.md +57 -0
- package/.claude/skills/gkg/references/mcp-tools.md +99 -0
- package/.claude/skills/google-adk-python/SKILL.md +132 -0
- package/.claude/skills/google-adk-python/references/agent-types-and-architecture.md +128 -0
- package/.claude/skills/google-adk-python/references/callbacks-plugins-observability.md +117 -0
- package/.claude/skills/google-adk-python/references/deployment-cloud-run-vertex-gke.md +138 -0
- package/.claude/skills/google-adk-python/references/evaluation-testing-cli.md +112 -0
- package/.claude/skills/google-adk-python/references/multi-agent-and-a2a-protocol.md +145 -0
- package/.claude/skills/google-adk-python/references/sessions-state-memory-artifacts.md +131 -0
- package/.claude/skills/google-adk-python/references/tools-and-mcp-integration.md +146 -0
- package/.claude/skills/install.ps1 +1295 -0
- package/.claude/skills/install.sh +1339 -0
- package/.claude/skills/markdown-novel-viewer/SKILL.md +313 -0
- package/.claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
- package/.claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
- package/.claude/skills/markdown-novel-viewer/assets/novel-theme.css +16 -0
- package/.claude/skills/markdown-novel-viewer/assets/reader.js +746 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-base.css +54 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-components.css +83 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-content.css +175 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-header.css +217 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-mermaid.css +128 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-overlays.css +202 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-responsive.css +285 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-sidebar.css +359 -0
- package/.claude/skills/markdown-novel-viewer/assets/styles/novel-theme-variables.css +56 -0
- package/.claude/skills/markdown-novel-viewer/assets/template.html +149 -0
- package/.claude/skills/markdown-novel-viewer/package.json +15 -0
- package/.claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
- package/.claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
- package/.claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +571 -0
- package/.claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +48 -0
- package/.claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
- package/.claude/skills/markdown-novel-viewer/scripts/server.cjs +411 -0
- package/.claude/skills/markdown-novel-viewer/scripts/tests/server.test.cjs +283 -0
- package/.claude/skills/markdown-novel-viewer/tests/dashboard-assets.test.cjs +340 -0
- package/.claude/skills/markdown-novel-viewer/tests/dashboard-renderer.test.cjs +404 -0
- package/.claude/skills/markdown-novel-viewer/tests/http-server.test.cjs +271 -0
- package/.claude/skills/markdown-novel-viewer/tests/run-tests.cjs +51 -0
- package/.claude/skills/markdown-novel-viewer/tests/test-framework.cjs +154 -0
- package/.claude/skills/markdown-novel-viewer/tests/verify-xss.cjs +90 -0
- package/.claude/skills/mcp-builder/LICENSE.txt +202 -0
- package/.claude/skills/mcp-builder/SKILL.md +328 -0
- package/.claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/.claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
- package/.claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
- package/.claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
- package/.claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/.claude/skills/mcp-builder/scripts/evaluation.py +381 -0
- package/.claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/.claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/.claude/skills/mcp-management/README.md +219 -0
- package/.claude/skills/mcp-management/SKILL.md +209 -0
- package/.claude/skills/mcp-management/assets/tools.json +3146 -0
- package/.claude/skills/mcp-management/references/configuration.md +114 -0
- package/.claude/skills/mcp-management/references/gemini-cli-integration.md +221 -0
- package/.claude/skills/mcp-management/references/mcp-protocol.md +116 -0
- package/.claude/skills/mcp-management/scripts/.env.example +10 -0
- package/.claude/skills/mcp-management/scripts/cli.ts +195 -0
- package/.claude/skills/mcp-management/scripts/mcp-client.ts +230 -0
- package/.claude/skills/mcp-management/scripts/package.json +20 -0
- package/.claude/skills/mcp-management/scripts/tsconfig.json +15 -0
- package/.claude/skills/media-processing/SKILL.md +91 -0
- package/.claude/skills/media-processing/references/common-workflows.md +132 -0
- package/.claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
- package/.claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
- package/.claude/skills/media-processing/references/ffmpeg-streaming.md +403 -0
- package/.claude/skills/media-processing/references/format-compatibility.md +375 -0
- package/.claude/skills/media-processing/references/imagemagick-batch.md +612 -0
- package/.claude/skills/media-processing/references/imagemagick-editing.md +623 -0
- package/.claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
- package/.claude/skills/media-processing/references/troubleshooting.md +109 -0
- package/.claude/skills/media-processing/scripts/README.md +111 -0
- package/.claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
- package/.claude/skills/media-processing/scripts/batch_resize.py +342 -0
- package/.claude/skills/media-processing/scripts/media_convert.py +311 -0
- package/.claude/skills/media-processing/scripts/remove-background.sh +96 -0
- package/.claude/skills/media-processing/scripts/remove-bg-node.js +158 -0
- package/.claude/skills/media-processing/scripts/requirements.txt +24 -0
- package/.claude/skills/media-processing/scripts/tests/.coverage +0 -0
- package/.claude/skills/media-processing/scripts/tests/requirements.txt +2 -0
- package/.claude/skills/media-processing/scripts/tests/test_batch_resize.py +372 -0
- package/.claude/skills/media-processing/scripts/tests/test_media_convert.py +259 -0
- package/.claude/skills/media-processing/scripts/tests/test_video_optimize.py +397 -0
- package/.claude/skills/media-processing/scripts/video_optimize.py +414 -0
- package/.claude/skills/mermaidjs-v11/SKILL.md +115 -0
- package/.claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
- package/.claude/skills/mermaidjs-v11/references/configuration.md +232 -0
- package/.claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
- package/.claude/skills/mermaidjs-v11/references/examples.md +344 -0
- package/.claude/skills/mermaidjs-v11/references/integration.md +310 -0
- package/.claude/skills/mintlify/SKILL.md +120 -0
- package/.claude/skills/mintlify/references/ai-features-and-integrations-reference.md +756 -0
- package/.claude/skills/mintlify/references/api-documentation-components-reference.md +873 -0
- package/.claude/skills/mintlify/references/deployment-and-continuous-integration-reference.md +674 -0
- package/.claude/skills/mintlify/references/docs-json-configuration-reference.md +724 -0
- package/.claude/skills/mintlify/references/mdx-components-reference.md +551 -0
- package/.claude/skills/mintlify/references/navigation-structure-and-organization-reference.md +775 -0
- package/.claude/skills/mobile-development/SKILL.md +212 -0
- package/.claude/skills/mobile-development/references/mobile-android.md +604 -0
- package/.claude/skills/mobile-development/references/mobile-best-practices.md +545 -0
- package/.claude/skills/mobile-development/references/mobile-debugging.md +1089 -0
- package/.claude/skills/mobile-development/references/mobile-frameworks.md +465 -0
- package/.claude/skills/mobile-development/references/mobile-ios.md +496 -0
- package/.claude/skills/mobile-development/references/mobile-mindset.md +544 -0
- package/.claude/skills/payment-integration/README.md +217 -0
- package/.claude/skills/payment-integration/SKILL.md +102 -0
- package/.claude/skills/payment-integration/references/creem/api.md +139 -0
- package/.claude/skills/payment-integration/references/creem/checkouts.md +99 -0
- package/.claude/skills/payment-integration/references/creem/licensing.md +136 -0
- package/.claude/skills/payment-integration/references/creem/overview.md +65 -0
- package/.claude/skills/payment-integration/references/creem/sdk.md +161 -0
- package/.claude/skills/payment-integration/references/creem/subscriptions.md +129 -0
- package/.claude/skills/payment-integration/references/creem/webhooks.md +120 -0
- package/.claude/skills/payment-integration/references/implementation-workflows.md +43 -0
- package/.claude/skills/payment-integration/references/multi-provider-order-management-patterns.md +821 -0
- package/.claude/skills/payment-integration/references/paddle/api.md +116 -0
- package/.claude/skills/payment-integration/references/paddle/best-practices.md +130 -0
- package/.claude/skills/payment-integration/references/paddle/overview.md +57 -0
- package/.claude/skills/payment-integration/references/paddle/paddle-js.md +106 -0
- package/.claude/skills/payment-integration/references/paddle/sdk.md +131 -0
- package/.claude/skills/payment-integration/references/paddle/subscriptions.md +118 -0
- package/.claude/skills/payment-integration/references/paddle/webhooks.md +112 -0
- package/.claude/skills/payment-integration/references/polar/benefits.md +396 -0
- package/.claude/skills/payment-integration/references/polar/best-practices.md +902 -0
- package/.claude/skills/payment-integration/references/polar/checkouts.md +266 -0
- package/.claude/skills/payment-integration/references/polar/overview.md +184 -0
- package/.claude/skills/payment-integration/references/polar/products.md +244 -0
- package/.claude/skills/payment-integration/references/polar/sdk.md +436 -0
- package/.claude/skills/payment-integration/references/polar/subscriptions.md +340 -0
- package/.claude/skills/payment-integration/references/polar/webhooks.md +405 -0
- package/.claude/skills/payment-integration/references/sepay/api.md +140 -0
- package/.claude/skills/payment-integration/references/sepay/best-practices.md +939 -0
- package/.claude/skills/payment-integration/references/sepay/overview.md +138 -0
- package/.claude/skills/payment-integration/references/sepay/qr-codes.md +228 -0
- package/.claude/skills/payment-integration/references/sepay/sdk.md +213 -0
- package/.claude/skills/payment-integration/references/sepay/webhooks.md +208 -0
- package/.claude/skills/payment-integration/references/stripe/stripe-best-practices.md +32 -0
- package/.claude/skills/payment-integration/references/stripe/stripe-cli.md +148 -0
- package/.claude/skills/payment-integration/references/stripe/stripe-js.md +116 -0
- package/.claude/skills/payment-integration/references/stripe/stripe-sdks.md +84 -0
- package/.claude/skills/payment-integration/references/stripe/stripe-upgrade.md +175 -0
- package/.claude/skills/payment-integration/scripts/.env.example +20 -0
- package/.claude/skills/payment-integration/scripts/checkout-helper.js +244 -0
- package/.claude/skills/payment-integration/scripts/package.json +17 -0
- package/.claude/skills/payment-integration/scripts/polar-webhook-verify.js +202 -0
- package/.claude/skills/payment-integration/scripts/sepay-webhook-verify.js +193 -0
- package/.claude/skills/payment-integration/scripts/test-scripts.js +237 -0
- package/.claude/skills/planning/SKILL.md +132 -0
- package/.claude/skills/planning/references/codebase-understanding.md +62 -0
- package/.claude/skills/planning/references/output-standards.md +141 -0
- package/.claude/skills/planning/references/plan-organization.md +160 -0
- package/.claude/skills/planning/references/research-phase.md +49 -0
- package/.claude/skills/planning/references/solution-design.md +63 -0
- package/.claude/skills/plans-kanban/SKILL.md +166 -0
- package/.claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
- package/.claude/skills/plans-kanban/assets/dashboard.css +1594 -0
- package/.claude/skills/plans-kanban/assets/dashboard.js +596 -0
- package/.claude/skills/plans-kanban/assets/favicon.png +0 -0
- package/.claude/skills/plans-kanban/package.json +13 -0
- package/.claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +884 -0
- package/.claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
- package/.claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
- package/.claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +175 -0
- package/.claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +272 -0
- package/.claude/skills/plans-kanban/scripts/lib/port-finder.cjs +48 -0
- package/.claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
- package/.claude/skills/plans-kanban/scripts/server.cjs +260 -0
- package/.claude/skills/problem-solving/SKILL.md +96 -0
- package/.claude/skills/problem-solving/references/attribution.md +69 -0
- package/.claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
- package/.claude/skills/problem-solving/references/inversion-exercise.md +91 -0
- package/.claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
- package/.claude/skills/problem-solving/references/scale-game.md +95 -0
- package/.claude/skills/problem-solving/references/simplification-cascades.md +80 -0
- package/.claude/skills/problem-solving/references/when-stuck.md +72 -0
- package/.claude/skills/react-best-practices/AGENTS.md +2249 -0
- package/.claude/skills/react-best-practices/README.md +123 -0
- package/.claude/skills/react-best-practices/SKILL.md +121 -0
- package/.claude/skills/react-best-practices/metadata.json +15 -0
- package/.claude/skills/react-best-practices/rules/_sections.md +46 -0
- package/.claude/skills/react-best-practices/rules/_template.md +28 -0
- package/.claude/skills/react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/.claude/skills/react-best-practices/rules/advanced-use-latest.md +49 -0
- package/.claude/skills/react-best-practices/rules/async-api-routes.md +38 -0
- package/.claude/skills/react-best-practices/rules/async-defer-await.md +80 -0
- package/.claude/skills/react-best-practices/rules/async-dependencies.md +36 -0
- package/.claude/skills/react-best-practices/rules/async-parallel.md +28 -0
- package/.claude/skills/react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/.claude/skills/react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/.claude/skills/react-best-practices/rules/bundle-conditional.md +31 -0
- package/.claude/skills/react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/.claude/skills/react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/.claude/skills/react-best-practices/rules/bundle-preload.md +50 -0
- package/.claude/skills/react-best-practices/rules/client-event-listeners.md +74 -0
- package/.claude/skills/react-best-practices/rules/client-swr-dedup.md +56 -0
- package/.claude/skills/react-best-practices/rules/js-batch-dom-css.md +82 -0
- package/.claude/skills/react-best-practices/rules/js-cache-function-results.md +80 -0
- package/.claude/skills/react-best-practices/rules/js-cache-property-access.md +28 -0
- package/.claude/skills/react-best-practices/rules/js-cache-storage.md +70 -0
- package/.claude/skills/react-best-practices/rules/js-combine-iterations.md +32 -0
- package/.claude/skills/react-best-practices/rules/js-early-exit.md +50 -0
- package/.claude/skills/react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/.claude/skills/react-best-practices/rules/js-index-maps.md +37 -0
- package/.claude/skills/react-best-practices/rules/js-length-check-first.md +49 -0
- package/.claude/skills/react-best-practices/rules/js-min-max-loop.md +82 -0
- package/.claude/skills/react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/.claude/skills/react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/.claude/skills/react-best-practices/rules/rendering-activity.md +26 -0
- package/.claude/skills/react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/.claude/skills/react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/.claude/skills/react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/.claude/skills/react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/.claude/skills/react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/.claude/skills/react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/.claude/skills/react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/.claude/skills/react-best-practices/rules/rerender-dependencies.md +45 -0
- package/.claude/skills/react-best-practices/rules/rerender-derived-state.md +29 -0
- package/.claude/skills/react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/.claude/skills/react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/.claude/skills/react-best-practices/rules/rerender-memo.md +44 -0
- package/.claude/skills/react-best-practices/rules/rerender-transitions.md +40 -0
- package/.claude/skills/react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/.claude/skills/react-best-practices/rules/server-cache-lru.md +41 -0
- package/.claude/skills/react-best-practices/rules/server-cache-react.md +26 -0
- package/.claude/skills/react-best-practices/rules/server-parallel-fetching.md +79 -0
- package/.claude/skills/react-best-practices/rules/server-serialization.md +38 -0
- package/.claude/skills/remotion/SKILL.md +43 -0
- package/.claude/skills/remotion/rules/3d.md +86 -0
- package/.claude/skills/remotion/rules/animations.md +29 -0
- package/.claude/skills/remotion/rules/assets/charts-bar-chart.tsx +173 -0
- package/.claude/skills/remotion/rules/assets/text-animations-typewriter.tsx +100 -0
- package/.claude/skills/remotion/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/.claude/skills/remotion/rules/assets.md +78 -0
- package/.claude/skills/remotion/rules/audio.md +172 -0
- package/.claude/skills/remotion/rules/calculate-metadata.md +104 -0
- package/.claude/skills/remotion/rules/can-decode.md +75 -0
- package/.claude/skills/remotion/rules/charts.md +58 -0
- package/.claude/skills/remotion/rules/compositions.md +146 -0
- package/.claude/skills/remotion/rules/display-captions.md +126 -0
- package/.claude/skills/remotion/rules/extract-frames.md +229 -0
- package/.claude/skills/remotion/rules/fonts.md +152 -0
- package/.claude/skills/remotion/rules/get-audio-duration.md +58 -0
- package/.claude/skills/remotion/rules/get-video-dimensions.md +68 -0
- package/.claude/skills/remotion/rules/get-video-duration.md +58 -0
- package/.claude/skills/remotion/rules/gifs.md +138 -0
- package/.claude/skills/remotion/rules/images.md +130 -0
- package/.claude/skills/remotion/rules/import-srt-captions.md +67 -0
- package/.claude/skills/remotion/rules/lottie.md +68 -0
- package/.claude/skills/remotion/rules/measuring-dom-nodes.md +35 -0
- package/.claude/skills/remotion/rules/measuring-text.md +143 -0
- package/.claude/skills/remotion/rules/sequencing.md +106 -0
- package/.claude/skills/remotion/rules/tailwind.md +11 -0
- package/.claude/skills/remotion/rules/text-animations.md +20 -0
- package/.claude/skills/remotion/rules/timing.md +179 -0
- package/.claude/skills/remotion/rules/transcribe-captions.md +19 -0
- package/.claude/skills/remotion/rules/transitions.md +122 -0
- package/.claude/skills/remotion/rules/trimming.md +53 -0
- package/.claude/skills/remotion/rules/videos.md +171 -0
- package/.claude/skills/repomix/SKILL.md +247 -0
- package/.claude/skills/repomix/references/configuration.md +211 -0
- package/.claude/skills/repomix/references/usage-patterns.md +232 -0
- package/.claude/skills/repomix/scripts/.coverage +0 -0
- package/.claude/skills/repomix/scripts/README.md +179 -0
- package/.claude/skills/repomix/scripts/repomix_batch.py +455 -0
- package/.claude/skills/repomix/scripts/repos.example.json +15 -0
- package/.claude/skills/repomix/scripts/requirements.txt +15 -0
- package/.claude/skills/repomix/scripts/tests/test_repomix_batch.py +531 -0
- package/.claude/skills/research/SKILL.md +170 -0
- package/.claude/skills/scout/SKILL.md +79 -0
- package/.claude/skills/scout/references/external-scouting.md +140 -0
- package/.claude/skills/scout/references/internal-scouting.md +119 -0
- package/.claude/skills/sequential-thinking/.env.example +8 -0
- package/.claude/skills/sequential-thinking/README.md +183 -0
- package/.claude/skills/sequential-thinking/SKILL.md +94 -0
- package/.claude/skills/sequential-thinking/package.json +31 -0
- package/.claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
- package/.claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
- package/.claude/skills/sequential-thinking/references/core-patterns.md +95 -0
- package/.claude/skills/sequential-thinking/references/examples-api.md +88 -0
- package/.claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
- package/.claude/skills/sequential-thinking/references/examples-debug.md +90 -0
- package/.claude/skills/sequential-thinking/scripts/format-thought.js +159 -0
- package/.claude/skills/sequential-thinking/scripts/process-thought.js +236 -0
- package/.claude/skills/sequential-thinking/tests/format-thought.test.js +133 -0
- package/.claude/skills/sequential-thinking/tests/process-thought.test.js +215 -0
- package/.claude/skills/shader/SKILL.md +112 -0
- package/.claude/skills/shader/references/glsl-cellular-voronoi-worley-noise-patterns.md +142 -0
- package/.claude/skills/shader/references/glsl-colors-rgb-hsb-gradients-mixing-color-spaces.md +143 -0
- package/.claude/skills/shader/references/glsl-fbm-fractional-brownian-motion-turbulence-octaves.md +146 -0
- package/.claude/skills/shader/references/glsl-fundamentals-data-types-vectors-precision-coordinates.md +104 -0
- package/.claude/skills/shader/references/glsl-noise-random-perlin-simplex-cellular-voronoi.md +115 -0
- package/.claude/skills/shader/references/glsl-pattern-symmetry-truchet-domain-warping.md +134 -0
- package/.claude/skills/shader/references/glsl-patterns-tiling-fract-matrices-transformations.md +133 -0
- package/.claude/skills/shader/references/glsl-procedural-textures-clouds-marble-wood-terrain.md +144 -0
- package/.claude/skills/shader/references/glsl-shader-builtin-functions-complete-api-reference.md +112 -0
- package/.claude/skills/shader/references/glsl-shapes-polygon-star-polar-sdf-combinations.md +124 -0
- package/.claude/skills/shader/references/glsl-shapes-sdf-circles-rectangles-polar-distance-fields.md +106 -0
- package/.claude/skills/shader/references/glsl-shaping-functions-step-smoothstep-curves-interpolation.md +141 -0
- package/.claude/skills/shopify/README.md +66 -0
- package/.claude/skills/shopify/SKILL.md +319 -0
- package/.claude/skills/shopify/references/app-development.md +470 -0
- package/.claude/skills/shopify/references/extensions.md +493 -0
- package/.claude/skills/shopify/references/themes.md +498 -0
- package/.claude/skills/shopify/scripts/.coverage +0 -0
- package/.claude/skills/shopify/scripts/requirements.txt +19 -0
- package/.claude/skills/shopify/scripts/shopify_init.py +423 -0
- package/.claude/skills/shopify/scripts/tests/.coverage +0 -0
- package/.claude/skills/shopify/scripts/tests/test_shopify_init.py +385 -0
- package/.claude/skills/skill-creator/LICENSE.txt +202 -0
- package/.claude/skills/skill-creator/SKILL.md +309 -0
- package/.claude/skills/skill-creator/references/metadata-quality-criteria.md +76 -0
- package/.claude/skills/skill-creator/references/plugin-marketplace-hosting.md +101 -0
- package/.claude/skills/skill-creator/references/plugin-marketplace-overview.md +55 -0
- package/.claude/skills/skill-creator/references/plugin-marketplace-schema.md +88 -0
- package/.claude/skills/skill-creator/references/plugin-marketplace-sources.md +103 -0
- package/.claude/skills/skill-creator/references/plugin-marketplace-troubleshooting.md +80 -0
- package/.claude/skills/skill-creator/references/script-quality-criteria.md +106 -0
- package/.claude/skills/skill-creator/references/structure-organization-criteria.md +114 -0
- package/.claude/skills/skill-creator/references/token-efficiency-criteria.md +74 -0
- package/.claude/skills/skill-creator/references/validation-checklist.md +83 -0
- package/.claude/skills/skill-creator/scripts/encoding_utils.py +36 -0
- package/.claude/skills/skill-creator/scripts/init_skill.py +308 -0
- package/.claude/skills/skill-creator/scripts/package_skill.py +115 -0
- package/.claude/skills/skill-creator/scripts/quick_validate.py +69 -0
- package/.claude/skills/template-skill/SKILL.md +6 -0
- package/.claude/skills/threejs/SKILL.md +141 -0
- package/.claude/skills/threejs/data/api-reference.csv +61 -0
- package/.claude/skills/threejs/data/categories.csv +14 -0
- package/.claude/skills/threejs/data/examples-all.csv +557 -0
- package/.claude/skills/threejs/data/use-cases.csv +21 -0
- package/.claude/skills/threejs/references/00-fundamentals.md +487 -0
- package/.claude/skills/threejs/references/01-getting-started.md +177 -0
- package/.claude/skills/threejs/references/02-loaders.md +169 -0
- package/.claude/skills/threejs/references/03-textures.md +170 -0
- package/.claude/skills/threejs/references/04-cameras.md +195 -0
- package/.claude/skills/threejs/references/05-lights.md +183 -0
- package/.claude/skills/threejs/references/06-animations.md +214 -0
- package/.claude/skills/threejs/references/07-math.md +260 -0
- package/.claude/skills/threejs/references/08-interaction.md +267 -0
- package/.claude/skills/threejs/references/09-postprocessing.md +240 -0
- package/.claude/skills/threejs/references/10-controls.md +259 -0
- package/.claude/skills/threejs/references/11-materials-advanced.md +270 -0
- package/.claude/skills/threejs/references/11-materials.md +519 -0
- package/.claude/skills/threejs/references/12-performance.md +269 -0
- package/.claude/skills/threejs/references/13-node-materials.md +298 -0
- package/.claude/skills/threejs/references/14-physics-vr.md +304 -0
- package/.claude/skills/threejs/references/15-specialized-loaders.md +333 -0
- package/.claude/skills/threejs/references/16-webgpu.md +302 -0
- package/.claude/skills/threejs/references/17-shader.md +641 -0
- package/.claude/skills/threejs/references/18-geometry.md +547 -0
- package/.claude/skills/threejs/scripts/core.py +236 -0
- package/.claude/skills/threejs/scripts/extract_examples.py +688 -0
- package/.claude/skills/threejs/scripts/generate_csv_from_json.py +135 -0
- package/.claude/skills/threejs/scripts/search.py +77 -0
- package/.claude/skills/ui-styling/LICENSE.txt +202 -0
- package/.claude/skills/ui-styling/SKILL.md +321 -0
- package/.claude/skills/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/.claude/skills/ui-styling/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Jura-Light.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Jura-Medium.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Jura-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Lora-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Lora-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Lora-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Lora-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/.claude/skills/ui-styling/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/.claude/skills/ui-styling/references/canvas-design-system.md +320 -0
- package/.claude/skills/ui-styling/references/shadcn-accessibility.md +471 -0
- package/.claude/skills/ui-styling/references/shadcn-components.md +424 -0
- package/.claude/skills/ui-styling/references/shadcn-theming.md +373 -0
- package/.claude/skills/ui-styling/references/tailwind-customization.md +483 -0
- package/.claude/skills/ui-styling/references/tailwind-responsive.md +382 -0
- package/.claude/skills/ui-styling/references/tailwind-utilities.md +455 -0
- package/.claude/skills/ui-styling/scripts/.coverage +0 -0
- package/.claude/skills/ui-styling/scripts/requirements.txt +17 -0
- package/.claude/skills/ui-styling/scripts/shadcn_add.py +292 -0
- package/.claude/skills/ui-styling/scripts/tailwind_config_gen.py +456 -0
- package/.claude/skills/ui-styling/scripts/tests/coverage-ui.json +1 -0
- package/.claude/skills/ui-styling/scripts/tests/requirements.txt +3 -0
- package/.claude/skills/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
- package/.claude/skills/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
- package/.claude/skills/ui-ux-pro-max/SKILL.md +351 -0
- package/.claude/skills/ui-ux-pro-max/data/charts.csv +26 -0
- package/.claude/skills/ui-ux-pro-max/data/colors.csv +97 -0
- package/.claude/skills/ui-ux-pro-max/data/icons.csv +101 -0
- package/.claude/skills/ui-ux-pro-max/data/landing.csv +31 -0
- package/.claude/skills/ui-ux-pro-max/data/products.csv +97 -0
- package/.claude/skills/ui-ux-pro-max/data/prompts.csv +24 -0
- package/.claude/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/.claude/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/.claude/skills/ui-ux-pro-max/data/styles.csv +59 -0
- package/.claude/skills/ui-ux-pro-max/data/typography.csv +58 -0
- package/.claude/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/.claude/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/.claude/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/.claude/skills/ui-ux-pro-max/scripts/core.py +257 -0
- package/.claude/skills/ui-ux-pro-max/scripts/design_system.py +494 -0
- package/.claude/skills/ui-ux-pro-max/scripts/search.py +84 -0
- package/.claude/skills/web-design-guidelines/SKILL.md +36 -0
- package/.claude/skills/web-frameworks/SKILL.md +324 -0
- package/.claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
- package/.claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
- package/.claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
- package/.claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
- package/.claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
- package/.claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
- package/.claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
- package/.claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
- package/.claude/skills/web-frameworks/scripts/.coverage +0 -0
- package/.claude/skills/web-frameworks/scripts/__init__.py +0 -0
- package/.claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
- package/.claude/skills/web-frameworks/scripts/requirements.txt +16 -0
- package/.claude/skills/web-frameworks/scripts/tests/coverage-web.json +1 -0
- package/.claude/skills/web-frameworks/scripts/tests/requirements.txt +3 -0
- package/.claude/skills/web-frameworks/scripts/tests/test_nextjs_init.py +319 -0
- package/.claude/skills/web-frameworks/scripts/tests/test_turborepo_migrate.py +374 -0
- package/.claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
- package/.claude/skills/web-testing/SKILL.md +96 -0
- package/.claude/skills/web-testing/references/accessibility-testing.md +84 -0
- package/.claude/skills/web-testing/references/api-testing.md +78 -0
- package/.claude/skills/web-testing/references/ci-cd-testing-workflows.md +121 -0
- package/.claude/skills/web-testing/references/component-testing.md +94 -0
- package/.claude/skills/web-testing/references/contract-testing.md +146 -0
- package/.claude/skills/web-testing/references/cross-browser-checklist.md +72 -0
- package/.claude/skills/web-testing/references/database-testing.md +139 -0
- package/.claude/skills/web-testing/references/e2e-testing-playwright.md +119 -0
- package/.claude/skills/web-testing/references/functional-testing-checklist.md +88 -0
- package/.claude/skills/web-testing/references/interactive-testing-patterns.md +89 -0
- package/.claude/skills/web-testing/references/load-testing-k6.md +93 -0
- package/.claude/skills/web-testing/references/mobile-gesture-testing.md +85 -0
- package/.claude/skills/web-testing/references/performance-core-web-vitals.md +124 -0
- package/.claude/skills/web-testing/references/playwright-component-testing.md +115 -0
- package/.claude/skills/web-testing/references/pre-release-checklist.md +75 -0
- package/.claude/skills/web-testing/references/security-checklists.md +81 -0
- package/.claude/skills/web-testing/references/security-testing-overview.md +92 -0
- package/.claude/skills/web-testing/references/shadow-dom-testing.md +70 -0
- package/.claude/skills/web-testing/references/test-data-management.md +131 -0
- package/.claude/skills/web-testing/references/test-flakiness-mitigation.md +86 -0
- package/.claude/skills/web-testing/references/testing-pyramid-strategy.md +76 -0
- package/.claude/skills/web-testing/references/unit-integration-testing.md +138 -0
- package/.claude/skills/web-testing/references/visual-regression.md +92 -0
- package/.claude/skills/web-testing/references/vulnerability-payloads.md +93 -0
- package/.claude/skills/web-testing/scripts/analyze-test-results.js +280 -0
- package/.claude/skills/web-testing/scripts/init-playwright.js +233 -0
- package/.claude/statusline.cjs +571 -0
- package/.claude/statusline.ps1 +307 -0
- package/.claude/statusline.sh +237 -0
- package/.commitlintrc.json +27 -0
- package/.coverage +0 -0
- package/.env.example +26 -0
- package/.github/workflows/branch-protection.yml +33 -0
- package/.github/workflows/release-beta.yml +63 -0
- package/.github/workflows/release.yml +63 -0
- package/.github/workflows/sync-dev-after-release.yml +32 -0
- package/.github/workflows/sync-main-to-dev.yml +35 -0
- package/.husky/commit-msg +12 -0
- package/.releaserc.beta-config.json +136 -0
- package/.releaserc.cjs +183 -0
- package/.releaserc.production.json +132 -0
- package/.repomixignore +22 -0
- package/AGENTS.md +61 -0
- package/CHANGELOG.md +2928 -0
- package/CLAUDE.md +88 -0
- package/GEMINI.md +75 -0
- package/LICENSE +18 -0
- package/README-MIRROR.md +174 -0
- package/README.md +602 -0
- package/TEST-MANIFEST.md +220 -0
- package/docs/assets/demo-landing-page-2.png +0 -0
- package/docs/assets/demo-landing-page-3.png +0 -0
- package/docs/assets/demo-landing-page.jpg +0 -0
- package/docs/assets/generated_generated_0.png +0 -0
- package/docs/assets/image-generation-test-report.md +223 -0
- package/docs/assets/imagen-correction-summary.md +161 -0
- package/docs/assets/imagen4_generated_1763658214_0.png +0 -0
- package/docs/assets/imagen4_generated_1763658238_0.png +0 -0
- package/docs/assets/imagen4_generated_1763658255_0.png +0 -0
- package/docs/assets/model-support-status.md +338 -0
- package/docs/assets/multimodal-generation-comprehensive-report.md +369 -0
- package/docs/assets/veo-video-generation-test-report.md +139 -0
- package/docs/assets/veo_generated_1763658722.mp4 +0 -0
- package/docs/assets/veo_generated_1763659088.mp4 +0 -0
- package/docs/code-standards.md +946 -0
- package/docs/codebase-summary.md +365 -0
- package/docs/infographics/cpg-marketing-2026-landscape.png +0 -0
- package/docs/infographics/cpg-marketing-2026-vietnam-creative.png +0 -0
- package/docs/infographics/cpg-marketing-2026-vietnam-search.png +0 -0
- package/docs/infographics/cpg-marketing-2026-vietnam-wild.png +0 -0
- package/docs/journals/2025-11-11-planning-skill-never-started.md +86 -0
- package/docs/journals/2025-11-11-windows-statusline-complete.md +71 -0
- package/docs/journals/2025-11-14-aesthetic-skill-ambitious-planning.md +107 -0
- package/docs/journals/2025-11-14-docs-commands-optimization-stuck.md +137 -0
- package/docs/journals/2510181655-massive-skills-integration-technical-debt.md +75 -0
- package/docs/journals/2510181700-obsession-with-conciseness.md +89 -0
- package/docs/journals/2510181710-git-workflow-evolution.md +108 -0
- package/docs/journals/2510181720-release-automation-reality-check.md +134 -0
- package/docs/journals/251106135700-wrong-about-agent-skills.md +184 -0
- package/docs/journals/251212-ck-name-pattern-refactor.md +70 -0
- package/docs/journals/INDEX.md +81 -0
- package/docs/project-overview-pdr.md +585 -0
- package/docs/project-roadmap.md +534 -0
- package/docs/referecences/claude-cli-usage-limits-api.md +522 -0
- package/docs/stlck-installation-guide.md +157 -0
- package/docs/system-architecture.md +1029 -0
- package/guide/COMMANDS.md +403 -0
- package/guide/COMMANDS.yaml +403 -0
- package/guide/ENVIRONMENT_RESOLVER.md +255 -0
- package/guide/SKILLS.md +234 -0
- package/guide/SKILLS.yaml +386 -0
- package/install-stlck.sh +163 -0
- package/package.json +18 -0
- package/plans/templates/bug-fix-template.md +69 -0
- package/plans/templates/feature-implementation-template.md +84 -0
- package/plans/templates/refactor-template.md +82 -0
- package/plans/templates/template-usage-guide.md +58 -0
- package/scripts/commands_data.yaml +363 -0
- package/scripts/generate-opencode.py +914 -0
- package/scripts/generate-release-manifest.cjs +201 -0
- package/scripts/generate_catalogs.py +168 -0
- package/scripts/prepare-release-assets.cjs +158 -0
- package/scripts/send-discord-release.cjs +204 -0
- package/scripts/skills_data.yaml +370 -0
- package/scripts/win_compat.py +57 -0
- package/shader.zip +0 -0
- package/tests/test-scout-block.ps1 +60 -0
- package/tests/test-scout-block.sh +117 -0
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
# SQLite Rules
|
|
2
|
+
|
|
3
|
+
Guidelines for designing schemas specific to SQLite.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Data Types
|
|
8
|
+
|
|
9
|
+
SQLite has **dynamic typing**, with only 5 storage classes:
|
|
10
|
+
|
|
11
|
+
| Storage Class | Use case | Notes |
|
|
12
|
+
|---------------|----------|-------|
|
|
13
|
+
| `INTEGER` | PK, FK, counts, booleans | |
|
|
14
|
+
| `REAL` | Floats, decimals | |
|
|
15
|
+
| `TEXT` | Strings, dates, JSON, enums | |
|
|
16
|
+
| `BLOB` | Binary data | |
|
|
17
|
+
| `NULL` | Null values | |
|
|
18
|
+
|
|
19
|
+
### Type affinity
|
|
20
|
+
SQLite does not strictly enforce types. Type declaration is just a "hint":
|
|
21
|
+
```sql
|
|
22
|
+
-- All of these will be stored
|
|
23
|
+
CREATE TABLE test (price REAL);
|
|
24
|
+
INSERT INTO test VALUES (100); -- Stored as INTEGER
|
|
25
|
+
INSERT INTO test VALUES (99.99); -- Stored as REAL
|
|
26
|
+
INSERT INTO test VALUES ('free'); -- Stored as TEXT (!)
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### Date/Time
|
|
30
|
+
SQLite **does not have** DATE/TIME type. Store as TEXT with ISO format:
|
|
31
|
+
```sql
|
|
32
|
+
created_at TEXT DEFAULT (datetime('now'))
|
|
33
|
+
-- Format: YYYY-MM-DD HH:MM:SS
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
---
|
|
37
|
+
|
|
38
|
+
## Metadata Tables (REQUIRED)
|
|
39
|
+
|
|
40
|
+
SQLite **does not support comments** on tables and columns. Need to create metadata tables:
|
|
41
|
+
|
|
42
|
+
### Create metadata tables
|
|
43
|
+
|
|
44
|
+
```sql
|
|
45
|
+
CREATE TABLE IF NOT EXISTS metadata_tables (
|
|
46
|
+
table_name TEXT PRIMARY KEY,
|
|
47
|
+
description TEXT NOT NULL,
|
|
48
|
+
created_at TEXT DEFAULT (datetime('now')),
|
|
49
|
+
updated_at TEXT DEFAULT (datetime('now'))
|
|
50
|
+
);
|
|
51
|
+
|
|
52
|
+
CREATE TABLE IF NOT EXISTS metadata_columns (
|
|
53
|
+
table_name TEXT NOT NULL,
|
|
54
|
+
column_name TEXT NOT NULL,
|
|
55
|
+
description TEXT NOT NULL,
|
|
56
|
+
data_type TEXT,
|
|
57
|
+
is_nullable INTEGER DEFAULT 1, -- 0=NOT NULL, 1=NULL
|
|
58
|
+
default_value TEXT,
|
|
59
|
+
created_at TEXT DEFAULT (datetime('now')),
|
|
60
|
+
PRIMARY KEY (table_name, column_name),
|
|
61
|
+
FOREIGN KEY (table_name) REFERENCES metadata_tables(table_name) ON DELETE CASCADE
|
|
62
|
+
);
|
|
63
|
+
|
|
64
|
+
CREATE INDEX idx_metadata_columns_table ON metadata_columns(table_name);
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### Insert metadata after creating table
|
|
68
|
+
|
|
69
|
+
```sql
|
|
70
|
+
-- Table metadata
|
|
71
|
+
INSERT INTO metadata_tables (table_name, description)
|
|
72
|
+
VALUES ('orders', 'Table storing customer order information');
|
|
73
|
+
|
|
74
|
+
-- Column metadata
|
|
75
|
+
INSERT INTO metadata_columns (table_name, column_name, description, data_type, is_nullable)
|
|
76
|
+
VALUES
|
|
77
|
+
('orders', 'id', 'Primary key, auto increment', 'INTEGER', 0),
|
|
78
|
+
('orders', 'order_number', 'Unique order code', 'TEXT', 0),
|
|
79
|
+
('orders', 'user_id', 'FK to users.id', 'INTEGER', 0),
|
|
80
|
+
('orders', 'status', 'pending|confirmed|shipped|cancelled', 'TEXT', 0),
|
|
81
|
+
('orders', 'total_amount', 'Total value', 'REAL', 0);
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### Query metadata
|
|
85
|
+
|
|
86
|
+
```sql
|
|
87
|
+
-- View schema with descriptions
|
|
88
|
+
SELECT
|
|
89
|
+
t.table_name,
|
|
90
|
+
t.description AS table_description,
|
|
91
|
+
c.column_name,
|
|
92
|
+
c.description AS column_description,
|
|
93
|
+
c.data_type
|
|
94
|
+
FROM metadata_tables t
|
|
95
|
+
LEFT JOIN metadata_columns c ON t.table_name = c.table_name
|
|
96
|
+
ORDER BY t.table_name, c.column_name;
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
---
|
|
100
|
+
|
|
101
|
+
## Auto Increment
|
|
102
|
+
|
|
103
|
+
```sql
|
|
104
|
+
-- Option 1: INTEGER PRIMARY KEY (recommended)
|
|
105
|
+
-- SQLite auto-increments INTEGER PRIMARY KEY automatically
|
|
106
|
+
CREATE TABLE users (
|
|
107
|
+
id INTEGER PRIMARY KEY,
|
|
108
|
+
name TEXT
|
|
109
|
+
);
|
|
110
|
+
|
|
111
|
+
-- Option 2: AUTOINCREMENT keyword
|
|
112
|
+
-- Ensures deleted IDs are not reused (slower)
|
|
113
|
+
CREATE TABLE users (
|
|
114
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
115
|
+
name TEXT
|
|
116
|
+
);
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
## Foreign Keys
|
|
122
|
+
|
|
123
|
+
**IMPORTANT**: FK is disabled by default in SQLite!
|
|
124
|
+
|
|
125
|
+
```sql
|
|
126
|
+
-- Enable FK for each connection
|
|
127
|
+
PRAGMA foreign_keys = ON;
|
|
128
|
+
|
|
129
|
+
-- Create table with FK
|
|
130
|
+
CREATE TABLE order_items (
|
|
131
|
+
id INTEGER PRIMARY KEY,
|
|
132
|
+
order_id INTEGER NOT NULL,
|
|
133
|
+
product_id INTEGER NOT NULL,
|
|
134
|
+
FOREIGN KEY (order_id) REFERENCES orders(id) ON DELETE CASCADE,
|
|
135
|
+
FOREIGN KEY (product_id) REFERENCES products(id) ON DELETE RESTRICT
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
-- Create index for FK
|
|
139
|
+
CREATE INDEX idx_order_items_order ON order_items(order_id);
|
|
140
|
+
CREATE INDEX idx_order_items_product ON order_items(product_id);
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
---
|
|
144
|
+
|
|
145
|
+
## ENUM substitute
|
|
146
|
+
|
|
147
|
+
SQLite does not have ENUM. Use CHECK constraint:
|
|
148
|
+
|
|
149
|
+
```sql
|
|
150
|
+
CREATE TABLE orders (
|
|
151
|
+
status TEXT NOT NULL DEFAULT 'pending'
|
|
152
|
+
CHECK (status IN ('pending', 'confirmed', 'shipped', 'cancelled'))
|
|
153
|
+
);
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
---
|
|
157
|
+
|
|
158
|
+
## Index Types
|
|
159
|
+
|
|
160
|
+
SQLite only supports B-Tree indexes:
|
|
161
|
+
|
|
162
|
+
```sql
|
|
163
|
+
-- Standard index
|
|
164
|
+
CREATE INDEX idx_orders_status ON orders(status);
|
|
165
|
+
|
|
166
|
+
-- Composite index
|
|
167
|
+
CREATE INDEX idx_orders_user_status ON orders(user_id, status);
|
|
168
|
+
|
|
169
|
+
-- Unique index
|
|
170
|
+
CREATE UNIQUE INDEX idx_orders_number ON orders(order_number);
|
|
171
|
+
|
|
172
|
+
-- Partial index (SQLite 3.8.0+)
|
|
173
|
+
CREATE INDEX idx_orders_active ON orders(user_id)
|
|
174
|
+
WHERE deleted_at IS NULL;
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
---
|
|
178
|
+
|
|
179
|
+
## Limitations
|
|
180
|
+
|
|
181
|
+
| Feature | Status | Workaround |
|
|
182
|
+
|---------|--------|------------|
|
|
183
|
+
| `ALTER COLUMN` | ❌ Not supported | Recreate table |
|
|
184
|
+
| `DROP COLUMN` | ✅ SQLite 3.35+ | Recreate table (older) |
|
|
185
|
+
| Comments | ❌ Not supported | Metadata tables |
|
|
186
|
+
| ENUM | ❌ Not supported | CHECK constraint |
|
|
187
|
+
| Stored procedures | ❌ Not supported | App logic |
|
|
188
|
+
| Concurrent writes | ⚠️ Limited | Single writer |
|
|
189
|
+
|
|
190
|
+
---
|
|
191
|
+
|
|
192
|
+
## Example DDL
|
|
193
|
+
|
|
194
|
+
```sql
|
|
195
|
+
-- Enable foreign keys
|
|
196
|
+
PRAGMA foreign_keys = ON;
|
|
197
|
+
|
|
198
|
+
-- Create table
|
|
199
|
+
CREATE TABLE orders (
|
|
200
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
201
|
+
order_number TEXT NOT NULL,
|
|
202
|
+
user_id INTEGER NOT NULL,
|
|
203
|
+
status TEXT NOT NULL DEFAULT 'pending'
|
|
204
|
+
CHECK (status IN ('pending', 'confirmed', 'shipped', 'cancelled')),
|
|
205
|
+
subtotal REAL NOT NULL DEFAULT 0,
|
|
206
|
+
discount_amount REAL NOT NULL DEFAULT 0,
|
|
207
|
+
total_amount REAL NOT NULL DEFAULT 0,
|
|
208
|
+
created_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
209
|
+
updated_at TEXT NOT NULL DEFAULT (datetime('now')),
|
|
210
|
+
deleted_at TEXT,
|
|
211
|
+
|
|
212
|
+
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE RESTRICT
|
|
213
|
+
);
|
|
214
|
+
|
|
215
|
+
-- Indexes
|
|
216
|
+
CREATE UNIQUE INDEX idx_orders_number ON orders(order_number);
|
|
217
|
+
CREATE INDEX idx_orders_user ON orders(user_id);
|
|
218
|
+
CREATE INDEX idx_orders_status ON orders(status);
|
|
219
|
+
CREATE INDEX idx_orders_updated ON orders(updated_at);
|
|
220
|
+
|
|
221
|
+
-- Metadata
|
|
222
|
+
INSERT INTO metadata_tables (table_name, description)
|
|
223
|
+
VALUES ('orders', 'Table storing order information');
|
|
224
|
+
|
|
225
|
+
INSERT INTO metadata_columns (table_name, column_name, description, data_type, is_nullable)
|
|
226
|
+
VALUES
|
|
227
|
+
('orders', 'id', 'Primary key', 'INTEGER', 0),
|
|
228
|
+
('orders', 'order_number', 'Unique order code', 'TEXT', 0),
|
|
229
|
+
('orders', 'user_id', 'FK to users.id', 'INTEGER', 0),
|
|
230
|
+
('orders', 'status', 'pending|confirmed|shipped|cancelled', 'TEXT', 0),
|
|
231
|
+
('orders', 'total_amount', 'Total payment', 'REAL', 0);
|
|
232
|
+
```
|
|
233
|
+
|
|
234
|
+
---
|
|
235
|
+
|
|
236
|
+
## Checklist
|
|
237
|
+
|
|
238
|
+
- [ ] `PRAGMA foreign_keys = ON` at start of each connection
|
|
239
|
+
- [ ] Metadata tables created
|
|
240
|
+
- [ ] INSERT metadata after each CREATE TABLE
|
|
241
|
+
- [ ] Use `TEXT` for dates (ISO format: YYYY-MM-DD HH:MM:SS)
|
|
242
|
+
- [ ] CHECK constraint instead of ENUM
|
|
243
|
+
- [ ] Index for FK columns
|
|
244
|
+
- [ ] Update metadata when ALTER/DROP table
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
# Transactional (OLTP) Rules
|
|
2
|
+
|
|
3
|
+
> **Note:** Core naming conventions, workflow, and checklist are in `SKILL.md` or `db-design.md` (always loaded).
|
|
4
|
+
|
|
5
|
+
Guidelines for designing schemas for day-to-day business operations.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Normalization Principles
|
|
10
|
+
|
|
11
|
+
### Prefer 3NF (Third Normal Form)
|
|
12
|
+
|
|
13
|
+
- Each table represents one clear entity/relationship
|
|
14
|
+
- No repeating information that can be referenced (use FK)
|
|
15
|
+
- Clear separation:
|
|
16
|
+
- `orders` (header) vs `order_items` (line items)
|
|
17
|
+
- `products` vs `product_variants`, `product_prices`
|
|
18
|
+
|
|
19
|
+
### Foreign Key Constraints
|
|
20
|
+
|
|
21
|
+
Use FK with appropriate ON DELETE / ON UPDATE:
|
|
22
|
+
|
|
23
|
+
```sql
|
|
24
|
+
-- Cascade: delete order → delete order_items
|
|
25
|
+
FOREIGN KEY (order_id) REFERENCES orders(id) ON DELETE CASCADE
|
|
26
|
+
|
|
27
|
+
-- Restrict: cannot delete user if orders exist
|
|
28
|
+
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE RESTRICT
|
|
29
|
+
|
|
30
|
+
-- Set null: delete category → product.category_id = NULL
|
|
31
|
+
FOREIGN KEY (category_id) REFERENCES categories(id) ON DELETE SET NULL
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
---
|
|
35
|
+
|
|
36
|
+
## Indexing Rules
|
|
37
|
+
|
|
38
|
+
### 1. Primary Key
|
|
39
|
+
- Usually `BIGINT` auto-increment or UUID
|
|
40
|
+
- Format: `PRIMARY KEY (id)`
|
|
41
|
+
|
|
42
|
+
### 2. Foreign Key Indexes
|
|
43
|
+
**IMPORTANT**: Create indexes for ALL foreign keys for efficient JOINs:
|
|
44
|
+
```sql
|
|
45
|
+
CREATE INDEX idx_orders_user_id ON orders(user_id);
|
|
46
|
+
CREATE INDEX idx_order_items_order_id ON order_items(order_id);
|
|
47
|
+
CREATE INDEX idx_order_items_product_id ON order_items(product_id);
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
### 3. Frequently Filtered Columns
|
|
51
|
+
Index columns commonly used in WHERE:
|
|
52
|
+
- `status`, `created_at`, `updated_at`
|
|
53
|
+
- Code/reference columns: `order_number`, `sku`
|
|
54
|
+
|
|
55
|
+
### 4. Composite Indexes
|
|
56
|
+
Based on actual query patterns:
|
|
57
|
+
```sql
|
|
58
|
+
-- Query: WHERE user_id = ? AND status = ? ORDER BY created_at DESC
|
|
59
|
+
CREATE INDEX idx_orders_user_status_created ON orders(user_id, status, created_at DESC);
|
|
60
|
+
|
|
61
|
+
-- Query: WHERE store_id = ? AND created_at BETWEEN ...
|
|
62
|
+
CREATE INDEX idx_orders_store_created ON orders(store_id, created_at);
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
**Composite index rules:**
|
|
66
|
+
- Put columns with **high selectivity** (fewer duplicate values) first
|
|
67
|
+
- Avoid duplicate/redundant indexes
|
|
68
|
+
- Index should cover WHERE + ORDER BY of query
|
|
69
|
+
|
|
70
|
+
### 5. Unique Constraints
|
|
71
|
+
```sql
|
|
72
|
+
UNIQUE (order_number)
|
|
73
|
+
UNIQUE (sku)
|
|
74
|
+
UNIQUE (user_id, email) -- compound unique
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
---
|
|
78
|
+
|
|
79
|
+
## Soft Delete Pattern
|
|
80
|
+
|
|
81
|
+
When you need to keep deleted data instead of permanently deleting:
|
|
82
|
+
|
|
83
|
+
```sql
|
|
84
|
+
-- Add deleted_at column
|
|
85
|
+
deleted_at TIMESTAMP NULL
|
|
86
|
+
|
|
87
|
+
-- Partial index for non-deleted records (PostgreSQL)
|
|
88
|
+
CREATE INDEX idx_orders_active ON orders(user_id, status)
|
|
89
|
+
WHERE deleted_at IS NULL;
|
|
90
|
+
|
|
91
|
+
-- Query only active records
|
|
92
|
+
SELECT * FROM orders WHERE deleted_at IS NULL;
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
---
|
|
96
|
+
|
|
97
|
+
## Anti-patterns to Avoid
|
|
98
|
+
|
|
99
|
+
### Missing FK Index
|
|
100
|
+
```sql
|
|
101
|
+
-- ❌ BAD: FK without index → slow JOINs
|
|
102
|
+
FOREIGN KEY (user_id) REFERENCES users(id)
|
|
103
|
+
-- Forgot CREATE INDEX
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
### Over-indexing
|
|
107
|
+
```sql
|
|
108
|
+
-- ❌ BAD: Indexing each column separately
|
|
109
|
+
CREATE INDEX idx_a ON orders(user_id);
|
|
110
|
+
CREATE INDEX idx_b ON orders(status);
|
|
111
|
+
CREATE INDEX idx_c ON orders(created_at);
|
|
112
|
+
|
|
113
|
+
-- ✅ GOOD: Composite index based on query pattern
|
|
114
|
+
CREATE INDEX idx_orders_user_status_created ON orders(user_id, status, created_at DESC);
|
|
115
|
+
```
|
|
116
|
+
|
|
117
|
+
### Using TEXT instead of ENUM
|
|
118
|
+
```sql
|
|
119
|
+
-- ❌ BAD: Cannot validate values
|
|
120
|
+
status TEXT
|
|
121
|
+
|
|
122
|
+
-- ✅ GOOD: Use ENUM or CHECK
|
|
123
|
+
status ENUM('pending', 'confirmed', 'shipped', 'cancelled')
|
|
124
|
+
-- or
|
|
125
|
+
status VARCHAR(32) CHECK (status IN ('pending', 'confirmed', 'shipped'))
|
|
126
|
+
```
|
|
127
|
+
|
|
128
|
+
### Missing Audit Columns
|
|
129
|
+
```sql
|
|
130
|
+
-- ❌ BAD
|
|
131
|
+
CREATE TABLE products (id INT, name VARCHAR(255));
|
|
132
|
+
|
|
133
|
+
-- ✅ GOOD
|
|
134
|
+
CREATE TABLE products (
|
|
135
|
+
id INT,
|
|
136
|
+
name VARCHAR(255),
|
|
137
|
+
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
138
|
+
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
|
|
139
|
+
);
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
---
|
|
143
|
+
|
|
144
|
+
## Example DDL
|
|
145
|
+
|
|
146
|
+
```sql
|
|
147
|
+
CREATE TABLE orders (
|
|
148
|
+
id BIGINT PRIMARY KEY AUTO_INCREMENT,
|
|
149
|
+
order_number VARCHAR(50) NOT NULL,
|
|
150
|
+
user_id BIGINT NOT NULL,
|
|
151
|
+
status VARCHAR(32) NOT NULL DEFAULT 'pending',
|
|
152
|
+
subtotal DECIMAL(18,2) NOT NULL DEFAULT 0,
|
|
153
|
+
discount_amount DECIMAL(18,2) NOT NULL DEFAULT 0,
|
|
154
|
+
total_amount DECIMAL(18,2) NOT NULL DEFAULT 0,
|
|
155
|
+
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
156
|
+
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
|
157
|
+
|
|
158
|
+
UNIQUE (order_number),
|
|
159
|
+
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE RESTRICT
|
|
160
|
+
);
|
|
161
|
+
|
|
162
|
+
CREATE INDEX idx_orders_user_id ON orders(user_id);
|
|
163
|
+
CREATE INDEX idx_orders_status ON orders(status);
|
|
164
|
+
CREATE INDEX idx_orders_user_status_created ON orders(user_id, status, created_at DESC);
|
|
165
|
+
```
|
|
166
|
+
|
|
167
|
+
---
|
|
168
|
+
|
|
169
|
+
## Checklist
|
|
170
|
+
|
|
171
|
+
- [ ] Audit columns: `created_at`, `updated_at`
|
|
172
|
+
- [ ] All FKs have indexes
|
|
173
|
+
- [ ] Unique constraints for business keys (`order_number`, `sku`, `email`)
|
|
174
|
+
- [ ] ENUM or CHECK for status/type columns
|
|
175
|
+
- [ ] Composite index based on main query patterns
|
|
176
|
+
- [ ] Soft delete if needed: `deleted_at` + partial index
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: debug
|
|
3
|
+
description: Debug systematically with root cause analysis before fixes. Use for bugs, test failures, unexpected behavior, performance issues, call stack tracing, multi-layer validation.
|
|
4
|
+
version: 3.1.0
|
|
5
|
+
languages: all
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Debugging
|
|
9
|
+
|
|
10
|
+
Comprehensive debugging framework combining systematic investigation, root cause tracing, defense-in-depth validation, and verification protocols.
|
|
11
|
+
|
|
12
|
+
## Core Principle
|
|
13
|
+
|
|
14
|
+
**NO FIXES WITHOUT ROOT CAUSE INVESTIGATION FIRST**
|
|
15
|
+
|
|
16
|
+
Random fixes waste time and create new bugs. Find the root cause, fix at source, validate at every layer, verify before claiming success.
|
|
17
|
+
|
|
18
|
+
## When to Use
|
|
19
|
+
|
|
20
|
+
**Always use for:** Test failures, bugs, unexpected behavior, performance issues, build failures, integration problems, before claiming work complete
|
|
21
|
+
|
|
22
|
+
**Especially when:** Under time pressure, "quick fix" seems obvious, tried multiple fixes, don't fully understand issue, about to claim success
|
|
23
|
+
|
|
24
|
+
## The Four Techniques
|
|
25
|
+
|
|
26
|
+
### 1. Systematic Debugging (`references/systematic-debugging.md`)
|
|
27
|
+
|
|
28
|
+
Four-phase framework ensuring proper investigation:
|
|
29
|
+
- Phase 1: Root Cause Investigation (read errors, reproduce, check changes, gather evidence)
|
|
30
|
+
- Phase 2: Pattern Analysis (find working examples, compare, identify differences)
|
|
31
|
+
- Phase 3: Hypothesis and Testing (form theory, test minimally, verify)
|
|
32
|
+
- Phase 4: Implementation (create test, fix once, verify)
|
|
33
|
+
|
|
34
|
+
**Key rule:** Complete each phase before proceeding. No fixes without Phase 1.
|
|
35
|
+
|
|
36
|
+
**Load when:** Any bug/issue requiring investigation and fix
|
|
37
|
+
|
|
38
|
+
### 2. Root Cause Tracing (`references/root-cause-tracing.md`)
|
|
39
|
+
|
|
40
|
+
Trace bugs backward through call stack to find original trigger.
|
|
41
|
+
|
|
42
|
+
**Technique:** When error appears deep in execution, trace backward level-by-level until finding source where invalid data originated. Fix at source, not at symptom.
|
|
43
|
+
|
|
44
|
+
**Includes:** `scripts/find-polluter.sh` for bisecting test pollution
|
|
45
|
+
|
|
46
|
+
**Load when:** Error deep in call stack, unclear where invalid data originated
|
|
47
|
+
|
|
48
|
+
### 3. Defense-in-Depth (`references/defense-in-depth.md`)
|
|
49
|
+
|
|
50
|
+
Validate at every layer data passes through. Make bugs impossible.
|
|
51
|
+
|
|
52
|
+
**Four layers:** Entry validation → Business logic → Environment guards → Debug instrumentation
|
|
53
|
+
|
|
54
|
+
**Load when:** After finding root cause, need to add comprehensive validation
|
|
55
|
+
|
|
56
|
+
### 4. Verification (`references/verification.md`)
|
|
57
|
+
|
|
58
|
+
Run verification commands and confirm output before claiming success.
|
|
59
|
+
|
|
60
|
+
**Iron law:** NO COMPLETION CLAIMS WITHOUT FRESH VERIFICATION EVIDENCE
|
|
61
|
+
|
|
62
|
+
Run the command. Read the output. Then claim the result.
|
|
63
|
+
|
|
64
|
+
**Load when:** About to claim work complete, fixed, or passing
|
|
65
|
+
|
|
66
|
+
## Quick Reference
|
|
67
|
+
|
|
68
|
+
```
|
|
69
|
+
Bug → systematic-debugging.md (Phase 1-4)
|
|
70
|
+
Error deep in stack? → root-cause-tracing.md (trace backward)
|
|
71
|
+
Found root cause? → defense-in-depth.md (add layers)
|
|
72
|
+
About to claim success? → verification.md (verify first)
|
|
73
|
+
```
|
|
74
|
+
|
|
75
|
+
## Red Flags
|
|
76
|
+
|
|
77
|
+
Stop and follow process if thinking:
|
|
78
|
+
- "Quick fix for now, investigate later"
|
|
79
|
+
- "Just try changing X and see if it works"
|
|
80
|
+
- "It's probably X, let me fix that"
|
|
81
|
+
- "Should work now" / "Seems fixed"
|
|
82
|
+
- "Tests pass, we're done"
|
|
83
|
+
|
|
84
|
+
**All mean:** Return to systematic process.
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
# Defense-in-Depth Validation
|
|
2
|
+
|
|
3
|
+
Validate at every layer data passes through to make bugs impossible.
|
|
4
|
+
|
|
5
|
+
## Core Principle
|
|
6
|
+
|
|
7
|
+
**Validate at EVERY layer data passes through. Make bug structurally impossible.**
|
|
8
|
+
|
|
9
|
+
When fix bug caused by invalid data, adding validation at one place feels sufficient. But single check can be bypassed by different code paths, refactoring, or mocks.
|
|
10
|
+
|
|
11
|
+
## Why Multiple Layers
|
|
12
|
+
|
|
13
|
+
Single validation: "We fixed bug"
|
|
14
|
+
Multiple layers: "We made bug impossible"
|
|
15
|
+
|
|
16
|
+
Different layers catch different cases:
|
|
17
|
+
- Entry validation catches most bugs
|
|
18
|
+
- Business logic catches edge cases
|
|
19
|
+
- Environment guards prevent context-specific dangers
|
|
20
|
+
- Debug logging helps when other layers fail
|
|
21
|
+
|
|
22
|
+
## The Four Layers
|
|
23
|
+
|
|
24
|
+
### Layer 1: Entry Point Validation
|
|
25
|
+
**Purpose:** Reject obviously invalid input at API boundary
|
|
26
|
+
|
|
27
|
+
```typescript
|
|
28
|
+
function createProject(name: string, workingDirectory: string) {
|
|
29
|
+
if (!workingDirectory || workingDirectory.trim() === '') {
|
|
30
|
+
throw new Error('workingDirectory cannot be empty');
|
|
31
|
+
}
|
|
32
|
+
if (!existsSync(workingDirectory)) {
|
|
33
|
+
throw new Error(`workingDirectory does not exist: ${workingDirectory}`);
|
|
34
|
+
}
|
|
35
|
+
if (!statSync(workingDirectory).isDirectory()) {
|
|
36
|
+
throw new Error(`workingDirectory is not a directory: ${workingDirectory}`);
|
|
37
|
+
}
|
|
38
|
+
// proceed
|
|
39
|
+
}
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
### Layer 2: Business Logic Validation
|
|
43
|
+
**Purpose:** Ensure data makes sense for this operation
|
|
44
|
+
|
|
45
|
+
```typescript
|
|
46
|
+
function initializeWorkspace(projectDir: string, sessionId: string) {
|
|
47
|
+
if (!projectDir) {
|
|
48
|
+
throw new Error('projectDir required for workspace initialization');
|
|
49
|
+
}
|
|
50
|
+
// proceed
|
|
51
|
+
}
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
### Layer 3: Environment Guards
|
|
55
|
+
**Purpose:** Prevent dangerous operations in specific contexts
|
|
56
|
+
|
|
57
|
+
```typescript
|
|
58
|
+
async function gitInit(directory: string) {
|
|
59
|
+
// In tests, refuse git init outside temp directories
|
|
60
|
+
if (process.env.NODE_ENV === 'test') {
|
|
61
|
+
const normalized = normalize(resolve(directory));
|
|
62
|
+
const tmpDir = normalize(resolve(tmpdir()));
|
|
63
|
+
|
|
64
|
+
if (!normalized.startsWith(tmpDir)) {
|
|
65
|
+
throw new Error(
|
|
66
|
+
`Refusing git init outside temp dir during tests: ${directory}`
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
// proceed
|
|
71
|
+
}
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
### Layer 4: Debug Instrumentation
|
|
75
|
+
**Purpose:** Capture context for forensics
|
|
76
|
+
|
|
77
|
+
```typescript
|
|
78
|
+
async function gitInit(directory: string) {
|
|
79
|
+
const stack = new Error().stack;
|
|
80
|
+
logger.debug('About to git init', {
|
|
81
|
+
directory,
|
|
82
|
+
cwd: process.cwd(),
|
|
83
|
+
stack,
|
|
84
|
+
});
|
|
85
|
+
// proceed
|
|
86
|
+
}
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
## Applying the Pattern
|
|
90
|
+
|
|
91
|
+
When find bug:
|
|
92
|
+
|
|
93
|
+
1. **Trace data flow** - Where does bad value originate? Where used?
|
|
94
|
+
2. **Map all checkpoints** - List every point data passes through
|
|
95
|
+
3. **Add validation at each layer** - Entry, business, environment, debug
|
|
96
|
+
4. **Test each layer** - Try to bypass layer 1, verify layer 2 catches it
|
|
97
|
+
|
|
98
|
+
## Example from Real Session
|
|
99
|
+
|
|
100
|
+
Bug: Empty `projectDir` caused `git init` in source code
|
|
101
|
+
|
|
102
|
+
**Data flow:**
|
|
103
|
+
1. Test setup → empty string
|
|
104
|
+
2. `Project.create(name, '')`
|
|
105
|
+
3. `WorkspaceManager.createWorkspace('')`
|
|
106
|
+
4. `git init` runs in `process.cwd()`
|
|
107
|
+
|
|
108
|
+
**Four layers added:**
|
|
109
|
+
- Layer 1: `Project.create()` validates not empty/exists/writable
|
|
110
|
+
- Layer 2: `WorkspaceManager` validates projectDir not empty
|
|
111
|
+
- Layer 3: `WorktreeManager` refuses git init outside tmpdir in tests
|
|
112
|
+
- Layer 4: Stack trace logging before git init
|
|
113
|
+
|
|
114
|
+
**Result:** All 1847 tests passed, bug impossible to reproduce
|
|
115
|
+
|
|
116
|
+
## Key Insight
|
|
117
|
+
|
|
118
|
+
All four layers were necessary. During testing, each layer caught bugs others missed:
|
|
119
|
+
- Different code paths bypassed entry validation
|
|
120
|
+
- Mocks bypassed business logic checks
|
|
121
|
+
- Edge cases on different platforms needed environment guards
|
|
122
|
+
- Debug logging identified structural misuse
|
|
123
|
+
|
|
124
|
+
**Don't stop at one validation point.** Add checks at every layer.
|