JIYIK CN >

Current Location:Home > Learning > OPERATING SYSTEM >

Undoing a rebase in Git

Author:JIYIK Last Updated:2025/04/21 Views:

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 rebasewhat we did on the branch.

We will now illustrate this with an example.


Use git reflogand git resetto undo changes done on a Git branchrebase

Suppose we have a mainbranch and we create a new branch on it feature1.

Suppose mainsome commits happened in the branch . We have feature1made a new branch based on these new commits rebase. This is what we want to undo.

To undo rebase, we can use Git's reflogundo command. Using undo git reflog, we can rebaseimmediately determine the head commit of the branch before we begin.

We will now run the command on the branch feature1( rebasethe 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 rebasethe commit before the operation.

We can git resetreset the branch to this commit using as shown below.

$ git reset HEAD@{2} --hard

After executing the above command, the branch feaure1is now in rebaseits previous state.

Alternatively, you can use git resetUndo rebaseas shown below.

$ git reset --hard ORIG_HEAD

ORIG_HEADHEADare created by commands that move your drastically , to record HEADthe 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_HEADthe unwanted that may change the viz .rebaseresetrebasemerge

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.

Article URL:

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

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

Scan to Read All Tech Tutorials

Social Media
  • https://www.github.com/onmpw
  • qq:1244347461

Recommended

Tags

Scan the Code
Easier Access Tutorial