Git老是有无法重置的二进制相同的修改?不用怕!


公元二〇一六年九月二十八日,新中国建国六十七年国庆前三天,有 重大发现!git

基本能够肯定问题所在:缓存

缘由就是 VS2015 建立项目时自动建立的 .gitattributes 文件,一直以来,我长期以来,都一直觉得里面只有微软风格的“永远绝对正确”却“永远绝对没用”的注释,
可是,我错了,我今天偶然的发现,一个项目在 git 中的差别, 放这个文件 和 不放这个文件有差别!
——那就说明这个文件在起做用啊。里面有什么东西?
——是的有:
Line 4:* text=auto
——虽然全文只有这样有用,可是也由于全文3K的长度,只有这9个字符有用,因此忙碌的码农们天然没空细看,结果给微软坑死!服务器

为何发生问题的人不多?由于只有设置成“以原样签出,以原样签入”的时候,才会和这条配置发生奇妙的反应。。。。我真的也是醉了!工具

--- 重要的分割线 ----开发工具

2016.09.29 通过验证,个人推论彻底正确,我已修复以前损坏的项目。
建议:你们对于 VS2015自动生成的 .gitattributes 文件直接删除掉。
提示:高科技是件危险的东西,在没搞懂以前,最好先估算下破坏程度再动手。编码

PS:热情的回答,长期的关注这个问题,竟然 0 支持,0 感谢,知乎有句方言怎么说来着:操作系统

“贵乎药丸”。.net


----再也不重要的分割线----日志


就是由于碰到这个问题,搜到这里来的,求大神!!!求深刻了解Git原理的大神。开发

@轻扬 不是这个问题,若是是编码的问题,二进制比较的时候能比较出来。

@张宇航 问者,咱们仍是本身研究下吧,各位咱们先列下本身的使用环境变量,看看有什么异同之处:

操做系统:Win10
开发工具:VS2015
版本工具:GitExtensions
出现位置:添加的子模块中。(刚刚试了把这个库单独拉出来,竟然显示所有文件都不一样。。。)
出现文件:目前有 *.cs *.sln 文件。
其它疑点:
这是一个好久的却在不断维护的库(从2013年开始创建,如今推送到的是OSC服务器上)
我有怀疑是 VS2015自带的 git版本(281)和 ge自带的版本(195)不匹配的问题,可是我用(195)的版本依然出现同样的结果。
2014.12日已经出现过一次状况,当时是所有做为更改提交。如今诡异的是,若是把项目切回这个更改之前,竟然显示文件不用更改。——难道是之前某次 git 的bug致使文件散列码错误,如今修复了又改回去了?


PS:有E文好的往官方发 bug 报告了吗?
这个应该是由于 git 库中存入的散列值和实际计算值不一样形成的?
能否经过清除 .git 目录里的缓存达到再也不提示有的目的?
由于有些文件,原来是不显示为这种状态的,可是一旦打开修改,再修改还原回去,就形成了这样。

2016.09.10 新发现
在当前目录里面是二进制相同的,可是查看他们提交上去的文件,却会发现,日志中提交到服务器的文件的换行符是不一样的。我这里由于在 Win 下使用,通常设置为“原样签出,原样签入”。不知道 @张宇航 的状况如何?问题应该仍是出如今编码这里,彷佛签出签入的换行符设置哪里有了故障。

相关文章
相关标签/搜索