Enhanced sq_quote()
[gitweb.git] / git-status.sh
index 621fa49d2bcad6c5343ac5c172fb9ca6a855c18d..6e2783a7b4df7ec77aa4d472e84db323f65ecc83 100755 (executable)
@@ -31,18 +31,26 @@ report () {
   [ "$header" ]
 }
 
-branch=`readlink "$GIT_DIR/HEAD"`
+branch=$(GIT_DIR="$GIT_DIR" git-symbolic-ref HEAD)
 case "$branch" in
 refs/heads/master) ;;
 *)     echo "# On branch $branch" ;;
 esac
 
-git-update-index --refresh >/dev/null 2>&1
+git-update-index -q --unmerged --refresh || exit
 
-if test -f "$GIT_DIR/HEAD"
+if GIT_DIR="$GIT_DIR" git-rev-parse --verify HEAD >/dev/null 2>&1
 then
        git-diff-index -M --cached HEAD |
-       sed 's/^://' |
+       sed -e '
+               s/^:// 
+               h
+               s/^[^\t]*//
+               s/ /\\ /g
+               x
+               s/\t.*$//
+               G
+               s/\n/ /' |
        report "Updated but not checked in" "will commit"
 
        committable="$?"
@@ -51,14 +59,24 @@ else
 # Initial commit
 #'
        git-ls-files |
-       sed 's/^/o o o o A /' |
+       sed -e '
+               s/ /\\ /g
+               s/^/o o o o A /' |
        report "Updated but not checked in" "will commit"
 
        committable="$?"
 fi
 
 git-diff-files |
-sed 's/^://' |
+sed -e '
+       s/^:// 
+       h
+       s/^[^\t]*//
+       s/ /\\ /g
+       x
+       s/\t.*$//
+       G
+       s/\n/ /' |
 report "Changed but not updated" "use git-update-index to mark for commit"
 
 if grep -v '^#' "$GIT_DIR/info/exclude" >/dev/null 2>&1