summaryrefslogtreecommitdiff
path: root/git-status-script
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@ppc970.osdl.org>2005-05-30 12:51:00 -0700
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-05-30 12:51:00 -0700
commita3e870f2e2bcacc80d5b81d7b77c15a7928a9082 (patch)
tree58f726b5db2132fe3c76e92253c3504dd80272e1 /git-status-script
parentf345b0a066572206aac4a4f9a57d746e213b6bff (diff)
downloadgit-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-xgit-status-script38
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