专栏首页walterlv - 吕毅的博客解决 Git 重命名时遇到的大小写不敏感的问题

解决 Git 重命名时遇到的大小写不敏感的问题

解决 Git 重命名时遇到的大小写不敏感的问题

发布于 2017-11-23 08:51 更新于 2018-07-30 12:33

Windows/Mac OS 操作系统文件的大小写是不敏感的,不管文件路径是何种奇怪的大小写,我们始终可以以另一种大小写的方式访问到这个路径种的文件或者文件夹。Linux 操作系统文件的大小写却是敏感的,不同大小写意味着不同的路径。于是,Windows 下的 A 文件在 Docs 文件夹下,B 文件在 docs 文件夹下,最终效果是 A B 都在 docs 文件夹下;而同样的情况放到 Linux 中,A B 就在两个不同的文件夹。

Git 是大小写不敏感的,导致跨操作系统共享的 Git 仓库就会遇到上面的情况。如果重命名的文件或文件夹只有大小写不同,那么对 Git 来说甚至都没有变化。阅读本文将解决 Git 大小写不敏感导致的重命名无效的问题。


更新:Windows 10 1803 更新已经可以支持区分大小写的文件夹了,于是此问题迎刃而解,后面会详细说明。

让人困扰的大小写问题

让我对此问题产生困扰的是下面这张图,Docsdocs 两个文件夹分开了:

▲ 分离的两个文件夹

Docs 改名为 docs,于是只有新增的文件才在 docs 文件夹下,旧文件依然在 Docs 中。README.md 中的链接可就遭殃了,还要注意大小写!

▲ 稍不注意,就 404 了

走的弯路

这种问题怎么看都不像是我一个人会遇到的问题,堆栈网上讨论肯定很多。至少截至本文发表时,How do I commit case-sensitive only filename changes in Git? 中问题已经得到了 600+ 个赞,回答累计得到 1400+ 个赞了……

里面探讨的方法归结起来两个:

  • git mv -f OldFileNameCase newfilenamecase
  • git config core.ignorecase false

尝试方法二:core.ignorecase false

第二种方法看起来更简单,于是我第一时间在我的全局 git 配置文件(C:\Users\lvyi\.gitconfig)中添加了一项:

[core]
    ignorecase = false

这时,git status 就能发现我的 git 仓库中 Docs 文件夹下的所有文件已经标记为修改了,都变成了 docs,于是愉快的提交推送:

$ git add .
$ git commit -m "Docs 文件夹改名为 docs 文件夹"
$ git push

然而去其他系统上看——居然有 Docsdocs 两份文件夹!!!而且比之前更严重,这一次可是里面的文件都完全重复了一份啊!!!

这时注意到 git add . 时,其实文件都是“新增”的,并不是“重命名”:

看来需要使用第一种方法了。

尝试方法一:mv

我写下命令:

$ git mv -f ./Docs ./docs -f

执行……推送后最终效果居然和第一种方法一样!依然是有 Docsdocs 两份文件夹。

尝试出的可行的方法

这是堆栈网那位只有 70+ 赞的方法的改进版本。先将文件夹重命名为临时文件夹,然后再从临时文件夹恢复成正常文件夹。

但是(划重点)中间需要先 commit 一次,否则和前面的方法效果一样,会存在两份文件夹!

$ git mv ./Docs ./docs.bak
$ git add .
$ git commit -m "改名(第 1/2 步)"

$ git mv ./docs.bak/ ./docs
$ git add .
$ git commit -m "改名(第 2/2 步)"

$ git push

中间的 git add . 其实是可以不需要的,因为 mv 命令会自动将修改加入暂存区。

至此,文件夹才真的做了仅大小写的改名。

使用 Windows 10 四月更新的特性(推荐)

我在 Windows 10 四月更新,文件夹名称也能区分大小写? 一文中提到可以使用 fsutil.exe file SetCaseSensitiveInfo 使某个特定的文件夹支持区分大小写。

经过尝试,使用此方法后,git 能够支持一次提交完美解决仅大小写的文件夹改名问题,完全不用管 git 的某种配置或其他任何因素。

首先,使用管理员权限在当前文件夹启动 PowerShell:

然后允许一下命令,以便开启此文件夹的大小写敏感功能。

> fsutil.exe file SetCaseSensitiveInfo . enable

随后,你可以像一般重命名一样去修改文件夹名称,然后像普通提交一样去 git commit。直接能生成一个仅修改文件夹名称大小写的新提交。

如果你在执行以上命令时出现了问题,请移步至 Windows 10 四月更新,文件夹名称也能区分大小写? 统一寻找解决方法。


参考资料

本文会经常更新,请阅读原文: https://walterlv.com/post/case-insensitive-in-git-rename.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系 (walter.lv@qq.com)

本文参与 腾讯云自媒体分享计划 ,欢迎热爱写作的你一起参与!
本文分享自作者个人站点/博客:https://walterlv.com复制
如有侵权,请联系 cloudcommunity@tencent.com 删除。
登录 后参与评论
0 条评论

相关文章

  • Git大小写不敏感问题避免,Jenkins代码构建失败踩坑记录

    前几天同事遇到一个问题,代码修改完本地可以运行,提交到 gitlab ,Jenkins 构建失败,报错找不到文件(图片)。

    德顺
  • 同事偷偷改了git目录让我跑不起项目

    由于被绿太狠了,心情不太好就开始了骚操作坑队友!common => COMMON结果如下:

    秋风的笔记
  • 用Python解决Verilog网表转CDL大小写重名的问题

    在用calibre v2lvs把APR网表转CDL时是不是经常遇到下图的情况?这是CDL不区分大小写的原因。最常见的解决方法就是写脚本替换。

    ExASIC
  • Windows 10 四月更新,文件夹名称也能区分大小写了

    发布于 2018-06-14 00:02 更新于 2018-09...

    walterlv
  • [第37期] 了解下git文件名大小写

    下午在搞代码部署的时候, 遇到一个文件名大小写的问题, 问题比较简单, 但是也简单整理下, 分享给大家。

    皮小蛋
  • 如何删除GIT仓库中的敏感信息

    正常Git仓库中应该尽量不包含数据库连接/AWS帐号/巨大二进制文件,否则一旦泄漏到Github,这些非常敏感信息会影响客户的信息安全已经公司的信誉。公司可能其...

    Edison.Ma
  • 可能每天都会用到的Git命令速查表

    老实说,莱纳斯·托瓦尔兹(Linus Torvalds)的小项目几乎感觉像是一个奇迹。

    王小婷
  • 从亲身经历谈谈如何用Git分支解决项目生产实践中的痛点

    最近笔者所在公司发生了一起小风波,事情大概是这样的:市场部老大在给客户现场演示系统时,正讨论着一个主题,恰巧系统在切换到相关功能时出现了异常,导致功能不可用,现...

    Tusi
  • 如何处理Git的大小写问题

    这个问题发生是因为Windows系统对大小写不敏感,所以Git也默认大小写不敏感。但像Github这类代码托管平台用的是Linux,Linux对大小写敏感。

    pai233
  • Git - 文件名大小写不敏感,怎么删除文件

    对于这个问题,没有使用 git rm 来删除 repo 的文件,再次上传之后,怎么移除这个文件。

    叉叉敌
  • Git 企业开发者教程

    为什么要写这样一个面向企业开发者的Git教程?这个问题也困扰我自己很久。其实我使用git的时间也不短了,但是就和正在阅读本文的每一位一样,常用的基本就是那么几个...

    企鹅号小编
  • git常见疑难杂症解决

    与人,请注意说话的语气,关心的话就温柔着来,开玩笑的话就嬉闹着来,正事就严肃着来。在亲人、情侣之间最常见的误会:明明是关心,出口便特别冲,满是愤怒的语气。

    小闫同学啊
  • react-native环境搭建的正确姿势

    上个月Facebook开源了Android版的react-native,react-native为何物就不多介绍,个人认为虽然取代不了native,但是确实有可...

    weishu
  • 日常开发过程中实际场景下使用git的一些简单总结

    公司内部有代码仓库和 github 仓库邮箱不一致。例如已经全局配置了公司内的信息

    flytam
  • GIT 常用快捷命令

    git rm --cached /path/to/file,然后正常 add 和 commit 即可。

    Alone88
  • 马蜂窝的前端火了!遇到冲突不怕怼,强制提交就是干

    相信大家都在世界杯期间有意无意地看到过马蜂窝的洗脑广告,短短的15秒,品牌名就出现了6次。“旅游之前,为什么要先上马蜂窝”,这些不断重复的广告词让人犹如魔咒般印...

    闰土大叔

扫码关注云+社区

领取腾讯云代金券