@vodailoc/kilo-kit-mcp 1.1.0 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.mcp/kilo-kit.codex-windows.toml +5 -0
- package/LICENSE +190 -190
- package/QUICKSTART.md +265 -255
- package/README.md +290 -266
- package/mcp/README.md +29 -5
- package/mcp/dist/server.js +1 -1
- package/mcp/package.json +1 -2
- package/package.json +3 -2
- package/skills/README.md +647 -647
- package/skills/SKILLS_INDEX.md +139 -139
- package/skills/ai-media/ai-multimodal/.env.example +97 -97
- package/skills/ai-media/ai-multimodal/SKILL.md +357 -357
- package/skills/ai-media/ai-multimodal/references/audio-processing.md +373 -373
- package/skills/ai-media/ai-multimodal/references/image-generation.md +558 -558
- package/skills/ai-media/ai-multimodal/references/video-analysis.md +502 -502
- package/skills/ai-media/ai-multimodal/references/vision-understanding.md +483 -483
- package/skills/ai-media/ai-multimodal/scripts/document_converter.py +395 -395
- package/skills/ai-media/ai-multimodal/scripts/gemini_batch_process.py +480 -480
- package/skills/ai-media/ai-multimodal/scripts/media_optimizer.py +506 -506
- package/skills/ai-media/ai-multimodal/scripts/requirements.txt +26 -26
- package/skills/ai-media/ai-multimodal/scripts/tests/requirements.txt +20 -20
- package/skills/ai-media/ai-multimodal/scripts/tests/test_document_converter.py +299 -299
- package/skills/ai-media/ai-multimodal/scripts/tests/test_gemini_batch_process.py +362 -362
- package/skills/ai-media/ai-multimodal/scripts/tests/test_media_optimizer.py +373 -373
- package/skills/ai-media/media-processing/SKILL.md +358 -358
- package/skills/ai-media/media-processing/references/ffmpeg-encoding.md +358 -358
- package/skills/ai-media/media-processing/references/ffmpeg-filters.md +503 -503
- package/skills/ai-media/media-processing/references/ffmpeg-streaming.md +403 -403
- package/skills/ai-media/media-processing/references/format-compatibility.md +375 -375
- package/skills/ai-media/media-processing/references/imagemagick-batch.md +612 -612
- package/skills/ai-media/media-processing/references/imagemagick-editing.md +623 -623
- package/skills/ai-media/media-processing/scripts/batch_resize.py +342 -342
- package/skills/ai-media/media-processing/scripts/media_convert.py +311 -311
- package/skills/ai-media/media-processing/scripts/requirements.txt +24 -24
- package/skills/ai-media/media-processing/scripts/tests/requirements.txt +2 -2
- package/skills/ai-media/media-processing/scripts/tests/test_batch_resize.py +372 -372
- package/skills/ai-media/media-processing/scripts/tests/test_media_convert.py +259 -259
- package/skills/ai-media/media-processing/scripts/tests/test_video_optimize.py +397 -397
- package/skills/ai-media/media-processing/scripts/video_optimize.py +414 -414
- package/skills/ai-media/screenshot/LICENSE.txt +201 -201
- package/skills/ai-media/screenshot/SKILL.md +267 -267
- package/skills/ai-media/screenshot/agents/openai.yaml +6 -6
- package/skills/ai-media/screenshot/assets/screenshot-small.svg +5 -5
- package/skills/ai-media/screenshot/scripts/ensure_macos_permissions.sh +54 -54
- package/skills/ai-media/screenshot/scripts/macos_display_info.swift +22 -22
- package/skills/ai-media/screenshot/scripts/macos_permissions.swift +40 -40
- package/skills/ai-media/screenshot/scripts/macos_window_info.swift +126 -126
- package/skills/ai-media/screenshot/scripts/take_screenshot.ps1 +163 -163
- package/skills/ai-media/screenshot/scripts/take_screenshot.py +585 -585
- package/skills/ai-media/sora/LICENSE.txt +201 -201
- package/skills/ai-media/sora/SKILL.md +153 -153
- package/skills/ai-media/sora/agents/openai.yaml +6 -6
- package/skills/ai-media/sora/assets/sora-small.svg +4 -4
- package/skills/ai-media/sora/references/cinematic-shots.md +53 -53
- package/skills/ai-media/sora/references/cli.md +248 -248
- package/skills/ai-media/sora/references/codex-network.md +28 -28
- package/skills/ai-media/sora/references/prompting.md +137 -137
- package/skills/ai-media/sora/references/sample-prompts.md +95 -95
- package/skills/ai-media/sora/references/social-ads.md +42 -42
- package/skills/ai-media/sora/references/troubleshooting.md +58 -58
- package/skills/ai-media/sora/references/video-api.md +45 -45
- package/skills/ai-media/sora/scripts/sora.py +970 -970
- package/skills/design/aesthetic/SKILL.md +121 -121
- package/skills/design/aesthetic/assets/design-guideline-template.md +163 -163
- package/skills/design/aesthetic/assets/design-story-template.md +135 -135
- package/skills/design/aesthetic/references/design-principles.md +62 -62
- package/skills/design/aesthetic/references/design-resources.md +75 -75
- package/skills/design/aesthetic/references/micro-interactions.md +53 -53
- package/skills/design/aesthetic/references/storytelling-design.md +50 -50
- package/skills/design/figma/LICENSE.txt +202 -202
- package/skills/design/figma/SKILL.md +42 -42
- package/skills/design/figma/agents/openai.yaml +14 -14
- package/skills/design/figma/assets/figma-small.svg +3 -3
- package/skills/design/figma/assets/icon.svg +28 -28
- package/skills/design/figma/references/figma-mcp-config.md +35 -35
- package/skills/design/figma/references/figma-tools-and-prompts.md +34 -34
- package/skills/design/figma-implement-design/LICENSE.txt +202 -202
- package/skills/design/figma-implement-design/SKILL.md +264 -264
- package/skills/design/figma-implement-design/agents/openai.yaml +14 -14
- package/skills/design/figma-implement-design/assets/figma-small.svg +3 -3
- package/skills/design/figma-implement-design/assets/icon.svg +28 -28
- package/skills/design/frontend-design/SKILL.md +41 -41
- package/skills/design/frontend-design/references/animejs.md +395 -395
- package/skills/design/ui-styling/LICENSE.txt +201 -201
- package/skills/design/ui-styling/SKILL.md +321 -321
- package/skills/design/ui-styling/canvas-fonts/ArsenalSC-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/BigShoulders-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Boldonse-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/BricolageGrotesque-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/CrimsonPro-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/DMMono-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/EricaOne-OFL.txt +94 -94
- package/skills/design/ui-styling/canvas-fonts/GeistMono-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Gloock-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/IBMPlexMono-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/InstrumentSans-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Italiana-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/JetBrainsMono-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Jura-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/LibreBaskerville-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Lora-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/NationalPark-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Outfit-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/PixelifySans-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/PoiretOne-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/RedHatMono-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Silkscreen-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/SmoochSans-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/Tektur-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/WorkSans-OFL.txt +93 -93
- package/skills/design/ui-styling/canvas-fonts/YoungSerif-OFL.txt +93 -93
- package/skills/design/ui-styling/references/canvas-design-system.md +320 -320
- package/skills/design/ui-styling/references/shadcn-accessibility.md +471 -471
- package/skills/design/ui-styling/references/shadcn-components.md +424 -424
- package/skills/design/ui-styling/references/shadcn-theming.md +373 -373
- package/skills/design/ui-styling/references/tailwind-customization.md +483 -483
- package/skills/design/ui-styling/references/tailwind-responsive.md +382 -382
- package/skills/design/ui-styling/references/tailwind-utilities.md +455 -455
- package/skills/design/ui-styling/scripts/requirements.txt +17 -17
- package/skills/design/ui-styling/scripts/shadcn_add.py +292 -292
- package/skills/design/ui-styling/scripts/tailwind_config_gen.py +456 -456
- package/skills/design/ui-styling/scripts/tests/requirements.txt +3 -3
- package/skills/design/ui-styling/scripts/tests/test_shadcn_add.py +266 -266
- package/skills/design/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -336
- package/skills/engineering/aspnet-core/LICENSE.txt +201 -201
- package/skills/engineering/aspnet-core/SKILL.md +61 -61
- package/skills/engineering/aspnet-core/agents/openai.yaml +5 -5
- package/skills/engineering/aspnet-core/references/_sections.md +40 -40
- package/skills/engineering/aspnet-core/references/apis-minimal-and-controllers.md +81 -81
- package/skills/engineering/aspnet-core/references/data-state-and-services.md +69 -69
- package/skills/engineering/aspnet-core/references/program-and-pipeline.md +103 -103
- package/skills/engineering/aspnet-core/references/realtime-grpc-and-background-work.md +58 -58
- package/skills/engineering/aspnet-core/references/security-and-identity.md +75 -75
- package/skills/engineering/aspnet-core/references/source-map.md +43 -43
- package/skills/engineering/aspnet-core/references/stack-selection.md +63 -63
- package/skills/engineering/aspnet-core/references/testing-performance-and-operations.md +92 -92
- package/skills/engineering/aspnet-core/references/ui-blazor.md +53 -53
- package/skills/engineering/aspnet-core/references/ui-mvc.md +56 -56
- package/skills/engineering/aspnet-core/references/ui-razor-pages.md +55 -55
- package/skills/engineering/aspnet-core/references/versioning-and-upgrades.md +51 -51
- package/skills/engineering/backend-development/SKILL.md +95 -95
- package/skills/engineering/backend-development/references/backend-api-design.md +495 -495
- package/skills/engineering/backend-development/references/backend-architecture.md +454 -454
- package/skills/engineering/backend-development/references/backend-authentication.md +338 -338
- package/skills/engineering/backend-development/references/backend-code-quality.md +659 -659
- package/skills/engineering/backend-development/references/backend-debugging.md +904 -904
- package/skills/engineering/backend-development/references/backend-devops.md +494 -494
- package/skills/engineering/backend-development/references/backend-mindset.md +387 -387
- package/skills/engineering/backend-development/references/backend-performance.md +397 -397
- package/skills/engineering/backend-development/references/backend-security.md +290 -290
- package/skills/engineering/backend-development/references/backend-technologies.md +256 -256
- package/skills/engineering/backend-development/references/backend-testing.md +429 -429
- package/skills/engineering/better-auth/SKILL.md +204 -204
- package/skills/engineering/better-auth/references/advanced-features.md +553 -553
- package/skills/engineering/better-auth/references/database-integration.md +577 -577
- package/skills/engineering/better-auth/references/email-password-auth.md +416 -416
- package/skills/engineering/better-auth/references/oauth-providers.md +430 -430
- package/skills/engineering/better-auth/scripts/better_auth_init.py +521 -521
- package/skills/engineering/better-auth/scripts/requirements.txt +15 -15
- package/skills/engineering/better-auth/scripts/tests/test_better_auth_init.py +421 -421
- package/skills/engineering/code-review/SKILL.md +140 -140
- package/skills/engineering/code-review/references/code-review-reception.md +208 -208
- package/skills/engineering/code-review/references/requesting-code-review.md +104 -104
- package/skills/engineering/code-review/references/verification-before-completion.md +138 -138
- package/skills/engineering/context-engineering/SKILL.md +86 -86
- package/skills/engineering/context-engineering/references/context-compression.md +84 -84
- package/skills/engineering/context-engineering/references/context-degradation.md +93 -93
- package/skills/engineering/context-engineering/references/context-fundamentals.md +75 -75
- package/skills/engineering/context-engineering/references/context-optimization.md +82 -82
- package/skills/engineering/context-engineering/references/evaluation.md +89 -89
- package/skills/engineering/context-engineering/references/memory-systems.md +88 -88
- package/skills/engineering/context-engineering/references/multi-agent-patterns.md +90 -90
- package/skills/engineering/context-engineering/references/project-development.md +97 -97
- package/skills/engineering/context-engineering/references/tool-design.md +86 -86
- package/skills/engineering/context-engineering/scripts/compression_evaluator.py +329 -329
- package/skills/engineering/context-engineering/scripts/context_analyzer.py +294 -294
- package/skills/engineering/databases/SKILL.md +232 -232
- package/skills/engineering/databases/references/mongodb-aggregation.md +447 -447
- package/skills/engineering/databases/references/mongodb-atlas.md +465 -465
- package/skills/engineering/databases/references/mongodb-crud.md +408 -408
- package/skills/engineering/databases/references/mongodb-indexing.md +442 -442
- package/skills/engineering/databases/references/postgresql-administration.md +594 -594
- package/skills/engineering/databases/references/postgresql-performance.md +527 -527
- package/skills/engineering/databases/references/postgresql-psql-cli.md +467 -467
- package/skills/engineering/databases/references/postgresql-queries.md +475 -475
- package/skills/engineering/databases/scripts/db_backup.py +502 -502
- package/skills/engineering/databases/scripts/db_migrate.py +414 -414
- package/skills/engineering/databases/scripts/db_performance_check.py +444 -444
- package/skills/engineering/databases/scripts/requirements.txt +20 -20
- package/skills/engineering/databases/scripts/tests/requirements.txt +4 -4
- package/skills/engineering/databases/scripts/tests/test_db_backup.py +340 -340
- package/skills/engineering/databases/scripts/tests/test_db_migrate.py +277 -277
- package/skills/engineering/databases/scripts/tests/test_db_performance_check.py +370 -370
- package/skills/engineering/diagnose/SKILL.md +117 -117
- package/skills/engineering/diagnose/scripts/hitl-loop.template.sh +41 -41
- package/skills/engineering/docs-seeker/SKILL.md +207 -207
- package/skills/engineering/docs-seeker/WORKFLOWS.md +505 -505
- package/skills/engineering/docs-seeker/references/best-practices.md +632 -632
- package/skills/engineering/docs-seeker/references/documentation-sources.md +461 -461
- package/skills/engineering/docs-seeker/references/error-handling.md +621 -621
- package/skills/engineering/docs-seeker/references/limitations.md +821 -821
- package/skills/engineering/docs-seeker/references/performance.md +574 -574
- package/skills/engineering/docs-seeker/references/tool-selection.md +262 -262
- package/skills/engineering/frontend-development/SKILL.md +398 -398
- package/skills/engineering/frontend-development/resources/common-patterns.md +330 -330
- package/skills/engineering/frontend-development/resources/complete-examples.md +871 -871
- package/skills/engineering/frontend-development/resources/component-patterns.md +501 -501
- package/skills/engineering/frontend-development/resources/data-fetching.md +766 -766
- package/skills/engineering/frontend-development/resources/file-organization.md +501 -501
- package/skills/engineering/frontend-development/resources/loading-and-error-states.md +500 -500
- package/skills/engineering/frontend-development/resources/performance.md +405 -405
- package/skills/engineering/frontend-development/resources/routing-guide.md +363 -363
- package/skills/engineering/frontend-development/resources/styling-guide.md +427 -427
- package/skills/engineering/frontend-development/resources/typescript-standards.md +417 -417
- package/skills/engineering/improve-codebase-architecture/DEEPENING.md +37 -37
- package/skills/engineering/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -44
- package/skills/engineering/improve-codebase-architecture/LANGUAGE.md +53 -53
- package/skills/engineering/improve-codebase-architecture/SKILL.md +71 -71
- package/skills/engineering/openai-docs/LICENSE.txt +201 -201
- package/skills/engineering/openai-docs/SKILL.md +69 -69
- package/skills/engineering/openai-docs/agents/openai.yaml +14 -14
- package/skills/engineering/openai-docs/assets/openai-small.svg +3 -3
- package/skills/engineering/openai-docs/references/gpt-5p4-prompting-guide.md +433 -433
- package/skills/engineering/openai-docs/references/latest-model.md +35 -35
- package/skills/engineering/openai-docs/references/upgrading-to-gpt-5p4.md +164 -164
- package/skills/engineering/playwright/LICENSE.txt +201 -201
- package/skills/engineering/playwright/NOTICE.txt +14 -14
- package/skills/engineering/playwright/SKILL.md +147 -147
- package/skills/engineering/playwright/agents/openai.yaml +6 -6
- package/skills/engineering/playwright/assets/playwright-small.svg +3 -3
- package/skills/engineering/playwright/references/cli.md +116 -116
- package/skills/engineering/playwright/references/workflows.md +95 -95
- package/skills/engineering/playwright/scripts/playwright_cli.sh +25 -25
- package/skills/engineering/playwright-interactive/LICENSE.txt +201 -201
- package/skills/engineering/playwright-interactive/NOTICE.txt +13 -13
- package/skills/engineering/playwright-interactive/SKILL.md +689 -689
- package/skills/engineering/playwright-interactive/agents/openai.yaml +6 -6
- package/skills/engineering/playwright-interactive/assets/playwright-small.svg +3 -3
- package/skills/engineering/render-deploy/LICENSE.txt +201 -201
- package/skills/engineering/render-deploy/SKILL.md +479 -479
- package/skills/engineering/render-deploy/agents/openai.yaml +14 -14
- package/skills/engineering/render-deploy/assets/docker.yaml +62 -62
- package/skills/engineering/render-deploy/assets/go-api.yaml +35 -35
- package/skills/engineering/render-deploy/assets/nextjs-postgres.yaml +35 -35
- package/skills/engineering/render-deploy/assets/node-express.yaml +25 -25
- package/skills/engineering/render-deploy/assets/python-django.yaml +89 -89
- package/skills/engineering/render-deploy/assets/render-small.svg +3 -3
- package/skills/engineering/render-deploy/assets/static-site.yaml +54 -54
- package/skills/engineering/render-deploy/references/blueprint-spec.md +718 -718
- package/skills/engineering/render-deploy/references/codebase-analysis.md +49 -49
- package/skills/engineering/render-deploy/references/configuration-guide.md +603 -603
- package/skills/engineering/render-deploy/references/deployment-details.md +224 -224
- package/skills/engineering/render-deploy/references/direct-creation.md +113 -113
- package/skills/engineering/render-deploy/references/error-patterns.md +13 -13
- package/skills/engineering/render-deploy/references/post-deploy-checks.md +36 -36
- package/skills/engineering/render-deploy/references/runtimes.md +473 -473
- package/skills/engineering/render-deploy/references/service-types.md +450 -450
- package/skills/engineering/render-deploy/references/troubleshooting-basics.md +36 -36
- package/skills/engineering/repomix/SKILL.md +215 -215
- package/skills/engineering/repomix/references/configuration.md +211 -211
- package/skills/engineering/repomix/references/usage-patterns.md +232 -232
- package/skills/engineering/repomix/scripts/README.md +179 -179
- package/skills/engineering/repomix/scripts/repomix_batch.py +455 -455
- package/skills/engineering/repomix/scripts/repos.example.json +15 -15
- package/skills/engineering/repomix/scripts/requirements.txt +15 -15
- package/skills/engineering/repomix/scripts/tests/test_repomix_batch.py +531 -531
- package/skills/engineering/setup-matt-pocock-skills/SKILL.md +121 -121
- package/skills/engineering/setup-matt-pocock-skills/domain.md +51 -51
- package/skills/engineering/setup-matt-pocock-skills/issue-tracker-github.md +22 -22
- package/skills/engineering/setup-matt-pocock-skills/issue-tracker-gitlab.md +23 -23
- package/skills/engineering/setup-matt-pocock-skills/issue-tracker-local.md +19 -19
- package/skills/engineering/setup-matt-pocock-skills/triage-labels.md +15 -15
- package/skills/engineering/shopify/README.md +66 -66
- package/skills/engineering/shopify/SKILL.md +319 -319
- package/skills/engineering/shopify/references/app-development.md +470 -470
- package/skills/engineering/shopify/references/extensions.md +493 -493
- package/skills/engineering/shopify/references/themes.md +498 -498
- package/skills/engineering/shopify/scripts/requirements.txt +19 -19
- package/skills/engineering/shopify/scripts/shopify_init.py +423 -423
- package/skills/engineering/shopify/scripts/tests/test_shopify_init.py +385 -385
- package/skills/engineering/tdd/SKILL.md +109 -109
- package/skills/engineering/tdd/deep-modules.md +33 -33
- package/skills/engineering/tdd/interface-design.md +31 -31
- package/skills/engineering/tdd/mocking.md +59 -59
- package/skills/engineering/tdd/refactoring.md +10 -10
- package/skills/engineering/tdd/tests.md +61 -61
- package/skills/engineering/to-issues/SKILL.md +81 -81
- package/skills/engineering/to-prd/SKILL.md +74 -74
- package/skills/engineering/triage/AGENT-BRIEF.md +168 -168
- package/skills/engineering/triage/OUT-OF-SCOPE.md +101 -101
- package/skills/engineering/triage/SKILL.md +103 -103
- package/skills/engineering/web-frameworks/SKILL.md +324 -324
- package/skills/engineering/web-frameworks/references/nextjs-app-router.md +465 -465
- package/skills/engineering/web-frameworks/references/nextjs-data-fetching.md +459 -459
- package/skills/engineering/web-frameworks/references/nextjs-optimization.md +511 -511
- package/skills/engineering/web-frameworks/references/nextjs-server-components.md +495 -495
- package/skills/engineering/web-frameworks/references/remix-icon-integration.md +603 -603
- package/skills/engineering/web-frameworks/references/turborepo-caching.md +551 -551
- package/skills/engineering/web-frameworks/references/turborepo-pipelines.md +517 -517
- package/skills/engineering/web-frameworks/references/turborepo-setup.md +542 -542
- package/skills/engineering/web-frameworks/scripts/nextjs_init.py +547 -547
- package/skills/engineering/web-frameworks/scripts/requirements.txt +16 -16
- package/skills/engineering/web-frameworks/scripts/tests/requirements.txt +3 -3
- package/skills/engineering/web-frameworks/scripts/tests/test_nextjs_init.py +319 -319
- package/skills/engineering/web-frameworks/scripts/tests/test_turborepo_migrate.py +374 -374
- package/skills/engineering/web-frameworks/scripts/turborepo_migrate.py +394 -394
- package/skills/engineering/write-a-skill/SKILL.md +117 -117
- package/skills/kilo-kit/SKILL.md +346 -346
- package/skills/kilo-kit/_template/SKILL.md +185 -185
- package/skills/kilo-kit/debugging/root-cause/SKILL.md +360 -360
- package/skills/kilo-kit/debugging/systematic/SKILL.md +339 -339
- package/skills/kilo-kit/debugging/verification/SKILL.md +424 -424
- package/skills/kilo-kit/development/backend/SKILL.md +540 -540
- package/skills/kilo-kit/development/security/SKILL.md +529 -529
- package/skills/kilo-kit/quality/code-review/SKILL.md +297 -297
- package/skills/kilo-kit/quality/testing/SKILL.md +540 -540
- package/skills/kilo-kit/references/output-formats.md +204 -204
- package/skills/kilo-kit/references/patterns.md +156 -156
- package/skills/kilo-kit/references/performance-benchmarks.md +90 -90
- package/skills/operations/chrome-devtools/SKILL.md +392 -392
- package/skills/operations/chrome-devtools/references/cdp-domains.md +694 -694
- package/skills/operations/chrome-devtools/references/performance-guide.md +940 -940
- package/skills/operations/chrome-devtools/references/puppeteer-reference.md +953 -953
- package/skills/operations/chrome-devtools/scripts/PERSISTENT-BROWSER.md +107 -107
- package/skills/operations/chrome-devtools/scripts/README.md +213 -213
- package/skills/operations/chrome-devtools/scripts/__tests__/selector.test.js +210 -210
- package/skills/operations/chrome-devtools/scripts/click.js +79 -79
- package/skills/operations/chrome-devtools/scripts/close-persistent.js +36 -36
- package/skills/operations/chrome-devtools/scripts/console.js +75 -75
- package/skills/operations/chrome-devtools/scripts/evaluate.js +49 -49
- package/skills/operations/chrome-devtools/scripts/fill.js +72 -72
- package/skills/operations/chrome-devtools/scripts/install-deps.sh +181 -181
- package/skills/operations/chrome-devtools/scripts/install.sh +83 -83
- package/skills/operations/chrome-devtools/scripts/launch-persistent.js +71 -71
- package/skills/operations/chrome-devtools/scripts/lib/browser.js +144 -144
- package/skills/operations/chrome-devtools/scripts/lib/selector.js +178 -178
- package/skills/operations/chrome-devtools/scripts/navigate.js +46 -46
- package/skills/operations/chrome-devtools/scripts/network.js +102 -102
- package/skills/operations/chrome-devtools/scripts/package-lock.json +1206 -1206
- package/skills/operations/chrome-devtools/scripts/package.json +15 -15
- package/skills/operations/chrome-devtools/scripts/performance.js +145 -145
- package/skills/operations/chrome-devtools/scripts/screenshot.js +180 -180
- package/skills/operations/chrome-devtools/scripts/snapshot.js +131 -131
- package/skills/operations/devops/.env.example +76 -76
- package/skills/operations/devops/SKILL.md +285 -285
- package/skills/operations/devops/references/browser-rendering.md +305 -305
- package/skills/operations/devops/references/cloudflare-d1-kv.md +123 -123
- package/skills/operations/devops/references/cloudflare-platform.md +271 -271
- package/skills/operations/devops/references/cloudflare-r2-storage.md +280 -280
- package/skills/operations/devops/references/cloudflare-workers-advanced.md +312 -312
- package/skills/operations/devops/references/cloudflare-workers-apis.md +309 -309
- package/skills/operations/devops/references/cloudflare-workers-basics.md +418 -418
- package/skills/operations/devops/references/docker-basics.md +297 -297
- package/skills/operations/devops/references/docker-compose.md +292 -292
- package/skills/operations/devops/references/gcloud-platform.md +297 -297
- package/skills/operations/devops/references/gcloud-services.md +304 -304
- package/skills/operations/devops/scripts/cloudflare_deploy.py +269 -269
- package/skills/operations/devops/scripts/docker_optimize.py +320 -320
- package/skills/operations/devops/scripts/requirements.txt +20 -20
- package/skills/operations/devops/scripts/tests/requirements.txt +3 -3
- package/skills/operations/devops/scripts/tests/test_cloudflare_deploy.py +285 -285
- package/skills/operations/devops/scripts/tests/test_docker_optimize.py +436 -436
- package/skills/operations/mcp-builder/LICENSE.txt +201 -201
- package/skills/operations/mcp-builder/SKILL.md +328 -328
- package/skills/operations/mcp-builder/reference/evaluation.md +601 -601
- package/skills/operations/mcp-builder/reference/mcp_best_practices.md +915 -915
- package/skills/operations/mcp-builder/reference/node_mcp_server.md +915 -915
- package/skills/operations/mcp-builder/reference/python_mcp_server.md +751 -751
- package/skills/operations/mcp-builder/scripts/connections.py +151 -151
- package/skills/operations/mcp-builder/scripts/evaluation.py +373 -373
- package/skills/operations/mcp-builder/scripts/example_evaluation.xml +22 -22
- package/skills/operations/mcp-builder/scripts/requirements.txt +2 -2
- package/skills/operations/mcp-management/README.md +219 -219
- package/skills/operations/mcp-management/SKILL.md +175 -175
- package/skills/operations/mcp-management/assets/tools.json +3043 -3043
- package/skills/operations/mcp-management/references/configuration.md +114 -114
- package/skills/operations/mcp-management/references/gemini-cli-integration.md +201 -201
- package/skills/operations/mcp-management/references/mcp-protocol.md +116 -116
- package/skills/operations/mcp-management/scripts/.env.example +10 -10
- package/skills/operations/mcp-management/scripts/cli.ts +155 -155
- package/skills/operations/mcp-management/scripts/dist/analyze-tools.js +70 -70
- package/skills/operations/mcp-management/scripts/dist/cli.js +131 -131
- package/skills/operations/mcp-management/scripts/dist/mcp-client.js +115 -115
- package/skills/operations/mcp-management/scripts/mcp-client.ts +163 -163
- package/skills/operations/mcp-management/scripts/package.json +18 -18
- package/skills/operations/mcp-management/scripts/tsconfig.json +15 -15
- package/skills/problem-solving/collision-zone-thinking/SKILL.md +62 -62
- package/skills/problem-solving/defense-in-depth/SKILL.md +130 -130
- package/skills/problem-solving/inversion-exercise/SKILL.md +58 -58
- package/skills/problem-solving/meta-pattern-recognition/SKILL.md +54 -54
- package/skills/problem-solving/root-cause-tracing/SKILL.md +177 -177
- package/skills/problem-solving/root-cause-tracing/find-polluter.sh +63 -63
- package/skills/problem-solving/scale-game/SKILL.md +63 -63
- package/skills/problem-solving/sequential-thinking/README.md +118 -118
- package/skills/problem-solving/sequential-thinking/SKILL.md +93 -93
- package/skills/problem-solving/sequential-thinking/references/advanced.md +122 -122
- package/skills/problem-solving/sequential-thinking/references/examples.md +274 -274
- package/skills/problem-solving/simplification-cascades/SKILL.md +76 -76
- package/skills/problem-solving/when-stuck/SKILL.md +88 -88
- package/skills/productivity/caveman/SKILL.md +49 -49
- package/skills/productivity/grill-me/SKILL.md +10 -10
- package/skills/productivity/grill-with-docs/ADR-FORMAT.md +47 -47
- package/skills/productivity/grill-with-docs/CONTEXT-FORMAT.md +77 -77
- package/skills/productivity/grill-with-docs/SKILL.md +88 -88
- package/skills/productivity/writing-skills/graphviz-conventions.dot +171 -171
- package/skills/productivity/zoom-out/SKILL.md +7 -7
- package/skills/writing-docs/doc/LICENSE.txt +201 -201
- package/skills/writing-docs/doc/SKILL.md +80 -80
- package/skills/writing-docs/doc/agents/openai.yaml +6 -6
- package/skills/writing-docs/doc/assets/doc-small.svg +3 -3
- package/skills/writing-docs/doc/scripts/render_docx.py +296 -296
- package/skills/writing-docs/docx/LICENSE.txt +30 -30
- package/skills/writing-docs/docx/SKILL.md +196 -196
- package/skills/writing-docs/docx/docx-js.md +349 -349
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -1499
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -146
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -1085
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -11
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -3081
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -23
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -185
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -287
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -1676
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -28
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -144
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -174
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -25
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -18
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -59
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -56
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -195
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -582
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -25
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -4439
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -570
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -509
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -12
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -108
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -96
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -3646
- package/skills/writing-docs/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -116
- package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -42
- package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -50
- package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -49
- package/skills/writing-docs/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -33
- package/skills/writing-docs/docx/ooxml/schemas/mce/mc.xsd +75 -75
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -560
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -67
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -14
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -20
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -13
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -4
- package/skills/writing-docs/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -8
- package/skills/writing-docs/docx/ooxml/scripts/pack.py +159 -159
- package/skills/writing-docs/docx/ooxml/scripts/unpack.py +29 -29
- package/skills/writing-docs/docx/ooxml/scripts/validate.py +69 -69
- package/skills/writing-docs/docx/ooxml/scripts/validation/__init__.py +15 -15
- package/skills/writing-docs/docx/ooxml/scripts/validation/base.py +951 -951
- package/skills/writing-docs/docx/ooxml/scripts/validation/docx.py +274 -274
- package/skills/writing-docs/docx/ooxml/scripts/validation/pptx.py +315 -315
- package/skills/writing-docs/docx/ooxml/scripts/validation/redlining.py +279 -279
- package/skills/writing-docs/docx/ooxml.md +609 -609
- package/skills/writing-docs/docx/scripts/__init__.py +1 -1
- package/skills/writing-docs/docx/scripts/document.py +1276 -1276
- package/skills/writing-docs/docx/scripts/templates/comments.xml +2 -2
- package/skills/writing-docs/docx/scripts/templates/commentsExtended.xml +2 -2
- package/skills/writing-docs/docx/scripts/templates/commentsExtensible.xml +2 -2
- package/skills/writing-docs/docx/scripts/templates/commentsIds.xml +2 -2
- package/skills/writing-docs/docx/scripts/templates/people.xml +2 -2
- package/skills/writing-docs/docx/scripts/utilities.py +374 -374
- package/skills/writing-docs/mermaidjs-v11/SKILL.md +115 -115
- package/skills/writing-docs/mermaidjs-v11/references/cli-usage.md +228 -228
- package/skills/writing-docs/mermaidjs-v11/references/configuration.md +232 -232
- package/skills/writing-docs/mermaidjs-v11/references/diagram-types.md +315 -315
- package/skills/writing-docs/mermaidjs-v11/references/examples.md +344 -344
- package/skills/writing-docs/mermaidjs-v11/references/integration.md +310 -310
- package/skills/writing-docs/pdf/LICENSE.txt +30 -30
- package/skills/writing-docs/pdf/SKILL.md +294 -294
- package/skills/writing-docs/pdf/forms.md +205 -205
- package/skills/writing-docs/pdf/reference.md +611 -611
- package/skills/writing-docs/pdf/scripts/check_bounding_boxes.py +70 -70
- package/skills/writing-docs/pdf/scripts/check_bounding_boxes_test.py +226 -226
- package/skills/writing-docs/pdf/scripts/check_fillable_fields.py +12 -12
- package/skills/writing-docs/pdf/scripts/convert_pdf_to_images.py +35 -35
- package/skills/writing-docs/pdf/scripts/create_validation_image.py +41 -41
- package/skills/writing-docs/pdf/scripts/extract_form_field_info.py +152 -152
- package/skills/writing-docs/pdf/scripts/fill_fillable_fields.py +114 -114
- package/skills/writing-docs/pdf/scripts/fill_pdf_form_with_annotations.py +107 -107
- package/skills/writing-docs/pptx/LICENSE.txt +30 -30
- package/skills/writing-docs/pptx/SKILL.md +483 -483
- package/skills/writing-docs/pptx/html2pptx.md +624 -624
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -1499
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -146
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -1085
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -11
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -3081
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -23
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -185
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -287
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -1676
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -28
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -144
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -174
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -25
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -18
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -59
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -56
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -195
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -582
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -25
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -4439
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -570
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -509
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -12
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -108
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -96
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -3646
- package/skills/writing-docs/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -116
- package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -42
- package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -50
- package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -49
- package/skills/writing-docs/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -33
- package/skills/writing-docs/pptx/ooxml/schemas/mce/mc.xsd +75 -75
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -560
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -67
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -14
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -20
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -13
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -4
- package/skills/writing-docs/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -8
- package/skills/writing-docs/pptx/ooxml/scripts/pack.py +159 -159
- package/skills/writing-docs/pptx/ooxml/scripts/unpack.py +29 -29
- package/skills/writing-docs/pptx/ooxml/scripts/validate.py +69 -69
- package/skills/writing-docs/pptx/ooxml/scripts/validation/__init__.py +15 -15
- package/skills/writing-docs/pptx/ooxml/scripts/validation/base.py +951 -951
- package/skills/writing-docs/pptx/ooxml/scripts/validation/docx.py +274 -274
- package/skills/writing-docs/pptx/ooxml/scripts/validation/pptx.py +315 -315
- package/skills/writing-docs/pptx/ooxml/scripts/validation/redlining.py +279 -279
- package/skills/writing-docs/pptx/ooxml.md +426 -426
- package/skills/writing-docs/pptx/scripts/html2pptx.js +978 -978
- package/skills/writing-docs/pptx/scripts/inventory.py +1020 -1020
- package/skills/writing-docs/pptx/scripts/rearrange.py +231 -231
- package/skills/writing-docs/pptx/scripts/replace.py +385 -385
- package/skills/writing-docs/pptx/scripts/thumbnail.py +450 -450
- package/skills/writing-docs/slides/LICENSE.txt +201 -201
- package/skills/writing-docs/slides/SKILL.md +71 -71
- package/skills/writing-docs/slides/agents/openai.yaml +6 -6
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/code.js +104 -104
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/image.js +333 -333
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/index.js +33 -33
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/latex.js +51 -51
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/layout.js +643 -643
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/layout_builders.js +358 -358
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/svg.js +36 -36
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/text.js +789 -789
- package/skills/writing-docs/slides/assets/pptxgenjs_helpers/util.js +24 -24
- package/skills/writing-docs/slides/assets/slides-small.svg +3 -3
- package/skills/writing-docs/slides/references/pptxgenjs-helpers.md +61 -61
- package/skills/writing-docs/slides/scripts/create_montage.py +300 -300
- package/skills/writing-docs/slides/scripts/detect_font.py +873 -873
- package/skills/writing-docs/slides/scripts/ensure_raster_image.py +202 -202
- package/skills/writing-docs/slides/scripts/render_slides.py +273 -273
- package/skills/writing-docs/slides/scripts/slides_test.py +201 -201
- package/skills/writing-docs/template-skill/SKILL.md +26 -26
- package/skills/writing-docs/xlsx/LICENSE.txt +30 -30
- package/skills/writing-docs/xlsx/SKILL.md +288 -288
- package/skills/writing-docs/xlsx/recalc.py +177 -177
- package/src/core/KILO_MASTER.md +448 -448
- package/src/tools/validate-skill.js +421 -421
|
@@ -1,455 +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())
|
|
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())
|