用git时,项目编译后,status一下,出现一大堆修改文件,看着头大。
当我们修改了bug后,我们真正修改的文件,混在这一大堆文件里,很难找出来add,commit。
这时候我们需要让git忽略某些文件。
这分两种情况,一种是编译生成的文件,这些文件并不需要加入版本控制,如build目录及一些编译中产生的临时文件等。
如果这种文件或目录不在git仓库里,只要把路径加入工作目录下的 .gitignore 文件中,以后就不会出现了。
如果已经在git仓库里了,
先恢复文件:
git checkout -- file
再从仓库移除:
git rm file
或
git rm -r tree
最后也要把路径加入工作目录下的 .gitignore 文件中。
另外一种情况代码里必须有这个文件,但编译中会修改这个文件,或我自己会临时修改这个文件,但这些文件都不需要提交仓库。
这时需要用另外的命令:
git update-index --assume-unchanged file
这样你对file的修改或编译系统对file的修改,git当看不见了。
如果要恢复git对它的监控:
git update-index --no-assume-unchanged file
git clean -df 时,没有版控的文件会被清除,第一种情况忽略的文件都会被clean的,第二种的不会。
git co . 恢复文件修改时,第二种情况的文件修改会被恢复。
.gitignore 必须加入版控,否则一 clean 就没了。
七个你无法忽视的Git使用技巧:http://www.linuxdiyf.com/linux/16134.html
分分钟学会使用Git备份Linux配置文件:http://www.linuxdiyf.com/linux/15667.html
linux服务器搭建git服务器方法:http://www.linuxdiyf.com/linux/14680.html
Ubuntu Git服务器搭建及Gitosis安装设置:http://www.linuxdiyf.com/linux/14589.html
搭建git服务器(fedora22-server):http://www.linuxdiyf.com/linux/13141.html