我有一个git结帐。所有的文件权限都不同于git认为它们应该是什么,因此它们都显示为修改。
没有触及文件的内容(只是想修改权限),我如何设置所有文件的权限,git认为他们应该是什么?
我有一个git结帐。所有的文件权限都不同于git认为它们应该是什么,因此它们都显示为修改。
没有触及文件的内容(只是想修改权限),我如何设置所有文件的权限,git认为他们应该是什么?
当前回答
我在Windows上使用cygwin的git, git应用解决方案不适合我。这是我的解决方案,在每个文件上运行chmod来重置其权限。
#!/bin/bash
IFS=$'\n'
for c in `git diff -p |sed -n '/diff --git/{N;s/diff --git//g;s/\n/ /g;s# a/.* b/##g;s/old mode //g;s/\(.*\) 100\(.*\)/chmod \2 \1/g;p}'`
do
eval $c
done
unset IFS
其他回答
我遇到了类似的问题,有人在服务器上的所有文件中添加了可执行标志,但是我也有本地修改的文件,除了那些权限被破坏的文件。然而,由于git唯一跟踪的权限是可执行标志,这个管道为我解决了这个问题:
git status | grep 'modified:' | awk '{print $3}' | xargs chmod a-x
基本上,该命令运行git status,过滤作为修饰符报告的文件,通过awk提取它们的路径,并删除可执行标志。
你也可以尝试一个前/后结帐挂钩。
参见:自定义Git - Git钩子
etckeeper工具可以处理权限和:
etckeeper init -d /mydir
你可以把它用在其他地方,而不是/等等。
使用你的包管理器安装或从上面的链接获取源代码。
我在Windows上使用cygwin的git, git应用解决方案不适合我。这是我的解决方案,在每个文件上运行chmod来重置其权限。
#!/bin/bash
IFS=$'\n'
for c in `git diff -p |sed -n '/diff --git/{N;s/diff --git//g;s/\n/ /g;s# a/.* b/##g;s/old mode //g;s/\(.*\) 100\(.*\)/chmod \2 \1/g;p}'`
do
eval $c
done
unset IFS
Git不存储除可执行脚本以外的文件权限。考虑使用git-cache-meta之类的工具来保存文件所有权和权限。
Git只能存储两种模式:755(可执行)和644(不可执行)。如果你的文件是444,git会存储它的644。