.gitignore 里面没有 .DS_Store 这条规则,导致我的 GitLab 仓库里面提交上去了大量 .DS_Store.gitignore加入了排除 .DS_Store 这条规则.DS_Store 的文件就立即删除,此时从硬盘上删除了所有 .DS_Store 但并没有删除 git 仓库里的。所以这条规则就不必要了,我想要所有东西都尽可能简化,所以我同时把这条规则从 .gitignore 删掉了git add . && git commit 后,git 还是无法检测到我删除了的.DS_Store,不管怎么扫描 git 都识别不到删除.DS_Store的变更。我确认本地硬盘已经没有.DS_Store了,但是 GitLab 上最新 commit 里还存在大量的.DS_Store。并且我确认 HEAD 是同一个。git add -u / git read-tree HEAD 等一堆命令,都无法识别到任何变更 1
geelaw 1 天前 via iPhone
欢迎来到 psychic debugging session 。
第一个问题:你试过找到一个仓库里有的 .DS_Store ,然后在那个目录下 git rm -f ./.DS_Store 再 git commit 再 git push 吗? 第二个问题:你试过关掉 Finder ,再删除 .DS_Store ,再 git add . 再 git commit 再 git push 吗? 第三个问题:想没想过给出程序的输出会更容易调试问题呢? |
2
hosiet 1 天前 via Android
首先,建议提供一个最小可复现样本。如果有大家都能看的例子仓库,那问题就容易解决了。
其次,你的 git add 和 git rm 命令有试过加 -f 参数(--force )吗? |
3
SingeeKing PRO 首先你的需求其实可以通过全局 gitignore 实现,这样就不需要每个项目写了(当然也不用搞个脚本在后台删)
对于已经添加进入 git 仓库的 .DS_Store ,`git add .` 是不会删除它们的,需要明确的 `git rm` 才行 |
4
SingeeKing PRO 另外,你问的盗版 AI 吗…… 我把你的贴子贴给了 ChatGPT 它直接指出了要用 git rm
https://chatgpt.com/share/6938bfdd-2774-800d-844e-3530f6555919 |
5
gscsnm 1 天前
git 版本低于 2 ?
|
6
DualVectorFoil 1 天前
我记得我没配置过,下好 git 直接自动生成 ~/.gitignore_global 里面有 .DS_Store 条目了
|
7
drymonfidelia OP @gscsnm
@SingeeKing 我知道应该用 git rm 来删,我想知道的问题是为什么我已经从 gitignore 删除了规则,也重新 read-tree 了,git 还是扫描不到更改,要用什么方法才能让 git 彻底重新扫描整个仓库 |
8
drymonfidelia OP @hosiet 我建了一个空的 git 仓库确实是复现不了,不知道要在什么条件下才能触发,现在这个仓库太大了发不上来
|
9
Yuunie 13 小时 52 分钟前
又有大小写,又有点,这文件是容易出问题
|
10
hosiet 9 小时 52 分钟前 via Android
已存在的 gitignore 只能处理(现实世界中)未来发生的修改,已经做过的提交是影响不了的。
所以你要做的是类似 git rm -f /path/to/.DS_Store 这样。哪怕这个文件夹不存在于硬盘上也没关系,路径写对了就能生效。 |
11
iamnotcodinggod 9 小时 35 分钟前
find . -name ".DS_Store" -print0 | xargs -0 git rm --cached
git commit -m "Remove .DS_Store from repository history" |
12
drymonfidelia OP @hosiet
@iamnotcodinggod 我知道用 git rm 可以把文件删掉,我想研究的问题是为什么已经删除这条规则了 git 还是扫描不出我的更改,因为如果没搞清楚以后还可能发生别的更改 git 扫描不到的情况 |
13
geelaw 5 小时 31 分钟前
@SingeeKing #3 我解读的他的意思是:删除了 .DS_Store 文件之后 git add . 还是无法把删除的事实记录到 staged 。
#1 的第二个问题已经提示了可能他删除 .DS_Store 和 Finder 重建 .DS_Store 和 git add . 的扫描之间有竞态条件,但是他似乎比较喜欢和大家玩 psychic debugging 游戏。 另外,无论 .gitignore 是否忽略 .DS_Store ,用 git add . 都是可以发现在 staged/index 里的 .DS_Store 文件已经从 working tree 删除的情况的。 |
14
hosiet 3 小时 23 分钟前 via Android
从没用过 mac 。macOS 有随时随地缺了就实时创建 .DS_Store 的特性吗?如果是这导致的,不如把仓库挪到 Linux 上先处理看看是否有解决,处理完再挪回来。
不过我还是那句话,没有可复现实例或者可复现操作流程的话,大家在论坛里帮你 debug 永远是低效甚至无效的。 |