Git 重命名大小写不敏感的问题

0. 前言

文章的内容为转载,如需更加详细的说明可以跳转这里

1. 简介

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

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

2. 问题产生

之前在使用 Git 的时候,由于我之前在创建 package 时,一时手残,把一个字母打成了大写,然后在没检查的情况下提交了……


但是我本地的库由于没有不区分大小写,因此在我修改完提交后,就出现了下图这样包名不一致的结果

但是这个问题,在本地运行的时候没有任何问题,但是万一以后再遇到相同的问题或者有其他项目运行出问题,本着折腾「强迫症」的习惯,开始搜索解决方法。

3. 解决方法

这是堆栈网那位只有 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 命令会自动将修改加入暂存区。
最终把远程库改为了下图

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

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

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

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


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

> cd '切换至需要开启大小写敏感的目录'
> fsutil.exe file SetCaseSensitiveInfo . enable

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

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 不得不说 Git 默认不区分文件名大小写真是一个大坑,由于之前的项目目录比较乱,项目下的文件夹命名都不规范,这两天...
    爱吃鸭梨的猫阅读 30,006评论 2 8
  • Add & Commit git init 初始化一个 Git 仓库(repository),即把当前所在目录变成...
    冬絮阅读 4,906评论 0 9
  • Oracle: 默认是大小写不敏感,表名、字段名等不区分大小写,小写字母会自动转换为大写字母; 需要用小写字母时需...
    东皇Amrzs阅读 6,009评论 0 8
  • 学车的这段时间,经常会打顺风车去驾校 很喜欢和车主聊天 今天碰到的是一个专科里的行政工作人员 有编制,可以说是很羡...
    丑姑兄阅读 219评论 0 0
  • 黑玉是村中的小公主,长辈宠爱,小辈追捧。 — 赵四叔喝醉了,不慎跌入湍急的河流中,黑玉路过,立马掐动法诀将其救起,...
    啊衿阅读 467评论 1 1