rebase-safely
SKILL.md
Rebase Safely
Master Git rebase without losing work or causing team chaos.
When to Use
- Updating feature branch with latest main
- Cleaning up commit history before PR
- Squashing multiple commits into one
- Reordering or editing commits
- Fixing commit messages
The Golden Rule
NEVER rebase commits that have been pushed to a shared branch.
Rebasing rewrites history. If others have based work on those commits, you'll cause merge conflicts and confusion.
Safe to rebase:
✓ Local commits not yet pushed
✓ Your own feature branch (not yet merged)
✓ Commits only you have seen
NOT safe to rebase:
✗ main/develop branch
✗ Shared feature branches
✗ Already merged commits
Basic Rebase Operations
Update Feature Branch with Main
# Fetch latest
git fetch origin
# Rebase onto main
git checkout feature-branch
git rebase origin/main
# If conflicts, resolve then:
git add <resolved-files>
git rebase --continue
# Force push YOUR branch only
git push --force-with-lease
Interactive Rebase - Clean Up History
# Rebase last 3 commits
git rebase -i HEAD~3
# Rebase from where branch diverged
git rebase -i main
Interactive rebase commands:
pick = use commit as-is
reword = use commit, but edit message
edit = use commit, but stop to amend
squash = meld into previous commit (keep message)
fixup = meld into previous commit (discard message)
drop = remove commit entirely
Common Scenarios
1. Squash Multiple Commits
Before:
abc123 fix: typo in login
def456 fix: another typo
ghi789 feat: add login page
git rebase -i HEAD~3
Change to:
pick ghi789 feat: add login page
squash def456 fix: another typo
squash abc123 fix: typo in login
Result: One clean commit with combined message.
2. Reorder Commits
git rebase -i HEAD~3
Just change the order of pick lines:
pick ghi789 third commit
pick abc123 first commit # moved down
pick def456 second commit # moved down
3. Edit a Past Commit
git rebase -i HEAD~3
Change pick to edit for the commit you want to change:
pick abc123 first commit
edit def456 second commit # stop here
pick ghi789 third commit
Make your changes, then:
git add <files>
git commit --amend
git rebase --continue
4. Fix Commit Message
git rebase -i HEAD~3
Change pick to reword:
pick abc123 first commit
reword def456 bad message # will prompt for new message
pick ghi789 third commit
5. Split a Commit
git rebase -i HEAD~2
Mark commit as edit:
edit abc123 big commit to split
pick def456 next commit
Then:
# Undo the commit but keep changes
git reset HEAD^
# Create multiple commits
git add file1.js
git commit -m "feat: first part"
git add file2.js
git commit -m "feat: second part"
git rebase --continue
Handling Conflicts
During Rebase
# See conflicted files
git status
# Resolve conflicts in each file
# Remove conflict markers (<<<<, ====, >>>>)
# Stage resolved files
git add <file>
# Continue rebase
git rebase --continue
# If it's too messy, abort
git rebase --abort
Conflict Tips
-
Understand both sides:
git show HEAD:<file> # Your version git show REBASE_HEAD:<file> # Incoming version -
Use merge tool:
git mergetool -
Skip problematic commit (careful!):
git rebase --skip
Safe Rebase Workflow
Before Starting
# Create backup branch
git branch backup-feature-branch
# Make sure working directory is clean
git status
During Rebase
# Check progress
git status
# See what's being applied
git log --oneline REBASE_HEAD~1..REBASE_HEAD
After Rebase
# Compare with backup to ensure nothing lost
git diff backup-feature-branch feature-branch
# Delete backup when satisfied
git branch -d backup-feature-branch
Rebase vs Merge
| Aspect | Rebase | Merge |
|---|---|---|
| History | Linear, clean | Preserves all commits |
| Conflicts | Resolved per-commit | Resolved once |
| Safe for shared branches | No | Yes |
| Traceability | Less (rewrites) | More (merge commits) |
Use rebase for: Local cleanup, updating feature branches Use merge for: Integrating shared branches, preserving history
Autosquash - Quick Fixups
# Create a fixup commit for previous commit
git commit --fixup=<commit-to-fix>
# Autosquash during rebase
git rebase -i --autosquash main
The fixup commits automatically get positioned correctly.
Recovering from Bad Rebase
Using Reflog
# Find pre-rebase state
git reflog
# Look for entry like "rebase (start)"
# Find the commit BEFORE that
# Reset to pre-rebase state
git reset --hard HEAD@{5} # or specific SHA
Using ORIG_HEAD
# Immediately after rebase, ORIG_HEAD points to pre-rebase
git reset --hard ORIG_HEAD
Common Mistakes to Avoid
- Rebasing shared branches - This breaks others' history
- Force pushing without lease - Use
--force-with-lease - Not creating backup - Always have an escape route
- Rebasing huge commit ranges - Do smaller rebases
- Ignoring conflicts - Each conflict needs careful resolution
- Rebasing merge commits - Gets complicated, prefer
--rebase-merges
Team Guidelines
## Rebase Policy
1. Rebase your feature branch onto main before creating PR
2. Never rebase after PR is opened (unless you're the only reviewer)
3. Squash fixup commits before merge
4. Use --force-with-lease, never --force
5. If unsure, ask before rebasing
Weekly Installs
5
Repository
latestaiagents/…t-skillsGitHub Stars
2
First Seen
Feb 4, 2026
Security Audits
Installed on
mcpjam5
claude-code5
replit5
junie5
windsurf5
zencoder5