在开始之前,我应该说我已经看过this post和this one,但由于某些原因,那里提供的解决方案对我不起作用。我的存储库位于~/sources
下,因此每条命令都是从该路径运行的。这就是我所做的:
将filemode更改为false:
$ git config --global core.filemode false
检查全局配置:
$ git config --list
...
core.filemode=false
core.repositoryformatversion=0
core.bare=false
core.logallrefupdates=true
...
重新初始化存储库:
$ git init
Reinitialized existing Git repository in /home/rperez/sources/.git/
检查需要添加的内容:
$ git status
我得到一个包含存储库中所有文件的列表。
我正在使用:
$ git --version
git version 2.9.3
更新:为两个不同的文件添加了git diff
$ git status
...
modified: testing/test-valid-swasset-update.php
...
Untracked files:
(use "git add <file>..." to include in what will be committed)
library/mpdf60/ttfontdata/dejavusanscondensedI.GDEFdata.php
...
上述文件的 git diff
输出:
$ git diff testing/test-valid-swasset-update.php
diff --git a/testing/test-valid-swasset-update.php b/testing/test-valid-swasset-update.php
old mode 100755
new mode 100644
我在这里缺少什么?
答案 0 :(得分:17)
问题中的diff输出表明 local git config将filemode
设置为true。这可能是预期的行为,因为为repo创建的默认配置定义了这个:
-> git init
Initialized empty Git repository in /tmp/foo/.git/
-> cat .git/config
[core]
repositoryformatversion = 0
filemode = true
bare = false
logallrefupdates = true
更改filemode
的全局配置不会影响这一点,因此实际上git config --global core.filemode false
不会执行任何操作,因为它始终会在本地重写。
因此,要更改此repo的文件模式,请更改本地配置:
$ git config core.filemode false
$ git config core.filemode
false
考虑到this question/answer,它有可能发挥作用,尽管它不适合我。
答案 1 :(得分:0)
您可以验证本地设置的含义: git config --local --list
...并设置如下的本地值:
git config --local core.filemode false