我想重做先前提交的更改。推送到分離頭上的主提交
Maxims-MacBook-Air:hellodebug.com maximveksler$ git log
commit 7f9dd753d39fd65b4272af713ef9c07a9f84f016
Author: Maxim Veksler <[email protected]>
Date: Sun Dec 28 09:12:17 2014 +0200
Imagine a Supercomputer Helping You Fix Bugs Faster
commit 54561ed320633e72bb35a7ab668a9996e6ffca8f
Author: Maxim Veksler <[email protected]>
Date: Sun Dec 28 08:57:25 2014 +0200
highcharts tweaks
commit d57144cbd004b3b9e893e8d50d7077634824ce9a
Author: Genady Okrain <[email protected]>
Date: Mon Dec 22 18:46:21 2014 +0200
sash api
所以,我把它弄壞了就7f9dd753d39fd65b4272af713ef9c07a9f84f016並決定別讓它從54561ed320633e72bb35a7ab668a9996e6ffca8f
Maxims-MacBook-Air:hellodebug.com maximveksler$ git checkout 54561ed320633e72bb35a7ab668a9996e6ffca8f
Note: checking out '54561ed320633e72bb35a7ab668a9996e6ffca8f'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:
git checkout -b new_branch_name
HEAD is now at 54561ed... highcharts tweaks
到目前爲止好,現在讓我們做固定。
Maxims-MacBook-Air:hellodebug.com maximveksler$ git commit -a -m'Back to not fucking it up'
[detached HEAD b5cb3e4] Back to not fucking it up
但現在我需要推回到主人,並upsteam。這裏來的雜亂的部分...
Maxims-MacBook-Air:hellodebug.com maximveksler$ git checkout HEAD
Maxims-MacBook-Air:hellodebug.com maximveksler$ git status
HEAD detached from 54561ed
nothing to commit, working directory clean
Maxims-MacBook-Air:hellodebug.com maximveksler$ git push
fatal: You are not currently on a branch.
To push the history leading to the current (detached HEAD)
state now, use
git push origin HEAD:<name-of-remote-branch>
Maxims-MacBook-Air:hellodebug.com maximveksler$ git push origin HEAD:master
Warning: Permanently added 'github.com,192.30.252.131' (RSA) to the list of known hosts.
To [email protected]:maximveksler/hellodebug.com.git
! [rejected] HEAD -> master (non-fast-forward)
error: failed to push some refs to '[email protected]:maximveksler/hellodebug.com.git'
hint: Updates were rejected because a pushed branch tip is behind its remote
hint: counterpart. Check out this branch and integrate the remote changes
hint: (e.g. 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
正確...所以現在我卡住了。讓我們嘗試一些更多的東西
Maxims-MacBook-Air:hellodebug.com maximveksler$ git up
Fetching origin
Warning: Permanently added 'github.com,192.30.252.128' (RSA) to the list of known hosts.
You're not currently on a branch. I'm exiting in case you're in the middle of something.
git up不會跟我們說話,這很酷。無論如何,我並不需要它。
Maxims-MacBook-Air:hellodebug.com maximveksler$ git checkout master
Warning: you are leaving 2 commits behind, not connected to
any of your branches:
e9e202c no border
b5cb3e4 Back to not fucking it up
If you want to keep them by creating a new branch, this may be a good time
to do so with:
git branch new_branch_name e9e202c
Switched to branch 'master'
Your branch is up-to-date with 'origin/master'.
什麼?沒有!回來提交,我愛你。
Maxims-MacBook-Air:hellodebug.com maximveksler$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
nothing to commit, working directory clean
迷失!永遠?我希望不是..
Maxims-MacBook-Air:hellodebug.com maximveksler$ git reflog
7f9dd75 [email protected]{0}: checkout: moving from e9e202c4703939064e099b735ceeb6b78dc7933a to master
e9e202c [email protected]{1}: commit: no border
b5cb3e4 [email protected]{2}: commit: Back to not fucking it up
54561ed [email protected]{3}: checkout: moving from master to 54561ed320633e72bb35a7ab668a9996e6ffca8f
7f9dd75 [email protected]{4}: commit: Imagine a Supercomputer Helping You Fix Bugs Faster
54561ed [email protected]{5}: commit: highcharts tweaks
好的,所以他們是在野外的某個地方,但我怎麼讓他們回來?說再見還爲時過早。
幫助?
[在SourceTree中投資0美元,它可以讓你看到你的本地和遠程分支達到了什麼樣的程度](http://www.sourcetreeapp.com/)。 –
@ ta.speot.is將問題卸載到工具上無法替代理解實際發生的情況以及如何解決問題。 – Abizern
@Abizern我建議他用SourceTree查看分支。這與'git log'的高度定製版本沒有多大區別。 –