X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-status.sh;h=837f334d8760c9ff4af4de5d057e97d7af3cfc61;hb=f8348be3be8493a62110a09ab0343213990b416b;hp=6e2783a7b4df7ec77aa4d472e84db323f65ecc83;hpb=0d0b7c237af0846123bef73879d65a3e78a56461;p=git.git diff --git a/git-status.sh b/git-status.sh index 6e2783a7..837f334d 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,16 +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 | + git-diff-index -M --cached --name-status --diff-filter=MDTCRA HEAD | sed -e ' - s/^:// - h - s/^[^\t]*// + s/\\/\\\\/g s/ /\\ /g - x - s/\t.*$// - G - s/\n/ /' | + ' | report "Updated but not checked in" "will commit" committable="$?" @@ -60,40 +55,48 @@ else #' git-ls-files | sed -e ' + s/\\/\\\\/g s/ /\\ /g - s/^/o o o o A /' | + s/^/A / + ' | report "Updated but not checked in" "will commit" committable="$?" fi -git-diff-files | +git-diff-files --name-status | sed -e ' - s/^:// - h - s/^[^\t]*// + s/\\/\\\\/g 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 + +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)