diff options
Diffstat (limited to 'git-status.sh')
-rwxr-xr-x | git-status.sh | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/git-status.sh b/git-status.sh new file mode 100755 index 0000000000..621fa49d2b --- /dev/null +++ b/git-status.sh @@ -0,0 +1,85 @@ +#!/bin/sh +# +# Copyright (c) 2005 Linus Torvalds +# +. git-sh-setup || die "Not a git archive" + +report () { + header="# +# $1: +# ($2) +# +" + trailer="" + while read oldmode mode oldsha sha status name newname + do + echo -n "$header" + header="" + trailer="# +" + case "$status" in + M ) echo "# modified: $name";; + D*) echo "# deleted: $name";; + T ) echo "# typechange: $name";; + C*) echo "# copied: $name -> $newname";; + R*) echo "# renamed: $name -> $newname";; + A*) echo "# new file: $name";; + U ) echo "# unmerged: $name";; + esac + done + echo -n "$trailer" + [ "$header" ] +} + +branch=`readlink "$GIT_DIR/HEAD"` +case "$branch" in +refs/heads/master) ;; +*) echo "# On branch $branch" ;; +esac + +git-update-index --refresh >/dev/null 2>&1 + +if test -f "$GIT_DIR/HEAD" +then + git-diff-index -M --cached HEAD | + sed 's/^://' | + report "Updated but not checked in" "will commit" + + committable="$?" +else + echo '# +# Initial commit +#' + git-ls-files | + sed 's/^/o o o o A /' | + report "Updated but not checked in" "will commit" + + committable="$?" +fi + +git-diff-files | +sed 's/^://' | +report "Changed but not updated" "use git-update-index to mark for commit" + +if grep -v '^#' "$GIT_DIR/info/exclude" >/dev/null 2>&1 +then + git-ls-files --others \ + --exclude-from="$GIT_DIR/info/exclude" \ + --exclude-per-directory=.gitignore | + sed -e ' + 1i\ +#\ +# Ignored files:\ +# (use "git add" to add to commit)\ +# + s/^/# / + $a\ +#' +fi + +case "$committable" in +0) + echo "nothing to commit" + exit 1 +esac +exit 0 |