Undoing a rebase in Git
This article will discuss undoing what has been done on a Git branch rebase
.
Rebasing is the operation of moving the base of a branch to a newer base. Suppose we have a feature branch that is based on the master branch. Then, the master branch has some new commits; we might want to rebase the feature branch based on these new commits.
We might reconsider this rebase
. We no longer want new feature branches to be based on new commits in the master branch.
We want our feature branch to be based on the commits we made when we first branched it from the master branch. So in order to achieve this, we now need to undo rebase
what we did on the branch.
We will now illustrate this with an example.
Use git reflog
and git reset
to undo changes done on a Git branchrebase
Suppose we have a main
branch and we create a new branch on it feature1
.
Suppose main
some commits happened in the branch . We have feature1
made a new branch based on these new commits rebase
. This is what we want to undo.
To undo rebase
, we can use Git's reflog
undo command. Using undo git reflog
, we can rebase
immediately determine the head commit of the branch before we begin.
We will now run the command on the branch feature1
( rebase
the one that is done with ).git reflog
$ git reflog
b745978 HEAD@{0}: rebase: that commit
4sd7c1c HEAD@{1}: rebase: this commit
adf3d3d HEAD@{2}: checkout: moving from main to feature1
...
We can see HEAD@{2}
that is rebase
the commit before the operation.
We can git reset
reset the branch to this commit using as shown below.
$ git reset HEAD@{2} --hard
After executing the above command, the branch feaure1
is now in rebase
its previous state.
Alternatively, you can use git reset
Undo rebase
as shown below.
$ git reset --hard ORIG_HEAD
ORIG_HEAD
HEAD
are created by commands that move your drastically , to record HEAD
the position of before the operation, so that you can easily change the tip of your branch back to the state it was in before you ran them.
The caveat with this alternative is that no other operations like , , or should be performed after ORIG_HEAD
the unwanted that may change the viz .rebase
reset
rebase
merge
Therefore, we can undo the unwanted branches on Git through these methods rebase
.
For reprinting, please send an email to 1244347461@qq.com for approval. After obtaining the author's consent, kindly include the source as a link.
Related Articles
Run a batch (.bat) file in CMD
Publish Date:2025/04/21 Views:169 Category:OPERATING SYSTEM
-
This article will show you how to use CMD to run a batch file.bat. There are three ways in which you can run a batch file. Let us discuss them in the following sections. Run batch (.bat) files in CMD by directly clicking on them This way yo
Running batch scripts using Task Scheduler
Publish Date:2025/04/21 Views:188 Category:OPERATING SYSTEM
-
This article will show you how to use Task Scheduler to run a batch file. Running batch scripts using Task Scheduler With Task Scheduler, you can automate tasks to run automatically at specific times. It only takes a few steps and you don't
Solve the error Make Command Not Found in Cygwin
Publish Date:2025/04/21 Views:75 Category:OPERATING SYSTEM
-
Cygwin allows Windows users to access certain Linux features and includes a large number of GNU and open source tools that are commonly found in popular Linux distributions. When using Cygwin, it is easy to encounter a command not found err
Difference between Bash Nohup and &
Publish Date:2025/04/21 Views:188 Category:OPERATING SYSTEM
-
This short article introduces the nohup command and the control operator to run Linux processes in the background through Bash. In addition, we will further study the key differences between nohup and . Running Linux processes in the backgr
Bash Nohup 与 & 的区别
Publish Date:2025/04/21 Views:186 Category:OPERATING SYSTEM
-
这篇简短的文章介绍了通过 Bash 在后台运行 Linux 进程的 nohup 命令和 控制运算符。 此外,我们将进一步研究 nohup 和 之间的主要区别。 在后台运行 Linux 进程 Linux 提供了两种在后台运行
Getting Timestamp in Bash
Publish Date:2025/04/21 Views:147 Category:OPERATING SYSTEM
-
This article discusses the date Bash command used to obtain the system date/time and UNIX timestamp. Get Timestamp Using date Command in Bash The Linux terminal uses the date command to print the current date and time. The simplest version
Pretty Printing JSON in Shell Script
Publish Date:2025/04/21 Views:145 Category:OPERATING SYSTEM
-
JSON is a textual method for representing JavaScript object literals and arrays and scalar data. It is relatively easier to read and write, and easier for manageable software to parse and generate. JSON is commonly used to serialize structu
Batch checks whether the specified environment variable contains a substring
Publish Date:2025/04/21 Views:72 Category:OPERATING SYSTEM
-
This article discusses how to use the Batch command to test whether an environment variable contains a specific substring. We will introduce two batch scripts that can be used in the above scenario. Checks whether the specified environment
Find the current folder name in Bash
Publish Date:2025/04/21 Views:189 Category:OPERATING SYSTEM
-
Finding a directory is very easy through Bash scripting. But finding the exact directory folder name you are in right now is a bit complicated. This article will introduce three methods to find the folder name from this article directory. I