这里讲的是使用 git ignore 时候的一种特殊情况
 
正常你在本地给项目添加了一些文件之后,一般都会自动全部跟踪,但是在这个时候你必须编辑一个ignore文件,把一些不需要跟踪到文件ignore掉
 
这些东西不是可以不ignore也可以ignore的,更是必须要ignore的:
  1. 它们可以不同步,因为它们是自动生成的,是根据你的代码生成的,而且每运行一次都会自动覆盖上次版本,它们是被动变化而且可以由你的代码生成
  2. 它们必须不同步,因为它们可能包括了编译或是编程环境信息,比如路径等不重要但是一定不一样的信息,这样势必每次即使没有修改也会造成冲突
 
只要在全部添加跟踪之前把需要ignore的文件ignore掉,就不会有其他问题
具体哪些文件需要ignore就不详细说了,根据项目类型的不同网上资源很多
 
这里以android项目为例讲一下没有在添加跟踪之前ignore相应文件的特殊情况该如何处理
android项目中的build文件是自动生成的文件,是在项目run或者rebuild之后就会全部自动生成,其中很多文件是带有各种路径信息的
 
一、在本地添加了跟踪(add之后)才编辑ignore文件
  1. 这种情况造成的结果非常简单,就是ignore文件失效,文件会继续被跟踪,被commit ,被push ,被 merge。。。
  2. 这时候要如何处理?非常简单,执行一句命令就好了,在本地cache中清空这些需要ignore的文件,至于本地cache是什么以及为什么叫这个名字这里不详细说,你只要知道其他它就指的是stage就好了
  3. 命令:git rm -r --cached xx(MPChartLib/build)
  4. (不过既然是清空stage,也就是说commit 也可以咯?没有试,下次有机会可以试一试)
 
二、在push到远程之后才编辑ignore文件
  1. 这种情况就稍微复杂一些,因为它涉及到git的合并原理
  2. 这种情况下即使你清空了本地,执行上面那条命令已经得到这个结果时“fatal: pathspec 'MPChartLib/build' did not match any files”,当你进行pull的时候,因为远程是仍然有这些文件的,而且关键是你的ignore动作不会当成最新操作,让远程的这些文件消失(不知道用push能不能行,但不能直接push因为可能有其他修改),所以当你pull的时候,它们会被一块pull下来,而你本地虽然ignore了,但是这些文件还是存在的,所以就可能会有两个结果:本地直接增加另一份ignore文件的拷贝;git 报文件合并冲突。实际使用中是报了文件合并冲突,见[1]
  3. 这个时候如何做呢,其实非常简单,就是在本地把build文件全部删除,然后再pull远程(注意这个操作成功的条件是刚才冲突的文件全部是build文件,如果有其他文件冲突,要先把它们的冲突解决),这次pull一定是能成功的,然后你再在本地删除刚pull的build文件,然后add commit push,ok,现在远程会把你的删除操作作为最新操作,并且删除掉远程的这个被ignore的文件
  4. 现在你重新生成build,再拉取远程也不会有问题了
 
 
 
1
error: The following untracked working tree files would be overwritten by merge:
    MPChartLib/build/intermediates/bundles/debug/classes.jar
    MPChartLib/build/intermediates/bundles/release/classes.jar
    MPChartLib/build/intermediates/incremental/mergeDebugAndroidTestAssets/merger.xml
    MPChartLib/build/intermediates/incremental/mergeDebugAndroidTestResources/merger.xml
    MPChartLib/build/intermediates/incremental/mergeDebugAndroidTestShaders/merger.xml
    MPChartLib/build/intermediates/incremental/mergeDebugAssets/merger.xml
    MPChartLib/build/intermediates/incremental/mergeDebugJniLibFolders/merger.xml
    MPChartLib/build/intermediates/incremental/mergeDebugShaders/merger.xml
    MPChartLib/build/intermediates/incremental/mergeReleaseAssets/merger.xml
    MPChartLib/build/intermediates/incremental/mergeReleaseJniLibFolders/merger.xml
    MPChartLib/build/intermediates/incremental/mergeReleaseShaders/merger.xml
    MPChartLib/build/intermediates/incremental/packageDebugResources/merger.xml
    MPChartLib/build/intermediates/incremental/packageReleaseResources/merger.xml
    MPChartLib/build/intermediates/res/resources-debug-androidTest.ap_
    MPChartLib/build/outputs/aar/MPChartLib-debug.aar
    MPChartLib/build/outputs/aar/MPChartLib-release.aar
Please move or remove them before you can merge.
Aborting

git gitignore文件失效处理的更多相关文章

  1. Git .gitignore文件简介及使用

    Git .gitignore文件简介及使用 By:授客 QQ:1033553122 .gitignore 这个文件的作用就是告诉Git哪些文件不需要添加到版本管理中.实际项目中,很多文件都是不需要版本 ...

  2. Git .gitignore文件忽略

    Git .gitignore文件忽略 学习了:http://blog.csdn.net/yonnangel/article/details/50115059 http://www.cnblogs.co ...

  3. Git .gitignore文件说明

    参见:https://book.git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%AE%B0%E5%BD%95%E6%AF%8F%E6%AC%A1%E ...

  4. Git .gitignore文件的使用

    本文转载自 http://blog.csdn.net/xmyzlz/article/details/8592302 在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .giti ...

  5. git rm -r --cache命令 及 git .gitignore 文件

    git 的  .gitignore 文件的作用是在代码提交时自动忽略一个文件.不将其纳入版本控制系统. 比如.一般我们会忽略IDE自动生成的配置文件等. 如果一个你要忽略的文件已经纳入到了git ,也 ...

  6. Git - .gitignore文件的用法

    .gitignore文件的作用 .gitignore文件用来忽略被指定的文件或文件夹的改动,被记录在.gitignore文件里的文件或文件夹,是无法被git跟踪到的,换句话说,被忽略的文件是不会被放入 ...

  7. .gitignore文件失效的解决方案

    通常在idea中,我们使用git进行项目管理的时候,一些不需要的文件如.idea,.target文件不需要上传至gitlab仓库,这时,就需要在项目中定义一个.gitignore文件,用来标识这些文件 ...

  8. git .gitignore 文件 解决二进制文件冲突问题

    .gitignore  主要是添加 忽略文件 .最近团队开发经常出现 UserInterfaceState.xcuserstate 冲突,打开发现是二进制文件 ,没法解决冲突. 只好 rm -rf 之 ...

  9. git .gitignore 文件不起作用

    .gitignore 不起作用的原因是因为 git 有以前文件缓存,只要清理一次缓存即可 git rm -r --cached . // 然后再进行 git git add . git commit

随机推荐

  1. 使用statsd+graphite+grafana构建业务及性能监控模块

    近些年随着DevOps概念越来越收到重视,除了传统的Splunk,Zabbix外在开源领域也有越来越多的软件可供使用.从数据收集,时序数据库,图形展示等主要方面有各类可扩展的软件用于搭建一个数据监控平 ...

  2. 如何在ASP.NET 5上搭建基于TypeScript的Angular2项目

    一.前言 就在上月,公司的一个同事建议当前的前端全面改用AngularJs进行开发,而我们采用的就是ASP.NET 5项目,原本我的计划是采用TypeScript直接进行Angular2开发.所以借用 ...

  3. OWIN的理解和实践(三) –Middleware开发入门

    上篇我们谈了Host和Server的建立,但Host和Server无法产出任何有实际意义的内容,真正的内容来自于加载于Server的Middleware,本篇我们就着重介绍下Middleware的开发 ...

  4. ORACLE EXP/IMP的使用详解

    导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp 是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,表的 ...

  5. Silverlight中文本框添加回车事件后,换行无法清除的解决方法

    在开发Silverlight的项目中,为了更好的用户体验,我们常要给一些控件添加一些快捷键.然而,在Silverlight中当用户回车提交后,光标停留在文本框的第二行怎么也清除不掉,经过一段时间研究, ...

  6. 走进AngularJs(四)自定义指令----(中)

    上一篇简单介绍了自定义一个指令的几个简单参数,restrict.template.templateUrl.replace.transclude,这几个理解起来相对容易很多,因为它们只涉及到了表现,而没 ...

  7. Java多线程系列--“JUC锁”08之 共享锁和ReentrantReadWriteLock

    概要 Java的JUC(java.util.concurrent)包中的锁包括"独占锁"和"共享锁".在“Java多线程系列--“JUC锁”02之 互斥锁Ree ...

  8. AngularJS快速入门指南13:表单

    一个AngularJS表单是一组输入型控件的集合. HTML控件 HTML输入型标签标包括: input标签 select标签 button标签 textarea标签 HTML表单 HTML表单将各种 ...

  9. 大叔也说Xamarin~Android篇~支付宝SDK的错误与解决

    回到目录 在为android程序引入支付宝后,可能没有那么顺利,有能出现各种各样的问题,大叔在引用支付宝后就出现了APL64的错误,在网上找不很多资料都不对正,还是在官网找到了几句话,说到了点子上,具 ...

  10. Atitit dsl对于数组的处理以及main函数的参数赋值

    Atitit dsl对于数组的处理以及main函数的参数赋值 1.1. 词法解析..添加了[] 方括号的解析支持1 1.2. Ast建立.添加了数组参数的支持..使用了递归下降法..getparam ...