Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to squash 7 pushed commits into one in to 1 in git?

I have tried multiple ways to squash my remote repo commits but didnt get it right. I want to squash them all and make it one . Below is the list of commits. Below is the summary of my pull request to upstream (which lists 7 commits). I want to list only one instead of 7.

enter image description here

like image 742
A srinivas Avatar asked May 12 '18 02:05

A srinivas


2 Answers

git reset --soft HEAD~7
git add --all
git commit
git push --force

First, reset git index to before the commits you want to squash. Use --soft so that git only resets the index and doesn't touch your working directory. Then create a commit as usual.

like image 54
iBug Avatar answered Oct 02 '22 23:10

iBug


Another way is to use squash - i other work interactive rebase

In order to do a git squash follow those steps:

# X is the number of commits you wish to squash, in your case 7
# In this interactive rebase there can be more that 7 commits if
# there was a merge in one of them
git rebase -i HEAD~X

Once you squash your commits - choose the s for squash = it will combine all the commits into a single commit.

enter image description here

like image 41
CodeWizard Avatar answered Oct 02 '22 21:10

CodeWizard