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

简介: 由于当年太年轻,资历不够深!!!导致文件命名不规范,现在想更正文件夹名字(common => COMMON),结果发现一个很奇特的现象!git 对文件(夹)名的大小写不敏感!!!!引发了一些问题。最终经过查阅资料得以解决。

前言



由于当年太年轻,资历不够深!!!导致文件命名不规范,现在想更正文件夹名字(common => COMMON),结果发现一个很奇特的现象!git 对文件(夹)名的大小写不敏感!!!!引发了一些问题。最终经过查阅资料得以解决,遂!写下这篇帖子记录一下。走~跟着渣渣一起吃着花生 🥜 喝着啤酒 🍺 燥起来~


demo部分目录结构



master 分支的代码及文件目录情况


# master分支原始目录
.
├── main.js
└── src
    └── components
        └── common
            ├── FootCell
            │   └── index.vue
            ├── Pagination
            │   └── index.vue
            ├── Table
            │   └── index.vue
            └── TitleCell
                └── index.vue


// main.js
const files = require.context('../components/common', true, /\.vue$/)


准备工作



模拟多用户


  • user1 分支:feature/user1
  • user2 分支:feature/user2

此时分别有两个用户user1user2在各自的电脑上拉取了这个项目。


骚操作开始 第一种



文件名的变更未同步到远端,但是引用路径却同步到远端了!


  • user1 不知道 git 大小写不敏感,user2 可知可不知,反正最后都!会!知!道!!!


【user1】向远端同步变更



更改文件名 + 更改引用路径


因为 这里 git 大小写不敏感所以只进行文件名变更(大小写)的话,不会被 git 检测到,所以必须要改动一个文件,让 git 检测到变更。才能进行commit!刚好文件名的变更导致了引用路径也需要变更!因此本次可以进行提交


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


# common => COMMON
  .
  ├── main.js
  └── src
      └── components
          └── COMMON
              ├── FootCell
              │   └── index.vue
              ├── Pagination
              │   └── index.vue
              ├── Table
              │   └── index.vue
              └── TitleCell
                  └── index.vue


// main.js
const files = require.context('../components/common', true, /\.vue$/)


  • 最后并把代码提交到了远端,并且告诉 user2 代码有更新


【user2】的响应



pull 代码


  • user2于是乎就先pull然后merge了一下,把 user1 的代码同步到自己的分支,结果如下:


# 此时 common => common 没有变化!!!
  .
  ├── main.js
  └── src
      └── components
          └── common
              ├── FootCell
              │   └── index.vue
              ├── Pagination
              │   └── index.vue
              ├── Table
              │   └── index.vue
              └── TitleCell
                  └── index.vue


// main.js 有变化!!!
const files = require.context('../components/COMMON', true, /\.vue$/)


这个时候,“报应”来的太突然,项目报错了!引用的路径是COMMON而实际项目的路径是common


  • 然后user2就好奇为啥会是这种情况,文件名没有变化??于是乎开启了探索之路~~


探索问题


因为user1绿了一波,心情不好搞事情,害得user2引发了 bug,但是刚好激发了user2的好奇心。


  • 为啥user1的是 COMMON,到我这里是 common???


最后user2查到了答案!原来是 git 对文件名的大小写不敏感,才会引发这个问题。好了那么接下来就是这么去解决这个问题呢??


温馨提示


因为 git 默认不区分大小写,所以如果只更改文件名的话 git 并不会检测到文件有变化,固!无法进行 commit,所以这次测试在更改文件名的时候附带的改动了其他地方,以便提交!


解决问题


既然user2已经知道了 git 默认大小写不敏感,那就让他敏感呗。多简单!


【user2】更新变更



1. 开启 敏感模式


git config core.ignorecase false # 让你变的敏感


其实user1压根就没有把文件名更改同步到到远端!(所以开头才说,他不知道 git 大小写不敏感!但是文件引用路径变更了,这个就导致其他人(user2)因为文件路径改变导致项目报错)


2. 切换分支,拉取最新代码


  • 切分支 checkout


git che master


  • 拉代码 pull


git pull


这个时候就会发现项目无法启动,因为 main.js 中的文件路径引用已经由 common => COMMON 了,但实际文件名依旧是 common


3. 手动更改文件名


  • common => COMMON


image.png


4. 暂存、提交、push、切分支、merge 到 feature/user2 分支


  • 暂存 add


git add .


  • 提交 commit


git commit -m user2手动同步更新文件名


image.png


  • 推送 push


# 这一步是替user1,将文件名变更同步到远端,供user3……等使用
#(此时如果其他用户是之前拉取的分支那么也会出现本篇文章所描述的问题!)
# 方法嘛~~ 就是当前文章~~哈哈哈
git push


  • 切分支 checkout


git che feature/user2


image.png

image.png


  • merge master 到 feature/user2 分支


git merge master


image.png


image.png


查看 commit 记录


image.png


骚操作开始 第二种



文件名变更实际已经同步到远端了,且引用路径也同步到了远端!


  • 这次user1 知道 git 大小写不敏感, user2 同样可知可不知,于是一开始就逼迫她,让她变得敏感再敏感!


【user1】向远端同步变更



  • user1 的分支:feature/user1


1. 让她敏感敏感再敏感


git config core.ignorecase false # emmmmm……俺敏感了


2. 更改文件名 & 文件引用路径


  • common => COMMON
  • 更改引用路径


// 旧
const files = require.context('../components/common', true, /\.vue$/)
// 新
const files = require.context('../components/COMMON', true, /\.vue$/)


3. 暂存(add)& 提交(commit)


  • 暂存 add


git add .


  • 提交 commit


git commit -m <msg>


4. 切换分支


  • git checkout master


image.png


image.png


4.merge 到 master 并 pull 向远端


  • merge 结果如下:

git merge feature/user1 # user1的分支合并到本地master


image.png


image.png


  • 推送 push


git push # 推送到远端master


【user2】更新变更



  • user2 的分支:feature/user2


1. 开启 敏感模式·情况一


git config core.ignorecase false


2. 切分支 & pull 代码


  • 切分支 checkout


git checkout master


  • 拉代码 pull


git pull # 更新 master 分支


  • 结果如下:


# 结果 error
KaKa:test2  xxx$ git pull
更新 5f318b9..5174f2e
error: 工作区中下列未跟踪的文件将会因为合并操作而被覆盖:
        src/components/COMMON/FootCell/index.vue
        src/components/COMMON/Pagination/index.vue
        src/components/COMMON/Table/index.vue
        src/components/COMMON/TitleCell/index.vue
请在合并前移动或删除。
正在终止


注意!上面那个问题一旦触发,那么你接下来所有的操作比如 check,switch,pull等操作都会报这个错误!!


  • 其实上面已经告诉你怎么操作了,按照提示 删除或者移动原有的common文件夹,然后再pull(check,switch)即可解决


  • 结果如下图:
    common文件名已经变更为COMMON

image.png


3. 切换分支 & merge 代码


如果上一步问题解决了那么这一步就没什么异常了,user2 的分支代码已经被更新了


  • 切分支 checkout


git checkout feature/user2


  • merge 代码


git merge master # 更新 feature/user2 分支


4 查看 commit 记录


  • 如下图:

image.png



5 恭喜同步成功


1 关闭 敏感模式·情况二


git config core.ignorecase true # git 默认不敏感


2. 切分支 & pull 代码


  • 切分支 checkout


git checkout master


  • 拉代码 pull


git pull # 更新 master 分支


  • 结果如下图:


image.png


40.jpg虽然远端的文件名已经由common => COMMON,但是当user2 执行pull的时候本地的文件名依旧还是老的common


3. 更改文件名、切换分支、merge master


  • 先更改文件名
    common => COMMON


  • 再切换分支:


git checkout feature/user2


  • COMMON文件夹变成空的了


image.png


image.png


  • 最后执行 merge 后的变化如下:


git merge master


  • COMMON文件夹又有内容了

image.png


4. 查看 commit


  • 记录如下:

image.png


5. 恭喜同步成功


另外一种方式 git rm



  • 删除文件夹 rm


git rm <文件夹路径> -r # -r 表示递归


  • 删除文件 rm


git rm <文件路径>


【user1】向远端同步变更



1. 开启 敏感模式·情况一


git config core.ignorecase false


2. 制作副本


common => common copy

复制副本以后不能直接将 common copy 改成 COMMON (此时 common 还存在)


3. 使用 rm 删除 common 文件夹


git rm ./src/components/common -r # -r 表示递归


4. 还原名字


  • common copy => COMMON
    看到这里有的同学该问了为啥不拷贝副本 common copy 以后立马直接对其变更名字(common copy => COMMON),然后执行第3步操作呢????问的好啊。鼓掌 👏

image.png


看到这个结果·····


其实本人也是很想这么操作的,可是现在回头想想,在不区分大小写的情况下:


common === COMMON // true,


  • 所以上面的提示是没有问题的 我个人认为


5. 暂存、commit、merge 到 master、推到远端


在这一步 你将遇到如下错误信息导致切换分支失败 (跟上面的还不太一样)


  • check 出问题


KaKa:test xxxx$ git che master
error: 工作区中下列未跟踪的文件将会因为检出操作而被覆盖:
        src/components/common/FootCell/index.vue
        src/components/common/Pagination/index.vue
        src/components/common/Table/index.vue
        src/components/common/TitleCell/index.vue
请在切换分支前移动或删除。
正在终止


  • 此时的项目结构是这样子的:


.
├── README.md
├── main.js
└── src
    └── components
        └── COMMON  <= # 重点!这里!!! 并没有 common
            ├── FootCell
            │   └── index.vue
            ├── Pagination
            │   └── index.vue
            ├── Table
            │   └── index.vue
            └── TitleCell
                └── index.vue
```


  • 并没有common文件夹!!那么就无解了??但是否定的!那我们就:

     忽略执行删除后的文件变更,直接 git checkout master


 
         


  • COMMON=> common
  • 再删除common


image.png


  • 最后执行 git check master


  • merge 出问题


KaKa-3:test xxxx$ git merge feature/user1
更新 5f318b9..24b399d
error: 工作区中下列未跟踪的文件将会因为合并操作而被覆盖:
        src/components/COMMON/FootCell/index.vue
        src/components/COMMON/Pagination/index.vue
        src/components/COMMON/Table/index.vue
        src/components/COMMON/TitleCell/index.vue
请在合并前移动或删除。
正在终止


  • 并没有COMMON,处理方法同上:
  • common=> COMMON
  • 再删除COMMON


image.png


  • 最后git merge feature/user1就可以了~


6. 查看 commit 记录


  • 如下图:


image.png


1. 关闭 敏感模式·情况二


git config core.ignorecase true


2. 更改文件名


  • common => COMMON
    然而尴尬的一幕它发生了!!!如下图:


image.png


image.png


  • 大小写不敏感引发的问题卧槽!Git 并没有检测到 文件有变化!


3. 卒!


  • 这种情况要么放弃,要么开启敏感模式!如果开启那就是情况一


【user2】更新变更



  • 此时 user2master 分支初始目录如下:


.
├── README.md
├── main.js
└── src
    └── components
        └── common
            ├── FootCell
            │   └── index.vue
            ├── Pagination
            │   └── index.vue
            ├── Table
            │   └── index.vue
            └── TitleCell
                └── index.vue


1. 开启 敏感模式·情况一


git config core.ignorecase false


2. pull 最新代码


KaKa:test2  xxxx$ git pull
更新 5f318b9..24b399d
error: 工作区中下列未跟踪的文件将会因为合并操作而被覆盖:
        src/components/COMMON/FootCell/index.vue
        src/components/COMMON/Pagination/index.vue
        src/components/COMMON/Table/index.vue
        src/components/COMMON/TitleCell/index.vue
请在合并前移动或删除。
正在终止


不出所料 会跟开头讲的 状况一致,这里就不重复赘述了,参考上面的即可解决。


3. 查看 commit 记录


  • 如下图:


image.png


1. 关闭 敏感模式·情况二


git config core.ignorecase true


2. pull 最新代码


  • 如下图


image.png


同前面所说,变更都过来了,唯独文件名由于本地的大小写不敏感,所以没有自动变更名字


3. 手动更改文件名


common => COMMON


4. 切换分支,mer master 代码


  • 切分支 checkout


git checkout feature/user2


  • merge 代码


git merge master


5. 查看 commit 记录


  • 如下图:


image.png


总结



综上的出来的结论就是多人协作开发的时候存在已下情况


  • 第一种方式user1 两种, user2 两种,总共四种情况。且文件都被标记为A
  • 都未开启敏感模式(绝大多数都是这个情况)
    这种情况可想而知,远端的文件名一直都是 common 而非 COMMON,所有人乃至以后都会一直存在这个问题(自己本地需要去手动的更改文件名),
  • 都开启了敏感模式
    这种情况 user2 在同步更新 master 分支代码的时候会遇到 error,根据提示删除或移动文件位置即可!(删除最简单直观)
  • 修改方(user1)开起了敏感模式,被通知方(user2)未开启 虽然文件名已经被改动且同步到了远端,但是当 user2 (master)拉取的时候会发现自己本地的文件名依旧是 common 未改动。这个时候只需要手动的去更改文件名,然后 mergeuser2 的分支即可
  • 修改方(user1)未开启敏感模式,被通知方(user2)开启了
    user1 自以为文件名已经更改成功且同步到了远端,实际并没有同步到远端,user2 自己手动更改,更改后 push 到远端,这样所有人的文件引用路径错误问题都能得到解决


  • 第二种方式
    通过git rm 这个操作来处理。通过这种方式变更文件会被标记为R


结束语



已上所有内容都是经过好几遍测试,一遍实践一遍记录的形式来撰写的,最后也反复检查了好几遍,目测没有什么问题,如果有问题了就请留言告知吧~

相关文章
|
7月前
|
项目管理 开发工具 git
版本控制与源代码管理:在 Visual Basic 项目中使用 Git
【4月更文挑战第27天】本文介绍了在Visual Basic项目中使用Git进行版本控制和源代码管理的重要性。Git作为一个流行的分布式版本控制系统,具备分布式架构、高效性能和强大分支管理等特点。在项目中,需先安装Git,然后初始化仓库、添加文件和提交更改。常用操作包括查看状态、日志、创建及切换分支和合并分支。团队协作时,借助远程仓库和推送拉取命令实现代码共享。虽然Git有学习曲线,但其优势在于强大的功能、灵活性和社区支持,能提升开发效率和代码质量。通过学习和实践,开发者可充分利用Git优化协作和项目管理。
80 1
|
2月前
|
Java Shell 开发工具
git集成IDEA,托管项目实现版本管理
git集成IDEA,托管项目实现版本管理
37 0
|
4月前
|
架构师 开发工具 git
项目去除git版本控制 去除版本控制
文章提供了去除本地项目Git版本控制的步骤,包括删除`.git`文件夹和`.idea`目录下的`vcs.xml`文件。
项目去除git版本控制 去除版本控制
|
4月前
|
jenkins 测试技术 开发工具
协同开发的艺术:Git 在团队项目中的高效应用
【8月更文第16天】在现代软件开发中,团队成员之间的高效协作是至关重要的。Git 作为一种分布式版本控制系统,为开发者提供了强大的工具来管理代码的变化和协作。本文将介绍如何利用 Git 来优化团队的工作流程,并提供实际操作的代码示例。
128 1
|
4月前
|
网络安全 开发工具 数据安全/隐私保护
Win10使用Git克隆项目出现fatal: Authentication failed for异常
Windows 10系统中使用Git克隆项目时出现"fatal: Authentication failed for"异常的解决方法,主要是通过修改凭据管理器中的Git凭据密码来解决因密码过期导致的身份验证失败问题。
88 0
Win10使用Git克隆项目出现fatal: Authentication failed for异常
|
4月前
|
安全 开发工具 git
coding上创建项目、创建代码仓库、将IDEA中的代码提交到coding上的代码仓库、Git的下载、IDEA上配置git
这篇文章是关于如何在IDEA中配置Git、在Coding.net上创建项目和代码仓库,并将IDEA中的代码提交到远程代码仓库的详细教程,涵盖了Git安装、IDEA配置、项目创建、代码提交等步骤。
coding上创建项目、创建代码仓库、将IDEA中的代码提交到coding上的代码仓库、Git的下载、IDEA上配置git
|
5月前
|
开发工具 git
使用Git拉取项目
使用Git拉取项目
|
4月前
|
Java 开发工具 git
【Azure 应用服务】本地Git部署Java项目到App Server,访问无效的原因
【Azure 应用服务】本地Git部署Java项目到App Server,访问无效的原因
|
4月前
|
开发工具 git
IDEA中怎么使用git下载项目到本地,通过URL克隆项目(giteegithub)
IDEA中怎么使用git下载项目到本地,通过URL克隆项目(giteegithub)
306 0
|
5月前
|
存储 开发工具 git
好的git管理方法,标明项目_编号_(功能,不过还是在没有bug出现时就提交为好)+Excel表管理的格式
好的git管理方法,标明项目_编号_(功能,不过还是在没有bug出现时就提交为好)+Excel表管理的格式