Skip to main content
  1. Learn
  2. Software Development
  3. Guides
  4. Git tutorial
  5. How to use Git
  6. How to manage history in Git
  7. Combine & move a commit
GuidesSoftware DevelopmentBacklog
Git

Project and code management together.

Combine & move a commit

Go to the “git-tutorial/tutorial6” directory you previously downloaded.

When you examine the history of this repository, it will look like the following:

Current history

We are going to modify the commit with the message “append description of the commit command.”

To do that, we will use the git rebase -i command.

$ git rebase -i HEAD~~

Your default text editor will open listing commits from HEAD down to HEAD~~, as shown below.

pick 9a54fd4 append description of the commit command
  pick 0d4a808 append description of the pull command

  # Rebase 326fc9f..0d4a808 onto d286baa
  #
  # Commands:
  #  p, pick = use commit
  #  r, reword = use commit, but edit the commit message
  #  e, edit = use commit, but stop for amending
  #  s, squash = use commit, but meld into previous commit
  #  f, fixup = like "squash," but discard this commit log message
  #  x, exec = run command (the rest of the line) using shell
  #
  # If you remove a line here THAT COMMIT WILL BE LOST.
  # However, if you remove everything, the rebase will be aborted.
  #

On the first line, change the word pick to edit, then save and quit.

You will see the following output and be checked out of that commit.

Stopped at d286baa... append description of the commit command
  You can amend the commit now, with

          git commit --amend

  Once you are satisfied with your changes, run

          git rebase --continue

Open the sample.txt file and make the change as shown below.

Anyone can learn Git with this tutorial and Backlog
add: Register a change in an index
commit: Record index state.
pull: Obtain the content of the remote repository

Use git commit --amend to commit the change.

$ git add sample.txt
$ git commit --amend

Then execute git rebase --continue to complete the rebase process.

$ git rebase --continue

While running a rebase on your current branch, you may run into conflicts in your changes. To proceed, you must manually resolve those conflicts, then run git add and git rebase --continue. There is no need to issue new commits to resolve the conflicts.

However, if you want to stop rebasing, you can call git rebase --abort, which will revert and exit the entire process and successfully modify the commit.

In cases where you specify edit on more than a single line when calling git rebase -i, you will be prompted to modify each of the commits one at a time.

Subscribe to our newsletter

Learn with Nulab to bring your best ideas to life