@heyai-rules/pilo-masterkit 2.1.0 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agent/agents/PILO_MASTER.md +77 -77
- package/.agent/agents/architect.md +211 -211
- package/.agent/agents/backend-specialist.md +263 -263
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-archaeologist.md +106 -106
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -101
- package/.agent/agents/dart-build-resolver.md +201 -201
- package/.agent/agents/database-architect.md +226 -226
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/debugger.md +225 -225
- package/.agent/agents/devops-engineer.md +242 -242
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/documentation-writer.md +104 -104
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/explorer-agent.md +73 -73
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/frontend-specialist.md +593 -593
- package/.agent/agents/game-developer.md +162 -162
- package/.agent/agents/gan-evaluator.md +209 -209
- package/.agent/agents/gan-generator.md +131 -131
- package/.agent/agents/gan-planner.md +99 -99
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -83
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/mobile-developer.md +377 -377
- package/.agent/agents/opensource-forker.md +198 -198
- package/.agent/agents/opensource-packager.md +249 -249
- package/.agent/agents/opensource-sanitizer.md +188 -188
- package/.agent/agents/orchestrator.md +416 -416
- package/.agent/agents/penetration-tester.md +188 -188
- package/.agent/agents/performance-optimizer.md +446 -446
- package/.agent/agents/personas/athena-agent/agent.json +10 -10
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +3 -3
- package/.agent/agents/personas/athena-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -10
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +3 -3
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -10
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +3 -3
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -10
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +3 -3
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/mihata-agent/agent.json +10 -10
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +3 -3
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/tesla-agent/agent.json +10 -10
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +3 -3
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -10
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +3 -3
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/venti-agent/agent.json +10 -10
- package/.agent/agents/personas/venti-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +3 -3
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/product-manager.md +112 -112
- package/.agent/agents/product-owner.md +95 -95
- package/.agent/agents/project-planner.md +406 -406
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/qa-automation-engineer.md +103 -103
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-auditor.md +170 -170
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/seo-specialist.md +111 -111
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/test-engineer.md +158 -158
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -20
- package/.agent/contexts/research.md +26 -26
- package/.agent/contexts/review.md +22 -22
- package/.agent/hooks/hooks.json +395 -395
- package/.agent/hooks/readme.md +222 -222
- package/.agent/mcp-configs/mcp-servers.json +181 -181
- package/.agent/rules/ARCHITECTURAL_BLUEPRINTS.md +62 -62
- package/.agent/rules/CODE_CRAFTSMANSHIP.md +69 -69
- package/.agent/rules/CORE_RULES.md +72 -72
- package/.agent/rules/PROJECT_MAP.md +58 -58
- package/.agent/rules/QUALITY_ASSURANCE.md +54 -54
- package/.agent/rules/SECURITY_ARMOR.md +44 -44
- package/.agent/rules/VERSION_ORCHESTRATION.md +64 -64
- package/.agent/rules/WORKFLOW_ORCHESTRATION.md +55 -55
- package/.agent/rules/common/agents.md +50 -50
- package/.agent/rules/common/code-review.md +124 -124
- package/.agent/rules/common/coding-style.md +48 -48
- package/.agent/rules/common/development-workflow.md +44 -44
- package/.agent/rules/common/git-workflow.md +24 -24
- package/.agent/rules/common/hooks.md +30 -30
- package/.agent/rules/common/patterns.md +31 -31
- package/.agent/rules/common/performance.md +55 -55
- package/.agent/rules/common/security.md +29 -29
- package/.agent/rules/common/testing.md +29 -29
- package/.agent/rules/cpp/coding-style.md +44 -44
- package/.agent/rules/cpp/hooks.md +39 -39
- package/.agent/rules/cpp/patterns.md +51 -51
- package/.agent/rules/cpp/security.md +51 -51
- package/.agent/rules/cpp/testing.md +44 -44
- package/.agent/rules/csharp/coding-style.md +72 -72
- package/.agent/rules/csharp/hooks.md +25 -25
- package/.agent/rules/csharp/patterns.md +50 -50
- package/.agent/rules/csharp/security.md +58 -58
- package/.agent/rules/csharp/testing.md +46 -46
- package/.agent/rules/dart/coding-style.md +159 -159
- package/.agent/rules/dart/hooks.md +66 -66
- package/.agent/rules/dart/patterns.md +261 -261
- package/.agent/rules/dart/security.md +135 -135
- package/.agent/rules/dart/testing.md +215 -215
- package/.agent/rules/golang/coding-style.md +32 -32
- package/.agent/rules/golang/hooks.md +17 -17
- package/.agent/rules/golang/patterns.md +45 -45
- package/.agent/rules/golang/security.md +34 -34
- package/.agent/rules/golang/testing.md +31 -31
- package/.agent/rules/java/coding-style.md +114 -114
- package/.agent/rules/java/hooks.md +18 -18
- package/.agent/rules/java/patterns.md +146 -146
- package/.agent/rules/java/security.md +100 -100
- package/.agent/rules/java/testing.md +131 -131
- package/.agent/rules/kotlin/coding-style.md +86 -86
- package/.agent/rules/kotlin/hooks.md +17 -17
- package/.agent/rules/kotlin/patterns.md +146 -146
- package/.agent/rules/kotlin/security.md +82 -82
- package/.agent/rules/kotlin/testing.md +128 -128
- package/.agent/rules/perl/coding-style.md +46 -46
- package/.agent/rules/perl/hooks.md +22 -22
- package/.agent/rules/perl/patterns.md +76 -76
- package/.agent/rules/perl/security.md +69 -69
- package/.agent/rules/perl/testing.md +54 -54
- package/.agent/rules/php/coding-style.md +40 -40
- package/.agent/rules/php/hooks.md +24 -24
- package/.agent/rules/php/patterns.md +33 -33
- package/.agent/rules/php/security.md +37 -37
- package/.agent/rules/php/testing.md +39 -39
- package/.agent/rules/python/coding-style.md +42 -42
- package/.agent/rules/python/hooks.md +19 -19
- package/.agent/rules/python/patterns.md +39 -39
- package/.agent/rules/python/security.md +30 -30
- package/.agent/rules/python/testing.md +38 -38
- package/.agent/rules/readme.md +111 -111
- package/.agent/rules/rust/coding-style.md +151 -151
- package/.agent/rules/rust/hooks.md +16 -16
- package/.agent/rules/rust/patterns.md +168 -168
- package/.agent/rules/rust/security.md +141 -141
- package/.agent/rules/rust/testing.md +154 -154
- package/.agent/rules/swift/coding-style.md +47 -47
- package/.agent/rules/swift/hooks.md +20 -20
- package/.agent/rules/swift/patterns.md +66 -66
- package/.agent/rules/swift/security.md +33 -33
- package/.agent/rules/swift/testing.md +45 -45
- package/.agent/rules/typescript/coding-style.md +199 -199
- package/.agent/rules/typescript/hooks.md +22 -22
- package/.agent/rules/typescript/patterns.md +52 -52
- package/.agent/rules/typescript/security.md +28 -28
- package/.agent/rules/typescript/testing.md +18 -18
- package/.agent/rules/web/coding-style.md +96 -96
- package/.agent/rules/web/design-quality.md +63 -63
- package/.agent/rules/web/hooks.md +120 -120
- package/.agent/rules/web/patterns.md +79 -79
- package/.agent/rules/web/performance.md +64 -64
- package/.agent/rules/web/security.md +57 -57
- package/.agent/rules/web/testing.md +55 -55
- package/.agent/rules/zh/agents.md +50 -50
- package/.agent/rules/zh/code-review.md +124 -124
- package/.agent/rules/zh/coding-style.md +48 -48
- package/.agent/rules/zh/development-workflow.md +44 -44
- package/.agent/rules/zh/git-workflow.md +24 -24
- package/.agent/rules/zh/hooks.md +30 -30
- package/.agent/rules/zh/patterns.md +31 -31
- package/.agent/rules/zh/performance.md +55 -55
- package/.agent/rules/zh/readme.md +108 -108
- package/.agent/rules/zh/security.md +29 -29
- package/.agent/rules/zh/testing.md +29 -29
- package/.agent/scripts/auto_preview.py +148 -148
- package/.agent/scripts/checklist.py +217 -217
- package/.agent/scripts/session_manager.py +120 -120
- package/.agent/scripts/verify_all.py +327 -327
- package/.agent/skills/agent-eval/SKILL.md +145 -145
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -73
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -178
- package/.agent/skills/agentic-engineering/SKILL.md +63 -63
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -51
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -385
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -339
- package/.agent/skills/api-design/SKILL.md +523 -523
- package/.agent/skills/api-patterns/SKILL.md +81 -81
- package/.agent/skills/api-patterns/api-style.md +42 -42
- package/.agent/skills/api-patterns/auth.md +24 -24
- package/.agent/skills/api-patterns/documentation.md +26 -26
- package/.agent/skills/api-patterns/graphql.md +41 -41
- package/.agent/skills/api-patterns/rate-limiting.md +31 -31
- package/.agent/skills/api-patterns/response.md +37 -37
- package/.agent/skills/api-patterns/rest.md +40 -40
- package/.agent/skills/api-patterns/scripts/api_validator.py +211 -211
- package/.agent/skills/api-patterns/security-testing.md +122 -122
- package/.agent/skills/api-patterns/trpc.md +41 -41
- package/.agent/skills/api-patterns/versioning.md +22 -22
- package/.agent/skills/app-builder/SKILL.md +75 -75
- package/.agent/skills/app-builder/agent-coordination.md +71 -71
- package/.agent/skills/app-builder/feature-building.md +53 -53
- package/.agent/skills/app-builder/project-detection.md +34 -34
- package/.agent/skills/app-builder/scaffolding.md +118 -118
- package/.agent/skills/app-builder/tech-stack.md +41 -41
- package/.agent/skills/app-builder/templates/SKILL.md +39 -39
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -76
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -92
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +169 -169
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +134 -134
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +119 -119
- package/.agent/skills/architecture/SKILL.md +55 -55
- package/.agent/skills/architecture/context-discovery.md +43 -43
- package/.agent/skills/architecture/examples.md +94 -94
- package/.agent/skills/architecture/pattern-selection.md +68 -68
- package/.agent/skills/architecture/patterns-reference.md +50 -50
- package/.agent/skills/architecture/trade-off-analysis.md +77 -77
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -179
- package/.agent/skills/article-writing/SKILL.md +79 -79
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -267
- package/.agent/skills/autonomous-loops/SKILL.md +610 -610
- package/.agent/skills/backend-patterns/SKILL.md +598 -598
- package/.agent/skills/bash-linux/SKILL.md +199 -199
- package/.agent/skills/behavioral-modes/SKILL.md +242 -242
- package/.agent/skills/benchmark/SKILL.md +93 -93
- package/.agent/skills/blueprint/SKILL.md +105 -105
- package/.agent/skills/brainstorming/SKILL.md +163 -163
- package/.agent/skills/brainstorming/dynamic-questioning.md +350 -350
- package/.agent/skills/brand-voice/SKILL.md +97 -97
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -55
- package/.agent/skills/browser-qa/SKILL.md +87 -87
- package/.agent/skills/bun-runtime/SKILL.md +84 -84
- package/.agent/skills/canary-watch/SKILL.md +99 -99
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -212
- package/.agent/skills/ck/SKILL.md +147 -147
- package/.agent/skills/ck/commands/forget.mjs +44 -44
- package/.agent/skills/ck/commands/info.mjs +24 -24
- package/.agent/skills/ck/commands/init.mjs +143 -143
- package/.agent/skills/ck/commands/list.mjs +40 -40
- package/.agent/skills/ck/commands/migrate.mjs +202 -202
- package/.agent/skills/ck/commands/resume.mjs +36 -36
- package/.agent/skills/ck/commands/save.mjs +210 -210
- package/.agent/skills/ck/commands/shared.mjs +387 -387
- package/.agent/skills/ck/hooks/session-start.mjs +224 -224
- package/.agent/skills/claude-api/SKILL.md +337 -337
- package/.agent/skills/claude-devfleet/SKILL.md +103 -103
- package/.agent/skills/clean-code/SKILL.md +201 -201
- package/.agent/skills/click-path-audit/SKILL.md +244 -244
- package/.agent/skills/clickhouse-io/SKILL.md +439 -439
- package/.agent/skills/code-review-checklist/SKILL.md +109 -109
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -233
- package/.agent/skills/coding-standards/SKILL.md +530 -530
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -299
- package/.agent/skills/configure-ecc/SKILL.md +367 -367
- package/.agent/skills/connections-optimizer/SKILL.md +189 -189
- package/.agent/skills/content-engine/SKILL.md +131 -131
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -161
- package/.agent/skills/context-budget/SKILL.md +135 -135
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -45
- package/.agent/skills/continuous-learning/SKILL.md +119 -119
- package/.agent/skills/continuous-learning/config.json +18 -18
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -69
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -365
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -271
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -198
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -150
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -244
- package/.agent/skills/continuous-learning-v2/config.json +8 -8
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -428
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -228
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -1426
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -984
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -183
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -723
- package/.agent/skills/cpp-testing/SKILL.md +324 -324
- package/.agent/skills/crosspost/SKILL.md +111 -111
- package/.agent/skills/csharp-testing/SKILL.md +321 -321
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -140
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -263
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -563
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -764
- package/.agent/skills/database-design/SKILL.md +52 -52
- package/.agent/skills/database-design/database-selection.md +43 -43
- package/.agent/skills/database-design/indexing.md +39 -39
- package/.agent/skills/database-design/migrations.md +48 -48
- package/.agent/skills/database-design/optimization.md +36 -36
- package/.agent/skills/database-design/orm-selection.md +30 -30
- package/.agent/skills/database-design/schema-design.md +56 -56
- package/.agent/skills/database-design/scripts/schema_validator.py +172 -172
- package/.agent/skills/database-migrations/SKILL.md +429 -429
- package/.agent/skills/deep-research/SKILL.md +155 -155
- package/.agent/skills/deployment-patterns/SKILL.md +427 -427
- package/.agent/skills/deployment-procedures/SKILL.md +241 -241
- package/.agent/skills/design-system/SKILL.md +82 -82
- package/.agent/skills/django-patterns/SKILL.md +734 -734
- package/.agent/skills/django-security/SKILL.md +593 -593
- package/.agent/skills/django-tdd/SKILL.md +729 -729
- package/.agent/skills/django-verification/SKILL.md +469 -469
- package/.agent/skills/dmux-workflows/SKILL.md +191 -191
- package/.agent/skills/doc.md +177 -177
- package/.agent/skills/docker-patterns/SKILL.md +364 -364
- package/.agent/skills/documentation-lookup/SKILL.md +90 -90
- package/.agent/skills/documentation-templates/SKILL.md +194 -194
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -321
- package/.agent/skills/e2e-testing/SKILL.md +326 -326
- package/.agent/skills/energy-procurement/SKILL.md +228 -228
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -50
- package/.agent/skills/eval-harness/SKILL.md +270 -270
- package/.agent/skills/exa-search/SKILL.md +103 -103
- package/.agent/skills/fal-ai-media/SKILL.md +284 -284
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -435
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -243
- package/.agent/skills/frontend-design/SKILL.md +452 -452
- package/.agent/skills/frontend-design/animation-guide.md +331 -331
- package/.agent/skills/frontend-design/color-system.md +311 -311
- package/.agent/skills/frontend-design/decision-trees.md +418 -418
- package/.agent/skills/frontend-design/motion-graphics.md +306 -306
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -183
- package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -722
- package/.agent/skills/frontend-design/typography-system.md +345 -345
- package/.agent/skills/frontend-design/ux-psychology.md +1116 -1116
- package/.agent/skills/frontend-design/visual-effects.md +383 -383
- package/.agent/skills/frontend-patterns/SKILL.md +642 -642
- package/.agent/skills/frontend-slides/SKILL.md +184 -184
- package/.agent/skills/frontend-slides/style-presets.md +330 -330
- package/.agent/skills/game-development/2d-games/SKILL.md +119 -119
- package/.agent/skills/game-development/3d-games/SKILL.md +135 -135
- package/.agent/skills/game-development/SKILL.md +167 -167
- package/.agent/skills/game-development/game-art/SKILL.md +185 -185
- package/.agent/skills/game-development/game-audio/SKILL.md +190 -190
- package/.agent/skills/game-development/game-design/SKILL.md +129 -129
- package/.agent/skills/game-development/mobile-games/SKILL.md +108 -108
- package/.agent/skills/game-development/multiplayer/SKILL.md +132 -132
- package/.agent/skills/game-development/pc-games/SKILL.md +144 -144
- package/.agent/skills/game-development/vr-ar/SKILL.md +123 -123
- package/.agent/skills/game-development/web-games/SKILL.md +150 -150
- package/.agent/skills/gan-style-harness/SKILL.md +278 -278
- package/.agent/skills/geo-fundamentals/SKILL.md +156 -156
- package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -289
- package/.agent/skills/git-workflow/SKILL.md +715 -715
- package/.agent/skills/golang-patterns/SKILL.md +674 -674
- package/.agent/skills/golang-testing/SKILL.md +720 -720
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -95
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -245
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -159
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -207
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -145
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -276
- package/.agent/skills/i18n-localization/SKILL.md +154 -154
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -241
- package/.agent/skills/intelligent-routing/SKILL.md +335 -335
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -247
- package/.agent/skills/investor-materials/SKILL.md +96 -96
- package/.agent/skills/investor-outreach/SKILL.md +91 -91
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -211
- package/.agent/skills/java-coding-standards/SKILL.md +147 -147
- package/.agent/skills/jira-integration/SKILL.md +293 -293
- package/.agent/skills/jpa-patterns/SKILL.md +151 -151
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -284
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -719
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -689
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -711
- package/.agent/skills/kotlin-testing/SKILL.md +824 -824
- package/.agent/skills/laravel-patterns/SKILL.md +415 -415
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -229
- package/.agent/skills/laravel-security/SKILL.md +285 -285
- package/.agent/skills/laravel-tdd/SKILL.md +283 -283
- package/.agent/skills/laravel-verification/SKILL.md +179 -179
- package/.agent/skills/lead-intelligence/SKILL.md +321 -321
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -85
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -75
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -98
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -60
- package/.agent/skills/lint-and-validate/SKILL.md +45 -45
- package/.agent/skills/lint-and-validate/scripts/lint_runner.py +184 -184
- package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -173
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -279
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -222
- package/.agent/skills/manim-video/SKILL.md +89 -89
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -52
- package/.agent/skills/market-research/SKILL.md +75 -75
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -67
- package/.agent/skills/mobile-design/SKILL.md +394 -394
- package/.agent/skills/mobile-design/decision-trees.md +516 -516
- package/.agent/skills/mobile-design/mobile-backend.md +491 -491
- package/.agent/skills/mobile-design/mobile-color-system.md +420 -420
- package/.agent/skills/mobile-design/mobile-debugging.md +122 -122
- package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -357
- package/.agent/skills/mobile-design/mobile-navigation.md +458 -458
- package/.agent/skills/mobile-design/mobile-performance.md +767 -767
- package/.agent/skills/mobile-design/mobile-testing.md +356 -356
- package/.agent/skills/mobile-design/mobile-typography.md +433 -433
- package/.agent/skills/mobile-design/platform-android.md +666 -666
- package/.agent/skills/mobile-design/platform-ios.md +561 -561
- package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -670
- package/.agent/skills/mobile-design/touch-psychology.md +537 -537
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -33
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -230
- package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +351 -351
- package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +240 -240
- package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +490 -490
- package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +264 -264
- package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +581 -581
- package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +432 -432
- package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +684 -684
- package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +150 -150
- package/.agent/skills/nextjs-react-expert/9-cache-components.md +103 -103
- package/.agent/skills/nextjs-react-expert/SKILL.md +293 -293
- package/.agent/skills/nextjs-react-expert/scripts/convert_rules.py +222 -222
- package/.agent/skills/nextjs-react-expert/scripts/react_performance_checker.py +252 -252
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -44
- package/.agent/skills/nodejs-best-practices/SKILL.md +333 -333
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -167
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -100
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -296
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -224
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -5
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -124
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -53
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -53
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -48
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -39
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -166
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -255
- package/.agent/skills/parallel-agents/SKILL.md +175 -175
- package/.agent/skills/performance-profiling/SKILL.md +143 -143
- package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -76
- package/.agent/skills/perl-patterns/SKILL.md +504 -504
- package/.agent/skills/perl-security/SKILL.md +503 -503
- package/.agent/skills/perl-testing/SKILL.md +475 -475
- package/.agent/skills/plan-writing/SKILL.md +152 -152
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -236
- package/.agent/skills/postgres-patterns/SKILL.md +147 -147
- package/.agent/skills/powershell-windows/SKILL.md +167 -167
- package/.agent/skills/product-lens/SKILL.md +85 -85
- package/.agent/skills/production-scheduling/SKILL.md +238 -238
- package/.agent/skills/project-flow-ops/SKILL.md +111 -111
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -349
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -397
- package/.agent/skills/python-patterns/SKILL.md +750 -750
- package/.agent/skills/python-testing/SKILL.md +816 -816
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -396
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -260
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -67
- package/.agent/skills/red-team-tactics/SKILL.md +199 -199
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -220
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -43
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -86
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -29
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -173
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -100
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -108
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -78
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -172
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -104
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -75
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -146
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -126
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -229
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -152
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -68
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -138
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -130
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -67
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -67
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -34
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -143
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -106
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -11
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -20
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -179
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -19
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -122
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -52
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -171
- package/.agent/skills/repo-scan/SKILL.md +63 -63
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -240
- package/.agent/skills/rules-distill/SKILL.md +264 -264
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -58
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -129
- package/.agent/skills/rust-patterns/SKILL.md +499 -499
- package/.agent/skills/rust-pro/SKILL.md +175 -175
- package/.agent/skills/rust-testing/SKILL.md +500 -500
- package/.agent/skills/safety-guard/SKILL.md +75 -75
- package/.agent/skills/santa-method/SKILL.md +306 -306
- package/.agent/skills/search-first/SKILL.md +161 -161
- package/.agent/skills/security-review/SKILL.md +495 -495
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -361
- package/.agent/skills/security-scan/SKILL.md +165 -165
- package/.agent/skills/seo-fundamentals/SKILL.md +129 -129
- package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -219
- package/.agent/skills/server-management/SKILL.md +161 -161
- package/.agent/skills/skill-comply/SKILL.md +58 -58
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -5
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -3
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -44
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -24
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -62
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -42
- package/.agent/skills/skill-comply/pyproject.toml +15 -15
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -85
- package/.agent/skills/skill-comply/scripts/grader.py +122 -122
- package/.agent/skills/skill-comply/scripts/parser.py +107 -107
- package/.agent/skills/skill-comply/scripts/report.py +170 -170
- package/.agent/skills/skill-comply/scripts/run.py +127 -127
- package/.agent/skills/skill-comply/scripts/runner.py +161 -161
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -70
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -72
- package/.agent/skills/skill-comply/scripts/utils.py +13 -13
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -137
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -90
- package/.agent/skills/skill-stocktake/SKILL.md +193 -193
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -87
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -56
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -170
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -154
- package/.agent/skills/springboot-patterns/SKILL.md +314 -314
- package/.agent/skills/springboot-security/SKILL.md +272 -272
- package/.agent/skills/springboot-tdd/SKILL.md +158 -158
- package/.agent/skills/springboot-verification/SKILL.md +231 -231
- package/.agent/skills/strategic-compact/SKILL.md +131 -131
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -54
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -143
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -216
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -190
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -259
- package/.agent/skills/systematic-debugging/SKILL.md +109 -109
- package/.agent/skills/tailwind-patterns/SKILL.md +269 -269
- package/.agent/skills/tdd-workflow/SKILL.md +463 -463
- package/.agent/skills/team-builder/SKILL.md +168 -168
- package/.agent/skills/testing-patterns/SKILL.md +178 -178
- package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -219
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -133
- package/.agent/skills/ui-demo/SKILL.md +465 -465
- package/.agent/skills/ui-ux-pro-max/SKILL.md +292 -292
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -31
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -45
- package/.agent/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/typography.csv +57 -57
- package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -31
- package/.agent/skills/ui-ux-pro-max/scripts/core.py +253 -253
- package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +1067 -1067
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -126
- package/.agent/skills/video-editing/SKILL.md +310 -310
- package/.agent/skills/videodb/SKILL.md +374 -374
- package/.agent/skills/videodb/reference/api-reference.md +550 -550
- package/.agent/skills/videodb/reference/capture-reference.md +407 -407
- package/.agent/skills/videodb/reference/capture.md +101 -101
- package/.agent/skills/videodb/reference/editor.md +443 -443
- package/.agent/skills/videodb/reference/generative.md +331 -331
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -564
- package/.agent/skills/videodb/reference/rtstream.md +65 -65
- package/.agent/skills/videodb/reference/search.md +230 -230
- package/.agent/skills/videodb/reference/streaming.md +406 -406
- package/.agent/skills/videodb/reference/use-cases.md +118 -118
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -282
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -117
- package/.agent/skills/visa-doc-translate/readme.md +86 -86
- package/.agent/skills/vulnerability-scanner/SKILL.md +276 -276
- package/.agent/skills/vulnerability-scanner/checklists.md +121 -121
- package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -458
- package/.agent/skills/web-design-guidelines/SKILL.md +57 -57
- package/.agent/skills/webapp-testing/SKILL.md +187 -187
- package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -173
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -125
- package/.agent/skills/x-api/SKILL.md +230 -230
- package/.agent/tasks/lessons.md +40 -40
- package/.agent/tasks/todo.md +33 -33
- package/.agent/tasks/two-track-merge-contract.md +1 -1
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/brainstorm.md +113 -113
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -23
- package/.agent/workflows/clean-memory.md +34 -34
- package/.agent/workflows/code-review.md +289 -289
- package/.agent/workflows/context-budget.md +23 -23
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/create.md +59 -59
- package/.agent/workflows/debug.md +103 -103
- package/.agent/workflows/deploy.md +176 -176
- package/.agent/workflows/devfleet.md +23 -23
- package/.agent/workflows/docs.md +23 -23
- package/.agent/workflows/e2e.md +268 -268
- package/.agent/workflows/enhance.md +63 -63
- package/.agent/workflows/eval.md +23 -23
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -164
- package/.agent/workflows/flutter-review.md +116 -116
- package/.agent/workflows/flutter-test.md +144 -144
- package/.agent/workflows/gan-build.md +99 -99
- package/.agent/workflows/gan-design.md +35 -35
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -73
- package/.agent/workflows/init-docs.md +46 -46
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -106
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -135
- package/.agent/workflows/plan.md +117 -117
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/preview.md +81 -81
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -23
- package/.agent/workflows/prp-commit.md +112 -112
- package/.agent/workflows/prp-implement.md +385 -385
- package/.agent/workflows/prp-plan.md +502 -502
- package/.agent/workflows/prp-pr.md +184 -184
- package/.agent/workflows/prp-prd.md +447 -447
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -20
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -175
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/status.md +86 -86
- package/.agent/workflows/tdd.md +231 -231
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/test.md +144 -144
- package/.agent/workflows/ui-ux-pro-max.md +295 -295
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -23
- package/LICENSE +176 -176
- package/README.md +144 -144
- package/package.json +1 -1
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +424 -354
- package/src/lib/installer.js +223 -11
|
@@ -1,715 +1,715 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: git-workflow
|
|
3
|
-
description: Git workflow patterns including branching strategies, commit conventions, merge vs rebase, conflict resolution, and collaborative development best practices for teams of all sizes.
|
|
4
|
-
origin: ECC
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Git Workflow Patterns
|
|
8
|
-
|
|
9
|
-
Best practices for Git version control, branching strategies, and collaborative development.
|
|
10
|
-
|
|
11
|
-
## When to Activate
|
|
12
|
-
|
|
13
|
-
- Setting up Git workflow for a new project
|
|
14
|
-
- Deciding on branching strategy (GitFlow, trunk-based, GitHub flow)
|
|
15
|
-
- Writing commit messages and PR descriptions
|
|
16
|
-
- Resolving merge conflicts
|
|
17
|
-
- Managing releases and version tags
|
|
18
|
-
- Onboarding new team members to Git practices
|
|
19
|
-
|
|
20
|
-
## Branching Strategies
|
|
21
|
-
|
|
22
|
-
### GitHub Flow (Simple, Recommended for Most)
|
|
23
|
-
|
|
24
|
-
Best for continuous deployment and small-to-medium teams.
|
|
25
|
-
|
|
26
|
-
```
|
|
27
|
-
main (protected, always deployable)
|
|
28
|
-
│
|
|
29
|
-
├── feature/user-auth → PR → merge to main
|
|
30
|
-
├── feature/payment-flow → PR → merge to main
|
|
31
|
-
└── fix/login-bug → PR → merge to main
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
**Rules:**
|
|
35
|
-
- `main` is always deployable
|
|
36
|
-
- Create feature branches from `main`
|
|
37
|
-
- Open Pull Request when ready for review
|
|
38
|
-
- After approval and CI passes, merge to `main`
|
|
39
|
-
- Deploy immediately after merge
|
|
40
|
-
|
|
41
|
-
### Trunk-Based Development (High-Velocity Teams)
|
|
42
|
-
|
|
43
|
-
Best for teams with strong CI/CD and feature flags.
|
|
44
|
-
|
|
45
|
-
```
|
|
46
|
-
main (trunk)
|
|
47
|
-
│
|
|
48
|
-
├── short-lived feature (1-2 days max)
|
|
49
|
-
├── short-lived feature
|
|
50
|
-
└── short-lived feature
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
**Rules:**
|
|
54
|
-
- Everyone commits to `main` or very short-lived branches
|
|
55
|
-
- Feature flags hide incomplete work
|
|
56
|
-
- CI must pass before merge
|
|
57
|
-
- Deploy multiple times per day
|
|
58
|
-
|
|
59
|
-
### GitFlow (Complex, Release-Cycle Driven)
|
|
60
|
-
|
|
61
|
-
Best for scheduled releases and enterprise projects.
|
|
62
|
-
|
|
63
|
-
```
|
|
64
|
-
main (production releases)
|
|
65
|
-
│
|
|
66
|
-
└── develop (integration branch)
|
|
67
|
-
│
|
|
68
|
-
├── feature/user-auth
|
|
69
|
-
├── feature/payment
|
|
70
|
-
│
|
|
71
|
-
├── release/1.0.0 → merge to main and develop
|
|
72
|
-
│
|
|
73
|
-
└── hotfix/critical → merge to main and develop
|
|
74
|
-
```
|
|
75
|
-
|
|
76
|
-
**Rules:**
|
|
77
|
-
- `main` contains production-ready code only
|
|
78
|
-
- `develop` is the integration branch
|
|
79
|
-
- Feature branches from `develop`, merge back to `develop`
|
|
80
|
-
- Release branches from `develop`, merge to `main` and `develop`
|
|
81
|
-
- Hotfix branches from `main`, merge to both `main` and `develop`
|
|
82
|
-
|
|
83
|
-
### When to Use Which
|
|
84
|
-
|
|
85
|
-
| Strategy | Team Size | Release Cadence | Best For |
|
|
86
|
-
|----------|-----------|-----------------|----------|
|
|
87
|
-
| GitHub Flow | Any | Continuous | SaaS, web apps, startups |
|
|
88
|
-
| Trunk-Based | 5+ experienced | Multiple/day | High-velocity teams, feature flags |
|
|
89
|
-
| GitFlow | 10+ | Scheduled | Enterprise, regulated industries |
|
|
90
|
-
|
|
91
|
-
## Commit Messages
|
|
92
|
-
|
|
93
|
-
### Conventional Commits Format
|
|
94
|
-
|
|
95
|
-
```
|
|
96
|
-
<type>(<scope>): <subject>
|
|
97
|
-
|
|
98
|
-
[optional body]
|
|
99
|
-
|
|
100
|
-
[optional footer(s)]
|
|
101
|
-
```
|
|
102
|
-
|
|
103
|
-
### Types
|
|
104
|
-
|
|
105
|
-
| Type | Use For | Example |
|
|
106
|
-
|------|---------|---------|
|
|
107
|
-
| `feat` | New feature | `feat(auth): add OAuth2 login` |
|
|
108
|
-
| `fix` | Bug fix | `fix(api): handle null response in user endpoint` |
|
|
109
|
-
| `docs` | Documentation | `docs(readme): update installation instructions` |
|
|
110
|
-
| `style` | Formatting, no code change | `style: fix indentation in login component` |
|
|
111
|
-
| `refactor` | Code refactoring | `refactor(db): extract connection pool to module` |
|
|
112
|
-
| `test` | Adding/updating tests | `test(auth): add unit tests for token validation` |
|
|
113
|
-
| `chore` | Maintenance tasks | `chore(deps): update dependencies` |
|
|
114
|
-
| `perf` | Performance improvement | `perf(query): add index to users table` |
|
|
115
|
-
| `ci` | CI/CD changes | `ci: add PostgreSQL service to test workflow` |
|
|
116
|
-
| `revert` | Revert previous commit | `revert: revert "feat(auth): add OAuth2 login"` |
|
|
117
|
-
|
|
118
|
-
### Good vs Bad Examples
|
|
119
|
-
|
|
120
|
-
```
|
|
121
|
-
# BAD: Vague, no context
|
|
122
|
-
git commit -m "fixed stuff"
|
|
123
|
-
git commit -m "updates"
|
|
124
|
-
git commit -m "WIP"
|
|
125
|
-
|
|
126
|
-
# GOOD: Clear, specific, explains why
|
|
127
|
-
git commit -m "fix(api): retry requests on 503 Service Unavailable
|
|
128
|
-
|
|
129
|
-
The external API occasionally returns 503 errors during peak hours.
|
|
130
|
-
Added exponential backoff retry logic with max 3 attempts.
|
|
131
|
-
|
|
132
|
-
Closes #123"
|
|
133
|
-
```
|
|
134
|
-
|
|
135
|
-
### Commit Message Template
|
|
136
|
-
|
|
137
|
-
Create `.gitmessage` in repo root:
|
|
138
|
-
|
|
139
|
-
```
|
|
140
|
-
# <type>(<scope>): <subject>
|
|
141
|
-
# # Types: feat, fix, docs, style, refactor, test, chore, perf, ci, revert
|
|
142
|
-
# Scope: api, ui, db, auth, etc.
|
|
143
|
-
# Subject: imperative mood, no period, max 50 chars
|
|
144
|
-
#
|
|
145
|
-
# [optional body] - explain why, not what
|
|
146
|
-
# [optional footer] - Breaking changes, closes #issue
|
|
147
|
-
```
|
|
148
|
-
|
|
149
|
-
Enable with: `git config commit.template .gitmessage`
|
|
150
|
-
|
|
151
|
-
## Merge vs Rebase
|
|
152
|
-
|
|
153
|
-
### Merge (Preserves History)
|
|
154
|
-
|
|
155
|
-
```bash
|
|
156
|
-
# Creates a merge commit
|
|
157
|
-
git checkout main
|
|
158
|
-
git merge feature/user-auth
|
|
159
|
-
|
|
160
|
-
# Result:
|
|
161
|
-
# * merge commit
|
|
162
|
-
# |\
|
|
163
|
-
# | * feature commits
|
|
164
|
-
# |/
|
|
165
|
-
# * main commits
|
|
166
|
-
```
|
|
167
|
-
|
|
168
|
-
**Use when:**
|
|
169
|
-
- Merging feature branches into `main`
|
|
170
|
-
- You want to preserve exact history
|
|
171
|
-
- Multiple people worked on the branch
|
|
172
|
-
- The branch has been pushed and others may have based work on it
|
|
173
|
-
|
|
174
|
-
### Rebase (Linear History)
|
|
175
|
-
|
|
176
|
-
```bash
|
|
177
|
-
# Rewrites feature commits onto target branch
|
|
178
|
-
git checkout feature/user-auth
|
|
179
|
-
git rebase main
|
|
180
|
-
|
|
181
|
-
# Result:
|
|
182
|
-
# * feature commits (rewritten)
|
|
183
|
-
# * main commits
|
|
184
|
-
```
|
|
185
|
-
|
|
186
|
-
**Use when:**
|
|
187
|
-
- Updating your local feature branch with latest `main`
|
|
188
|
-
- You want a linear, clean history
|
|
189
|
-
- The branch is local-only (not pushed)
|
|
190
|
-
- You're the only one working on the branch
|
|
191
|
-
|
|
192
|
-
### Rebase Workflow
|
|
193
|
-
|
|
194
|
-
```bash
|
|
195
|
-
# Update feature branch with latest main (before PR)
|
|
196
|
-
git checkout feature/user-auth
|
|
197
|
-
git fetch origin
|
|
198
|
-
git rebase origin/main
|
|
199
|
-
|
|
200
|
-
# Fix any conflicts
|
|
201
|
-
# Tests should still pass
|
|
202
|
-
|
|
203
|
-
# Force push (only if you're the only contributor)
|
|
204
|
-
git push --force-with-lease origin feature/user-auth
|
|
205
|
-
```
|
|
206
|
-
|
|
207
|
-
### When NOT to Rebase
|
|
208
|
-
|
|
209
|
-
```
|
|
210
|
-
# NEVER rebase branches that:
|
|
211
|
-
- Have been pushed to a shared repository
|
|
212
|
-
- Other people have based work on
|
|
213
|
-
- Are protected branches (main, develop)
|
|
214
|
-
- Are already merged
|
|
215
|
-
|
|
216
|
-
# Why: Rebase rewrites history, breaking others' work
|
|
217
|
-
```
|
|
218
|
-
|
|
219
|
-
## Pull Request Workflow
|
|
220
|
-
|
|
221
|
-
### PR Title Format
|
|
222
|
-
|
|
223
|
-
```
|
|
224
|
-
<type>(<scope>): <description>
|
|
225
|
-
|
|
226
|
-
Examples:
|
|
227
|
-
feat(auth): add SSO support for enterprise users
|
|
228
|
-
fix(api): resolve race condition in order processing
|
|
229
|
-
docs(api): add OpenAPI specification for v2 endpoints
|
|
230
|
-
```
|
|
231
|
-
|
|
232
|
-
### PR Description Template
|
|
233
|
-
|
|
234
|
-
```markdown
|
|
235
|
-
## What
|
|
236
|
-
|
|
237
|
-
Brief description of what this PR does.
|
|
238
|
-
|
|
239
|
-
## Why
|
|
240
|
-
|
|
241
|
-
Explain the motivation and context.
|
|
242
|
-
|
|
243
|
-
## How
|
|
244
|
-
|
|
245
|
-
Key implementation details worth highlighting.
|
|
246
|
-
|
|
247
|
-
## Testing
|
|
248
|
-
|
|
249
|
-
- [ ] Unit tests added/updated
|
|
250
|
-
- [ ] Integration tests added/updated
|
|
251
|
-
- [ ] Manual testing performed
|
|
252
|
-
|
|
253
|
-
## Screenshots (if applicable)
|
|
254
|
-
|
|
255
|
-
Before/after screenshots for UI changes.
|
|
256
|
-
|
|
257
|
-
## Checklist
|
|
258
|
-
|
|
259
|
-
- [ ] Code follows project style guidelines
|
|
260
|
-
- [ ] Self-review completed
|
|
261
|
-
- [ ] Comments added for complex logic
|
|
262
|
-
- [ ] Documentation updated
|
|
263
|
-
- [ ] No new warnings introduced
|
|
264
|
-
- [ ] Tests pass locally
|
|
265
|
-
- [ ] Related issues linked
|
|
266
|
-
|
|
267
|
-
Closes #123
|
|
268
|
-
```
|
|
269
|
-
|
|
270
|
-
### Code Review Checklist
|
|
271
|
-
|
|
272
|
-
**For Reviewers:**
|
|
273
|
-
|
|
274
|
-
- [ ] Does the code solve the stated problem?
|
|
275
|
-
- [ ] Are there any edge cases not handled?
|
|
276
|
-
- [ ] Is the code readable and maintainable?
|
|
277
|
-
- [ ] Are there sufficient tests?
|
|
278
|
-
- [ ] Are there security concerns?
|
|
279
|
-
- [ ] Is the commit history clean (squashed if needed)?
|
|
280
|
-
|
|
281
|
-
**For Authors:**
|
|
282
|
-
|
|
283
|
-
- [ ] Self-review completed before requesting review
|
|
284
|
-
- [ ] CI passes (tests, lint, typecheck)
|
|
285
|
-
- [ ] PR size is reasonable (<500 lines ideal)
|
|
286
|
-
- [ ] Related to a single feature/fix
|
|
287
|
-
- [ ] Description clearly explains the change
|
|
288
|
-
|
|
289
|
-
## Conflict Resolution
|
|
290
|
-
|
|
291
|
-
### Identify Conflicts
|
|
292
|
-
|
|
293
|
-
```bash
|
|
294
|
-
# Check for conflicts before merge
|
|
295
|
-
git checkout main
|
|
296
|
-
git merge feature/user-auth --no-commit --no-ff
|
|
297
|
-
|
|
298
|
-
# If conflicts, Git will show:
|
|
299
|
-
# CONFLICT (content): Merge conflict in src/auth/login.ts
|
|
300
|
-
# Automatic merge failed; fix conflicts and then commit the result.
|
|
301
|
-
```
|
|
302
|
-
|
|
303
|
-
### Resolve Conflicts
|
|
304
|
-
|
|
305
|
-
```bash
|
|
306
|
-
# See conflicted files
|
|
307
|
-
git status
|
|
308
|
-
|
|
309
|
-
# View conflict markers in file
|
|
310
|
-
# <<<<<<< HEAD
|
|
311
|
-
# content from main
|
|
312
|
-
# =======
|
|
313
|
-
# content from feature branch
|
|
314
|
-
# >>>>>>> feature/user-auth
|
|
315
|
-
|
|
316
|
-
# Option 1: Manual resolution
|
|
317
|
-
# Edit file, remove markers, keep correct content
|
|
318
|
-
|
|
319
|
-
# Option 2: Use merge tool
|
|
320
|
-
git mergetool
|
|
321
|
-
|
|
322
|
-
# Option 3: Accept one side
|
|
323
|
-
git checkout --ours src/auth/login.ts # Keep main version
|
|
324
|
-
git checkout --theirs src/auth/login.ts # Keep feature version
|
|
325
|
-
|
|
326
|
-
# After resolving, stage and commit
|
|
327
|
-
git add src/auth/login.ts
|
|
328
|
-
git commit
|
|
329
|
-
```
|
|
330
|
-
|
|
331
|
-
### Conflict Prevention Strategies
|
|
332
|
-
|
|
333
|
-
```bash
|
|
334
|
-
# 1. Keep feature branches small and short-lived
|
|
335
|
-
# 2. Rebase frequently onto main
|
|
336
|
-
git checkout feature/user-auth
|
|
337
|
-
git fetch origin
|
|
338
|
-
git rebase origin/main
|
|
339
|
-
|
|
340
|
-
# 3. Communicate with team about touching shared files
|
|
341
|
-
# 4. Use feature flags instead of long-lived branches
|
|
342
|
-
# 5. Review and merge PRs promptly
|
|
343
|
-
```
|
|
344
|
-
|
|
345
|
-
## Branch Management
|
|
346
|
-
|
|
347
|
-
### Naming Conventions
|
|
348
|
-
|
|
349
|
-
```
|
|
350
|
-
# Feature branches
|
|
351
|
-
feature/user-authentication
|
|
352
|
-
feature/JIRA-123-payment-integration
|
|
353
|
-
|
|
354
|
-
# Bug fixes
|
|
355
|
-
fix/login-redirect-loop
|
|
356
|
-
fix/456-null-pointer-exception
|
|
357
|
-
|
|
358
|
-
# Hotfixes (production issues)
|
|
359
|
-
hotfix/critical-security-patch
|
|
360
|
-
hotfix/database-connection-leak
|
|
361
|
-
|
|
362
|
-
# Releases
|
|
363
|
-
release/1.2.0
|
|
364
|
-
release/2024-01-hotfix
|
|
365
|
-
|
|
366
|
-
# Experiments/POCs
|
|
367
|
-
experiment/new-caching-strategy
|
|
368
|
-
poc/graphql-migration
|
|
369
|
-
```
|
|
370
|
-
|
|
371
|
-
### Branch Cleanup
|
|
372
|
-
|
|
373
|
-
```bash
|
|
374
|
-
# Delete local branches that are merged
|
|
375
|
-
git branch --merged main | grep -v "^\*\|main" | xargs -n 1 git branch -d
|
|
376
|
-
|
|
377
|
-
# Delete remote-tracking references for deleted remote branches
|
|
378
|
-
git fetch -p
|
|
379
|
-
|
|
380
|
-
# Delete local branch
|
|
381
|
-
git branch -d feature/user-auth # Safe delete (only if merged)
|
|
382
|
-
git branch -D feature/user-auth # Force delete
|
|
383
|
-
|
|
384
|
-
# Delete remote branch
|
|
385
|
-
git push origin --delete feature/user-auth
|
|
386
|
-
```
|
|
387
|
-
|
|
388
|
-
### Stash Workflow
|
|
389
|
-
|
|
390
|
-
```bash
|
|
391
|
-
# Save work in progress
|
|
392
|
-
git stash push -m "WIP: user authentication"
|
|
393
|
-
|
|
394
|
-
# List stashes
|
|
395
|
-
git stash list
|
|
396
|
-
|
|
397
|
-
# Apply most recent stash
|
|
398
|
-
git stash pop
|
|
399
|
-
|
|
400
|
-
# Apply specific stash
|
|
401
|
-
git stash apply stash@{2}
|
|
402
|
-
|
|
403
|
-
# Drop stash
|
|
404
|
-
git stash drop stash@{0}
|
|
405
|
-
```
|
|
406
|
-
|
|
407
|
-
## Release Management
|
|
408
|
-
|
|
409
|
-
### Semantic Versioning
|
|
410
|
-
|
|
411
|
-
```
|
|
412
|
-
MAJOR.MINOR.PATCH
|
|
413
|
-
|
|
414
|
-
MAJOR: Breaking changes
|
|
415
|
-
MINOR: New features, backward compatible
|
|
416
|
-
PATCH: Bug fixes, backward compatible
|
|
417
|
-
|
|
418
|
-
Examples:
|
|
419
|
-
1.0.0 → 1.0.1 (patch: bug fix)
|
|
420
|
-
1.0.1 → 1.1.0 (minor: new feature)
|
|
421
|
-
1.1.0 → 2.0.0 (major: breaking change)
|
|
422
|
-
```
|
|
423
|
-
|
|
424
|
-
### Creating Releases
|
|
425
|
-
|
|
426
|
-
```bash
|
|
427
|
-
# Create annotated tag
|
|
428
|
-
git tag -a v1.2.0 -m "Release v1.2.0
|
|
429
|
-
|
|
430
|
-
Features:
|
|
431
|
-
- Add user authentication
|
|
432
|
-
- Implement password reset
|
|
433
|
-
|
|
434
|
-
Fixes:
|
|
435
|
-
- Resolve login redirect issue
|
|
436
|
-
|
|
437
|
-
Breaking Changes:
|
|
438
|
-
- None"
|
|
439
|
-
|
|
440
|
-
# Push tag to remote
|
|
441
|
-
git push origin v1.2.0
|
|
442
|
-
|
|
443
|
-
# List tags
|
|
444
|
-
git tag -l
|
|
445
|
-
|
|
446
|
-
# Delete tag
|
|
447
|
-
git tag -d v1.2.0
|
|
448
|
-
git push origin --delete v1.2.0
|
|
449
|
-
```
|
|
450
|
-
|
|
451
|
-
### Changelog Generation
|
|
452
|
-
|
|
453
|
-
```bash
|
|
454
|
-
# Generate changelog from commits
|
|
455
|
-
git log v1.1.0..v1.2.0 --oneline --no-merges
|
|
456
|
-
|
|
457
|
-
# Or use conventional-changelog
|
|
458
|
-
npx conventional-changelog -i CHANGELOG.md -s
|
|
459
|
-
```
|
|
460
|
-
|
|
461
|
-
## Git Configuration
|
|
462
|
-
|
|
463
|
-
### Essential Configs
|
|
464
|
-
|
|
465
|
-
```bash
|
|
466
|
-
# User identity
|
|
467
|
-
git config --global user.name "Your Name"
|
|
468
|
-
git config --global user.email "your@email.com"
|
|
469
|
-
|
|
470
|
-
# Default branch name
|
|
471
|
-
git config --global init.defaultBranch main
|
|
472
|
-
|
|
473
|
-
# Pull behavior (rebase instead of merge)
|
|
474
|
-
git config --global pull.rebase true
|
|
475
|
-
|
|
476
|
-
# Push behavior (push current branch only)
|
|
477
|
-
git config --global push.default current
|
|
478
|
-
|
|
479
|
-
# Auto-correct typos
|
|
480
|
-
git config --global help.autocorrect 1
|
|
481
|
-
|
|
482
|
-
# Better diff algorithm
|
|
483
|
-
git config --global diff.algorithm histogram
|
|
484
|
-
|
|
485
|
-
# Color output
|
|
486
|
-
git config --global color.ui auto
|
|
487
|
-
```
|
|
488
|
-
|
|
489
|
-
### Useful Aliases
|
|
490
|
-
|
|
491
|
-
```bash
|
|
492
|
-
# Add to ~/.gitconfig
|
|
493
|
-
[alias]
|
|
494
|
-
co = checkout
|
|
495
|
-
br = branch
|
|
496
|
-
ci = commit
|
|
497
|
-
st = status
|
|
498
|
-
unstage = reset HEAD --
|
|
499
|
-
last = log -1 HEAD
|
|
500
|
-
visual = log --oneline --graph --all
|
|
501
|
-
amend = commit --amend --no-edit
|
|
502
|
-
wip = commit -m "WIP"
|
|
503
|
-
undo = reset --soft HEAD~1
|
|
504
|
-
contributors = shortlog -sn
|
|
505
|
-
```
|
|
506
|
-
|
|
507
|
-
### Gitignore Patterns
|
|
508
|
-
|
|
509
|
-
```gitignore
|
|
510
|
-
# Dependencies
|
|
511
|
-
node_modules/
|
|
512
|
-
vendor/
|
|
513
|
-
|
|
514
|
-
# Build outputs
|
|
515
|
-
dist/
|
|
516
|
-
build/
|
|
517
|
-
*.o
|
|
518
|
-
*.exe
|
|
519
|
-
|
|
520
|
-
# Environment files
|
|
521
|
-
.env
|
|
522
|
-
.env.local
|
|
523
|
-
.env.*.local
|
|
524
|
-
|
|
525
|
-
# IDE
|
|
526
|
-
.idea/
|
|
527
|
-
.vscode/
|
|
528
|
-
*.swp
|
|
529
|
-
*.swo
|
|
530
|
-
|
|
531
|
-
# OS files
|
|
532
|
-
.DS_Store
|
|
533
|
-
Thumbs.db
|
|
534
|
-
|
|
535
|
-
# Logs
|
|
536
|
-
*.log
|
|
537
|
-
logs/
|
|
538
|
-
|
|
539
|
-
# Test coverage
|
|
540
|
-
coverage/
|
|
541
|
-
|
|
542
|
-
# Cache
|
|
543
|
-
.cache/
|
|
544
|
-
*.tsbuildinfo
|
|
545
|
-
```
|
|
546
|
-
|
|
547
|
-
## Common Workflows
|
|
548
|
-
|
|
549
|
-
### Starting a New Feature
|
|
550
|
-
|
|
551
|
-
```bash
|
|
552
|
-
# 1. Update main branch
|
|
553
|
-
git checkout main
|
|
554
|
-
git pull origin main
|
|
555
|
-
|
|
556
|
-
# 2. Create feature branch
|
|
557
|
-
git checkout -b feature/user-auth
|
|
558
|
-
|
|
559
|
-
# 3. Make changes and commit
|
|
560
|
-
git add .
|
|
561
|
-
git commit -m "feat(auth): implement OAuth2 login"
|
|
562
|
-
|
|
563
|
-
# 4. Push to remote
|
|
564
|
-
git push -u origin feature/user-auth
|
|
565
|
-
|
|
566
|
-
# 5. Create Pull Request on GitHub/GitLab
|
|
567
|
-
```
|
|
568
|
-
|
|
569
|
-
### Updating a PR with New Changes
|
|
570
|
-
|
|
571
|
-
```bash
|
|
572
|
-
# 1. Make additional changes
|
|
573
|
-
git add .
|
|
574
|
-
git commit -m "feat(auth): add error handling"
|
|
575
|
-
|
|
576
|
-
# 2. Push updates
|
|
577
|
-
git push origin feature/user-auth
|
|
578
|
-
```
|
|
579
|
-
|
|
580
|
-
### Syncing Fork with Upstream
|
|
581
|
-
|
|
582
|
-
```bash
|
|
583
|
-
# 1. Add upstream remote (once)
|
|
584
|
-
git remote add upstream https://github.com/original/repo.git
|
|
585
|
-
|
|
586
|
-
# 2. Fetch upstream
|
|
587
|
-
git fetch upstream
|
|
588
|
-
|
|
589
|
-
# 3. Merge upstream/main into your main
|
|
590
|
-
git checkout main
|
|
591
|
-
git merge upstream/main
|
|
592
|
-
|
|
593
|
-
# 4. Push to your fork
|
|
594
|
-
git push origin main
|
|
595
|
-
```
|
|
596
|
-
|
|
597
|
-
### Undoing Mistakes
|
|
598
|
-
|
|
599
|
-
```bash
|
|
600
|
-
# Undo last commit (keep changes)
|
|
601
|
-
git reset --soft HEAD~1
|
|
602
|
-
|
|
603
|
-
# Undo last commit (discard changes)
|
|
604
|
-
git reset --hard HEAD~1
|
|
605
|
-
|
|
606
|
-
# Undo last commit pushed to remote
|
|
607
|
-
git revert HEAD
|
|
608
|
-
git push origin main
|
|
609
|
-
|
|
610
|
-
# Undo specific file changes
|
|
611
|
-
git checkout HEAD -- path/to/file
|
|
612
|
-
|
|
613
|
-
# Fix last commit message
|
|
614
|
-
git commit --amend -m "New message"
|
|
615
|
-
|
|
616
|
-
# Add forgotten file to last commit
|
|
617
|
-
git add forgotten-file
|
|
618
|
-
git commit --amend --no-edit
|
|
619
|
-
```
|
|
620
|
-
|
|
621
|
-
## Git Hooks
|
|
622
|
-
|
|
623
|
-
### Pre-Commit Hook
|
|
624
|
-
|
|
625
|
-
```bash
|
|
626
|
-
#!/bin/bash
|
|
627
|
-
# .git/hooks/pre-commit
|
|
628
|
-
|
|
629
|
-
# Run linting
|
|
630
|
-
npm run lint || exit 1
|
|
631
|
-
|
|
632
|
-
# Run tests
|
|
633
|
-
npm test || exit 1
|
|
634
|
-
|
|
635
|
-
# Check for secrets
|
|
636
|
-
if git diff --cached | grep -E '(password|api_key|secret)'; then
|
|
637
|
-
echo "Possible secret detected. Commit aborted."
|
|
638
|
-
exit 1
|
|
639
|
-
fi
|
|
640
|
-
```
|
|
641
|
-
|
|
642
|
-
### Pre-Push Hook
|
|
643
|
-
|
|
644
|
-
```bash
|
|
645
|
-
#!/bin/bash
|
|
646
|
-
# .git/hooks/pre-push
|
|
647
|
-
|
|
648
|
-
# Run full test suite
|
|
649
|
-
npm run test:all || exit 1
|
|
650
|
-
|
|
651
|
-
# Check for console.log statements
|
|
652
|
-
if git diff origin/main | grep -E 'console\.log'; then
|
|
653
|
-
echo "Remove console.log statements before pushing."
|
|
654
|
-
exit 1
|
|
655
|
-
fi
|
|
656
|
-
```
|
|
657
|
-
|
|
658
|
-
## Anti-Patterns
|
|
659
|
-
|
|
660
|
-
```
|
|
661
|
-
# BAD: Committing directly to main
|
|
662
|
-
git checkout main
|
|
663
|
-
git commit -m "fix bug"
|
|
664
|
-
|
|
665
|
-
# GOOD: Use feature branches and PRs
|
|
666
|
-
|
|
667
|
-
# BAD: Committing secrets
|
|
668
|
-
git add .env # Contains API keys
|
|
669
|
-
|
|
670
|
-
# GOOD: Add to .gitignore, use environment variables
|
|
671
|
-
|
|
672
|
-
# BAD: Giant PRs (1000+ lines)
|
|
673
|
-
# GOOD: Break into smaller, focused PRs
|
|
674
|
-
|
|
675
|
-
# BAD: "Update" commit messages
|
|
676
|
-
git commit -m "update"
|
|
677
|
-
git commit -m "fix"
|
|
678
|
-
|
|
679
|
-
# GOOD: Descriptive messages
|
|
680
|
-
git commit -m "fix(auth): resolve redirect loop after login"
|
|
681
|
-
|
|
682
|
-
# BAD: Rewriting public history
|
|
683
|
-
git push --force origin main
|
|
684
|
-
|
|
685
|
-
# GOOD: Use revert for public branches
|
|
686
|
-
git revert HEAD
|
|
687
|
-
|
|
688
|
-
# BAD: Long-lived feature branches (weeks/months)
|
|
689
|
-
# GOOD: Keep branches short (days), rebase frequently
|
|
690
|
-
|
|
691
|
-
# BAD: Committing generated files
|
|
692
|
-
git add dist/
|
|
693
|
-
git add node_modules/
|
|
694
|
-
|
|
695
|
-
# GOOD: Add to .gitignore
|
|
696
|
-
```
|
|
697
|
-
|
|
698
|
-
## Quick Reference
|
|
699
|
-
|
|
700
|
-
| Task | Command |
|
|
701
|
-
|------|---------|
|
|
702
|
-
| Create branch | `git checkout -b feature/name` |
|
|
703
|
-
| Switch branch | `git checkout branch-name` |
|
|
704
|
-
| Delete branch | `git branch -d branch-name` |
|
|
705
|
-
| Merge branch | `git merge branch-name` |
|
|
706
|
-
| Rebase branch | `git rebase main` |
|
|
707
|
-
| View history | `git log --oneline --graph` |
|
|
708
|
-
| View changes | `git diff` |
|
|
709
|
-
| Stage changes | `git add .` or `git add -p` |
|
|
710
|
-
| Commit | `git commit -m "message"` |
|
|
711
|
-
| Push | `git push origin branch-name` |
|
|
712
|
-
| Pull | `git pull origin branch-name` |
|
|
713
|
-
| Stash | `git stash push -m "message"` |
|
|
714
|
-
| Undo last commit | `git reset --soft HEAD~1` |
|
|
715
|
-
| Revert commit | `git revert HEAD` |
|
|
1
|
+
---
|
|
2
|
+
name: git-workflow
|
|
3
|
+
description: Git workflow patterns including branching strategies, commit conventions, merge vs rebase, conflict resolution, and collaborative development best practices for teams of all sizes.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Git Workflow Patterns
|
|
8
|
+
|
|
9
|
+
Best practices for Git version control, branching strategies, and collaborative development.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Setting up Git workflow for a new project
|
|
14
|
+
- Deciding on branching strategy (GitFlow, trunk-based, GitHub flow)
|
|
15
|
+
- Writing commit messages and PR descriptions
|
|
16
|
+
- Resolving merge conflicts
|
|
17
|
+
- Managing releases and version tags
|
|
18
|
+
- Onboarding new team members to Git practices
|
|
19
|
+
|
|
20
|
+
## Branching Strategies
|
|
21
|
+
|
|
22
|
+
### GitHub Flow (Simple, Recommended for Most)
|
|
23
|
+
|
|
24
|
+
Best for continuous deployment and small-to-medium teams.
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
main (protected, always deployable)
|
|
28
|
+
│
|
|
29
|
+
├── feature/user-auth → PR → merge to main
|
|
30
|
+
├── feature/payment-flow → PR → merge to main
|
|
31
|
+
└── fix/login-bug → PR → merge to main
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
**Rules:**
|
|
35
|
+
- `main` is always deployable
|
|
36
|
+
- Create feature branches from `main`
|
|
37
|
+
- Open Pull Request when ready for review
|
|
38
|
+
- After approval and CI passes, merge to `main`
|
|
39
|
+
- Deploy immediately after merge
|
|
40
|
+
|
|
41
|
+
### Trunk-Based Development (High-Velocity Teams)
|
|
42
|
+
|
|
43
|
+
Best for teams with strong CI/CD and feature flags.
|
|
44
|
+
|
|
45
|
+
```
|
|
46
|
+
main (trunk)
|
|
47
|
+
│
|
|
48
|
+
├── short-lived feature (1-2 days max)
|
|
49
|
+
├── short-lived feature
|
|
50
|
+
└── short-lived feature
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
**Rules:**
|
|
54
|
+
- Everyone commits to `main` or very short-lived branches
|
|
55
|
+
- Feature flags hide incomplete work
|
|
56
|
+
- CI must pass before merge
|
|
57
|
+
- Deploy multiple times per day
|
|
58
|
+
|
|
59
|
+
### GitFlow (Complex, Release-Cycle Driven)
|
|
60
|
+
|
|
61
|
+
Best for scheduled releases and enterprise projects.
|
|
62
|
+
|
|
63
|
+
```
|
|
64
|
+
main (production releases)
|
|
65
|
+
│
|
|
66
|
+
└── develop (integration branch)
|
|
67
|
+
│
|
|
68
|
+
├── feature/user-auth
|
|
69
|
+
├── feature/payment
|
|
70
|
+
│
|
|
71
|
+
├── release/1.0.0 → merge to main and develop
|
|
72
|
+
│
|
|
73
|
+
└── hotfix/critical → merge to main and develop
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
**Rules:**
|
|
77
|
+
- `main` contains production-ready code only
|
|
78
|
+
- `develop` is the integration branch
|
|
79
|
+
- Feature branches from `develop`, merge back to `develop`
|
|
80
|
+
- Release branches from `develop`, merge to `main` and `develop`
|
|
81
|
+
- Hotfix branches from `main`, merge to both `main` and `develop`
|
|
82
|
+
|
|
83
|
+
### When to Use Which
|
|
84
|
+
|
|
85
|
+
| Strategy | Team Size | Release Cadence | Best For |
|
|
86
|
+
|----------|-----------|-----------------|----------|
|
|
87
|
+
| GitHub Flow | Any | Continuous | SaaS, web apps, startups |
|
|
88
|
+
| Trunk-Based | 5+ experienced | Multiple/day | High-velocity teams, feature flags |
|
|
89
|
+
| GitFlow | 10+ | Scheduled | Enterprise, regulated industries |
|
|
90
|
+
|
|
91
|
+
## Commit Messages
|
|
92
|
+
|
|
93
|
+
### Conventional Commits Format
|
|
94
|
+
|
|
95
|
+
```
|
|
96
|
+
<type>(<scope>): <subject>
|
|
97
|
+
|
|
98
|
+
[optional body]
|
|
99
|
+
|
|
100
|
+
[optional footer(s)]
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
### Types
|
|
104
|
+
|
|
105
|
+
| Type | Use For | Example |
|
|
106
|
+
|------|---------|---------|
|
|
107
|
+
| `feat` | New feature | `feat(auth): add OAuth2 login` |
|
|
108
|
+
| `fix` | Bug fix | `fix(api): handle null response in user endpoint` |
|
|
109
|
+
| `docs` | Documentation | `docs(readme): update installation instructions` |
|
|
110
|
+
| `style` | Formatting, no code change | `style: fix indentation in login component` |
|
|
111
|
+
| `refactor` | Code refactoring | `refactor(db): extract connection pool to module` |
|
|
112
|
+
| `test` | Adding/updating tests | `test(auth): add unit tests for token validation` |
|
|
113
|
+
| `chore` | Maintenance tasks | `chore(deps): update dependencies` |
|
|
114
|
+
| `perf` | Performance improvement | `perf(query): add index to users table` |
|
|
115
|
+
| `ci` | CI/CD changes | `ci: add PostgreSQL service to test workflow` |
|
|
116
|
+
| `revert` | Revert previous commit | `revert: revert "feat(auth): add OAuth2 login"` |
|
|
117
|
+
|
|
118
|
+
### Good vs Bad Examples
|
|
119
|
+
|
|
120
|
+
```
|
|
121
|
+
# BAD: Vague, no context
|
|
122
|
+
git commit -m "fixed stuff"
|
|
123
|
+
git commit -m "updates"
|
|
124
|
+
git commit -m "WIP"
|
|
125
|
+
|
|
126
|
+
# GOOD: Clear, specific, explains why
|
|
127
|
+
git commit -m "fix(api): retry requests on 503 Service Unavailable
|
|
128
|
+
|
|
129
|
+
The external API occasionally returns 503 errors during peak hours.
|
|
130
|
+
Added exponential backoff retry logic with max 3 attempts.
|
|
131
|
+
|
|
132
|
+
Closes #123"
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
### Commit Message Template
|
|
136
|
+
|
|
137
|
+
Create `.gitmessage` in repo root:
|
|
138
|
+
|
|
139
|
+
```
|
|
140
|
+
# <type>(<scope>): <subject>
|
|
141
|
+
# # Types: feat, fix, docs, style, refactor, test, chore, perf, ci, revert
|
|
142
|
+
# Scope: api, ui, db, auth, etc.
|
|
143
|
+
# Subject: imperative mood, no period, max 50 chars
|
|
144
|
+
#
|
|
145
|
+
# [optional body] - explain why, not what
|
|
146
|
+
# [optional footer] - Breaking changes, closes #issue
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
Enable with: `git config commit.template .gitmessage`
|
|
150
|
+
|
|
151
|
+
## Merge vs Rebase
|
|
152
|
+
|
|
153
|
+
### Merge (Preserves History)
|
|
154
|
+
|
|
155
|
+
```bash
|
|
156
|
+
# Creates a merge commit
|
|
157
|
+
git checkout main
|
|
158
|
+
git merge feature/user-auth
|
|
159
|
+
|
|
160
|
+
# Result:
|
|
161
|
+
# * merge commit
|
|
162
|
+
# |\
|
|
163
|
+
# | * feature commits
|
|
164
|
+
# |/
|
|
165
|
+
# * main commits
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
**Use when:**
|
|
169
|
+
- Merging feature branches into `main`
|
|
170
|
+
- You want to preserve exact history
|
|
171
|
+
- Multiple people worked on the branch
|
|
172
|
+
- The branch has been pushed and others may have based work on it
|
|
173
|
+
|
|
174
|
+
### Rebase (Linear History)
|
|
175
|
+
|
|
176
|
+
```bash
|
|
177
|
+
# Rewrites feature commits onto target branch
|
|
178
|
+
git checkout feature/user-auth
|
|
179
|
+
git rebase main
|
|
180
|
+
|
|
181
|
+
# Result:
|
|
182
|
+
# * feature commits (rewritten)
|
|
183
|
+
# * main commits
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
**Use when:**
|
|
187
|
+
- Updating your local feature branch with latest `main`
|
|
188
|
+
- You want a linear, clean history
|
|
189
|
+
- The branch is local-only (not pushed)
|
|
190
|
+
- You're the only one working on the branch
|
|
191
|
+
|
|
192
|
+
### Rebase Workflow
|
|
193
|
+
|
|
194
|
+
```bash
|
|
195
|
+
# Update feature branch with latest main (before PR)
|
|
196
|
+
git checkout feature/user-auth
|
|
197
|
+
git fetch origin
|
|
198
|
+
git rebase origin/main
|
|
199
|
+
|
|
200
|
+
# Fix any conflicts
|
|
201
|
+
# Tests should still pass
|
|
202
|
+
|
|
203
|
+
# Force push (only if you're the only contributor)
|
|
204
|
+
git push --force-with-lease origin feature/user-auth
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
### When NOT to Rebase
|
|
208
|
+
|
|
209
|
+
```
|
|
210
|
+
# NEVER rebase branches that:
|
|
211
|
+
- Have been pushed to a shared repository
|
|
212
|
+
- Other people have based work on
|
|
213
|
+
- Are protected branches (main, develop)
|
|
214
|
+
- Are already merged
|
|
215
|
+
|
|
216
|
+
# Why: Rebase rewrites history, breaking others' work
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
## Pull Request Workflow
|
|
220
|
+
|
|
221
|
+
### PR Title Format
|
|
222
|
+
|
|
223
|
+
```
|
|
224
|
+
<type>(<scope>): <description>
|
|
225
|
+
|
|
226
|
+
Examples:
|
|
227
|
+
feat(auth): add SSO support for enterprise users
|
|
228
|
+
fix(api): resolve race condition in order processing
|
|
229
|
+
docs(api): add OpenAPI specification for v2 endpoints
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
### PR Description Template
|
|
233
|
+
|
|
234
|
+
```markdown
|
|
235
|
+
## What
|
|
236
|
+
|
|
237
|
+
Brief description of what this PR does.
|
|
238
|
+
|
|
239
|
+
## Why
|
|
240
|
+
|
|
241
|
+
Explain the motivation and context.
|
|
242
|
+
|
|
243
|
+
## How
|
|
244
|
+
|
|
245
|
+
Key implementation details worth highlighting.
|
|
246
|
+
|
|
247
|
+
## Testing
|
|
248
|
+
|
|
249
|
+
- [ ] Unit tests added/updated
|
|
250
|
+
- [ ] Integration tests added/updated
|
|
251
|
+
- [ ] Manual testing performed
|
|
252
|
+
|
|
253
|
+
## Screenshots (if applicable)
|
|
254
|
+
|
|
255
|
+
Before/after screenshots for UI changes.
|
|
256
|
+
|
|
257
|
+
## Checklist
|
|
258
|
+
|
|
259
|
+
- [ ] Code follows project style guidelines
|
|
260
|
+
- [ ] Self-review completed
|
|
261
|
+
- [ ] Comments added for complex logic
|
|
262
|
+
- [ ] Documentation updated
|
|
263
|
+
- [ ] No new warnings introduced
|
|
264
|
+
- [ ] Tests pass locally
|
|
265
|
+
- [ ] Related issues linked
|
|
266
|
+
|
|
267
|
+
Closes #123
|
|
268
|
+
```
|
|
269
|
+
|
|
270
|
+
### Code Review Checklist
|
|
271
|
+
|
|
272
|
+
**For Reviewers:**
|
|
273
|
+
|
|
274
|
+
- [ ] Does the code solve the stated problem?
|
|
275
|
+
- [ ] Are there any edge cases not handled?
|
|
276
|
+
- [ ] Is the code readable and maintainable?
|
|
277
|
+
- [ ] Are there sufficient tests?
|
|
278
|
+
- [ ] Are there security concerns?
|
|
279
|
+
- [ ] Is the commit history clean (squashed if needed)?
|
|
280
|
+
|
|
281
|
+
**For Authors:**
|
|
282
|
+
|
|
283
|
+
- [ ] Self-review completed before requesting review
|
|
284
|
+
- [ ] CI passes (tests, lint, typecheck)
|
|
285
|
+
- [ ] PR size is reasonable (<500 lines ideal)
|
|
286
|
+
- [ ] Related to a single feature/fix
|
|
287
|
+
- [ ] Description clearly explains the change
|
|
288
|
+
|
|
289
|
+
## Conflict Resolution
|
|
290
|
+
|
|
291
|
+
### Identify Conflicts
|
|
292
|
+
|
|
293
|
+
```bash
|
|
294
|
+
# Check for conflicts before merge
|
|
295
|
+
git checkout main
|
|
296
|
+
git merge feature/user-auth --no-commit --no-ff
|
|
297
|
+
|
|
298
|
+
# If conflicts, Git will show:
|
|
299
|
+
# CONFLICT (content): Merge conflict in src/auth/login.ts
|
|
300
|
+
# Automatic merge failed; fix conflicts and then commit the result.
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
### Resolve Conflicts
|
|
304
|
+
|
|
305
|
+
```bash
|
|
306
|
+
# See conflicted files
|
|
307
|
+
git status
|
|
308
|
+
|
|
309
|
+
# View conflict markers in file
|
|
310
|
+
# <<<<<<< HEAD
|
|
311
|
+
# content from main
|
|
312
|
+
# =======
|
|
313
|
+
# content from feature branch
|
|
314
|
+
# >>>>>>> feature/user-auth
|
|
315
|
+
|
|
316
|
+
# Option 1: Manual resolution
|
|
317
|
+
# Edit file, remove markers, keep correct content
|
|
318
|
+
|
|
319
|
+
# Option 2: Use merge tool
|
|
320
|
+
git mergetool
|
|
321
|
+
|
|
322
|
+
# Option 3: Accept one side
|
|
323
|
+
git checkout --ours src/auth/login.ts # Keep main version
|
|
324
|
+
git checkout --theirs src/auth/login.ts # Keep feature version
|
|
325
|
+
|
|
326
|
+
# After resolving, stage and commit
|
|
327
|
+
git add src/auth/login.ts
|
|
328
|
+
git commit
|
|
329
|
+
```
|
|
330
|
+
|
|
331
|
+
### Conflict Prevention Strategies
|
|
332
|
+
|
|
333
|
+
```bash
|
|
334
|
+
# 1. Keep feature branches small and short-lived
|
|
335
|
+
# 2. Rebase frequently onto main
|
|
336
|
+
git checkout feature/user-auth
|
|
337
|
+
git fetch origin
|
|
338
|
+
git rebase origin/main
|
|
339
|
+
|
|
340
|
+
# 3. Communicate with team about touching shared files
|
|
341
|
+
# 4. Use feature flags instead of long-lived branches
|
|
342
|
+
# 5. Review and merge PRs promptly
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
## Branch Management
|
|
346
|
+
|
|
347
|
+
### Naming Conventions
|
|
348
|
+
|
|
349
|
+
```
|
|
350
|
+
# Feature branches
|
|
351
|
+
feature/user-authentication
|
|
352
|
+
feature/JIRA-123-payment-integration
|
|
353
|
+
|
|
354
|
+
# Bug fixes
|
|
355
|
+
fix/login-redirect-loop
|
|
356
|
+
fix/456-null-pointer-exception
|
|
357
|
+
|
|
358
|
+
# Hotfixes (production issues)
|
|
359
|
+
hotfix/critical-security-patch
|
|
360
|
+
hotfix/database-connection-leak
|
|
361
|
+
|
|
362
|
+
# Releases
|
|
363
|
+
release/1.2.0
|
|
364
|
+
release/2024-01-hotfix
|
|
365
|
+
|
|
366
|
+
# Experiments/POCs
|
|
367
|
+
experiment/new-caching-strategy
|
|
368
|
+
poc/graphql-migration
|
|
369
|
+
```
|
|
370
|
+
|
|
371
|
+
### Branch Cleanup
|
|
372
|
+
|
|
373
|
+
```bash
|
|
374
|
+
# Delete local branches that are merged
|
|
375
|
+
git branch --merged main | grep -v "^\*\|main" | xargs -n 1 git branch -d
|
|
376
|
+
|
|
377
|
+
# Delete remote-tracking references for deleted remote branches
|
|
378
|
+
git fetch -p
|
|
379
|
+
|
|
380
|
+
# Delete local branch
|
|
381
|
+
git branch -d feature/user-auth # Safe delete (only if merged)
|
|
382
|
+
git branch -D feature/user-auth # Force delete
|
|
383
|
+
|
|
384
|
+
# Delete remote branch
|
|
385
|
+
git push origin --delete feature/user-auth
|
|
386
|
+
```
|
|
387
|
+
|
|
388
|
+
### Stash Workflow
|
|
389
|
+
|
|
390
|
+
```bash
|
|
391
|
+
# Save work in progress
|
|
392
|
+
git stash push -m "WIP: user authentication"
|
|
393
|
+
|
|
394
|
+
# List stashes
|
|
395
|
+
git stash list
|
|
396
|
+
|
|
397
|
+
# Apply most recent stash
|
|
398
|
+
git stash pop
|
|
399
|
+
|
|
400
|
+
# Apply specific stash
|
|
401
|
+
git stash apply stash@{2}
|
|
402
|
+
|
|
403
|
+
# Drop stash
|
|
404
|
+
git stash drop stash@{0}
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
## Release Management
|
|
408
|
+
|
|
409
|
+
### Semantic Versioning
|
|
410
|
+
|
|
411
|
+
```
|
|
412
|
+
MAJOR.MINOR.PATCH
|
|
413
|
+
|
|
414
|
+
MAJOR: Breaking changes
|
|
415
|
+
MINOR: New features, backward compatible
|
|
416
|
+
PATCH: Bug fixes, backward compatible
|
|
417
|
+
|
|
418
|
+
Examples:
|
|
419
|
+
1.0.0 → 1.0.1 (patch: bug fix)
|
|
420
|
+
1.0.1 → 1.1.0 (minor: new feature)
|
|
421
|
+
1.1.0 → 2.0.0 (major: breaking change)
|
|
422
|
+
```
|
|
423
|
+
|
|
424
|
+
### Creating Releases
|
|
425
|
+
|
|
426
|
+
```bash
|
|
427
|
+
# Create annotated tag
|
|
428
|
+
git tag -a v1.2.0 -m "Release v1.2.0
|
|
429
|
+
|
|
430
|
+
Features:
|
|
431
|
+
- Add user authentication
|
|
432
|
+
- Implement password reset
|
|
433
|
+
|
|
434
|
+
Fixes:
|
|
435
|
+
- Resolve login redirect issue
|
|
436
|
+
|
|
437
|
+
Breaking Changes:
|
|
438
|
+
- None"
|
|
439
|
+
|
|
440
|
+
# Push tag to remote
|
|
441
|
+
git push origin v1.2.0
|
|
442
|
+
|
|
443
|
+
# List tags
|
|
444
|
+
git tag -l
|
|
445
|
+
|
|
446
|
+
# Delete tag
|
|
447
|
+
git tag -d v1.2.0
|
|
448
|
+
git push origin --delete v1.2.0
|
|
449
|
+
```
|
|
450
|
+
|
|
451
|
+
### Changelog Generation
|
|
452
|
+
|
|
453
|
+
```bash
|
|
454
|
+
# Generate changelog from commits
|
|
455
|
+
git log v1.1.0..v1.2.0 --oneline --no-merges
|
|
456
|
+
|
|
457
|
+
# Or use conventional-changelog
|
|
458
|
+
npx conventional-changelog -i CHANGELOG.md -s
|
|
459
|
+
```
|
|
460
|
+
|
|
461
|
+
## Git Configuration
|
|
462
|
+
|
|
463
|
+
### Essential Configs
|
|
464
|
+
|
|
465
|
+
```bash
|
|
466
|
+
# User identity
|
|
467
|
+
git config --global user.name "Your Name"
|
|
468
|
+
git config --global user.email "your@email.com"
|
|
469
|
+
|
|
470
|
+
# Default branch name
|
|
471
|
+
git config --global init.defaultBranch main
|
|
472
|
+
|
|
473
|
+
# Pull behavior (rebase instead of merge)
|
|
474
|
+
git config --global pull.rebase true
|
|
475
|
+
|
|
476
|
+
# Push behavior (push current branch only)
|
|
477
|
+
git config --global push.default current
|
|
478
|
+
|
|
479
|
+
# Auto-correct typos
|
|
480
|
+
git config --global help.autocorrect 1
|
|
481
|
+
|
|
482
|
+
# Better diff algorithm
|
|
483
|
+
git config --global diff.algorithm histogram
|
|
484
|
+
|
|
485
|
+
# Color output
|
|
486
|
+
git config --global color.ui auto
|
|
487
|
+
```
|
|
488
|
+
|
|
489
|
+
### Useful Aliases
|
|
490
|
+
|
|
491
|
+
```bash
|
|
492
|
+
# Add to ~/.gitconfig
|
|
493
|
+
[alias]
|
|
494
|
+
co = checkout
|
|
495
|
+
br = branch
|
|
496
|
+
ci = commit
|
|
497
|
+
st = status
|
|
498
|
+
unstage = reset HEAD --
|
|
499
|
+
last = log -1 HEAD
|
|
500
|
+
visual = log --oneline --graph --all
|
|
501
|
+
amend = commit --amend --no-edit
|
|
502
|
+
wip = commit -m "WIP"
|
|
503
|
+
undo = reset --soft HEAD~1
|
|
504
|
+
contributors = shortlog -sn
|
|
505
|
+
```
|
|
506
|
+
|
|
507
|
+
### Gitignore Patterns
|
|
508
|
+
|
|
509
|
+
```gitignore
|
|
510
|
+
# Dependencies
|
|
511
|
+
node_modules/
|
|
512
|
+
vendor/
|
|
513
|
+
|
|
514
|
+
# Build outputs
|
|
515
|
+
dist/
|
|
516
|
+
build/
|
|
517
|
+
*.o
|
|
518
|
+
*.exe
|
|
519
|
+
|
|
520
|
+
# Environment files
|
|
521
|
+
.env
|
|
522
|
+
.env.local
|
|
523
|
+
.env.*.local
|
|
524
|
+
|
|
525
|
+
# IDE
|
|
526
|
+
.idea/
|
|
527
|
+
.vscode/
|
|
528
|
+
*.swp
|
|
529
|
+
*.swo
|
|
530
|
+
|
|
531
|
+
# OS files
|
|
532
|
+
.DS_Store
|
|
533
|
+
Thumbs.db
|
|
534
|
+
|
|
535
|
+
# Logs
|
|
536
|
+
*.log
|
|
537
|
+
logs/
|
|
538
|
+
|
|
539
|
+
# Test coverage
|
|
540
|
+
coverage/
|
|
541
|
+
|
|
542
|
+
# Cache
|
|
543
|
+
.cache/
|
|
544
|
+
*.tsbuildinfo
|
|
545
|
+
```
|
|
546
|
+
|
|
547
|
+
## Common Workflows
|
|
548
|
+
|
|
549
|
+
### Starting a New Feature
|
|
550
|
+
|
|
551
|
+
```bash
|
|
552
|
+
# 1. Update main branch
|
|
553
|
+
git checkout main
|
|
554
|
+
git pull origin main
|
|
555
|
+
|
|
556
|
+
# 2. Create feature branch
|
|
557
|
+
git checkout -b feature/user-auth
|
|
558
|
+
|
|
559
|
+
# 3. Make changes and commit
|
|
560
|
+
git add .
|
|
561
|
+
git commit -m "feat(auth): implement OAuth2 login"
|
|
562
|
+
|
|
563
|
+
# 4. Push to remote
|
|
564
|
+
git push -u origin feature/user-auth
|
|
565
|
+
|
|
566
|
+
# 5. Create Pull Request on GitHub/GitLab
|
|
567
|
+
```
|
|
568
|
+
|
|
569
|
+
### Updating a PR with New Changes
|
|
570
|
+
|
|
571
|
+
```bash
|
|
572
|
+
# 1. Make additional changes
|
|
573
|
+
git add .
|
|
574
|
+
git commit -m "feat(auth): add error handling"
|
|
575
|
+
|
|
576
|
+
# 2. Push updates
|
|
577
|
+
git push origin feature/user-auth
|
|
578
|
+
```
|
|
579
|
+
|
|
580
|
+
### Syncing Fork with Upstream
|
|
581
|
+
|
|
582
|
+
```bash
|
|
583
|
+
# 1. Add upstream remote (once)
|
|
584
|
+
git remote add upstream https://github.com/original/repo.git
|
|
585
|
+
|
|
586
|
+
# 2. Fetch upstream
|
|
587
|
+
git fetch upstream
|
|
588
|
+
|
|
589
|
+
# 3. Merge upstream/main into your main
|
|
590
|
+
git checkout main
|
|
591
|
+
git merge upstream/main
|
|
592
|
+
|
|
593
|
+
# 4. Push to your fork
|
|
594
|
+
git push origin main
|
|
595
|
+
```
|
|
596
|
+
|
|
597
|
+
### Undoing Mistakes
|
|
598
|
+
|
|
599
|
+
```bash
|
|
600
|
+
# Undo last commit (keep changes)
|
|
601
|
+
git reset --soft HEAD~1
|
|
602
|
+
|
|
603
|
+
# Undo last commit (discard changes)
|
|
604
|
+
git reset --hard HEAD~1
|
|
605
|
+
|
|
606
|
+
# Undo last commit pushed to remote
|
|
607
|
+
git revert HEAD
|
|
608
|
+
git push origin main
|
|
609
|
+
|
|
610
|
+
# Undo specific file changes
|
|
611
|
+
git checkout HEAD -- path/to/file
|
|
612
|
+
|
|
613
|
+
# Fix last commit message
|
|
614
|
+
git commit --amend -m "New message"
|
|
615
|
+
|
|
616
|
+
# Add forgotten file to last commit
|
|
617
|
+
git add forgotten-file
|
|
618
|
+
git commit --amend --no-edit
|
|
619
|
+
```
|
|
620
|
+
|
|
621
|
+
## Git Hooks
|
|
622
|
+
|
|
623
|
+
### Pre-Commit Hook
|
|
624
|
+
|
|
625
|
+
```bash
|
|
626
|
+
#!/bin/bash
|
|
627
|
+
# .git/hooks/pre-commit
|
|
628
|
+
|
|
629
|
+
# Run linting
|
|
630
|
+
npm run lint || exit 1
|
|
631
|
+
|
|
632
|
+
# Run tests
|
|
633
|
+
npm test || exit 1
|
|
634
|
+
|
|
635
|
+
# Check for secrets
|
|
636
|
+
if git diff --cached | grep -E '(password|api_key|secret)'; then
|
|
637
|
+
echo "Possible secret detected. Commit aborted."
|
|
638
|
+
exit 1
|
|
639
|
+
fi
|
|
640
|
+
```
|
|
641
|
+
|
|
642
|
+
### Pre-Push Hook
|
|
643
|
+
|
|
644
|
+
```bash
|
|
645
|
+
#!/bin/bash
|
|
646
|
+
# .git/hooks/pre-push
|
|
647
|
+
|
|
648
|
+
# Run full test suite
|
|
649
|
+
npm run test:all || exit 1
|
|
650
|
+
|
|
651
|
+
# Check for console.log statements
|
|
652
|
+
if git diff origin/main | grep -E 'console\.log'; then
|
|
653
|
+
echo "Remove console.log statements before pushing."
|
|
654
|
+
exit 1
|
|
655
|
+
fi
|
|
656
|
+
```
|
|
657
|
+
|
|
658
|
+
## Anti-Patterns
|
|
659
|
+
|
|
660
|
+
```
|
|
661
|
+
# BAD: Committing directly to main
|
|
662
|
+
git checkout main
|
|
663
|
+
git commit -m "fix bug"
|
|
664
|
+
|
|
665
|
+
# GOOD: Use feature branches and PRs
|
|
666
|
+
|
|
667
|
+
# BAD: Committing secrets
|
|
668
|
+
git add .env # Contains API keys
|
|
669
|
+
|
|
670
|
+
# GOOD: Add to .gitignore, use environment variables
|
|
671
|
+
|
|
672
|
+
# BAD: Giant PRs (1000+ lines)
|
|
673
|
+
# GOOD: Break into smaller, focused PRs
|
|
674
|
+
|
|
675
|
+
# BAD: "Update" commit messages
|
|
676
|
+
git commit -m "update"
|
|
677
|
+
git commit -m "fix"
|
|
678
|
+
|
|
679
|
+
# GOOD: Descriptive messages
|
|
680
|
+
git commit -m "fix(auth): resolve redirect loop after login"
|
|
681
|
+
|
|
682
|
+
# BAD: Rewriting public history
|
|
683
|
+
git push --force origin main
|
|
684
|
+
|
|
685
|
+
# GOOD: Use revert for public branches
|
|
686
|
+
git revert HEAD
|
|
687
|
+
|
|
688
|
+
# BAD: Long-lived feature branches (weeks/months)
|
|
689
|
+
# GOOD: Keep branches short (days), rebase frequently
|
|
690
|
+
|
|
691
|
+
# BAD: Committing generated files
|
|
692
|
+
git add dist/
|
|
693
|
+
git add node_modules/
|
|
694
|
+
|
|
695
|
+
# GOOD: Add to .gitignore
|
|
696
|
+
```
|
|
697
|
+
|
|
698
|
+
## Quick Reference
|
|
699
|
+
|
|
700
|
+
| Task | Command |
|
|
701
|
+
|------|---------|
|
|
702
|
+
| Create branch | `git checkout -b feature/name` |
|
|
703
|
+
| Switch branch | `git checkout branch-name` |
|
|
704
|
+
| Delete branch | `git branch -d branch-name` |
|
|
705
|
+
| Merge branch | `git merge branch-name` |
|
|
706
|
+
| Rebase branch | `git rebase main` |
|
|
707
|
+
| View history | `git log --oneline --graph` |
|
|
708
|
+
| View changes | `git diff` |
|
|
709
|
+
| Stage changes | `git add .` or `git add -p` |
|
|
710
|
+
| Commit | `git commit -m "message"` |
|
|
711
|
+
| Push | `git push origin branch-name` |
|
|
712
|
+
| Pull | `git pull origin branch-name` |
|
|
713
|
+
| Stash | `git stash push -m "message"` |
|
|
714
|
+
| Undo last commit | `git reset --soft HEAD~1` |
|
|
715
|
+
| Revert commit | `git revert HEAD` |
|