出于某种原因,当我最初为我的git项目从存储库中提取时, 我的工作副本中有大量的文件,它们没有明显的更改,但一直出现在我的非阶段性更改区域中。

我在Windows xp上使用Git Gui,当我去看文件,看看有什么改变。 我看到的是:

old mode 100755  
new mode 100644  

有人知道这是什么意思吗?

如何将这些文件从未分级更改列表中删除?(为了挑出我最近编辑过并想提交的文件,不得不浏览100个文件,这很烦人)。


对我来说,这看起来像unix文件权限模式(755=rwxr-xr-x, 644=rw-r——r——)-旧模式包括+x(可执行)标志,新模式没有。

这个msysgit问题的回复建议设置核心。Filemode为false,以摆脱这个问题:

git config core.filemode false

你可以试试 git重置-硬头 将回购重置为预期的默认状态。


设置的核心。Filemode设为false可以工作,但要确保~/中的设置。Gitconfig不会被.git/config中的那些覆盖。


似乎您更改了目录的一些权限。我执行以下步骤来恢复它。

$  git diff > backup-diff.txt                ### in case you have some other code changes 

$  git checkout .

我只有一个更改权限的麻烦文件。 为了单独回滚它,我只是用rm <file>手动删除它,然后签出一个新的副本。

幸运的是,我还没有上演。

如果我有,我可以在运行git checkout - <文件>之前运行git reset - <文件>


当您在远程存储库中执行所有文件时,就会发生这种情况。使它们重新可执行将使一切恢复正常。

chmod +x <yourfile> //For one file
chmod +x folder/* // For files in a folder

你可能需要做:

chmod -x <file> // Removes execute bit

相反,对于未被设置为可执行文件并且由于上述操作而更改的文件。有一个更好的方法来做到这一点,但这只是一个非常快速和肮脏的修复。


我曾经遇到过这个问题,当从旧硬盘驱动器复制工作文件的git repo几次。该问题源于所有者和权限从旧驱动器/机器更改到新驱动器/机器的事实。简而言之,运行以下命令来解决问题(感谢超级用户的回答):

sudo chmod -R -x . # remove the executable bit from all files

前一个命令将实际解决git diff报告的差异,但将撤销您列出目录的能力,因此ls ./失败,ls: .:权限被拒绝。要解决这个问题:

sudo chmod -R +X . # add the executable bit only for directories

坏消息是,如果您确实有任何想要保持可执行的文件,例如.sh脚本,则需要恢复它们。你可以为每个文件执行以下命令:

chmod +x ./build.sh # where build.sh is the file you want to make executable again

我只是在与master区分我的分支时遇到了这个问题。当我期望我的分支与master相同时,Git返回了一个“模式”错误。我通过删除文件,然后合并主在再次修正。

首先我运行差异:

git checkout my-branch
git diff master

这返回:

diff --git a/bin/script.sh b/bin/script.sh
old mode 100755
new mode 100644

然后我运行以下来修复:

rm bin/script.sh
git merge -X theirs master

在此之后,git diff返回my-branch和master之间没有差异。


我也遇到过同样的问题。这救了我的命:

这将把所有权限还原为差异,这样您就什么都没有了,只剩下您对文件所做的更改。

https://gist.github.com/jtdp/5443498

git diff -p -R --no-color \
| grep -E "^(diff|(old|new) mode)" --color=never  \
| git apply

详情见https://stackoverflow.com/a/4408378/450383


您可以使用以下命令将文件模式更改回。 Git添加——chmod=+x——文件名 然后提交到分支。


这通常发生在回购在Windows和Linux/Unix机器之间克隆时。

只需告诉git忽略文件模式更改。这里有几种方法:

配置仅为当前回购: Git配置核心。filemode假 在全球范围内配置: Git配置——全局核心。filemode假 在~/.gitconfig中添加: (核心) Filemode = false

只要从中选择一个。


设置git配置核心的可接受答案。Filemode false,工作,但有后果。设置的核心。Filemode to false告诉git忽略文件系统上的任何可执行位变化,这样它就不会将其视为更改。如果您确实需要在将来的任何时候对这个存储库进行可执行位更改,您将不得不手动执行,或者设置core。文件模式返回为true。

如果所有修改的文件都应该具有模式100755,那么另一种影响较小的替代方法是执行如下操作

chmod 100755 $(git ls-files --modified)

它只是做了模态的改变,不多不少,没有额外的含义。

(在我的例子中,这是因为在MacOS上OneDrive与我的文件系统同步;不改变核心。filemode,我保留了模式改变可能在未来再次发生的可能性;就我的情况而言,我想知道它是否会再次发生,以及改变核心。filemode将隐藏它从我,这是我不想要)


这招对我很管用:

git ls-files -m | xargs -L 1 chmod 644

该解决方案将git文件权限从100755更改为100644,并将更改推回bitbucket远程回购。

看看你的回购的文件权限:git ls-files——stage 如果100755而你要100644

然后执行如下命令: Git ls-files——stage | sed 's/\t/ /g' | cut -d' ' -f4 | xargs Git update-index——chmod=-x

现在再次检查你的回购文件权限:git ls-files——stage 现在提交您的更改:

吉特状态

Git commit -m“恢复文件权限”

git push


这与bkm的发现类似,但它也会考虑任何已删除的文件,并且只在应用更改时给出警告。

这可以很好地恢复上次提交的文件模式设置。

git diff -p --no-ext-diff --no-color --diff-filter=d | grep -E "^(diff|old mode|new mode)" | sed -e "s/^old/NEW/;s/^new/old/;s/^NEW/new/" | git apply

如果有任何删除的文件,上面的许多解决方案都将失效。

这将列出仅被修改而未删除的文件,并将它们全部更改为755

git diff-files --name-only --diff-filter=d | xargs -L 1 chmod 755