我想screenshots/
在我的 git repo 中包含一個名為的檔案夾(主要是為了支持 README)來顯示......我創建的應用程式的螢屏截圖,所以我做到了。但是,下次我嘗試向 repo 推送新的提交時,我收到一個錯誤,提示我洗掉上游 repo 中所做的更改。
顯然,我不希望我的專案源代碼中有一堆螢屏截圖。有沒有辦法“忽略”上游的某些目錄?
我知道有.gitignore
,但這是為了將某些檔案夾保留在本地專案的源代碼中,但不想對其進行版本控制。我想要的是與.gitignore 相反的東西。
uj5u.com熱心網友回復:
考慮一下 Git 存盤的內容會有所幫助。Git 從一開始就不存盤檔案夾。相反,Git 存盤提交,提交又存盤(部分)檔案,作為一種存檔,及時凍結。這些檔案具有可能包含斜杠的長名稱,例如path/to/file.ext
. 您的作業系統可能(幾乎可以肯定“確實”)要求將此檔案提取為一個名為的檔案,該檔案file.ext
位于一個名為的檔案夾to
中,該檔案夾位于名為path
. 您的作業系統可能會呼叫它path\to\file.ext
而不是path/to/file.ext
. 但對于 Git,它只是一個名為 的檔案,檔案名path/to/file.ext
中帶有(正向)斜杠。1
無論如何,上面的真正要點是要注意,在 Git 存盤庫中的存盤單元是commit。每個提交:
- 用一個獨特的、非常大的、看起來隨機的數字進行編號,通常以十六進制表示。
- 完全是只讀的。這是編號技術發揮作用所必需的,這意味著一旦提交,任何提交的任何部分都無法更改。(
git commit --amend
例如,命令標志有點謊言:它只是進行新的和改進的替換提交,將舊的提交推到一邊。) - 存盤兩個東西:
- 每個提交都包含每個檔案的完整快照,就像您(或任何人)提交時的形式一樣。每個檔案的這種存盤形式可以占用非常少的磁盤空間,有時對于這個特定的提交來說根本沒有空間,因為檔案在提交內和提交之間進行了重復資料洗掉。但是只有 Git 可以讀取這些檔案,實際上沒有任何東西,甚至 Git 本身,都不能覆寫它們。
- 每個提交都存盤一些元資料,或有關提交本身的資訊。這包括提交人的姓名和電子郵件地址等內容。
任何給定提交中存盤的快照在您運行或. 此命令意味著:從任何先前簽出的提交中洗掉所有提取的檔案,并將新選擇的提交中的所有檔案放置到位。 這里有很多挑剔的細節,我故意掩飾,但這是or的基本作業(無論您喜歡哪個命令)。git checkout
git switch
git checkout
git switch
簽出一些提交后,您現在可以處理/處理這些檔案。您處理/使用的檔案不在 Git 中。它們在您的作業樹或作業樹中,作為普通檔案存盤在作業系統所需的檔案夾中。你可以對這些檔案做任何你喜歡的事情,因為它們是普通檔案,不受 Git 的任何控制。當你處理完這些檔案后,你必須運行git add
: 2這告訴 Git掃描這些檔案并尋找更新,如果 / 需要,Git 將把更新復制到它的索引中,為下一個git commit
. 然后你跑git commit
, 并且 Git 將其索引中的所有內容(所有最初簽出的檔案,除了由您的git add
ed 檔案更新的檔案)轉換為新提交的新快照。
這意味著很簡單:
- 檔案要么
screenshot/*
在提交中,要么不在; - 如果它們在您簽出的提交中,它們將在您進行的下一次提交中,如果不是,它們不會——除非您使用
git add
或git rm
更改情況。
反過來,這意味著您問題的最初答案是:不,您不能那樣做。 但....
1從技術上講,這僅適用于出現在 Git索引中的檔案。一旦索引的檔案集被凍結到新的提交中,Git 會將每個單獨的路徑名組件存盤在樹物件中,并且需要多個樹物件來組合完整的路徑名。但是 Git 并沒有讓你單獨使用樹物件:相反,它會將樹復制到索引中,讓你使用索引,然后提交索引中的內容。由于索引中沒有檔案夾,因此提交中不能有檔案夾:即使內部樹結構理論上允許這樣做,Git也無法存盤空檔案夾。然而,有一個子模塊技巧,它需要使用兩個 Git 存盤庫,可以偽造它。
但是等等,還有更多!或更少!
Git確實提供了所謂的稀疏結賬。通過稀疏簽出,你告訴 Git:看,我知道我要簽出的這個提交中有一百萬個檔案。但例如,我只想查看和處理src/
檔案。根本不用費心提取任何screenshot/
或doc/
檔案。您不需要將作業系統級別的檔案夾命名為screenshot
and doc
。你可以重新使用那些我在下一次提交中沒有看到的檔案,即使我在作業時不會也看不到它們。現在,繼續檢查提交 <插入哈希 ID 或分支名稱>。
您必須仔細設定稀疏簽出(直到最近,主要是手動設定;新的 Git 版本有一些內容更多地針對只使用Git 的人,而不是為Git 本身撰寫新代碼的人,以使這更容易)。任何未設定稀疏簽出的人都會看到所有screenshot/
檔案。
或者,如果沒有人需要在查看源screenshot/
檔案的同時查看檔案,您可以只創建兩個獨立的提交流:
- 一個提交流包含螢屏截圖。您
git checkout screenshots
還是git switch screenshots
要獲取最新的。Git 從您的作業樹中洗掉所有當前簽出的檔案(可能是所有源檔案),并將提交的螢屏截圖檔案放置到位。現在您可以更新螢屏截圖并添加和提交,并在以后設定新的螢屏截圖。 - 另一個提交流包含源檔案。您
git checkout main
或git switch dev
其他任何人都可以獲得最新的此類提交。Git 洗掉所有當前簽出的檔案(無論是源檔案還是螢屏截圖),并將最新提交的檔案放置在適當的位置。
在此設定中,您可以使用螢屏截圖或來源,但不要同時使用兩者。這很好用;這只是習慣的不同心態。新的(從 Git 2.5 開始)git worktree
特性——最好不要過于廣泛地使用,除非你的 Git 版本至少是 2.15——使得在screenshots
分支上有一個完全獨立的作業樹和在main
or dev
or上有一個完全獨立的不同作業樹成為可能任何分支。請記住,不可能將作業樹與來自兩者的檔案結合起來。3
要設定單獨的提交流分支,請使用:
git switch --orphan screenshots
例如。(舊git checkout
的也有 a --orphan
as well 但如果你使用它,你 must also git rm -r .
,這有點可怕。)這個switch
命令清空 Git 的索引,同時也清除你的作業樹(盡管未跟蹤的檔案將保留在其中)。您現在可以創建screenshots/
目錄、填充它并運行git add screenshots
以添加screenshots/*
. 下一次git commit
運行將使用第一個提交作為其第一個也是唯一一個提交來創建分支。這個分支現在與其他分支分離,并且不能輕易地與其他分支混合,并且當你git checkout main
或時git switch main
,Git 將洗掉所有提交的screenshot/*
檔案并使用源檔案重新填充作業樹。
請注意,這種單獨的提交流技巧很像擁有一個完全獨立的存盤庫,只包含螢屏截圖。它為您提供的只是git clone
讓您獲得與“兩個存盤庫”相關的所有提交,因為這些提交位于單個存盤庫而不是兩個存盤庫中。如果螢屏截圖實際上不是專案的一部分,那么首先使用單獨的存盤庫可能更明智。
3可以獲得兩組檔案,但不能使用普通檔案git checkout
或git switch
. 您需要告訴 Git 從源中獲取最新提交,以及從截圖分支獲取最新提交,然后您需要將這兩者結合起來。有一些相對簡單的方法可以做到這一點,例如,git archive
將它們放入一個區域,沒有人會對它們做任何作業,但可以在單個作業系統級檔案夾中同時訪問兩者。
git worktree add
在 Git 版本 2.15 之前要小心的原因是,在git gc
. 如果您有一個添加的作業樹放置 2 周或更長時間,您可能會開始丟失其中完成的作業。不保證會斷,但這樣的誘惑命運是不明智的。??
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/470948.html
標籤:混帐
上一篇:Git:拉取同事的功能分支