diff options
author | Michael Allen <michael@michaelallen.io> | 2015-03-10 16:21:40 +0000 |
---|---|---|
committer | Michael Allen <michael@michaelallen.io> | 2015-03-10 16:21:40 +0000 |
commit | 18c874f385e991552f71b93b9dc68bcdfd7d9c19 (patch) | |
tree | 6003bb228d81fedfc37be4b50743c05f7c876d24 /git-base.sh | |
parent | 82f5bd7c9c9118f2e5b623860beee1c76e03cec0 (diff) | |
download | git-sonar-18c874f385e991552f71b93b9dc68bcdfd7d9c19.tar.gz git-sonar-18c874f385e991552f71b93b9dc68bcdfd7d9c19.zip |
try to tell if a dir is dirty
Diffstat (limited to 'git-base.sh')
-rwxr-xr-x | git-base.sh | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/git-base.sh b/git-base.sh index 2debafa..fbd7ef9 100755 --- a/git-base.sh +++ b/git-base.sh @@ -205,6 +205,52 @@ unstaged="%{$fg_bold[red]%}" conflicted="%{$fg_bold[yellow]%}" untracked="%{$fg_bold[white]%}" +is_dirty() { + if ! git rev-parse; then + #not in repo, thus not dirty + return 1 + else + #in repo, might be dirty + if [[ -n "$(git ls-files --exclude-standard --others)" ]]; then + #untracked files thus dirty + return 0 + else + #no untracked files + if git show HEAD --; then + #has a commit hash, thus not on an initial commit + if ! git diff --quiet --ignore-submodules HEAD --; then + #has differences thus dirty + return 0 + else + return 1 + fi + else + #no commit hash, thus can't use HEAD. + #As it's inital commit we can just list the files. + if [[ -n "$(ls -a -1 | grep -Ev '(\.|\.\.|\.git)')" ]]; then + #files listed and no commit hash, thus changes + return 0 + else + return 1 + fi + fi + fi + fi + { + #returns 1 if not a git repo + git rev-parse && { + #returns 1 if untracked files + git ls-files --exclude-standard --others && ! { + git show HEAD -- || + #returns 1 if unstaged or staged files + git diff --quiet --ignore-submodules HEAD -- + } + } + } + exitCode="$?" + return "$exitCode" +} + porcelain_status() { echo "$(git status --porcelain 2>/dev/null)" } |