我有一个git结帐。所有的文件权限都不同于git认为它们应该是什么,因此它们都显示为修改。

没有触及文件的内容(只是想修改权限),我如何设置所有文件的权限,git认为他们应该是什么?


当前回答

你也可以尝试一个前/后结帐挂钩。

参见:自定义Git - Git钩子

其他回答

我知道这很古老,但我来自谷歌,我没有找到答案

如果你没有零钱想留着,我有一个简单的解决办法:

git config core.fileMode true
git reset --hard HEAD
git diff -p \
| grep -E '^(diff|old mode|new mode)' \
| sed -e 's/^old/NEW/;s/^new/old/;s/^NEW/new/' \
| git apply

将工作在大多数情况下,但如果你有外部差异工具,如meld安装,你必须添加-no-ext-diff

git diff --no-ext-diff -p \
    | grep -E '^(diff|old mode|new mode)' \
    | sed -e 's/^old/NEW/;s/^new/old/;s/^NEW/new/' \
    | git apply

在我的情况下需要什么

你也可以尝试一个前/后结帐挂钩。

参见:自定义Git - Git钩子

最简单的方法就是把权限改回来。正如@kroger指出的,git只跟踪可执行位。所以你可能只需要运行chmod -x文件名来修复它(或者如果需要的话+x)。

我遇到了类似的问题,有人在服务器上的所有文件中添加了可执行标志,但是我也有本地修改的文件,除了那些权限被破坏的文件。然而,由于git唯一跟踪的权限是可执行标志,这个管道为我解决了这个问题:

git status | grep 'modified:' | awk '{print $3}' | xargs chmod a-x

基本上,该命令运行git status,过滤作为修饰符报告的文件,通过awk提取它们的路径,并删除可执行标志。