-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add some simpler ways to do the same things #93
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -80,10 +80,10 @@ For clarity's sake all examples in this document use a customized bash prompt in | |
<a name="diff-last"></a> | ||
### What did I just commit? | ||
|
||
Let's say that you just blindly committed changes with `git commit -a` and you're not sure what the actual content of the commit you just made was. You can check the difference between your current HEAD and what your HEAD just was with: | ||
Let's say that you just blindly committed changes with `git commit -a` and you're not sure what the actual content of the commit you just made was. You can show the latest commit on your current HEAD with: | ||
|
||
```sh | ||
(master)$ git diff HEAD@{1} HEAD | ||
(master)$ git show | ||
``` | ||
|
||
<a name="#i-wrote-the-wrong-thing-in-a-commit-message"></a> | ||
|
@@ -95,11 +95,10 @@ If you wrote the wrong thing and the commit has not yet been pushed, you can do | |
$ git commit --amend | ||
``` | ||
|
||
Another way to change the commit message: | ||
You can specify the commit message inline if you want: | ||
|
||
```sh | ||
$ git reset --soft HEAD^ | ||
$ git commit -a -m 'xxxxxxx' | ||
$ git commit --amend -m 'xxxxxxx' | ||
``` | ||
|
||
If you have already pushed the message, you can amend the commit and force push, but this is not recommended. | ||
|
@@ -122,7 +121,7 @@ If you need to change all of history, see the man page for 'git filter-branch'. | |
In order to remove a file from a commit, do the following: | ||
|
||
```sh | ||
$ git checkout HEAD~2 myfile | ||
$ git checkout HEAD^ myfile | ||
$ git add -A | ||
$ git commit --amend | ||
``` | ||
|
@@ -158,6 +157,8 @@ $ git rebase --onto SHA1_OF_BAD_COMMIT^ SHA1_OF_BAD_COMMIT | |
$ git push -f [remote] [branch] | ||
``` | ||
|
||
Or do an [interactive rebase](#interactive-rebase) and remove the line(s) correspoding to commit(s) you want to see removed. | ||
|
||
<a name="#force-push"></a> | ||
### I tried to push my amended commit to a remote, but I got an error message | ||
|
||
|
@@ -533,9 +534,14 @@ For more, see [this SO thread](http://stackoverflow.com/questions/11058312/how-c | |
<a name="interactive-rebase"></a> | ||
### I need to combine commits | ||
|
||
You need to do something called an interactive rebase. | ||
Let's suppose you are working in a branch that is/will become a pull-request against `master`. In the simplest case when all you want to do is to combine *all* commits into a single one and you don't care about commit timestamps, you can reset and recommit. Make sure the master branch is up to date and all your changes committed, then: | ||
|
||
If you are working in a branch that is/will become a pull-request against `master`, you can rebase against your `master` branch. Make sure the master branch is up to date, then: | ||
```sh | ||
(my-branch)$ git reset --soft master | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If I am up to date on master, wouldn't soft resetting to master have no effect? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This line assumes that you are on
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ahh, I see. Should have seen that from |
||
(my-branch)$ git commit -am "New awesome feature" | ||
``` | ||
|
||
If you want more control, and also preserve timestamps, you need to do something called an interactive rebase: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. and also to preserve timestamps There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Fixed, thanks! |
||
|
||
```sh | ||
(my-branch)$ git rebase -i master | ||
|
@@ -550,6 +556,7 @@ If you aren't working against another branch you'll have to rebase relative to y | |
After you run the interactive rebase command, you will see something like this in your text editor: | ||
|
||
```vim | ||
pick a9c8a1d Some refactoring | ||
pick 01b2fd8 New awesome feature | ||
pick b729ad5 fixup | ||
pick e3851e8 another fix | ||
|
@@ -575,20 +582,24 @@ pick e3851e8 another fix | |
|
||
All the lines beginning with a `#` are comments, they won't affect your rebase. | ||
|
||
If you want to **combine all your commits with the oldest (first) commit**, you should edit the letter next to each commit except the first to say `f`: | ||
Then you replace `pick` commands with any in the list above, and you can also remove commits by removing corresponding lines. | ||
|
||
For example, if you want to **leave the oldest (first) commit alone and combine all the following commits with the second oldest**, you should edit the letter next to each commit except the first and the second to say `f`: | ||
|
||
```vim | ||
pick a9c8a1d Some refactoring | ||
pick 01b2fd8 New awesome feature | ||
f b729ad5 fixup | ||
f e3851e8 another fix | ||
``` | ||
|
||
If you want to combine all your commit with the oldest commit **and rename the commit**, you should additionally add an `r` next to the first commit: | ||
If you want to combine these commits **and rename the commit**, you should additionally add an `r` next to the second commit or simply use `s` instead of `f`: | ||
|
||
```vim | ||
r 01b2fd8 New awesome feature | ||
f b729ad5 fixup | ||
f e3851e8 another fix | ||
pick a9c8a1d Some refactoring | ||
pick 01b2fd8 New awesome feature | ||
s b729ad5 fixup | ||
s e3851e8 another fix | ||
``` | ||
|
||
You can then rename the commit in the next text prompt that pops up. | ||
|
@@ -709,6 +720,8 @@ After you have resolved all conflicts and tested your code, `git add` the files | |
(my-branch)$ git rebase --continue | ||
``` | ||
|
||
If after resolving all the conflicts you end up with an identical tree to what it was before the commit, you need to `git rebase --skip` instead. | ||
|
||
If at any time you want to stop the entire rebase and go back to the original state of your branch, you can do so: | ||
|
||
```sh | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also believe I fixed a bug. This checkout was supposed to reference a previous commit, i.e.
HEAD^
orHEAD~1
, right?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You're right!