Toybrick

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

shon

中级会员

积分
320
楼主
发表于 2019-1-11 18:05:08    查看: 6387|回复: 0 | [复制链接]    打印 | 只看该作者
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:
  1. # 此为注释 – 将被 Git 忽略
  2.   
  3. *.a       # 忽略所有 .a 结尾的文件
  4. !lib.a    # 但 lib.a 除外
  5. /TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
  6. build/    # 忽略 build/ 目录下的所有文件
  7. doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
复制代码

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


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

产品中心 购买渠道 开源社区 Wiki教程 资料下载 关于Toybrick


快速回复 返回顶部 返回列表