git本地分支和stash內容報錯消失的問題
本地一個長期更新的專案,git log突然報錯:
xxx@yyy:~/android/project/kernel/.git$ git log .
fatal: your current branch 'project-dev' does not have any commits yet
如果git status,發現檔案全部是new狀態.
如果git branch -v,發現本地分支資訊消失.
如果git stash list,也沒有任何訊息.
看來,即使git本身如此優秀,也是避免不了他自己出錯的時候-_-
一. 解決git log:
檢視 .git/objects 資料夾,發現提交都在,說明有救
ls .git/refs/heads 資料夾,發現自己的project-dev分支不見了.
平常我都是在secureCRT環境下作業,並自動儲存操作記錄. 所以,很容易通過 grep -rn 'git log'找回原來提交的commit資訊. 於是,找到project-dev分支的最新的提交commit id是1f37a1b5706b3877c693bab220a31d312043fc1c.
於是執行 vi .git/refs/heads/project-dev,並把1f37a1b5706b3877c693bab220a31d312043fc1c儲存在此檔案中.
git log和git branch -v,原來提交資訊都回來了.
二. 解決git stash list內容不見的問題.
cat .git/logs/refs/stash 檔案,找到自己想要的stash id:
xxx@yyy:~/android/project/kernel$ cat .git/logs/refs/stash
0000000000000000000000000000000000000000 6d83090b5d140597866f32b5dbbca642acab3cba ... On project-dev: enable HDMI display
...//...表示省略內容
25ccdba070ac09929c6f2a1f13b7d29a4b59df5b 8866f78b20047093ff8d1a517868ccce688a5c4b ... On project-dev: wifi&bt temp
以上中,0000000000000000000000000000000000000000是最原始的內容,不對應任何stash提交,6d83090b5d140597866f32b5dbbca642acab3cba是第一個. 8866f78b20047093ff8d1a517868ccce688a5c4b是最後一個. 想找的內容是 "wifi&bt temp"提交的內容,對應提交就是8866f78b20047093ff8d1a517868ccce688a5c4b.
於是,執行git show 8866f78b20047093ff8d1a517868ccce688a5c4b內容看看,正確.
再次執行以下指令儲存此stash為diff檔案:
git show 8866f78b20047093ff8d1a517868ccce688a5c4b > wifi.bt.diff
最後,執行git apply打入diff檔案.
git apply wifi.bt.diff
對其他想儲存的stash id內容做同樣的操作.
到此這篇關於git本地分支和stash內容報錯消失的文章就介紹到這了,更多相關git本地分支和stash報錯內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!