@ngxtm/devkit 2.1.0 → 3.0.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/README.md +57 -197
- package/cli/detect.js +292 -0
- package/cli/index.js +204 -92
- package/cli/init.js +245 -0
- package/cli/update.js +243 -0
- package/cli/utils.js +195 -0
- package/hooks/lib/__tests__/ck-config-utils.test.cjs +10 -0
- package/hooks/lib/__tests__/statusline-integration.test.cjs +46 -75
- package/hooks/scout-block/tests/test-monorepo-scenarios.cjs +2 -2
- package/hooks/tests/test-ckignore.cjs +7 -2
- package/package.json +16 -20
- package/rules-index.json +76 -0
- package/scripts/generate-index.js +223 -0
- package/scripts/merge-commands.js +290 -0
- package/scripts/organize-rules.js +226 -0
- package/templates/base/hooks/lib/ck-config-utils.cjs +769 -0
- package/templates/base/hooks/lib/ck-paths.cjs +110 -0
- package/templates/base/hooks/lib/colors.cjs +95 -0
- package/templates/base/hooks/lib/config-counter.cjs +103 -0
- package/templates/base/hooks/lib/context-builder.cjs +600 -0
- package/templates/base/hooks/lib/context-tracker.cjs +335 -0
- package/templates/base/hooks/lib/privacy-checker.cjs +297 -0
- package/templates/base/hooks/lib/project-detector.cjs +430 -0
- package/templates/base/hooks/lib/scout-checker.cjs +172 -0
- package/templates/base/hooks/lib/transcript-parser.cjs +164 -0
- package/templates/base/hooks/privacy-block.cjs +145 -0
- package/agents/backend-engineer.md +0 -154
- package/agents/brainstormer.md +0 -169
- package/agents/business-analyst.md +0 -166
- package/agents/database-architect.md +0 -159
- package/agents/debugger.md +0 -155
- package/agents/designer.md +0 -150
- package/agents/devops-engineer.md +0 -155
- package/agents/docs-manager.md +0 -171
- package/agents/frontend-engineer.md +0 -159
- package/agents/game-engineer.md +0 -148
- package/agents/mobile-engineer.md +0 -149
- package/agents/performance-engineer.md +0 -152
- package/agents/planner.md +0 -161
- package/agents/project-manager.md +0 -160
- package/agents/researcher.md +0 -146
- package/agents/reviewer.md +0 -155
- package/agents/scouter.md +0 -157
- package/agents/security-engineer.md +0 -154
- package/agents/tech-lead.md +0 -159
- package/agents/tester.md +0 -157
- package/agents-claudekit/brainstormer.md +0 -113
- package/agents-claudekit/code-reviewer.md +0 -157
- package/agents-claudekit/code-simplifier.md +0 -42
- package/agents-claudekit/copywriter.md +0 -110
- package/agents-claudekit/database-admin.md +0 -92
- package/agents-claudekit/debugger.md +0 -137
- package/agents-claudekit/docs-manager.md +0 -208
- package/agents-claudekit/fullstack-developer.md +0 -95
- package/agents-claudekit/git-manager.md +0 -394
- package/agents-claudekit/journal-writer.md +0 -113
- package/agents-claudekit/mcp-manager.md +0 -93
- package/agents-claudekit/planner.md +0 -108
- package/agents-claudekit/project-manager.md +0 -125
- package/agents-claudekit/researcher.md +0 -38
- package/agents-claudekit/scout-external.md +0 -141
- package/agents-claudekit/scout.md +0 -107
- package/agents-claudekit/tester.md +0 -105
- package/agents-claudekit/ui-ux-designer.md +0 -236
- package/commands/ask.md +0 -64
- package/commands/brainstorm.md +0 -64
- package/commands/code.md +0 -64
- package/commands/cook.md +0 -64
- package/commands/debug.md +0 -64
- package/commands/design/fast.md +0 -134
- package/commands/fix/fast.md +0 -84
- package/commands/fix/hard.md +0 -116
- package/commands/fix.md +0 -64
- package/commands/plan/fast.md +0 -78
- package/commands/plan/hard.md +0 -131
- package/commands/plan.md +0 -64
- package/commands/test.md +0 -64
- package/hooks/tests/test-modularization-hook.cjs +0 -126
- package/matrix-skills/_index.yaml +0 -275
- package/matrix-skills/ai-ml.yaml +0 -353
- package/matrix-skills/architecture.yaml +0 -93
- package/matrix-skills/backend.yaml +0 -280
- package/matrix-skills/cloud.yaml +0 -112
- package/matrix-skills/data.yaml +0 -74
- package/matrix-skills/design.yaml +0 -98
- package/matrix-skills/devops.yaml +0 -200
- package/matrix-skills/frontend.yaml +0 -200
- package/matrix-skills/gaming.yaml +0 -39
- package/matrix-skills/languages.yaml +0 -160
- package/matrix-skills/management.yaml +0 -50
- package/matrix-skills/mcp.yaml +0 -82
- package/matrix-skills/mobile.yaml +0 -85
- package/matrix-skills/performance.yaml +0 -23
- package/matrix-skills/planning.yaml +0 -117
- package/matrix-skills/quality.yaml +0 -195
- package/matrix-skills/research.yaml +0 -106
- package/matrix-skills/security.yaml +0 -293
- package/matrix-skills/tools.yaml +0 -352
- package/output-styles/coding-level-0-eli5.md +0 -103
- package/output-styles/coding-level-1-junior.md +0 -124
- package/output-styles/coding-level-2-mid.md +0 -146
- package/output-styles/coding-level-3-senior.md +0 -148
- package/output-styles/coding-level-4-lead.md +0 -159
- package/output-styles/coding-level-5-god.md +0 -91
- package/rules/README.md +0 -141
- package/rules/metadata.json +0 -54
- package/settings.json +0 -3
- package/statusline.cjs +0 -500
- package/statusline.ps1 +0 -307
- package/statusline.sh +0 -237
- package/workflows/development-rules.md +0 -42
- package/workflows/documentation-management.md +0 -121
- package/workflows/orchestration-protocol.md +0 -16
- package/workflows/primary-workflow.md +0 -45
- /package/{commands → merged-commands}/ask/fast.md +0 -0
- /package/{commands → merged-commands}/ask/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/ask.md +0 -0
- /package/{commands → merged-commands}/auto.md +0 -0
- /package/{commands-claudekit → merged-commands}/bootstrap/auto/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/bootstrap/auto/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/bootstrap/auto.md +0 -0
- /package/{commands-claudekit → merged-commands}/bootstrap.md +0 -0
- /package/{commands → merged-commands}/brainstorm/fast.md +0 -0
- /package/{commands → merged-commands}/brainstorm/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/brainstorm.md +0 -0
- /package/{commands-claudekit → merged-commands}/ck-help.md +0 -0
- /package/{commands-claudekit → merged-commands}/code/auto.md +0 -0
- /package/{commands → merged-commands}/code/fast.md +0 -0
- /package/{commands → merged-commands}/code/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/code/no-test.md +0 -0
- /package/{commands-claudekit → merged-commands}/code/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/code.md +0 -0
- /package/{commands-claudekit → merged-commands}/coding-level.md +0 -0
- /package/{commands-claudekit → merged-commands}/content/cro.md +0 -0
- /package/{commands-claudekit → merged-commands}/content/enhance.md +0 -0
- /package/{commands-claudekit → merged-commands}/content/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/content/good.md +0 -0
- /package/{commands-claudekit → merged-commands}/cook/auto/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/cook/auto/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/cook/auto.md +0 -0
- /package/{commands → merged-commands}/cook/fast.md +0 -0
- /package/{commands → merged-commands}/cook/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/cook.md +0 -0
- /package/{commands → merged-commands}/debug/fast.md +0 -0
- /package/{commands → merged-commands}/debug/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/debug.md +0 -0
- /package/{commands → merged-commands}/deploy/check.md +0 -0
- /package/{commands → merged-commands}/deploy/preview.md +0 -0
- /package/{commands → merged-commands}/deploy/production.md +0 -0
- /package/{commands → merged-commands}/deploy/rollback.md +0 -0
- /package/{commands → merged-commands}/deploy.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/3d.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/describe.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/good.md +0 -0
- /package/{commands → merged-commands}/design/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/screenshot.md +0 -0
- /package/{commands-claudekit → merged-commands}/design/video.md +0 -0
- /package/{commands → merged-commands}/design.md +0 -0
- /package/{commands → merged-commands}/docs/audit.md +0 -0
- /package/{commands → merged-commands}/docs/business.md +0 -0
- /package/{commands → merged-commands}/docs/core.md +0 -0
- /package/{commands-claudekit → merged-commands}/docs/init.md +0 -0
- /package/{commands-claudekit → merged-commands}/docs/summarize.md +0 -0
- /package/{commands-claudekit → merged-commands}/docs/update.md +0 -0
- /package/{commands → merged-commands}/docs.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/ci.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/logs.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/test.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/types.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix/ui.md +0 -0
- /package/{commands-claudekit → merged-commands}/fix.md +0 -0
- /package/{commands-claudekit → merged-commands}/git/cm.md +0 -0
- /package/{commands-claudekit → merged-commands}/git/cp.md +0 -0
- /package/{commands-claudekit → merged-commands}/git/merge.md +0 -0
- /package/{commands-claudekit → merged-commands}/git/pr.md +0 -0
- /package/{commands-claudekit → merged-commands}/integrate/polar.md +0 -0
- /package/{commands-claudekit → merged-commands}/integrate/sepay.md +0 -0
- /package/{commands-claudekit → merged-commands}/journal.md +0 -0
- /package/{commands-claudekit → merged-commands}/kanban.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/archive.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/ci.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/cro.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/fast.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/two.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan/validate.md +0 -0
- /package/{commands-claudekit → merged-commands}/plan.md +0 -0
- /package/{commands-claudekit → merged-commands}/preview.md +0 -0
- /package/{commands-claudekit → merged-commands}/review/codebase/parallel.md +0 -0
- /package/{commands-claudekit → merged-commands}/review/codebase.md +0 -0
- /package/{commands → merged-commands}/review/fast.md +0 -0
- /package/{commands → merged-commands}/review/hard.md +0 -0
- /package/{commands → merged-commands}/review.md +0 -0
- /package/{commands-claudekit → merged-commands}/scout/ext.md +0 -0
- /package/{commands-claudekit → merged-commands}/scout.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/add.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/create.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/fix-logs.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/optimize/auto.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/optimize.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/plan.md +0 -0
- /package/{commands-claudekit → merged-commands}/skill/update.md +0 -0
- /package/{commands → merged-commands}/test/fast.md +0 -0
- /package/{commands → merged-commands}/test/hard.md +0 -0
- /package/{commands-claudekit → merged-commands}/test/ui.md +0 -0
- /package/{commands-claudekit → merged-commands}/test.md +0 -0
- /package/{commands-claudekit → merged-commands}/use-mcp.md +0 -0
- /package/{commands-claudekit → merged-commands}/watzup.md +0 -0
- /package/{commands-claudekit → merged-commands}/worktree.md +0 -0
- /package/{rules → templates/dart/rules}/dart/best-practices/SKILL.md +0 -0
- /package/{rules → templates/dart/rules}/dart/language/SKILL.md +0 -0
- /package/{rules → templates/dart/rules}/dart/tooling/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/auto-route-navigation/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/auto-route-navigation/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/auto-route-navigation/references/router-config.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc-state-management/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc-state-management/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc-state-management/references/auth-bloc-example.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc-state-management/references/equatable-usage.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc-state-management/references/property-based-state.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/bloc.rule.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/cicd/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/cicd/references/advanced-workflow.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/cicd/references/fastlane.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/cicd/references/github-actions.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/dependency-injection/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/dependency-injection/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/dependency-injection/references/modules.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/error-handling/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/error-handling/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/error-handling/references/error-mapping.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/feature-based-clean-architecture/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/feature-based-clean-architecture/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/feature-based-clean-architecture/references/folder-structure.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-navigation/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-navigation/references/app-pages.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-navigation/references/middleware-example.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-state-management/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-state-management/references/binding-example.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/getx-state-management/references/reactive-vs-simple.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/go-router-navigation/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/idiomatic-flutter/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/layer-based-clean-architecture/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/layer-based-clean-architecture/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/layer-based-clean-architecture/references/repository-mapping.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/localization/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/localization/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/localization/references/sheet-loader.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/navigator-v1-navigation/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/navigator-v1-navigation/references/on-generate-route.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/performance/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/retrofit-networking/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/retrofit-networking/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/retrofit-networking/references/token-refresh.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/riverpod-state-management/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/riverpod-state-management/references/architecture.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/riverpod-state-management/references/best-practices.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/riverpod-state-management/references/testing.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/riverpod.rule.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/security/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/security/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/security/references/network-security.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/SKILL.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/REFERENCE.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/bloc-testing.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/integration-testing.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/robot-pattern.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/unit-testing.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/testing/references/widget-testing.md +0 -0
- /package/{rules → templates/flutter/rules}/flutter/widgets/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/chi-router/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/chi-router/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/chi-router/references/routing-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/cobra-cli/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/cobra-cli/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/cobra-cli/references/command-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/core/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/core/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/core/references/concurrency-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/core/references/error-handling.md +0 -0
- /package/{rules → templates/golang/rules}/golang/echo-framework/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/echo-framework/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/echo-framework/references/middleware-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/echo-framework/references/routing-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/ent-orm/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/ent-orm/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/ent-orm/references/schema-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/fiber-framework/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/fiber-framework/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/fiber-framework/references/routing-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gin-framework/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gin-framework/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gin-framework/references/middleware-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gorm-orm/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gorm-orm/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gorm-orm/references/model-definitions.md +0 -0
- /package/{rules → templates/golang/rules}/golang/gorm-orm/references/query-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/grpc/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/grpc/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/grpc/references/service-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/testify/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/testify/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/testify/references/assert-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/validator/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/validator/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/validator/references/validation-tags.md +0 -0
- /package/{rules → templates/golang/rules}/golang/viper-config/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/viper-config/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/viper-config/references/config-loading.md +0 -0
- /package/{rules → templates/golang/rules}/golang/wire-di/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/wire-di/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/wire-di/references/provider-patterns.md +0 -0
- /package/{rules → templates/golang/rules}/golang/zap-logging/SKILL.md +0 -0
- /package/{rules → templates/golang/rules}/golang/zap-logging/references/REFERENCE.md +0 -0
- /package/{rules → templates/golang/rules}/golang/zap-logging/references/logger-config.md +0 -0
- /package/{rules → templates/java/rules}/java/build-gradle/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/build-gradle/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/build-gradle/references/kotlin-dsl.md +0 -0
- /package/{rules → templates/java/rules}/java/build-gradle/references/task-configuration.md +0 -0
- /package/{rules → templates/java/rules}/java/build-maven/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/build-maven/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/build-maven/references/dependency-management.md +0 -0
- /package/{rules → templates/java/rules}/java/build-maven/references/lifecycle-phases.md +0 -0
- /package/{rules → templates/java/rules}/java/graalvm-native/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/graalvm-native/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/java-collections-streams/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/java-collections-streams/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/java-collections-streams/references/collectors-patterns.md +0 -0
- /package/{rules → templates/java/rules}/java/java-collections-streams/references/stream-pipelines.md +0 -0
- /package/{rules → templates/java/rules}/java/java-concurrency/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/java-concurrency/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/java-concurrency/references/completable-future.md +0 -0
- /package/{rules → templates/java/rules}/java/java-concurrency/references/executor-patterns.md +0 -0
- /package/{rules → templates/java/rules}/java/java-concurrency/references/virtual-threads.md +0 -0
- /package/{rules → templates/java/rules}/java/java-core-language/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/java-core-language/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/java-core-language/references/jvm-memory-model.md +0 -0
- /package/{rules → templates/java/rules}/java/java-core-language/references/modern-java-features.md +0 -0
- /package/{rules → templates/java/rules}/java/java-project-structure/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/java-project-structure/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/java-project-structure/references/maven-project-layout.md +0 -0
- /package/{rules → templates/java/rules}/java/java-project-structure/references/module-system.md +0 -0
- /package/{rules → templates/java/rules}/java/micronaut-core/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/micronaut-core/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/micronaut-reactive/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/micronaut-reactive/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/quarkus-core/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/quarkus-core/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/quarkus-reactive/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/quarkus-reactive/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-batch/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-batch/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-architecture/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-architecture/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-architecture/references/auto-configuration.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-architecture/references/configuration-properties.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-web/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-boot-web/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-cloud/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-cloud/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-data-jpa/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-data-jpa/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-security/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-security/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/spring-security/references/jwt-auth-flow.md +0 -0
- /package/{rules → templates/java/rules}/java/testing-junit-mockito/SKILL.md +0 -0
- /package/{rules → templates/java/rules}/java/testing-junit-mockito/references/REFERENCE.md +0 -0
- /package/{rules → templates/java/rules}/java/testing-junit-mockito/references/junit5-patterns.md +0 -0
- /package/{rules → templates/java/rules}/java/testing-junit-mockito/references/mockito-patterns.md +0 -0
- /package/{rules → templates/java/rules}/java/testing-junit-mockito/references/spring-boot-testing.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/best-practices/SKILL.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/best-practices/references/REFERENCE.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/language/SKILL.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/language/references/REFERENCE.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/tooling/SKILL.md +0 -0
- /package/{rules → templates/javascript/rules}/javascript/tooling/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/api-standards/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/api-standards/references/pagination-wrapper.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/architecture/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/architecture/references/dynamic-module.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/caching/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/caching/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/caching/references/cache-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/configuration/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/configuration/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/configuration/references/config-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/controllers-services/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/controllers-services/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/controllers-services/references/controller-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/controllers-services/references/service-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/database/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/database/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/database/references/typeorm-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/deployment/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/deployment/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/deployment/references/deployment-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/documentation/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/documentation/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/documentation/references/swagger-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/error-handling/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/error-handling/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/error-handling/references/exception-filters.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/file-uploads/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/file-uploads/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/file-uploads/references/upload-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/observability/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/observability/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/observability/references/logging-metrics.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/performance/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/performance/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/performance/references/performance-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/real-time/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/real-time/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/real-time/references/websocket-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/scheduling/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/scheduling/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/scheduling/references/scheduling-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/search/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/search/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/search/references/search-patterns.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/security/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/security/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/security/references/authentication.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/testing/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/testing/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/testing/references/unit-testing.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/transport/SKILL.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/transport/references/REFERENCE.md +0 -0
- /package/{rules → templates/nestjs/rules}/nestjs/transport/references/microservices-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/app-router/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/app-router/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/app-router/references/routing-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/architecture/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/architecture/references/fsd-structure.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/authentication/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/authentication/references/auth-implementation.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/caching/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/caching/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/caching/references/cache-strategies.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/data-access-layer/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/data-access-layer/references/patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/data-fetching/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/data-fetching/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/data-fetching/references/fetch-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/internationalization/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/internationalization/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/internationalization/references/i18n-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/optimization/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/optimization/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/optimization/references/optimization-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/rendering/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/rendering/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/rendering/references/rendering-modes.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-actions/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-actions/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-actions/references/action-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-components/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-components/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/server-components/references/component-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/state-management/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/state-management/references/REFERENCE.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/state-management/references/state-patterns.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/styling/SKILL.md +0 -0
- /package/{rules → templates/nextjs/rules}/nextjs/styling/references/implementation.md +0 -0
- /package/{rules → templates/react/rules}/react/component-patterns/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/component-patterns/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/hooks/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/hooks/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/hooks.rule.md +0 -0
- /package/{rules → templates/react/rules}/react/performance/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/performance/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/security/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/security/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/state-management/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/state-management/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/testing/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/testing/references/REFERENCE.md +0 -0
- /package/{rules → templates/react/rules}/react/tooling/SKILL.md +0 -0
- /package/{rules → templates/react/rules}/react/typescript/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/actix-web/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/actix-web/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/actix-web/references/handler-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/async-graphql/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/async-graphql/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/async-graphql/references/schema-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/axum/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/axum/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/axum/references/handler-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/bevy/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/bevy/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/bevy/references/ecs-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/clap/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/clap/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/clap/references/derive-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/core/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/core/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/core/references/error-handling.md +0 -0
- /package/{rules → templates/rust/rules}/rust/diesel-orm/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/diesel-orm/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/diesel-orm/references/schema-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/rocket/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/rocket/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/rocket/references/handler-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sea-orm/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sea-orm/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sea-orm/references/entity-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/serde-serialization/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/serde-serialization/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/serde-serialization/references/serialization-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sqlx-database/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sqlx-database/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/sqlx-database/references/query-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tauri/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tauri/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tauri/references/command-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tokio-runtime/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tokio-runtime/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tokio-runtime/references/async-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tokio-runtime/references/synchronization.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tonic/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tonic/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tonic/references/service-patterns.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tracing/SKILL.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tracing/references/REFERENCE.md +0 -0
- /package/{rules → templates/rust/rules}/rust/tracing/references/instrumentation.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/best-practices/SKILL.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/best-practices/references/REFERENCE.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/language/SKILL.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/language/references/REFERENCE.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/patterns.rule.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/security/SKILL.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/security/references/REFERENCE.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/tooling/SKILL.md +0 -0
- /package/{rules → templates/typescript/rules}/typescript/tooling/references/REFERENCE.md +0 -0
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Merge Commands Script
|
|
5
|
+
*
|
|
6
|
+
* Merges commands from two sources:
|
|
7
|
+
* - commands/ (agent-assistant style)
|
|
8
|
+
* - commands-claudekit/ (claudekit style)
|
|
9
|
+
*
|
|
10
|
+
* Strategy:
|
|
11
|
+
* 1. For conflicting commands, prefer claudekit (more sophisticated)
|
|
12
|
+
* 2. For sub-commands, merge all unique sub-commands from both sources
|
|
13
|
+
* 3. For unique commands, copy as-is
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
const fs = require('fs');
|
|
17
|
+
const path = require('path');
|
|
18
|
+
|
|
19
|
+
const PACKAGE_ROOT = path.join(__dirname, '..');
|
|
20
|
+
const COMMANDS_DIR = path.join(PACKAGE_ROOT, 'commands');
|
|
21
|
+
const COMMANDS_CLAUDEKIT_DIR = path.join(PACKAGE_ROOT, 'commands-claudekit');
|
|
22
|
+
const MERGED_DIR = path.join(PACKAGE_ROOT, 'merged-commands');
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Merge strategy for conflicting commands
|
|
26
|
+
* - 'claudekit': Use claudekit version
|
|
27
|
+
* - 'agent': Use agent-assistant version
|
|
28
|
+
* - 'merge': Merge both (claudekit base, add agent sub-commands)
|
|
29
|
+
*/
|
|
30
|
+
const MERGE_STRATEGY = {
|
|
31
|
+
// Prefer claudekit for these (more sophisticated)
|
|
32
|
+
'ask.md': 'claudekit',
|
|
33
|
+
'bootstrap.md': 'claudekit',
|
|
34
|
+
'ck-help.md': 'claudekit',
|
|
35
|
+
'coding-level.md': 'claudekit',
|
|
36
|
+
'debug.md': 'claudekit',
|
|
37
|
+
'journal.md': 'claudekit',
|
|
38
|
+
'kanban.md': 'claudekit',
|
|
39
|
+
'preview.md': 'claudekit',
|
|
40
|
+
'scout.md': 'claudekit',
|
|
41
|
+
'use-mcp.md': 'claudekit',
|
|
42
|
+
'watzup.md': 'claudekit',
|
|
43
|
+
'worktree.md': 'claudekit',
|
|
44
|
+
|
|
45
|
+
// Prefer agent-assistant for these
|
|
46
|
+
'auto.md': 'agent',
|
|
47
|
+
'deploy.md': 'agent',
|
|
48
|
+
|
|
49
|
+
// Merge both for these (combine sub-commands)
|
|
50
|
+
'brainstorm.md': 'merge',
|
|
51
|
+
'code.md': 'merge',
|
|
52
|
+
'cook.md': 'merge',
|
|
53
|
+
'design.md': 'merge',
|
|
54
|
+
'docs.md': 'merge',
|
|
55
|
+
'fix.md': 'merge',
|
|
56
|
+
'plan.md': 'merge',
|
|
57
|
+
'review.md': 'merge',
|
|
58
|
+
'test.md': 'merge'
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
/**
|
|
62
|
+
* For merged commands, which source provides the base .md file
|
|
63
|
+
*/
|
|
64
|
+
const MERGE_BASE = {
|
|
65
|
+
'brainstorm.md': 'claudekit',
|
|
66
|
+
'code.md': 'claudekit',
|
|
67
|
+
'cook.md': 'claudekit',
|
|
68
|
+
'design.md': 'agent',
|
|
69
|
+
'docs.md': 'claudekit',
|
|
70
|
+
'fix.md': 'claudekit',
|
|
71
|
+
'plan.md': 'claudekit',
|
|
72
|
+
'review.md': 'agent',
|
|
73
|
+
'test.md': 'claudekit'
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Get all files and directories from a path recursively
|
|
78
|
+
*/
|
|
79
|
+
function getAllEntries(dir, basePath = '') {
|
|
80
|
+
const entries = { files: [], dirs: [] };
|
|
81
|
+
|
|
82
|
+
if (!fs.existsSync(dir)) return entries;
|
|
83
|
+
|
|
84
|
+
const items = fs.readdirSync(dir, { withFileTypes: true });
|
|
85
|
+
|
|
86
|
+
for (const item of items) {
|
|
87
|
+
const relativePath = path.join(basePath, item.name);
|
|
88
|
+
|
|
89
|
+
if (item.isDirectory()) {
|
|
90
|
+
entries.dirs.push(relativePath);
|
|
91
|
+
const subEntries = getAllEntries(path.join(dir, item.name), relativePath);
|
|
92
|
+
entries.files.push(...subEntries.files);
|
|
93
|
+
entries.dirs.push(...subEntries.dirs);
|
|
94
|
+
} else {
|
|
95
|
+
entries.files.push(relativePath);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return entries;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Copy file with directory creation
|
|
104
|
+
*/
|
|
105
|
+
function copyFile(src, dest) {
|
|
106
|
+
const destDir = path.dirname(dest);
|
|
107
|
+
fs.mkdirSync(destDir, { recursive: true });
|
|
108
|
+
fs.copyFileSync(src, dest);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Copy directory recursively
|
|
113
|
+
*/
|
|
114
|
+
function copyDir(src, dest) {
|
|
115
|
+
if (!fs.existsSync(src)) return 0;
|
|
116
|
+
|
|
117
|
+
fs.mkdirSync(dest, { recursive: true });
|
|
118
|
+
let count = 0;
|
|
119
|
+
|
|
120
|
+
const entries = fs.readdirSync(src, { withFileTypes: true });
|
|
121
|
+
|
|
122
|
+
for (const entry of entries) {
|
|
123
|
+
const srcPath = path.join(src, entry.name);
|
|
124
|
+
const destPath = path.join(dest, entry.name);
|
|
125
|
+
|
|
126
|
+
if (entry.isDirectory()) {
|
|
127
|
+
count += copyDir(srcPath, destPath);
|
|
128
|
+
} else {
|
|
129
|
+
fs.copyFileSync(srcPath, destPath);
|
|
130
|
+
count++;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
return count;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Merge commands from both sources
|
|
139
|
+
*/
|
|
140
|
+
function mergeCommands() {
|
|
141
|
+
console.log('\n' + '='.repeat(60));
|
|
142
|
+
console.log(' MERGE COMMANDS');
|
|
143
|
+
console.log('='.repeat(60));
|
|
144
|
+
|
|
145
|
+
// Clean merged directory
|
|
146
|
+
if (fs.existsSync(MERGED_DIR)) {
|
|
147
|
+
fs.rmSync(MERGED_DIR, { recursive: true, force: true });
|
|
148
|
+
}
|
|
149
|
+
fs.mkdirSync(MERGED_DIR, { recursive: true });
|
|
150
|
+
|
|
151
|
+
const agentEntries = getAllEntries(COMMANDS_DIR);
|
|
152
|
+
const claudekitEntries = getAllEntries(COMMANDS_CLAUDEKIT_DIR);
|
|
153
|
+
|
|
154
|
+
// Collect all unique files and dirs
|
|
155
|
+
const allFiles = new Set([...agentEntries.files, ...claudekitEntries.files]);
|
|
156
|
+
const processedDirs = new Set();
|
|
157
|
+
|
|
158
|
+
let copiedFromAgent = 0;
|
|
159
|
+
let copiedFromClaudekit = 0;
|
|
160
|
+
let merged = 0;
|
|
161
|
+
|
|
162
|
+
// Process each file
|
|
163
|
+
for (const relativePath of allFiles) {
|
|
164
|
+
const fileName = path.basename(relativePath);
|
|
165
|
+
const dirName = path.dirname(relativePath);
|
|
166
|
+
|
|
167
|
+
// Check if this is a root-level command file
|
|
168
|
+
const isRootCommand = dirName === '.';
|
|
169
|
+
const commandName = isRootCommand ? fileName : path.basename(dirName) + '.md';
|
|
170
|
+
|
|
171
|
+
const agentPath = path.join(COMMANDS_DIR, relativePath);
|
|
172
|
+
const claudekitPath = path.join(COMMANDS_CLAUDEKIT_DIR, relativePath);
|
|
173
|
+
const mergedPath = path.join(MERGED_DIR, relativePath);
|
|
174
|
+
|
|
175
|
+
const existsInAgent = fs.existsSync(agentPath);
|
|
176
|
+
const existsInClaudekit = fs.existsSync(claudekitPath);
|
|
177
|
+
|
|
178
|
+
// Determine source
|
|
179
|
+
if (existsInAgent && existsInClaudekit) {
|
|
180
|
+
// Both have this file - apply strategy
|
|
181
|
+
const strategy = MERGE_STRATEGY[fileName] || MERGE_STRATEGY[commandName];
|
|
182
|
+
|
|
183
|
+
if (strategy === 'agent') {
|
|
184
|
+
copyFile(agentPath, mergedPath);
|
|
185
|
+
copiedFromAgent++;
|
|
186
|
+
} else if (strategy === 'claudekit' || strategy === 'merge' || !strategy) {
|
|
187
|
+
// Default to claudekit for conflicts
|
|
188
|
+
copyFile(claudekitPath, mergedPath);
|
|
189
|
+
copiedFromClaudekit++;
|
|
190
|
+
if (strategy === 'merge') merged++;
|
|
191
|
+
}
|
|
192
|
+
} else if (existsInAgent) {
|
|
193
|
+
copyFile(agentPath, mergedPath);
|
|
194
|
+
copiedFromAgent++;
|
|
195
|
+
} else if (existsInClaudekit) {
|
|
196
|
+
copyFile(claudekitPath, mergedPath);
|
|
197
|
+
copiedFromClaudekit++;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
// Copy unique subdirectories from both sources
|
|
202
|
+
const agentDirs = new Set(agentEntries.dirs.map(d => d.split(path.sep)[0]));
|
|
203
|
+
const claudekitDirs = new Set(claudekitEntries.dirs.map(d => d.split(path.sep)[0]));
|
|
204
|
+
|
|
205
|
+
// For directories that exist in both, we need to merge their contents
|
|
206
|
+
for (const dir of agentDirs) {
|
|
207
|
+
const agentSubDir = path.join(COMMANDS_DIR, dir);
|
|
208
|
+
const claudekitSubDir = path.join(COMMANDS_CLAUDEKIT_DIR, dir);
|
|
209
|
+
const mergedSubDir = path.join(MERGED_DIR, dir);
|
|
210
|
+
|
|
211
|
+
if (claudekitDirs.has(dir)) {
|
|
212
|
+
// Both have this directory - merge contents
|
|
213
|
+
// Claudekit files already copied above, add agent-only files
|
|
214
|
+
if (fs.existsSync(agentSubDir)) {
|
|
215
|
+
const agentFiles = fs.readdirSync(agentSubDir, { withFileTypes: true });
|
|
216
|
+
for (const entry of agentFiles) {
|
|
217
|
+
const mergedEntryPath = path.join(mergedSubDir, entry.name);
|
|
218
|
+
if (!fs.existsSync(mergedEntryPath)) {
|
|
219
|
+
const agentEntryPath = path.join(agentSubDir, entry.name);
|
|
220
|
+
if (entry.isDirectory()) {
|
|
221
|
+
copyDir(agentEntryPath, mergedEntryPath);
|
|
222
|
+
} else {
|
|
223
|
+
copyFile(agentEntryPath, mergedEntryPath);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
// Count final files
|
|
232
|
+
const finalEntries = getAllEntries(MERGED_DIR);
|
|
233
|
+
|
|
234
|
+
console.log(`\n From agent-assistant: ${copiedFromAgent} files`);
|
|
235
|
+
console.log(` From claudekit: ${copiedFromClaudekit} files`);
|
|
236
|
+
console.log(` Merged conflicts: ${merged} files`);
|
|
237
|
+
console.log(` Total merged: ${finalEntries.files.length} files`);
|
|
238
|
+
console.log('\n' + '='.repeat(60));
|
|
239
|
+
|
|
240
|
+
return finalEntries.files.length;
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
/**
|
|
244
|
+
* List merged commands
|
|
245
|
+
*/
|
|
246
|
+
function listMergedCommands() {
|
|
247
|
+
if (!fs.existsSync(MERGED_DIR)) {
|
|
248
|
+
console.log('No merged commands. Run: npm run merge-commands');
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
const entries = getAllEntries(MERGED_DIR);
|
|
253
|
+
console.log('\nMerged Commands:\n');
|
|
254
|
+
|
|
255
|
+
// Get root-level commands
|
|
256
|
+
const rootCommands = entries.files
|
|
257
|
+
.filter(f => !f.includes(path.sep))
|
|
258
|
+
.map(f => f.replace('.md', ''))
|
|
259
|
+
.sort();
|
|
260
|
+
|
|
261
|
+
for (const cmd of rootCommands) {
|
|
262
|
+
console.log(` /${cmd}`);
|
|
263
|
+
|
|
264
|
+
// Check for sub-commands
|
|
265
|
+
const subDir = cmd;
|
|
266
|
+
const subCommands = entries.files
|
|
267
|
+
.filter(f => f.startsWith(subDir + path.sep))
|
|
268
|
+
.map(f => f.replace(subDir + path.sep, '').replace('.md', '').replace(/\\/g, ':'))
|
|
269
|
+
.sort();
|
|
270
|
+
|
|
271
|
+
for (const sub of subCommands) {
|
|
272
|
+
console.log(` /${cmd}:${sub}`);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
console.log(`\nTotal: ${entries.files.length} command files\n`);
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Run if called directly
|
|
280
|
+
if (require.main === module) {
|
|
281
|
+
const arg = process.argv[2];
|
|
282
|
+
|
|
283
|
+
if (arg === 'list') {
|
|
284
|
+
listMergedCommands();
|
|
285
|
+
} else {
|
|
286
|
+
mergeCommands();
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
module.exports = { mergeCommands, listMergedCommands };
|
|
@@ -0,0 +1,226 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Organize Rules Script
|
|
5
|
+
*
|
|
6
|
+
* Reorganizes rules from rules/ into templates/{tech}/rules/
|
|
7
|
+
* This enables per-project installation of only relevant rules.
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
const fs = require('fs');
|
|
11
|
+
const path = require('path');
|
|
12
|
+
|
|
13
|
+
const PACKAGE_ROOT = path.join(__dirname, '..');
|
|
14
|
+
const RULES_DIR = path.join(PACKAGE_ROOT, 'rules');
|
|
15
|
+
const TEMPLATES_DIR = path.join(PACKAGE_ROOT, 'templates');
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Mapping from rules subdirectory to template tech
|
|
19
|
+
*/
|
|
20
|
+
const RULES_MAPPING = {
|
|
21
|
+
'flutter': 'flutter',
|
|
22
|
+
'dart': 'dart',
|
|
23
|
+
'golang': 'golang',
|
|
24
|
+
'python': 'python',
|
|
25
|
+
'react': 'react',
|
|
26
|
+
'nextjs': 'nextjs',
|
|
27
|
+
'nestjs': 'nestjs',
|
|
28
|
+
'typescript': 'typescript',
|
|
29
|
+
'javascript': 'javascript',
|
|
30
|
+
'nodejs': 'nodejs',
|
|
31
|
+
'prisma': 'prisma',
|
|
32
|
+
'supabase': 'supabase',
|
|
33
|
+
'tailwind': 'tailwind',
|
|
34
|
+
'docker': 'docker',
|
|
35
|
+
'java': 'java',
|
|
36
|
+
'rust': 'rust',
|
|
37
|
+
'vue': 'vue',
|
|
38
|
+
'angular': 'angular',
|
|
39
|
+
'svelte': 'svelte'
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Copy directory recursively
|
|
44
|
+
*/
|
|
45
|
+
function copyDir(src, dest) {
|
|
46
|
+
if (!fs.existsSync(src)) return 0;
|
|
47
|
+
|
|
48
|
+
fs.mkdirSync(dest, { recursive: true });
|
|
49
|
+
let count = 0;
|
|
50
|
+
|
|
51
|
+
const entries = fs.readdirSync(src, { withFileTypes: true });
|
|
52
|
+
|
|
53
|
+
for (const entry of entries) {
|
|
54
|
+
if (entry.name.startsWith('.') || entry.name === '__tests__') continue;
|
|
55
|
+
|
|
56
|
+
const srcPath = path.join(src, entry.name);
|
|
57
|
+
const destPath = path.join(dest, entry.name);
|
|
58
|
+
|
|
59
|
+
if (entry.isDirectory()) {
|
|
60
|
+
count += copyDir(srcPath, destPath);
|
|
61
|
+
} else {
|
|
62
|
+
fs.copyFileSync(srcPath, destPath);
|
|
63
|
+
count++;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
return count;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Get directory size in KB
|
|
72
|
+
*/
|
|
73
|
+
function getDirSize(dir) {
|
|
74
|
+
if (!fs.existsSync(dir)) return 0;
|
|
75
|
+
|
|
76
|
+
let size = 0;
|
|
77
|
+
const entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
78
|
+
|
|
79
|
+
for (const entry of entries) {
|
|
80
|
+
const entryPath = path.join(dir, entry.name);
|
|
81
|
+
if (entry.isDirectory()) {
|
|
82
|
+
size += getDirSize(entryPath);
|
|
83
|
+
} else {
|
|
84
|
+
size += fs.statSync(entryPath).size;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return size;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Organize rules into templates
|
|
93
|
+
*/
|
|
94
|
+
function organizeRules() {
|
|
95
|
+
console.log('\n' + '='.repeat(60));
|
|
96
|
+
console.log(' ORGANIZE RULES INTO TEMPLATES');
|
|
97
|
+
console.log('='.repeat(60));
|
|
98
|
+
|
|
99
|
+
if (!fs.existsSync(RULES_DIR)) {
|
|
100
|
+
console.log('\nNo rules directory found.\n');
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// Get all subdirectories in rules/
|
|
105
|
+
const rulesDirs = fs.readdirSync(RULES_DIR, { withFileTypes: true })
|
|
106
|
+
.filter(d => d.isDirectory())
|
|
107
|
+
.map(d => d.name);
|
|
108
|
+
|
|
109
|
+
const stats = {};
|
|
110
|
+
|
|
111
|
+
for (const ruleDir of rulesDirs) {
|
|
112
|
+
const srcDir = path.join(RULES_DIR, ruleDir);
|
|
113
|
+
const tech = RULES_MAPPING[ruleDir] || ruleDir;
|
|
114
|
+
const destDir = path.join(TEMPLATES_DIR, tech, 'rules', ruleDir);
|
|
115
|
+
|
|
116
|
+
// Copy rules
|
|
117
|
+
const count = copyDir(srcDir, destDir);
|
|
118
|
+
const sizeKB = Math.round(getDirSize(destDir) / 1024);
|
|
119
|
+
|
|
120
|
+
stats[tech] = stats[tech] || { files: 0, sizeKB: 0 };
|
|
121
|
+
stats[tech].files += count;
|
|
122
|
+
stats[tech].sizeKB += sizeKB;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// Print stats
|
|
126
|
+
console.log('\nTemplates created:\n');
|
|
127
|
+
for (const [tech, data] of Object.entries(stats).sort()) {
|
|
128
|
+
console.log(` ${tech.padEnd(15)} ${String(data.files).padStart(4)} files ${String(data.sizeKB).padStart(5)} KB`);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
const totalFiles = Object.values(stats).reduce((sum, s) => sum + s.files, 0);
|
|
132
|
+
const totalSize = Object.values(stats).reduce((sum, s) => sum + s.sizeKB, 0);
|
|
133
|
+
console.log(` ${'─'.repeat(35)}`);
|
|
134
|
+
console.log(` ${'TOTAL'.padEnd(15)} ${String(totalFiles).padStart(4)} files ${String(totalSize).padStart(5)} KB`);
|
|
135
|
+
|
|
136
|
+
console.log('\n' + '='.repeat(60) + '\n');
|
|
137
|
+
|
|
138
|
+
return stats;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
/**
|
|
142
|
+
* Create base template with essential hooks
|
|
143
|
+
*/
|
|
144
|
+
function createBaseTemplate() {
|
|
145
|
+
const baseDir = path.join(TEMPLATES_DIR, 'base');
|
|
146
|
+
const hooksDir = path.join(baseDir, 'hooks');
|
|
147
|
+
|
|
148
|
+
fs.mkdirSync(hooksDir, { recursive: true });
|
|
149
|
+
|
|
150
|
+
// Copy essential hooks
|
|
151
|
+
const srcHooks = path.join(PACKAGE_ROOT, 'hooks');
|
|
152
|
+
if (fs.existsSync(srcHooks)) {
|
|
153
|
+
// Copy only essential hooks (not the full set)
|
|
154
|
+
const essentialHooks = [
|
|
155
|
+
'privacy-block.cjs',
|
|
156
|
+
'lib'
|
|
157
|
+
];
|
|
158
|
+
|
|
159
|
+
for (const hook of essentialHooks) {
|
|
160
|
+
const srcPath = path.join(srcHooks, hook);
|
|
161
|
+
const destPath = path.join(hooksDir, hook);
|
|
162
|
+
|
|
163
|
+
if (fs.existsSync(srcPath)) {
|
|
164
|
+
if (fs.statSync(srcPath).isDirectory()) {
|
|
165
|
+
copyDir(srcPath, destPath);
|
|
166
|
+
} else {
|
|
167
|
+
fs.copyFileSync(srcPath, destPath);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
console.log(' Created base template with essential hooks');
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* Generate rules-index.json
|
|
178
|
+
*/
|
|
179
|
+
function generateRulesIndex() {
|
|
180
|
+
const index = {
|
|
181
|
+
version: '1.0.0',
|
|
182
|
+
generatedAt: new Date().toISOString(),
|
|
183
|
+
templates: {}
|
|
184
|
+
};
|
|
185
|
+
|
|
186
|
+
if (!fs.existsSync(TEMPLATES_DIR)) {
|
|
187
|
+
return index;
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
const templates = fs.readdirSync(TEMPLATES_DIR, { withFileTypes: true })
|
|
191
|
+
.filter(d => d.isDirectory() && d.name !== 'base')
|
|
192
|
+
.map(d => d.name);
|
|
193
|
+
|
|
194
|
+
for (const template of templates) {
|
|
195
|
+
const rulesDir = path.join(TEMPLATES_DIR, template, 'rules');
|
|
196
|
+
if (!fs.existsSync(rulesDir)) continue;
|
|
197
|
+
|
|
198
|
+
const rules = fs.readdirSync(rulesDir, { withFileTypes: true })
|
|
199
|
+
.filter(d => d.isDirectory())
|
|
200
|
+
.map(d => d.name);
|
|
201
|
+
|
|
202
|
+
const sizeKB = Math.round(getDirSize(rulesDir) / 1024);
|
|
203
|
+
|
|
204
|
+
index.templates[template] = {
|
|
205
|
+
path: `templates/${template}/rules`,
|
|
206
|
+
rules: rules,
|
|
207
|
+
sizeKB: sizeKB
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
// Write index
|
|
212
|
+
const indexPath = path.join(PACKAGE_ROOT, 'rules-index.json');
|
|
213
|
+
fs.writeFileSync(indexPath, JSON.stringify(index, null, 2));
|
|
214
|
+
console.log(` Generated rules-index.json`);
|
|
215
|
+
|
|
216
|
+
return index;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
// Run if called directly
|
|
220
|
+
if (require.main === module) {
|
|
221
|
+
organizeRules();
|
|
222
|
+
createBaseTemplate();
|
|
223
|
+
generateRulesIndex();
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
module.exports = { organizeRules, createBaseTemplate, generateRulesIndex };
|