博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
git status将文件状态标为renamed问题探究
阅读量:6293 次
发布时间:2019-06-22

本文共 691 字,大约阅读时间需要 2 分钟。

问题描述

线上项目有一个小bug,我修改了xx.js中的一行代码解决了问题,然后webpack打包,准备提交代码。

git add .git status

这时候我发现,git status的输出为:

renamed:    xx.1.js -> xx.2.js

我发现这不太对啊:renamed虽然可以体现出来webpack打包的时候改掉文件名hash值这个重命名的过程,但不能体现我改了文件内容啊。

我觉得应该这样输出才对:

deleted:     xx.1.jsnew file:    xx.2.js

于是开始找答案,看为什么和我想的不一样。

问题解决

搜了一圈,最终有些收获,结论先行:

git把文件标为
renamed的意思是并不是很具体的指这个文件
重命名了。他是一个
泛指,这是一个种所谓
heuristic(启发式,不懂不懂)的用法。

关于这个问题没有找到足够的资料,但是通过我的测试,发现:

一个文件的改动的行数低于
总行数的50%的,并且进行
重命名操作就会出现这种被标为
renamed的情况

测试方法如下:

  1. a.txt,里面内容为0-99的数字,每个一行,共100行。
  2. 把这个文件做commit
  3. 重命名a.txt为b.txt
  4. 删除49行内容,然后做add操作,然后做git status操作
  5. 删除50行内容,然后做add操作,然后做git status操作
  6. 删除51行内容,然后做add操作,然后做git status操作

同时在找资料的时候我也尝试了下面两个链接里提到的方式,但是在我的版本(2.19.2.windows.1)都没有成功复现。

参考文档

转载地址:http://eacta.baihongyu.com/

你可能感兴趣的文章
python中一切皆对象------类的基础(五)
查看>>
modprobe
查看>>
android中用ExpandableListView实现三级扩展列表
查看>>
%Error opening tftp://255.255.255.255/cisconet.cfg
查看>>
java读取excel、txt 文件内容,传到、显示到另一个页面的文本框里面。
查看>>
《从零开始学Swift》学习笔记(Day 51)——扩展构造函数
查看>>
python多线程队列安全
查看>>
[汇编语言学习笔记][第四章第一个程序的编写]
查看>>
android 打开各种文件(setDataAndType)转:
查看>>
补交:最最原始的第一次作业(当时没有选上课,所以不知道)
查看>>
Vue实例初始化的选项配置对象详解
查看>>
PLM产品技术的发展趋势 来源:e-works 作者:清软英泰 党伟升 罗先海 耿坤瑛
查看>>
vue part3.3 小案例ajax (axios) 及页面异步显示
查看>>
浅谈MVC3自定义分页
查看>>
.net中ashx文件有什么用?功能有那些,一般用在什么情况下?
查看>>
select、poll、epoll之间的区别总结[整理]【转】
查看>>
CSS基础知识(上)
查看>>
PHP中常见的面试题2(附答案)
查看>>
26.Azure备份服务器(下)
查看>>
mybatis学习
查看>>