git diff

如果你不关注未纳入版本控制的文件(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 status

如果你同样关注git 文件夹中是否有未纳入版本控制的文件,那么 git status 是更妥善的办法,使用 git status -s命令输出当前状态,如果git 文件夹是干净的(也没有untracked文件),则不输出任何内容,否则显示改变或增加的文件列表。所以我们可以使用类似下面这样的表达式来判断git 文件夹是否干净。

$ [[ -z $(git status -s) ]] || echo 'modified/untracked'
Logo

更多推荐