diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-30 12:51:00 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-30 12:51:00 -0700 |
commit | a3e870f2e2bcacc80d5b81d7b77c15a7928a9082 (patch) | |
tree | 58f726b5db2132fe3c76e92253c3504dd80272e1 /git-status-script | |
parent | f345b0a066572206aac4a4f9a57d746e213b6bff (diff) | |
download | git-a3e870f2e2bcacc80d5b81d7b77c15a7928a9082.tar.gz |
Add "commit" helper script
This is meant to make raw git not hugely less usable than something
like raw CVS. I want to make a 1.0 release of the plumbing, and the
actual commit part was just too intimidating.
Diffstat (limited to 'git-status-script')
-rwxr-xr-x | git-status-script | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/git-status-script b/git-status-script new file mode 100755 index 0000000000..72a93f74e8 --- /dev/null +++ b/git-status-script @@ -0,0 +1,38 @@ +#!/bin/sh +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";; + N) echo "# new file: $name";; + U) echo "# unmerged: $name";; + esac + done + echo -n "$trailer" + [ "$header" ] +} + +git-update-cache --refresh >& /dev/null +git-diff-cache -B -C --cached HEAD | sed 's/^://' | report "Updated but not checked in" "will commit" +committable="$?" +git-diff-files | sed 's/^://' | report "Changed but not updated" "use git-update-cache to mark for commit" +if [ "$committable" == "0" ] +then + echo "nothing to commit" + exit 1 +fi +exit 0 |