在程序中添加了.gitignore 文件:
1 | /Demo/Demo-Info.plist |
Demo-Info.plist这个是后来添加的,但是每次Demo-Info.plist有更改git都还是提示,这个蛋疼了,难道.gitignore文件失效了吗?
google半天找到解决办法,由于忽略Demo-Info.plist这个文件的需求是后来提出来的,之前Demo-Info.plist是add过的,所以在local cache里有cahce了,所以导致忽略Demo-Info.plist失败,解决办法,找到cache删除就搞定执行
1 | find . -iname "Demo-Info.plist" |xargs git rm -rf --cached |
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法。这个文件每一行保存了一个匹配的规则例如:
1 | # 此为注释 – 将被 Git 忽略 |
这样设置了以后 所有的 .pyc
文件都不会添加到版本库中去。
另外 git 提供了一个全局的 .gitignore,你可以在你的用户目录下创建 ~/.gitignoreglobal
文件,以同样的规则来划定哪些文件是不需要版本控制的。
需要执行 git config --global core.excludesfile ~/.gitignoreglobal
来使得它生效。
其他的一些过滤条件:
1 | * ?:代表任意的一个字符 |
由于git不会加入空目录,所以下面做法会导致tmp不会存在tmp/*
//忽略tmp文件夹所有文件
改下方法,在tmp下也加一个.gitignore,内容为:
1 | * |
还有一种情况,就是已经commit了,再加入gitignore是无效的,所以需要删除下缓存git rm -r --cached ignore_file
注意:
.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。
正确的做法是在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。git update-index --assume-unchanged PATH
#在PATH处输入要忽略的文件git update-index --no-assume-unchanged PATH
#恢复要跟踪的文件
另外 git 还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。用来保存的是公共的需要排除的文件。而 .git/info/exclude
这里设置的则是你自己本地需要排除的文件。 他不会影响到其他人。也不会提交到版本库中去。
.gitignore 还有个有意思的小功能, 一个空的 .gitignore 文件 可以当作是一个 placeholder 。当你需要为项目创建一个空的 log 目录时, 这就变的很有用。 你可以创建一个 log 目录 在里面放置一个空的 .gitignore 文件。这样当你 clone 这个 repo 的时候 git 会自动的创建好一个空的 log 目录了。