X-Git-Url: https://git.madduck.net/code/vcsh.git/blobdiff_plain/dad32b0f91c8e2cf9986ea1eb3f869e4774a963e..9867819bf0fc3882b9ede33462b6d98f10b7535a:/vcsh?ds=inline diff --git a/vcsh b/vcsh index 15eec51..b10d809 100755 --- a/vcsh +++ b/vcsh @@ -285,13 +285,36 @@ retire() { } list_untracked() { + temp_file_others=$(mktemp) || fatal 'Could not create temp file' + temp_file_untracked=$(mktemp) || fatal 'Could not create temp file' + temp_file_untracked_copy=$(mktemp) || fatal 'Could not create temp file' + + # create dummy git repo + temp_repo=$(mktemp -d) + ( + cd $temp_repo + git init -q + mktemp -p $(pwd) > /dev/null + git add . + git commit -q -m "dummy" + ) + + export GIT_DIR=$temp_repo/.git + git ls-files --others --directory | sort -u > $temp_file_untracked + for VCSH_REPO_NAME in $(list); do - [ -n $ran_once ] && files_untracked=$(printf '%s\n' "$files_untracked" | grep -Fx "$files_other") export GIT_DIR="$VCSH_REPO_D/$VCSH_REPO_NAME.git" - files_other="$(git ls-files --others)" - [ -z $ran_once ] && { ran_once=1; files_untracked=$files_other; } + git ls-files --others --directory | ( + while read line; do + echo "$line" + printf '%s/\n' "$(echo "$line" | cut -d'/' -f1)" + done + ) | sort -u > $temp_file_others + cp $temp_file_untracked $temp_file_untracked_copy + comm -12 --nocheck-order $temp_file_others $temp_file_untracked_copy > $temp_file_untracked done - echo "$files_untracked" | sort -u + cat $temp_file_untracked + rm -r $temp_file_others $temp_file_untracked $temp_file_untracked_copy $temp_repo || fatal 'Could not delete temp file' } rename() {