我已经运行了以下命令来忽略监视/跟踪特定的目录/文件:

git update-index --assume-unchanged <file>

我如何撤销这一点,以便<文件>再次被监视/跟踪?


当前回答

添加到@adardesign的答案中,如果你想一次性将所有已添加到假设不变列表中的文件重置为no-assume-unchanged,你可以执行以下操作:

git ls-files -v | grep '^h' | sed 's/^..//' | sed 's/\ /\\ /g' | xargs -I FILE git update-index --no-assume-unchanged FILE || true

这将从grep中删除输出的两个字符,即。"h ",然后转义文件名中可能出现的任何空格,最后|| true将防止命令在循环中的某些文件出现错误时过早终止。

其他回答

我猜(嘿)你的意思是“假设不变”,因为我没有看到任何“假设改变”选项。假设不变的反义词是不假设不变。

这里没有不包括的。但我想补充我的意见。有时,我运行一个构建,它改变了很多文件,然后我想做一些事情,所以这个命令真的帮助了我很多。

Git update-index——假设-unchanged ' Git状态| grep modified | sed 's|modified:||g'| xargs '

希望其他人也能觉得它有用。

在Windows中没有一个解决方案对我有效-它似乎使用大写H而不是H来表示文件状态,grep命令需要一个额外的插入符号,因为^也表示行开始以及否定下一个字符。

Windows的解决方案

Open Git Bash and change to the relevant top level directory. git ls-files -v | grep '^^H' to list all the uncached files git ls-files -v | grep '^^H' | cut -c 3- | tr '\012' '\000' | xargs -0 git update-index --no-skip-worktree to undo the files skipping of all files that was done via update-index --skip-worktree git ls-files -v | grep '^^H]' | cut -c 3- | tr '\012' '\000' | xargs -0 git update-index --no-assume-unchanged to undo the files skipping of all files that was done via update-index --assume-unchanged git ls-files -v | grep '^^H' to again list all the uncached files and check whether the above commands have worked - this should now not return anything

要撤消/显示设置为assume-unchanged的dir's/files,执行以下命令:

git update-index --no-assume-unchanged <file>

要获得一个目录下的未修改的文件列表,运行以下命令:

git ls-files -v|grep '^h'

Git update-index函数有几个选项,你可以输入如下:

git update-index --help

在这里你会发现各种选项-如何处理函数update-index。

[如果你不知道文件名]

git update-index --really-refresh 

[如果你知道文件名]

git update-index --no-assume-unchanged <file>

将恢复所有已添加到忽略列表中的文件。

git update-index --assume-unchanged <file>