版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/10km/article/details/100689481
如果你不关注未纳入版本控制的文件(untracked)的文件,使用git diff
就可以判断git工作文件夹是否干净,如果是干净的,git diff
将没有输出,否则输出修改的文件的差异
#!/bin/bash
if [[ -n $(git diff --stat) ]]
then
echo 'dirty'
else
echo 'clean'
fi
如果觉得判断字符串是否为空的[[ ]]
条件判断语句写得太麻烦,配合 --quiet
选项还可以更简单使程序的返回代码(EXIT CODE)来判断
git diff --quiet || echo 'dirty'
但是,前面第一句话就说了,git diff
只是比较已经纳入版本控制的文件被修改的差异,如果git工作文件夹有新加入的文件,git diff
是不关注的,这种情况下,git diff
依然会认为文件夹是干净的(clean).
如果你同样关注git 文件夹中是否有未纳入版本控制的文件,那么 git status
是更妥善的办法,使用 git status -s
命令输出当前状态,如果git 文件夹是干净的(也没有untracked文件),则不输出任何内容,否则显示改变或增加的文件列表。所以我们可以使用类似下面这样的表达式来判断git 文件夹是否干净。
$ [[ -z $(git status -s) ]] || echo 'modified/untracked'