git 忽略大小写(重命名文件)

文章目录

        • [1. 场景描述](#1. 场景描述)
        • [2. 配置命令](#2. 配置命令)
        • [3. 流程分析](#3. 流程分析)
        • [4. 最佳实践](#4. 最佳实践)
1. 场景描述

作为一个使用 git 作为版本控制的程序员,相信各位都遇到过这种问题,文件名或目录名的大小写整错了

场景描述

比如:想要创建一个文件 User.php,但是文件名打成了 user.php,并且已将 user.php 提交到了版本库

然后,你应该会将错误的 user.php 修改为正确 User.php,但是发现 git 没有监听到文件发生变化

问题原因

这是因为 git 默认不区分文件名的大小写,也就是对大小写不敏感,所以此时 git 并不认为文件发生变化了

我的解决办法

先尝试使用 git mv 命令从工作区和暂存区重命名文件,发现是不行的,继续尝试其他方法

plaintext 复制代码
$ git mv user.php User.php
fatal: destination exists, source=liang.php, destination=Liang.php

之前我遇到这种问题,会先修改其名称(不仅仅修改大小写),提交到版本库,然后再修改为正确的名称,再次提交

比如:将 user.php 修改为 user1.php 后提交到版本库,然后再修改为 User.php,再提交到版本库

但是,这种办法肯定不好的,为了解决这个问题不仅仅是多了两个提交记录,而且还要自己去找到大小写错误的文件

其实,git 提供了严格区分大小写的配置项,接下来我们学习一下这个配置,当修改了名称的大小写,让 git 自己去发现

2. 配置命令

查看当前是否忽略大小写配置,输出结果:true(忽略大小写,默认配置)、false(已经严格区分大小写)

bash 复制代码
git config --get core.ignorecase

全局设置,将忽略大小写关闭,也就是开启大小写敏感,从而能够正确识别文件名大小写的更改

bash 复制代码
git config --global core.ignorecase false

不过,有时从远程仓库拉取到本地时,当前项目的 git 配置可能默认就是忽略大小写(经测试 gitee 是这样的)

通过查看本地仓库配置文件内容,或者查看本地仓库配置都可以证实

bash 复制代码
# 查看本地仓库配置文件内容
cat .git/config
# 查看本地仓库配置中的忽略大小写配置
git config --local --list | grep ignorecase

因为项目配置优先级高于全局配置,所以此时全局配置开启大小写敏感已经失效,需要手动设置当前项目开启大小写敏感

bash 复制代码
git config core.ignorecase false
3. 流程分析

开启大小写敏感后,修改文件名,git 能监听到文件变化了,直接提交是不是就可以将文件重命名成功了呢 ?

将 user.php 重命名为 User.php,查看状态可以发现

  • user.php 没有提示被删除,所以它还在被 git 管理追踪
  • User.php 是一个没有追踪的文件,需要将它提交到暂存区
plaintext 复制代码
On branch master
Your branch is up to date with 'origin/master'.

Untracked files:
  (use "git add <file>..." to include in what will be committed)
	User.php

nothing added to commit but untracked files present (use "git add" to track)

如果直接将 User.php 提交到版本库,会怎么样 ?你会发现远程库既有 user.php,又有 User.php(此时你是不是很无语)

bash 复制代码
git add User.php
git commit -m '将 user.php 修改为 User.php'
git push

因为远程库有两个相同名称的文件(只是大小写不同),别人 clone 仓库时,能拉取成功,但是会有以下提示

plaintext 复制代码
warning: the following paths have collided (e.g. case-sensitive paths
on a case-insensitive filesystem) and only one from the same
colliding group is in the working tree:

  'User.php'
  'user.php'

所以,我们需要将远程库的无用的 user.php 删除掉。然后,别人重新 clone 就可以得到正确的 User.php 了

bash 复制代码
git rm --cached user.php
git commit -m '删除暂存区中的 user.php'
git push
4. 最佳实践

首先,关闭忽略大小写,也就是开启大小写敏感,修改文件名称时让 git 可以追踪的到

bash 复制代码
git config core.ignorecase false

手动修改文件名称,然后从暂存区删除旧文件,将新文件提交到暂存区

bash 复制代码
git rm --cached user.php
git add User.php

此时查看状态,也可以发现当前确实是一个重命名的操作

plaintext 复制代码
On branch master
Your branch is up to date with 'origin/master'.

Changes to be committed:
  (use "git restore --staged <file>..." to unstage)
	renamed:    user.php -> User.php

然后正常提交并推送到远程库即可

bash 复制代码
git commit -m 'renamed: user.php -> User.php'
git push
相关推荐
金融小师妹5 小时前
基于NLP情绪分析与机器学习预测:避险情绪升温,黄金价格触及5200关键阈值
大数据·人工智能·机器学习·重构
long跨境电商5 小时前
跨境平台竞争下,卖家自养买家号测评如何安全高效操作?
大数据
八角Z5 小时前
OpenClaw Windows 10 完整安装步骤细化说明
大数据·人工智能·windows·机器学习
墨染天姬5 小时前
【AI】企业知识库的信息孤岛问题如何解决?
大数据·人工智能·elasticsearch
AI-小柒5 小时前
Seedance 2.0(即梦 2.0)深度解析:AI 视频进入「导演级」可控时代
大数据·人工智能·网络协议·tcp/ip·http·音视频
TImCheng06095 小时前
落地实施方案:为销售团队引入AI工具的四阶段(选型-试点-培训-复盘)攻略
大数据·人工智能
认真的薛薛6 小时前
13.k8s中Prometheus监控集群及其服务,endpoint暴露服务,es采集k8s日志
elasticsearch·kubernetes·prometheus
Lunar*6 小时前
告别臃肿!使用 git-filter-repo 优雅清理 Git 历史记录
git
EasyGBS6 小时前
从“联网互通”到“安全可信”:EasyGBS支持GB35114国密协议,覆盖全场景安防合规升级
大数据·人工智能·安全·gb28181·gb35114