通常來講,咱們總會遇到有些文件無需歸入 Git 管理的狀況,也不但願它們總出如今未跟蹤文件列表。一般都是些自動生成的文件,像是日誌或者編譯過程當中建立的文件等等。咱們能夠建立一個名爲 .gitignore 的文件,列出要忽略的文件模式,來看一個簡單的例子:
# cat .gitignore
*.[oa]
*~
第一行告訴 Git 忽略全部以 .o 或 .a 結尾的文件。通常這類對象文件和存檔文件都是編譯過程當中出現的,咱們用不着跟蹤它們的版本。第二行告訴 Git 忽略全部以波浪符(~)結尾的文件,許多文本編輯軟件(好比 Emacs)都用這樣的文件名保存副本。此外,你可能還須要忽略 log,tmp 或者 pid 目錄,以及自動生成的文檔等等。要養成一開始就設置好 .gitignore 文件的習慣,以避免未來誤提交這類無用的文件。
文件 .gitignore 的格式規範以下:
- 全部空行或者以註釋符號 # 開頭的行都會被 Git 忽略。
- 可使用標準的 glob 模式匹配。
- 匹配模式最後跟反斜槓(/)說明要忽略的是目錄。
- 要忽略指定模式之外的文件或目錄,能夠在模式前加上驚歎號(!)取反。
所謂的 glob 模式是指 shell 所使用的、簡化了的正則表達式。星號(*)匹配零個或多個任意字符;[abc] 匹配任何一個列在方括號中的字符(這個例子要麼匹配一個 a,要麼匹配一個 b,要麼匹配一個 c);問號(?)只匹配一個任意字符;若是在方括號中使用短劃線分隔兩個字符,表示全部在這兩個字符範圍內的均可以匹配(好比 [0-9] 表示匹配全部 0 到 9 的數字)。
咱們再看一個 .gitignore 文件的例子:
# 忽略全部 .a 結尾的文件
*.a
# 但 lib.a 除外
!lib.a
# 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
/TODO
# 忽略 build/ 目錄下的全部文件
build/
# 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt
doc/*.txt
其餘信息能夠直接 man gitignore 查看。