Git并没有忽略文件模式的改变(chmod),为什么?

时间:2016-12-13 14:16:55

标签: git ignore

在开始之前,我应该说我已经看过this postthis 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

我在这里缺少什么?

2 个答案:

答案 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