Size: 705
Comment:
|
Size: 1323
Comment: Comment about git soft reset
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
== Workflow for gitorious and github == Initial checkout: {{{#!highlight sh # Fork repo on gitorious/github # Pull repo from gitorious/github # Add remote for upstream, e.g. cd Spoon-Knife git remote add upstream git://github.com/octocat/Spoon-Knife.git git fetch upstream }}} When needing to merge upstream changes back into master: {{{#!highlight sh git fetch upstream git merge upstream/master }}} == Cookbook == |
|
Line 12: | Line 34: |
git reset --soft HEAD^ }}} just changes the repository without changing the files you've edited on disk. However: {{{ |
|
Line 14: | Line 42: |
will reset both repository and revert files. |
Workflow for gitorious and github
Initial checkout:
When needing to merge upstream changes back into master:
Cookbook
Reverting changes
Amend the previous commit that has not been propogated (i.e. undo it, then start a new one with the pending changes in the index):
git commit --amend -a -m "New commit message"
Undo a commit that has not been propagated:
git reset --soft HEAD^
just changes the repository without changing the files you've edited on disk. However:
git reset --hard HEAD^
will reset both repository and revert files.
Once a commit that has been propagated, there is no way to undo. However, the following will create a new commit undoing the previous commit's changes:
git revert HEAD
Pull with rebase instead of merge
git pull --rebase
Configure a branch to always do a rebase instead of a merge:
git config branch.master.rebase true