X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-status.sh;h=62a24a9b03a259fa94f61b3cb060c2b99f55e40e;hb=e24317b4d093e4b148996172d0b749f09a0e6f2e;hp=44398d760c4b212bfebbbe09c4bb11d2068ad49d;hpb=79a9d8ea0d88a3667ad19be8e705405ab5d896f1;p=git.git diff --git a/git-status.sh b/git-status.sh index 44398d76..62a24a9b 100755 --- a/git-status.sh +++ b/git-status.sh @@ -11,7 +11,7 @@ report () { # " trailer="" - while read oldmode mode oldsha sha status name newname + while read status name newname do echo -n "$header" header="" @@ -41,8 +41,11 @@ git-update-index -q --unmerged --refresh || exit if GIT_DIR="$GIT_DIR" git-rev-parse --verify HEAD >/dev/null 2>&1 then - git-diff-index -M --cached HEAD | - sed 's/^://' | + git-diff-index -M --cached --name-status HEAD | + sed -e ' + s/\\/\\\\/g + s/ /\\ /g + ' | report "Updated but not checked in" "will commit" committable="$?" @@ -51,31 +54,49 @@ else # Initial commit #' git-ls-files | - sed 's/^/o o o o A /' | + sed -e ' + s/\\/\\\\/g + s/ /\\ /g + s/^/A / + ' | report "Updated but not checked in" "will commit" committable="$?" fi -git-diff-files | -sed 's/^://' | +git-diff-files --name-status | +sed -e ' + s/\\/\\\\/g + s/ /\\ /g +' | report "Changed but not updated" "use git-update-index to mark for commit" -if grep -v '^#' "$GIT_DIR/info/exclude" >/dev/null 2>&1 + +if test -f "$GIT_DIR/info/exclude" 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 + git-ls-files -z --others \ + --exclude-from="$GIT_DIR/info/exclude" \ + --exclude-per-directory=.gitignore +else + git-ls-files -z --others \ + --exclude-per-directory=.gitignore +fi | +perl -e '$/ = "\0"; + my $shown = 0; + while (<>) { + chomp; + s|\\|\\\\|g; + s|\t|\\t|g; + s|\n|\\n|g; + s/^/# /; + if (!$shown) { + print "#\n# Untracked files:\n"; + print "# (use \"git add\" to add to commit)\n#\n"; + $shown = 1; + } + print "$_\n"; + } +' case "$committable" in 0)