.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 14 小时 36 分钟前 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 14 小时 36 分钟前 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 10 小时 48 分钟前
git 版本低于 2 ?
|
6
DualVectorFoil 10 小时 22 分钟前
我记得我没配置过,下好 git 直接自动生成 ~/.gitignore_global 里面有 .DS_Store 条目了
|
7
drymonfidelia OP @gscsnm
@SingeeKing 我知道应该用 git rm 来删,我想知道的问题是为什么我已经从 gitignore 删除了规则,也重新 read-tree 了,git 还是扫描不到更改,要用什么方法才能让 git 彻底重新扫描整个仓库 |
8
drymonfidelia OP @hosiet 我建了一个空的 git 仓库确实是复现不了,不知道要在什么条件下才能触发,现在这个仓库太大了发不上来
|