rebase
Rebase Skill (Fusion Framework)
This skill helps you rebase feature branches onto the latest main branch, handling common conflicts in a pnpm monorepo.
Overview
When rebasing a feature branch, you'll often encounter conflicts in pnpm-lock.yaml due to parallel dependency changes. The correct approach is to regenerate the lockfile rather than manually resolving conflicts.
Standard Rebase Workflow
1. Prepare for rebase
# Navigate to your worktree or branch
cd /path/to/worktree
# Ensure you're on the correct branch
git branch
# Fetch latest changes from origin (including main)
git fetch origin
git fetch origin main:refs/remotes/origin/main
2. Start the rebase
# Rebase your branch onto the latest main
git rebase origin/main
3. Handle pnpm-lock.yaml conflicts
CRITICAL: When pnpm-lock.yaml has conflicts during rebase:
# Regenerate it from package.json files
pnpm install
# Stage the regenerated lockfile
git add pnpm-lock.yaml
# Continue the rebase
git rebase --continue
4. Handle "Version Packages" commit conflicts
When you encounter a "Version Packages (next)" commit with conflicts:
This happens when your feature branch has pre-release versions (e.g., 2.0.0-next.0) but main has been updated with newer regular versions.
Resolution strategy:
- package.json: Use
--ours(HEAD version from main) - CHANGELOG.md: Use
--ours(HEAD changelog from main)
# For all package.json conflicts, keep HEAD version
git checkout --ours "packages/*/package.json"
git add "packages/*/package.json"
# For all CHANGELOG.md conflicts, keep HEAD changelog
git checkout --ours "packages/*/CHANGELOG.md"
git add "packages/*/CHANGELOG.md"
# Also check other affected files
git checkout --ours "vue-press/package.json" 2>/dev/null || true
git add "vue-press/package.json" 2>/dev/null || true
# Continue the rebase
git rebase --continue
Why? The main branch has the authoritative versions and changelogs. Your feature branch's pre-release versions will be regenerated when you create a new changeset after rebasing.
5. Handle other conflicts
For conflicts in source files (.ts, .tsx, etc.):
# Manually resolve conflicts in the files
# Then stage the resolved files
git add path/to/resolved-file.ts
# Continue the rebase
git rebase --continue
6. Complete the rebase
After all commits are rebased successfully:
# Verify the branch is clean
git status
# Force push to update the remote branch
git push --force-with-lease origin YOUR_BRANCH_NAME
7. Align pre.json initial versions (if in pre mode)
If .changeset/pre.json exists (pre-release mode), align initialVersions to current package versions for packages changed by the rebase:
# From repo root
node .github/skills/rebase/scripts/align-pre-initial-versions.cjs
What it does:
- Reads
.changeset/pre.jsonto get thetag(e.g.,next) - Updates
initialVersionswhen the current package version does NOT end with-TAG.NUMBER(e.g.,2.0.0or2.1.0) - Skips entries where the current version ends with
-TAG.NUMBER(e.g.,2.0.0-next.0), preserving ongoing pre state
8. Sanity check vs remote
Before pushing, verify local rebase result against the remote branch.
# Ensure you have latest remote
git fetch origin
# Set a helper var for current branch
BRANCH=$(git rev-parse --abbrev-ref HEAD)
# Quick overview of what will change on the remote
git diff --stat origin/$BRANCH...HEAD
# See the file list (useful to spot unintended changes)
git diff --name-only origin/$BRANCH...HEAD | sort
# Review commit differences (left/right) without merges
git log --oneline --left-right --cherry --no-merges origin/$BRANCH...HEAD
# Optional: preview the push without sending any data
git push --force-with-lease --dry-run origin $BRANCH
Proceed to push only if the changes match expectations.
9. Generate raw data report
Run the data extraction script:
# From repo root
node .github/skills/rebase/scripts/generate-rebase-report.cjs --no-fetch
This generates .tmp/skills/rebase/<timestamp>-rebase-report.md with raw data:
- Ahead/behind counts and diff summary
- Highlights & Anomalies: largest diffs, config changes, dependency summary
- Full commit list (all 57+ commits with hashes and messages)
- Changed packages and top-level folders
- pre.json initialVersions changes (version baseline updates)
- pnpm-lock.yaml churn
- Detailed Dependency Changes - Complete breakdown per package:
- ⚠️ Major version bumps (e.g.,
zod: ^3.23.8 → ^4.3.5) - ➕ Added dependencies (e.g.,
@azure/search-documents: ^12.2.0) - ➖ Removed dependencies
- Minor/patch version changes
- Organized by section: dependencies, devDependencies, peerDependencies
- ⚠️ Major version bumps (e.g.,
10. Generate human-readable summary (automatic)
After the raw report is generated, the AI agent will automatically:
- Read the latest report from
.tmp/skills/rebase/<timestamp>-rebase-report.md - Analyze the "Detailed Dependency Changes" section
- Create a human-readable summary with:
- Breaking dependency changes - Each major bump explained (what package, what changed, why it matters, what to test)
- New dependencies added - What was added and its purpose
- Version baselines updated - Which packages bumped and what that means
- Risk assessment - Overall risk level (🟢 LOW, 🟡 MEDIUM, 🔴 HIGH) with reasoning
- Pre-push checklist - Specific tests to run based on detected changes
The summary will be displayed in the chat for review before you push.
- Next steps: sanity checks and push confirmation
Open the SUMMARY.md file in your editor to review before pushing.
Common Scenarios
Reset local branch to match remote
If your local branch has diverged incorrectly:
# Fetch latest
git fetch origin
# Hard reset to remote branch
git reset --hard origin/YOUR_BRANCH_NAME
Abort a rebase in progress
If you need to start over:
git rebase --abort
Continue after fixing conflicts
# After resolving conflicts and staging changes
git rebase --continue
Skip a commit during rebase
Only if the commit is no longer needed:
git rebase --skip
Rebase Checklist
- Fetch latest changes from origin
- Start rebase onto
origin/main - For
pnpm-lock.yamlconflicts:- Remove the file with
git rm pnpm-lock.yaml - Run
pnpm installto regenerate - Stage with
git add pnpm-lock.yaml
- Remove the file with
- For source file conflicts:
- Manually resolve conflicts
- Stage resolved files
- Continue rebase with
git rebase --continue - Repeat until all commits are applied
- Force push with
--force-with-lease
Why Regenerate pnpm-lock.yaml?
The lockfile contains exact dependency resolutions for the entire monorepo. During a rebase:
- Base branch (main) has new/updated dependencies
- Your branch has different/updated dependencies
- Git cannot merge these semantically - it only sees text conflicts
By regenerating with pnpm install:
- pnpm reads all current
package.jsonfiles (including your changes) - Resolves dependencies against the latest registry state
- Creates a consistent lockfile that works with both sets of changes
- Respects workspace protocols and catalog references
Troubleshooting
"diverged and have X and Y different commits"
Your local branch has commits that aren't on remote. Common causes:
- Previous force push to a different commit
- Local branch accidentally pointing to wrong commit
Fix: Reset to remote and rebase:
git fetch origin
git fetch origin main:refs/remotes/origin/main
git reset --hard origin/YOUR_BRANCH_NAME
git rebase origin/main
Rebase conflicts on every commit
You may be rebasing in the wrong direction. Ensure:
- You're ON your feature branch
- You're rebasing ONTO main:
git rebase origin/main
pnpm install fails during rebase
Check:
- All
package.jsonchanges are staged/committed - No syntax errors in modified
package.jsonfiles - You're running from the repository root
Example: Complete rebase flow
# 1. Navigate and prepare
cd /Users/odin.rochmann/dev/GitHub/fusion-framework.worktree/react-19
git fetch origin
git fetch origin main:refs/remotes/origin/main
# 2. Ensure clean state
git status # Should show "nothing to commit, working tree clean"
# 3. Start rebase
git rebase origin/main
# 4. If pnpm-lock.yaml conflict appears:
git rm pnpm-lock.yaml
pnpm install
git add pnpm-lock.yaml
git rebase --continue
# 5. Repeat step 4 for each commit with lockfile conflicts
# 6. When rebase completes:
git push --force-with-lease origin react-19
Related Skills
pnpm-dependency-analysis- Analyze dependencies before/after rebasedependabot-pr-handler- Handle automated dependency updates that may conflict during rebase