女王控的博客

Git忽略规则及.gitignore规则不生效的解决办法

案例

在 git 中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:

bash 复制代码
# 此为注释 – 将被 Git 忽略
*.a       # 忽略所有 .a 结尾的文件
!lib.a    # 但 lib.a 除外
/TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/    # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore 只能忽略那些原来没有被 track 的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore 是无效的。那么解决方法就是先把本地缓存删除(改变成未 track 状态),然后再提交:

bash 复制代码
git rm -r --cached .
git add .
git commit -m 'update .gitignore'

如果有些文件已经被你忽略了,当你使用 git add 时是无法添加的,比如我忽略了*.class,现在我想把 HelloWorld.class 添加到 git 中去:git 会提示我们这个文件已经被我们忽略了,需要加上-f 参数才能强制添加到 git 中去:

bash 复制代码
$ git add HelloWorld.class
The following paths are ignored by one of your .gitignore files:
HelloWorld.class
Use -f if you really want to add them.

如果我们意外的将想要忽略的文件添加到缓存中去了,我们可以使用 rm 命令将其从中移除,不会删除本地文件:

bash 复制代码
$ git rm HelloWorld.class --cached
rm 'HelloWorld.class'

查看 gitignore 规则

如果你发现.gitignore 写得有问题,需要找出来到底哪个规则写错了,可以用 git check-ignore 命令检查:

bash 复制代码
$ git check-ignore -v HelloWorld.class
.gitignore:1:*.class HelloWorld.class

可以看到 HelloWorld.class 匹配到了我们的第一条*.class 的忽略规则所以文件被忽略了。

评论

阅读上一篇

CSS居中设置
2017-11-20 23:01:05

阅读下一篇

JS 设计模式
2017-11-16 17:51:52
0%