最近項目中,來了一新同事,協同開發的過程中,發現老是提示pod install,於是照做了,做完項目可以跑成功但發現提示我跟同事一樣的問題,Podfile.lock文件需要提交,於是便提交了,然而同事拉取了我的提交日誌以後便和我報了一模一樣的錯,需要pod install或者update一下,這時候 ...
最近項目中,來了一新同事,協同開發的過程中,發現老是提示pod install,於是照做了,做完項目可以跑成功但發現提示我跟同事一樣的問題,Podfile.lock文件需要提交,於是便提交了,然而同事拉取了我的提交日誌以後便和我報了一模一樣的錯,需要pod install或者update一下,這時候發現陷入死迴圈了!!!。於是考慮忽略Podfile.lock文件,但是期間嘗試了很多方法都無法忽略Podfile.lock文件,後來發現每次Podfile.lock文件需要提交時顯示的更改內容是pod版本號不一致,於是想到如果我和同事將電腦上的pod版本號統一成一個版本是不是就可以了呢,最後將我的更新到和同事一個版本。
#更新CocoaPods到固定的某一個版本 $ sudo gem install -n /usr/local/bin cocoapods -v ***//指定安裝cocoaPods版本, ***為需要更新到的版本號
網上有人說可以解決,但是親測還是解決不了我個人的問題,可能原因還是不一樣,最後繼續查閱資料多番測試,發現是忽略文件添加的Podfile.lock無效導致的問題。
在git中如果想忽略掉某個文件,不讓這個文件提交到版本庫中,可以使用修改根目錄中 .gitignore 文件的方法(如果沒有這個文件,則需自己手工建立此文件)。這個文件每一行保存了一個匹配的規則例如:
# 此為註釋 – 將被 Git 忽略 *.a # 忽略所有 .a 結尾的文件 !lib.a # 但 lib.a 除外 /TODO # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO build/ # 忽略 build/ 目錄下的所有文件 doc/*.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt把某些目錄或文件加入忽略規則,按照上述方法定義後發現並未生效,原因是.gitignore只能忽略那些原來沒有被追蹤的文件,如果某些文件已經被納入了版本管理中,則修改.gitignore是無效的。那麼解決方法就是先把本地緩存刪除(改變成未被追蹤狀態),然後再提交,這樣就不會出現忽略的文件了。
git
清除本地緩存命令如下:
git rm -r --cached . git add . git commit -m 'update .gitignore'
註意::不要誤解了.gitignore的用途,該文件只能作用於未被跟蹤的文件,也就是那些從來沒有被git記錄過的文件(自添加以後,從未add及commit過的文件)。如果文件曾經被git記錄過,那麼.gitignore就對他們完全無效。