bugl
bugl
HomeLearnPatternsSearch
HomeLearnPatternsSearch

Loading lesson path

Learn/Git/Git Undo
Git•Git Undo

Git Amend

Change Platform:

GitHub

Bitbucket

GitLab

What is Git Amend?

Git Amend is a command that allows you to modify the most recent commit. You can use it to fix typos, add or remove files, or change the commit message.

When to Use Git Amend

Use Git Amend when you need to make small changes to your last commit. It's perfect for fixing mistakes, adding forgotten files, or updating the commit message.

Fix Last Commit Message

To change the last commit message, follow these steps: Open your terminal and navigate to your repository.

Formula

Type git commit -- amend - m "New message"

to change the commit message. Press Enter to save the changes.

Example git commit --amend -m "Corrected commit message"

Add Files to Last Commit

To add files to the last commit, follow these steps: Open your terminal and navigate to your repository.

Formula

Type git add < file >

to add the file to the staging area. Type git commit --amend to add the file to the last commit. Press Enter to save the changes.

Example git add forgotten.txt git commit --amend

Remove Files from Last Commit

To remove files from the last commit, follow these steps: Open your terminal and navigate to your repository. Type git reset HEAD^ -- <file> to remove the file from the staging area. Type git commit --amend to remove the file from the last commit. Press Enter to save the changes.

Example git reset HEAD^ -- unwanted.txt git commit --amend 1 file changed, 3 insertions(+), 1 deletion(-)

Now let's check the log

Example git log --oneline 07c5bc5 (HEAD -> master) Adding plines to reddme

Formula

9a9add8 (origin/master) Added .gitignore

81912ba Corrected spelling error

Formula

3fdaa5b Merge pull request #1 from w3schools - test/update - readme

836e5bf (origin/update-readme, update-readme) Updated readme for GitHub Branches daf4f7c (origin/html-skeleton, html-skeleton) Updated index.html with basic meta facaeae (gh-page/master) Merge branch 'master' of https://github.com/w3schools-test/hello-world e7de78f Updated index.html. Resized image 5a04b6f Updated README.md with a line about focus d29d69f Updated README.md with a line about GitHub e0b6038 merged with hello-world-images after fixing conflicts 1f1584e added new image dfa79db updated index.html with emergency fix 0312c55 Added image to Hello World 09f4acd Updated index.html with a new line 221ec6e First release of Hello World! Oh no! the commit message is full of spelling errors. Embarrassing. Let's amend that:

Example git commit --amend -m "Added lines to README.md" [master eaa69ce] Added lines to README.md

Formula

Date: Thu Apr 22 12:18:52 2021 + 0200

1 file changed, 3 insertions(+), 1 deletion(-))

And re-check the log

Example git log --oneline eaa69ce (HEAD -> master) Added lines to README.md

Formula

9a9add8 (origin/master) Added .gitignore

81912ba Corrected spelling error

Formula

3fdaa5b Merge pull request #1 from w3schools - test/update - readme

836e5bf (origin/update-readme, update-readme) Updated readme for GitHub Branches daf4f7c (origin/html-skeleton, html-skeleton) Updated index.html with basic meta facaeae (gh-page/master) Merge branch 'master' of https://github.com/w3schools-test/hello-world e7de78f Updated index.html. Resized image 5a04b6f Updated README.md with a line about focus d29d69f Updated README.md with a line about GitHub e0b6038 merged with hello-world-images after fixing conflicts 1f1584e added new image dfa79db updated index.html with emergency fix 0312c55 Added image to Hello World 09f4acd Updated index.html with a new line 221ec6e First release of Hello World! We see the previous commit is replaced with our amended one!

Warning:

Messing with the commit history of a repository can be dangerous. It is usually ok to make these kinds of changes to your own local repository. However, you should avoid making changes that rewrite history to remote repositories, especially if others are working with them.

Git Amend Files

Adding files with

--amend works the same way as above. Just add them to the staging environment before committing.

Previous

Git Reset

Next

Git Rebase