linux shell:判断git工作文件夹是否干净(clean)

  • 2019 年 10 月 5 日
  • 笔记

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/10km/article/details/100689481

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'