@macpaw/cctk 1.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/License +21 -0
- package/README.md +142 -0
- package/bin/index.js +5 -0
- package/dist/index.js +1 -0
- package/package.json +65 -0
- package/templates/claude/agents/brainstormer.md +113 -0
- package/templates/claude/agents/code-reviewer.md +157 -0
- package/templates/claude/agents/copywriter.md +110 -0
- package/templates/claude/agents/database-admin.md +92 -0
- package/templates/claude/agents/debugger.md +137 -0
- package/templates/claude/agents/docs-manager.md +208 -0
- package/templates/claude/agents/fullstack-developer.md +95 -0
- package/templates/claude/agents/git-manager.md +394 -0
- package/templates/claude/agents/journal-writer.md +113 -0
- package/templates/claude/agents/mcp-manager.md +89 -0
- package/templates/claude/agents/planner.md +108 -0
- package/templates/claude/agents/project-manager.md +125 -0
- package/templates/claude/agents/registry.json +304 -0
- package/templates/claude/agents/researcher.md +37 -0
- package/templates/claude/agents/scout-external.md +140 -0
- package/templates/claude/agents/scout.md +106 -0
- package/templates/claude/agents/tester.md +105 -0
- package/templates/claude/agents/ui-ux-designer.md +208 -0
- package/templates/claude/commands/ask.md +56 -0
- package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
- package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
- package/templates/claude/commands/bootstrap/auto.md +110 -0
- package/templates/claude/commands/bootstrap.md +130 -0
- package/templates/claude/commands/brainstorm.md +75 -0
- package/templates/claude/commands/code/auto.md +198 -0
- package/templates/claude/commands/code/no-test.md +172 -0
- package/templates/claude/commands/code/parallel.md +100 -0
- package/templates/claude/commands/code.md +197 -0
- package/templates/claude/commands/coding-level.md +37 -0
- package/templates/claude/commands/content/cro.md +41 -0
- package/templates/claude/commands/content/enhance.md +12 -0
- package/templates/claude/commands/content/fast.md +11 -0
- package/templates/claude/commands/content/good.md +14 -0
- package/templates/claude/commands/cook/auto/fast.md +26 -0
- package/templates/claude/commands/cook/auto/parallel.md +49 -0
- package/templates/claude/commands/cook/auto.md +15 -0
- package/templates/claude/commands/cook.md +101 -0
- package/templates/claude/commands/debug.md +13 -0
- package/templates/claude/commands/docs/init.md +37 -0
- package/templates/claude/commands/docs/summarize.md +22 -0
- package/templates/claude/commands/docs/update.md +78 -0
- package/templates/claude/commands/fix/ci.md +17 -0
- package/templates/claude/commands/fix/fast.md +18 -0
- package/templates/claude/commands/fix/hard.md +35 -0
- package/templates/claude/commands/fix/logs.md +26 -0
- package/templates/claude/commands/fix/parallel.md +54 -0
- package/templates/claude/commands/fix/test.md +20 -0
- package/templates/claude/commands/fix/types.md +9 -0
- package/templates/claude/commands/fix/ui.md +33 -0
- package/templates/claude/commands/fix.md +43 -0
- package/templates/claude/commands/git/cm.md +5 -0
- package/templates/claude/commands/git/cp.md +4 -0
- package/templates/claude/commands/git/merge.md +40 -0
- package/templates/claude/commands/git/pr.md +50 -0
- package/templates/claude/commands/journal.md +7 -0
- package/templates/claude/commands/kanban.md +99 -0
- package/templates/claude/commands/plan/archive.md +57 -0
- package/templates/claude/commands/plan/ci.md +33 -0
- package/templates/claude/commands/plan/cro.md +67 -0
- package/templates/claude/commands/plan/fast.md +66 -0
- package/templates/claude/commands/plan/hard.md +92 -0
- package/templates/claude/commands/plan/parallel.md +129 -0
- package/templates/claude/commands/plan/two.md +45 -0
- package/templates/claude/commands/plan/validate.md +117 -0
- package/templates/claude/commands/plan.md +30 -0
- package/templates/claude/commands/preview.md +87 -0
- package/templates/claude/commands/registry.json +313 -0
- package/templates/claude/commands/review/codebase/parallel.md +122 -0
- package/templates/claude/commands/review/codebase.md +47 -0
- package/templates/claude/commands/scout/ext.md +35 -0
- package/templates/claude/commands/scout.md +28 -0
- package/templates/claude/commands/skill/add.md +36 -0
- package/templates/claude/commands/skill/create.md +29 -0
- package/templates/claude/commands/skill/fix-logs.md +22 -0
- package/templates/claude/commands/skill/optimize/auto.md +25 -0
- package/templates/claude/commands/skill/optimize.md +34 -0
- package/templates/claude/commands/skill/plan.md +45 -0
- package/templates/claude/commands/test/ui.md +91 -0
- package/templates/claude/commands/test.md +8 -0
- package/templates/claude/commands/use-mcp.md +34 -0
- package/templates/claude/commands/watzup.md +8 -0
- package/templates/claude/commands/worktree.md +126 -0
- package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
- package/templates/claude/hooks/docs/README.md +42 -0
- package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
- package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
- package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
- package/templates/claude/hooks/privacy-block.cjs +289 -0
- package/templates/claude/hooks/registry.json +77 -0
- package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
- package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
- package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
- package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
- package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
- package/templates/claude/hooks/scout-block.cjs +167 -0
- package/templates/claude/hooks/session-end.cjs +35 -0
- package/templates/claude/hooks/session-init.cjs +214 -0
- package/templates/claude/hooks/subagent-init.cjs +161 -0
- package/templates/claude/hooks/write-compact-marker.cjs +153 -0
- package/templates/claude/output-styles/coding-level-1.md +148 -0
- package/templates/claude/output-styles/coding-level-2.md +159 -0
- package/templates/claude/output-styles/coding-level-3.md +91 -0
- package/templates/claude/scripts/README.md +33 -0
- package/templates/claude/scripts/generate-catalogs.cjs +318 -0
- package/templates/claude/scripts/registry.json +48 -0
- package/templates/claude/scripts/set-active-plan.cjs +45 -0
- package/templates/claude/scripts/validate-docs.cjs +447 -0
- package/templates/claude/scripts/worktree.cjs +658 -0
- package/templates/claude/skills/README.md +112 -0
- package/templates/claude/skills/ai-artist/SKILL.md +75 -0
- package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
- package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
- package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
- package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
- package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
- package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
- package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
- package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
- package/templates/claude/skills/backend-development/SKILL.md +95 -0
- package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
- package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
- package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
- package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
- package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
- package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
- package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
- package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
- package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
- package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
- package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
- package/templates/claude/skills/better-auth/SKILL.md +204 -0
- package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
- package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
- package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
- package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
- package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
- package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
- package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
- package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
- package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
- package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
- package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
- package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
- package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
- package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
- package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
- package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
- package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
- package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
- package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
- package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
- package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
- package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
- package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
- package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
- package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
- package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
- package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
- package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
- package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
- package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
- package/templates/claude/skills/claude-code/references/configuration.md +480 -0
- package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
- package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
- package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
- package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
- package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
- package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
- package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
- package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
- package/templates/claude/skills/claude-code/skill.md +60 -0
- package/templates/claude/skills/code-review/SKILL.md +143 -0
- package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
- package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
- package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
- package/templates/claude/skills/context-engineering/SKILL.md +86 -0
- package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
- package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
- package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
- package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
- package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
- package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
- package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
- package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
- package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
- package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
- package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
- package/templates/claude/skills/databases/SKILL.md +232 -0
- package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
- package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
- package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
- package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
- package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
- package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
- package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
- package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
- package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
- package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
- package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
- package/templates/claude/skills/debugging/SKILL.md +84 -0
- package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
- package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
- package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
- package/templates/claude/skills/debugging/references/verification.md +123 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
- package/templates/claude/skills/devops/SKILL.md +293 -0
- package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
- package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
- package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
- package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
- package/templates/claude/skills/devops/references/docker-basics.md +297 -0
- package/templates/claude/skills/devops/references/docker-compose.md +292 -0
- package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
- package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
- package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
- package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
- package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
- package/templates/claude/skills/docs-seeker/package.json +24 -0
- package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
- package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
- package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
- package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
- package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
- package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
- package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
- package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
- package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
- package/templates/claude/skills/frontend-design/SKILL.md +85 -0
- package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
- package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
- package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
- package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
- package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
- package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
- package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
- package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
- package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
- package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
- package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
- package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
- package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
- package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
- package/templates/claude/skills/frontend-development/SKILL.md +399 -0
- package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
- package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
- package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
- package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
- package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
- package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
- package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
- package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
- package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
- package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
- package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
- package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
- package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
- package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
- package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
- package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
- package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
- package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/templates/claude/skills/mcp-management/README.md +219 -0
- package/templates/claude/skills/mcp-management/SKILL.md +209 -0
- package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
- package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
- package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
- package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
- package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
- package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
- package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
- package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
- package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
- package/templates/claude/skills/media-processing/SKILL.md +91 -0
- package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
- package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
- package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
- package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
- package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
- package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
- package/templates/claude/skills/media-processing/scripts/README.md +102 -0
- package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
- package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
- package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
- package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
- package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
- package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
- package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
- package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
- package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
- package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
- package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
- package/templates/claude/skills/planning/SKILL.md +115 -0
- package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
- package/templates/claude/skills/planning/references/output-standards.md +127 -0
- package/templates/claude/skills/planning/references/plan-organization.md +150 -0
- package/templates/claude/skills/planning/references/research-phase.md +49 -0
- package/templates/claude/skills/planning/references/solution-design.md +63 -0
- package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
- package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
- package/templates/claude/skills/plans-kanban/package.json +13 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
- package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
- package/templates/claude/skills/problem-solving/SKILL.md +96 -0
- package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
- package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
- package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
- package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
- package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
- package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
- package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
- package/templates/claude/skills/registry.json +258 -0
- package/templates/claude/skills/repomix/SKILL.md +247 -0
- package/templates/claude/skills/repomix/references/configuration.md +211 -0
- package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
- package/templates/claude/skills/repomix/scripts/README.md +179 -0
- package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
- package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
- package/templates/claude/skills/research/SKILL.md +168 -0
- package/templates/claude/skills/sequential-thinking/.env.example +8 -0
- package/templates/claude/skills/sequential-thinking/README.md +183 -0
- package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
- package/templates/claude/skills/sequential-thinking/package.json +31 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
- package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
- package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
- package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
- package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
- package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
- package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
- package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
- package/templates/claude/skills/skill-creator/SKILL.md +266 -0
- package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
- package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
- package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
- package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
- package/templates/claude/skills/template-skill/SKILL.md +6 -0
- package/templates/claude/skills/vitest/SKILL.md +595 -0
- package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
- package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
- package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
- package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
- package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
- package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
- package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
- package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
- package/templates/claude/workflows/development-rules.md +40 -0
- package/templates/claude/workflows/documentation-management.md +121 -0
- package/templates/claude/workflows/orchestration-protocol.md +16 -0
- package/templates/claude/workflows/primary-workflow.md +45 -0
- package/templates/claude/workflows/registry.json +37 -0
- package/templates/common/.cct.json +41 -0
- package/templates/common/.cctkignore +22 -0
- package/templates/common/.env.example +39 -0
- package/templates/common/.mcp.json.example +16 -0
- package/templates/common/metadata.json +15 -0
- package/templates/common/settings.json +79 -0
- package/templates/common/statusline.cjs +271 -0
- package/templates/config/.repomixignore +22 -0
- package/templates/config/AGENTS.md +55 -0
- package/templates/config/CLAUDE.md +87 -0
- package/templates/plans/bug-fix-template.md +69 -0
- package/templates/plans/feature-implementation-template.md +84 -0
- package/templates/plans/refactor-template.md +82 -0
- package/templates/plans/template-usage-guide.md +58 -0
|
@@ -0,0 +1,455 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
Batch process multiple repositories using Repomix.
|
|
4
|
+
|
|
5
|
+
This script processes multiple repositories (local or remote) using the repomix CLI tool.
|
|
6
|
+
Supports configuration through environment variables loaded from multiple .env file locations.
|
|
7
|
+
"""
|
|
8
|
+
|
|
9
|
+
import os
|
|
10
|
+
import sys
|
|
11
|
+
import subprocess
|
|
12
|
+
import json
|
|
13
|
+
from pathlib import Path
|
|
14
|
+
from typing import List, Dict, Optional, Tuple
|
|
15
|
+
from dataclasses import dataclass
|
|
16
|
+
import argparse
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
@dataclass
|
|
20
|
+
class RepomixConfig:
|
|
21
|
+
"""Configuration for repomix execution."""
|
|
22
|
+
style: str = "xml"
|
|
23
|
+
output_dir: str = "repomix-output"
|
|
24
|
+
remove_comments: bool = False
|
|
25
|
+
include_pattern: Optional[str] = None
|
|
26
|
+
ignore_pattern: Optional[str] = None
|
|
27
|
+
no_security_check: bool = False
|
|
28
|
+
verbose: bool = False
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
class EnvLoader:
|
|
32
|
+
"""Load environment variables from multiple .env file locations."""
|
|
33
|
+
|
|
34
|
+
@staticmethod
|
|
35
|
+
def load_env_files() -> Dict[str, str]:
|
|
36
|
+
"""
|
|
37
|
+
Load environment variables from .env files in order of precedence.
|
|
38
|
+
|
|
39
|
+
Order: process.env > skill/.env > skills/.env > .claude/.env
|
|
40
|
+
|
|
41
|
+
Returns:
|
|
42
|
+
Dictionary of environment variables
|
|
43
|
+
"""
|
|
44
|
+
env_vars = {}
|
|
45
|
+
script_dir = Path(__file__).parent.resolve()
|
|
46
|
+
|
|
47
|
+
# Define search paths in reverse order (lowest to highest priority)
|
|
48
|
+
search_paths = [
|
|
49
|
+
script_dir.parent.parent.parent / ".env", # .claude/.env
|
|
50
|
+
script_dir.parent.parent / ".env", # skills/.env
|
|
51
|
+
script_dir.parent / ".env", # skill/.env (repomix/.env)
|
|
52
|
+
]
|
|
53
|
+
|
|
54
|
+
# Load from files (lower priority first)
|
|
55
|
+
for env_path in search_paths:
|
|
56
|
+
if env_path.exists():
|
|
57
|
+
env_vars.update(EnvLoader._parse_env_file(env_path))
|
|
58
|
+
|
|
59
|
+
# Override with process environment (highest priority)
|
|
60
|
+
env_vars.update(os.environ)
|
|
61
|
+
|
|
62
|
+
return env_vars
|
|
63
|
+
|
|
64
|
+
@staticmethod
|
|
65
|
+
def _parse_env_file(path: Path) -> Dict[str, str]:
|
|
66
|
+
"""
|
|
67
|
+
Parse a .env file and return key-value pairs.
|
|
68
|
+
|
|
69
|
+
Args:
|
|
70
|
+
path: Path to .env file
|
|
71
|
+
|
|
72
|
+
Returns:
|
|
73
|
+
Dictionary of environment variables
|
|
74
|
+
"""
|
|
75
|
+
env_vars = {}
|
|
76
|
+
try:
|
|
77
|
+
with open(path, 'r', encoding='utf-8') as f:
|
|
78
|
+
for line in f:
|
|
79
|
+
line = line.strip()
|
|
80
|
+
# Skip comments and empty lines
|
|
81
|
+
if not line or line.startswith('#'):
|
|
82
|
+
continue
|
|
83
|
+
# Parse KEY=VALUE
|
|
84
|
+
if '=' in line:
|
|
85
|
+
key, value = line.split('=', 1)
|
|
86
|
+
key = key.strip()
|
|
87
|
+
value = value.strip()
|
|
88
|
+
# Remove quotes if present
|
|
89
|
+
if value.startswith('"') and value.endswith('"'):
|
|
90
|
+
value = value[1:-1]
|
|
91
|
+
elif value.startswith("'") and value.endswith("'"):
|
|
92
|
+
value = value[1:-1]
|
|
93
|
+
env_vars[key] = value
|
|
94
|
+
except Exception as e:
|
|
95
|
+
print(f"Warning: Failed to parse {path}: {e}", file=sys.stderr)
|
|
96
|
+
|
|
97
|
+
return env_vars
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
class RepomixBatchProcessor:
|
|
101
|
+
"""Process multiple repositories with repomix."""
|
|
102
|
+
|
|
103
|
+
def __init__(self, config: RepomixConfig):
|
|
104
|
+
"""
|
|
105
|
+
Initialize batch processor.
|
|
106
|
+
|
|
107
|
+
Args:
|
|
108
|
+
config: Repomix configuration
|
|
109
|
+
"""
|
|
110
|
+
self.config = config
|
|
111
|
+
self.env_vars = EnvLoader.load_env_files()
|
|
112
|
+
|
|
113
|
+
def check_repomix_installed(self) -> bool:
|
|
114
|
+
"""
|
|
115
|
+
Check if repomix is installed and accessible.
|
|
116
|
+
|
|
117
|
+
Returns:
|
|
118
|
+
True if repomix is installed, False otherwise
|
|
119
|
+
"""
|
|
120
|
+
try:
|
|
121
|
+
result = subprocess.run(
|
|
122
|
+
["repomix", "--version"],
|
|
123
|
+
capture_output=True,
|
|
124
|
+
text=True,
|
|
125
|
+
timeout=5,
|
|
126
|
+
env=self.env_vars
|
|
127
|
+
)
|
|
128
|
+
return result.returncode == 0
|
|
129
|
+
except (subprocess.SubprocessError, FileNotFoundError):
|
|
130
|
+
return False
|
|
131
|
+
|
|
132
|
+
def process_repository(
|
|
133
|
+
self,
|
|
134
|
+
repo_path: str,
|
|
135
|
+
output_name: Optional[str] = None,
|
|
136
|
+
is_remote: bool = False
|
|
137
|
+
) -> Tuple[bool, str]:
|
|
138
|
+
"""
|
|
139
|
+
Process a single repository with repomix.
|
|
140
|
+
|
|
141
|
+
Args:
|
|
142
|
+
repo_path: Path to local repository or remote repository URL
|
|
143
|
+
output_name: Custom output filename (optional)
|
|
144
|
+
is_remote: Whether repo_path is a remote URL
|
|
145
|
+
|
|
146
|
+
Returns:
|
|
147
|
+
Tuple of (success, message)
|
|
148
|
+
"""
|
|
149
|
+
# Create output directory if it doesn't exist
|
|
150
|
+
output_dir = Path(self.config.output_dir)
|
|
151
|
+
output_dir.mkdir(parents=True, exist_ok=True)
|
|
152
|
+
|
|
153
|
+
# Determine output filename
|
|
154
|
+
if output_name:
|
|
155
|
+
output_file = output_dir / output_name
|
|
156
|
+
else:
|
|
157
|
+
if is_remote:
|
|
158
|
+
# Extract repo name from URL
|
|
159
|
+
repo_name = repo_path.rstrip('/').split('/')[-1]
|
|
160
|
+
else:
|
|
161
|
+
repo_name = Path(repo_path).name
|
|
162
|
+
|
|
163
|
+
extension = self._get_extension(self.config.style)
|
|
164
|
+
output_file = output_dir / f"{repo_name}-output.{extension}"
|
|
165
|
+
|
|
166
|
+
# Build repomix command
|
|
167
|
+
cmd = self._build_command(repo_path, output_file, is_remote)
|
|
168
|
+
|
|
169
|
+
if self.config.verbose:
|
|
170
|
+
print(f"Executing: {' '.join(cmd)}")
|
|
171
|
+
|
|
172
|
+
try:
|
|
173
|
+
result = subprocess.run(
|
|
174
|
+
cmd,
|
|
175
|
+
capture_output=True,
|
|
176
|
+
text=True,
|
|
177
|
+
timeout=300, # 5 minute timeout
|
|
178
|
+
env=self.env_vars
|
|
179
|
+
)
|
|
180
|
+
|
|
181
|
+
if result.returncode == 0:
|
|
182
|
+
return True, f"Successfully processed {repo_path} -> {output_file}"
|
|
183
|
+
else:
|
|
184
|
+
error_msg = result.stderr or result.stdout or "Unknown error"
|
|
185
|
+
return False, f"Failed to process {repo_path}: {error_msg}"
|
|
186
|
+
|
|
187
|
+
except subprocess.TimeoutExpired:
|
|
188
|
+
return False, f"Timeout processing {repo_path} (exceeded 5 minutes)"
|
|
189
|
+
except Exception as e:
|
|
190
|
+
return False, f"Error processing {repo_path}: {str(e)}"
|
|
191
|
+
|
|
192
|
+
def _build_command(
|
|
193
|
+
self,
|
|
194
|
+
repo_path: str,
|
|
195
|
+
output_file: Path,
|
|
196
|
+
is_remote: bool
|
|
197
|
+
) -> List[str]:
|
|
198
|
+
"""
|
|
199
|
+
Build repomix command with configuration options.
|
|
200
|
+
|
|
201
|
+
Args:
|
|
202
|
+
repo_path: Path to repository
|
|
203
|
+
output_file: Output file path
|
|
204
|
+
is_remote: Whether this is a remote repository
|
|
205
|
+
|
|
206
|
+
Returns:
|
|
207
|
+
Command as list of strings
|
|
208
|
+
"""
|
|
209
|
+
cmd = ["npx" if is_remote else "repomix"]
|
|
210
|
+
|
|
211
|
+
if is_remote:
|
|
212
|
+
cmd.extend(["repomix", "--remote", repo_path])
|
|
213
|
+
else:
|
|
214
|
+
cmd.append(repo_path)
|
|
215
|
+
|
|
216
|
+
# Add configuration options
|
|
217
|
+
cmd.extend(["--style", self.config.style])
|
|
218
|
+
cmd.extend(["-o", str(output_file)])
|
|
219
|
+
|
|
220
|
+
if self.config.remove_comments:
|
|
221
|
+
cmd.append("--remove-comments")
|
|
222
|
+
|
|
223
|
+
if self.config.include_pattern:
|
|
224
|
+
cmd.extend(["--include", self.config.include_pattern])
|
|
225
|
+
|
|
226
|
+
if self.config.ignore_pattern:
|
|
227
|
+
cmd.extend(["-i", self.config.ignore_pattern])
|
|
228
|
+
|
|
229
|
+
if self.config.no_security_check:
|
|
230
|
+
cmd.append("--no-security-check")
|
|
231
|
+
|
|
232
|
+
if self.config.verbose:
|
|
233
|
+
cmd.append("--verbose")
|
|
234
|
+
|
|
235
|
+
return cmd
|
|
236
|
+
|
|
237
|
+
@staticmethod
|
|
238
|
+
def _get_extension(style: str) -> str:
|
|
239
|
+
"""
|
|
240
|
+
Get file extension for output style.
|
|
241
|
+
|
|
242
|
+
Args:
|
|
243
|
+
style: Output style (xml, markdown, json, plain)
|
|
244
|
+
|
|
245
|
+
Returns:
|
|
246
|
+
File extension
|
|
247
|
+
"""
|
|
248
|
+
extensions = {
|
|
249
|
+
"xml": "xml",
|
|
250
|
+
"markdown": "md",
|
|
251
|
+
"json": "json",
|
|
252
|
+
"plain": "txt"
|
|
253
|
+
}
|
|
254
|
+
return extensions.get(style, "xml")
|
|
255
|
+
|
|
256
|
+
def process_batch(
|
|
257
|
+
self,
|
|
258
|
+
repositories: List[Dict[str, str]]
|
|
259
|
+
) -> Dict[str, List[str]]:
|
|
260
|
+
"""
|
|
261
|
+
Process multiple repositories.
|
|
262
|
+
|
|
263
|
+
Args:
|
|
264
|
+
repositories: List of repository configurations
|
|
265
|
+
Each dict should contain:
|
|
266
|
+
- 'path': Repository path or URL
|
|
267
|
+
- 'output': Optional output filename
|
|
268
|
+
- 'remote': Optional boolean for remote repos
|
|
269
|
+
|
|
270
|
+
Returns:
|
|
271
|
+
Dictionary with 'success' and 'failed' lists
|
|
272
|
+
"""
|
|
273
|
+
results = {"success": [], "failed": []}
|
|
274
|
+
|
|
275
|
+
for repo in repositories:
|
|
276
|
+
repo_path = repo.get("path")
|
|
277
|
+
if not repo_path:
|
|
278
|
+
results["failed"].append("Missing 'path' in repository config")
|
|
279
|
+
continue
|
|
280
|
+
|
|
281
|
+
output_name = repo.get("output")
|
|
282
|
+
is_remote = repo.get("remote", False)
|
|
283
|
+
|
|
284
|
+
success, message = self.process_repository(
|
|
285
|
+
repo_path,
|
|
286
|
+
output_name,
|
|
287
|
+
is_remote
|
|
288
|
+
)
|
|
289
|
+
|
|
290
|
+
if success:
|
|
291
|
+
results["success"].append(message)
|
|
292
|
+
else:
|
|
293
|
+
results["failed"].append(message)
|
|
294
|
+
|
|
295
|
+
print(message)
|
|
296
|
+
|
|
297
|
+
return results
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
def load_repositories_from_file(file_path: str) -> List[Dict[str, str]]:
|
|
301
|
+
"""
|
|
302
|
+
Load repository configurations from JSON file.
|
|
303
|
+
|
|
304
|
+
Expected format:
|
|
305
|
+
[
|
|
306
|
+
{"path": "/path/to/repo", "output": "custom.xml"},
|
|
307
|
+
{"path": "owner/repo", "remote": true},
|
|
308
|
+
...
|
|
309
|
+
]
|
|
310
|
+
|
|
311
|
+
Args:
|
|
312
|
+
file_path: Path to JSON file
|
|
313
|
+
|
|
314
|
+
Returns:
|
|
315
|
+
List of repository configurations
|
|
316
|
+
"""
|
|
317
|
+
try:
|
|
318
|
+
with open(file_path, 'r', encoding='utf-8') as f:
|
|
319
|
+
data = json.load(f)
|
|
320
|
+
if isinstance(data, list):
|
|
321
|
+
return data
|
|
322
|
+
else:
|
|
323
|
+
print(f"Error: Expected array in {file_path}", file=sys.stderr)
|
|
324
|
+
return []
|
|
325
|
+
except json.JSONDecodeError as e:
|
|
326
|
+
print(f"Error: Invalid JSON in {file_path}: {e}", file=sys.stderr)
|
|
327
|
+
return []
|
|
328
|
+
except Exception as e:
|
|
329
|
+
print(f"Error: Failed to read {file_path}: {e}", file=sys.stderr)
|
|
330
|
+
return []
|
|
331
|
+
|
|
332
|
+
|
|
333
|
+
def main():
|
|
334
|
+
"""Main entry point for the script."""
|
|
335
|
+
parser = argparse.ArgumentParser(
|
|
336
|
+
description="Batch process multiple repositories with repomix"
|
|
337
|
+
)
|
|
338
|
+
|
|
339
|
+
# Input options
|
|
340
|
+
parser.add_argument(
|
|
341
|
+
"repos",
|
|
342
|
+
nargs="*",
|
|
343
|
+
help="Repository paths or URLs to process"
|
|
344
|
+
)
|
|
345
|
+
parser.add_argument(
|
|
346
|
+
"-f", "--file",
|
|
347
|
+
help="JSON file containing repository configurations"
|
|
348
|
+
)
|
|
349
|
+
|
|
350
|
+
# Output options
|
|
351
|
+
parser.add_argument(
|
|
352
|
+
"--style",
|
|
353
|
+
choices=["xml", "markdown", "json", "plain"],
|
|
354
|
+
default="xml",
|
|
355
|
+
help="Output format (default: xml)"
|
|
356
|
+
)
|
|
357
|
+
parser.add_argument(
|
|
358
|
+
"-o", "--output-dir",
|
|
359
|
+
default="repomix-output",
|
|
360
|
+
help="Output directory (default: repomix-output)"
|
|
361
|
+
)
|
|
362
|
+
|
|
363
|
+
# Processing options
|
|
364
|
+
parser.add_argument(
|
|
365
|
+
"--remove-comments",
|
|
366
|
+
action="store_true",
|
|
367
|
+
help="Remove comments from source files"
|
|
368
|
+
)
|
|
369
|
+
parser.add_argument(
|
|
370
|
+
"--include",
|
|
371
|
+
help="Include pattern (glob)"
|
|
372
|
+
)
|
|
373
|
+
parser.add_argument(
|
|
374
|
+
"--ignore",
|
|
375
|
+
help="Ignore pattern (glob)"
|
|
376
|
+
)
|
|
377
|
+
parser.add_argument(
|
|
378
|
+
"--no-security-check",
|
|
379
|
+
action="store_true",
|
|
380
|
+
help="Disable security checks"
|
|
381
|
+
)
|
|
382
|
+
parser.add_argument(
|
|
383
|
+
"-v", "--verbose",
|
|
384
|
+
action="store_true",
|
|
385
|
+
help="Verbose output"
|
|
386
|
+
)
|
|
387
|
+
parser.add_argument(
|
|
388
|
+
"--remote",
|
|
389
|
+
action="store_true",
|
|
390
|
+
help="Treat all repos as remote URLs"
|
|
391
|
+
)
|
|
392
|
+
|
|
393
|
+
args = parser.parse_args()
|
|
394
|
+
|
|
395
|
+
# Create configuration
|
|
396
|
+
config = RepomixConfig(
|
|
397
|
+
style=args.style,
|
|
398
|
+
output_dir=args.output_dir,
|
|
399
|
+
remove_comments=args.remove_comments,
|
|
400
|
+
include_pattern=args.include,
|
|
401
|
+
ignore_pattern=args.ignore,
|
|
402
|
+
no_security_check=args.no_security_check,
|
|
403
|
+
verbose=args.verbose
|
|
404
|
+
)
|
|
405
|
+
|
|
406
|
+
# Initialize processor
|
|
407
|
+
processor = RepomixBatchProcessor(config)
|
|
408
|
+
|
|
409
|
+
# Check if repomix is installed
|
|
410
|
+
if not processor.check_repomix_installed():
|
|
411
|
+
print("Error: repomix is not installed or not in PATH", file=sys.stderr)
|
|
412
|
+
print("Install with: npm install -g repomix", file=sys.stderr)
|
|
413
|
+
return 1
|
|
414
|
+
|
|
415
|
+
# Collect repositories to process
|
|
416
|
+
repositories = []
|
|
417
|
+
|
|
418
|
+
# Load from file if specified
|
|
419
|
+
if args.file:
|
|
420
|
+
repositories.extend(load_repositories_from_file(args.file))
|
|
421
|
+
|
|
422
|
+
# Add command line repositories
|
|
423
|
+
if args.repos:
|
|
424
|
+
for repo_path in args.repos:
|
|
425
|
+
repositories.append({
|
|
426
|
+
"path": repo_path,
|
|
427
|
+
"remote": args.remote
|
|
428
|
+
})
|
|
429
|
+
|
|
430
|
+
# Validate we have repositories to process
|
|
431
|
+
if not repositories:
|
|
432
|
+
print("Error: No repositories specified", file=sys.stderr)
|
|
433
|
+
print("Use: repomix_batch.py <repo1> <repo2> ...", file=sys.stderr)
|
|
434
|
+
print("Or: repomix_batch.py -f repos.json", file=sys.stderr)
|
|
435
|
+
return 1
|
|
436
|
+
|
|
437
|
+
# Process batch
|
|
438
|
+
print(f"Processing {len(repositories)} repositories...")
|
|
439
|
+
results = processor.process_batch(repositories)
|
|
440
|
+
|
|
441
|
+
# Print summary
|
|
442
|
+
print("\n" + "=" * 50)
|
|
443
|
+
print(f"Success: {len(results['success'])}")
|
|
444
|
+
print(f"Failed: {len(results['failed'])}")
|
|
445
|
+
|
|
446
|
+
if results['failed']:
|
|
447
|
+
print("\nFailed repositories:")
|
|
448
|
+
for failure in results['failed']:
|
|
449
|
+
print(f" - {failure}")
|
|
450
|
+
|
|
451
|
+
return 0 if not results['failed'] else 1
|
|
452
|
+
|
|
453
|
+
|
|
454
|
+
if __name__ == "__main__":
|
|
455
|
+
sys.exit(main())
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: research
|
|
3
|
+
description: Use when you need to research, analyze, and plan technical solutions that are scalable, secure, and maintainable.
|
|
4
|
+
license: MIT
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Research
|
|
8
|
+
|
|
9
|
+
## Research Methodology
|
|
10
|
+
|
|
11
|
+
Always honoring **YAGNI**, **KISS**, and **DRY** principles.
|
|
12
|
+
**Be honest, be brutal, straight to the point, and be concise.**
|
|
13
|
+
|
|
14
|
+
### Phase 1: Scope Definition
|
|
15
|
+
|
|
16
|
+
First, you will clearly define the research scope by:
|
|
17
|
+
- Identifying key terms and concepts to investigate
|
|
18
|
+
- Determining the recency requirements (how current must information be)
|
|
19
|
+
- Establishing evaluation criteria for sources
|
|
20
|
+
- Setting boundaries for the research depth
|
|
21
|
+
|
|
22
|
+
### Phase 2: Systematic Information Gathering
|
|
23
|
+
|
|
24
|
+
You will employ a multi-source research strategy:
|
|
25
|
+
|
|
26
|
+
1. **Search Strategy**:
|
|
27
|
+
- Check if `gemini` bash command is available, if so, execute `gemini -m gemini-2.5-flash -p "...your search prompt..."` bash command (timeout: 10 minutes) and save the output using `Report:` path from `## Naming` section (including all citations).
|
|
28
|
+
- If `gemini` bash command is not available, fallback to `WebSearch` tool.
|
|
29
|
+
- Run multiple `gemini` bash commands or `WebSearch` tools in parallel to search for relevant information.
|
|
30
|
+
- Craft precise search queries with relevant keywords
|
|
31
|
+
- Include terms like "best practices", "2024", "latest", "security", "performance"
|
|
32
|
+
- Search for official documentation, GitHub repositories, and authoritative blogs
|
|
33
|
+
- Prioritize results from recognized authorities (official docs, major tech companies, respected developers)
|
|
34
|
+
- **IMPORTANT:** You are allowed to perform at most **5 researches (max 5 tool calls)**, user might request less than this amount, **strictly respect it**, think carefully based on the task before performing each related research topic.
|
|
35
|
+
|
|
36
|
+
2. **Deep Content Analysis**:
|
|
37
|
+
- When you found a potential Github repository URL, use `docs-seeker` skill to find read it.
|
|
38
|
+
- Focus on official documentation, API references, and technical specifications
|
|
39
|
+
- Analyze README files from popular GitHub repositories
|
|
40
|
+
- Review changelog and release notes for version-specific information
|
|
41
|
+
|
|
42
|
+
3. **Video Content Research**:
|
|
43
|
+
- Prioritize content from official channels, recognized experts, and major conferences
|
|
44
|
+
- Focus on practical demonstrations and real-world implementations
|
|
45
|
+
|
|
46
|
+
4. **Cross-Reference Validation**:
|
|
47
|
+
- Verify information across multiple independent sources
|
|
48
|
+
- Check publication dates to ensure currency
|
|
49
|
+
- Identify consensus vs. controversial approaches
|
|
50
|
+
- Note any conflicting information or debates in the community
|
|
51
|
+
|
|
52
|
+
### Phase 3: Analysis and Synthesis
|
|
53
|
+
|
|
54
|
+
You will analyze gathered information by:
|
|
55
|
+
- Identifying common patterns and best practices
|
|
56
|
+
- Evaluating pros and cons of different approaches
|
|
57
|
+
- Assessing maturity and stability of technologies
|
|
58
|
+
- Recognizing security implications and performance considerations
|
|
59
|
+
- Determining compatibility and integration requirements
|
|
60
|
+
|
|
61
|
+
### Phase 4: Report Generation
|
|
62
|
+
|
|
63
|
+
**Notes:**
|
|
64
|
+
- Research reports are saved using `Report:` path from `## Naming` section.
|
|
65
|
+
- If `## Naming` section is not available, ask main agent to provide the output path.
|
|
66
|
+
|
|
67
|
+
You will create a comprehensive markdown report with the following structure:
|
|
68
|
+
|
|
69
|
+
```markdown
|
|
70
|
+
# Research Report: [Topic]
|
|
71
|
+
|
|
72
|
+
## Executive Summary
|
|
73
|
+
[2-3 paragraph overview of key findings and recommendations]
|
|
74
|
+
|
|
75
|
+
## Research Methodology
|
|
76
|
+
- Sources consulted: [number]
|
|
77
|
+
- Date range of materials: [earliest to most recent]
|
|
78
|
+
- Key search terms used: [list]
|
|
79
|
+
|
|
80
|
+
## Key Findings
|
|
81
|
+
|
|
82
|
+
### 1. Technology Overview
|
|
83
|
+
[Comprehensive description of the technology/topic]
|
|
84
|
+
|
|
85
|
+
### 2. Current State & Trends
|
|
86
|
+
[Latest developments, version information, adoption trends]
|
|
87
|
+
|
|
88
|
+
### 3. Best Practices
|
|
89
|
+
[Detailed list of recommended practices with explanations]
|
|
90
|
+
|
|
91
|
+
### 4. Security Considerations
|
|
92
|
+
[Security implications, vulnerabilities, and mitigation strategies]
|
|
93
|
+
|
|
94
|
+
### 5. Performance Insights
|
|
95
|
+
[Performance characteristics, optimization techniques, benchmarks]
|
|
96
|
+
|
|
97
|
+
## Comparative Analysis
|
|
98
|
+
[If applicable, comparison of different solutions/approaches]
|
|
99
|
+
|
|
100
|
+
## Implementation Recommendations
|
|
101
|
+
|
|
102
|
+
### Quick Start Guide
|
|
103
|
+
[Step-by-step getting started instructions]
|
|
104
|
+
|
|
105
|
+
### Code Examples
|
|
106
|
+
[Relevant code snippets with explanations]
|
|
107
|
+
|
|
108
|
+
### Common Pitfalls
|
|
109
|
+
[Mistakes to avoid and their solutions]
|
|
110
|
+
|
|
111
|
+
## Resources & References
|
|
112
|
+
|
|
113
|
+
### Official Documentation
|
|
114
|
+
- [Linked list of official docs]
|
|
115
|
+
|
|
116
|
+
### Recommended Tutorials
|
|
117
|
+
- [Curated list with descriptions]
|
|
118
|
+
|
|
119
|
+
### Community Resources
|
|
120
|
+
- [Forums, Discord servers, Stack Overflow tags]
|
|
121
|
+
|
|
122
|
+
### Further Reading
|
|
123
|
+
- [Advanced topics and deep dives]
|
|
124
|
+
|
|
125
|
+
## Appendices
|
|
126
|
+
|
|
127
|
+
### A. Glossary
|
|
128
|
+
[Technical terms and definitions]
|
|
129
|
+
|
|
130
|
+
### B. Version Compatibility Matrix
|
|
131
|
+
[If applicable]
|
|
132
|
+
|
|
133
|
+
### C. Raw Research Notes
|
|
134
|
+
[Optional: detailed notes from research process]
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
## Quality Standards
|
|
138
|
+
|
|
139
|
+
You will ensure all research meets these criteria:
|
|
140
|
+
- **Accuracy**: Information is verified across multiple sources
|
|
141
|
+
- **Currency**: Prioritize information from the last 12 months unless historical context is needed
|
|
142
|
+
- **Completeness**: Cover all aspects requested by the user
|
|
143
|
+
- **Actionability**: Provide practical, implementable recommendations
|
|
144
|
+
- **Clarity**: Use clear language, define technical terms, provide examples
|
|
145
|
+
- **Attribution**: Always cite sources and provide links for verification
|
|
146
|
+
|
|
147
|
+
## Special Considerations
|
|
148
|
+
|
|
149
|
+
- When researching security topics, always check for recent CVEs and security advisories
|
|
150
|
+
- For performance-related research, look for benchmarks and real-world case studies
|
|
151
|
+
- When investigating new technologies, assess community adoption and support levels
|
|
152
|
+
- For API documentation, verify endpoint availability and authentication requirements
|
|
153
|
+
- Always note deprecation warnings and migration paths for older technologies
|
|
154
|
+
|
|
155
|
+
## Output Requirements
|
|
156
|
+
|
|
157
|
+
Your final report must:
|
|
158
|
+
1. Be saved using the `Report:` path from `## Naming` section with a descriptive filename
|
|
159
|
+
2. Include a timestamp of when the research was conducted
|
|
160
|
+
3. Provide clear section navigation with a table of contents for longer reports
|
|
161
|
+
4. Use code blocks with appropriate syntax highlighting
|
|
162
|
+
5. Include diagrams or architecture descriptions where helpful (in mermaid or ASCII art)
|
|
163
|
+
6. Conclude with specific, actionable next steps
|
|
164
|
+
|
|
165
|
+
**IMPORTANT:** Sacrifice grammar for the sake of concision when writing reports.
|
|
166
|
+
**IMPORTANT:** In reports, list any unresolved questions at the end, if any.
|
|
167
|
+
|
|
168
|
+
**Remember:** You are not just collecting information, but providing strategic technical intelligence that enables informed decision-making. Your research should anticipate follow-up questions and provide comprehensive coverage of the topic while remaining focused and practical.
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
# Sequential Thinking Configuration
|
|
2
|
+
|
|
3
|
+
# Disable thought logging output (useful for automated processing)
|
|
4
|
+
# Set to "true" to disable console logging
|
|
5
|
+
DISABLE_THOUGHT_LOGGING=false
|
|
6
|
+
|
|
7
|
+
# History file location (optional, defaults to scripts/.thought-history.json)
|
|
8
|
+
# THOUGHT_HISTORY_FILE=/path/to/custom/history.json
|