Git『Everything up-to-date』問題解決

今天提交代碼的時候遇到了一個小問題,這里解決了記下小記。

提交代碼遇到『Everything up-to-date』

上網查了下,發(fā)現中文大多答非所問,少數能解決的并沒有闡述原理,所以我寫這篇文章記錄下。

這里先上stackoverflow的回答,基礎好的可以看這個。

接下來說我自己的理解,出現這個問題的原因是git提交改動到緩存,要push的時候不會將本地所有的分支都push掉,所以出現這個問題。我們應該告訴git提交哪個分支。

這里有種特殊的情況是如果你是fork別人的倉庫再clone到本地的話,即使git上只有一個主分支,他還是可能出現這個錯誤。那么我們就需要新建分支提交改動然后合并分支。

接下來先創(chuàng)建一個新分支提交改動

$ git branch newbranch

然后輸入這條命令檢查是否創(chuàng)建成功

$ git branch

這時終端輸出

  newbranch
* master

這樣就創(chuàng)建成功了,前面的*代表的是當前你所在的工作分支。我們接下來就要切換工作分支。

$ git checkout newbranch

這樣就切換完了,可以$ git branch確認下。然后你要將你的改動提交到新的分支上。

$ git add .
$ git commit -a

此時可以$ git status檢查下提交情況。如果提交成功,我們接下來就要回主分支了,代碼和之前一樣。

$ git checkout master

然后我們要將新分支提交的改動合并到主分支上

$ git merge newbranch

合并分支可能產生沖突這是正常的,雖然我們這是新建的分支不會產生沖突,但還是在這里記錄下。下面的代碼可以查看產生沖突的文件,然后做對應的修改再提交一次就可以了。

$ git diff

我們的問題就解決了,接下來就可以push代碼了。

$ git push -u origin master

新建分支的朋友別忘了刪除這個分支

$ git branch -D newbranch

如果想保留分支只是想刪除已經合并的部分只要把大寫的D改成小寫的d就行了。

也歡迎來我的博客看看。

參考資料

分支與合并@基礎

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容