X-Git-Url: https://git.madduck.net/code/vcsh.git/blobdiff_plain/88dc47b049d19ca62dd29ec9d594b8a8dc858f40..974ccb022b59ac80145a6d43ff4f11b18ae49de1:/vcsh?ds=sidebyside diff --git a/vcsh b/vcsh index 6a81343..8e765c4 100755 --- a/vcsh +++ b/vcsh @@ -284,6 +284,40 @@ retire() { unset VCSH_DIRECTORY } +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) || fatal 'Could not create temp repo' + ( + cd $temp_repo || fatal 'Could not cd into temp repo' + git init -q + mktemp -q -p $(pwd) > /dev/null || fatal 'Could not create dummy file' + 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 + export GIT_DIR="$VCSH_REPO_D/$VCSH_REPO_NAME.git" + 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 || fatal 'Could not copy temp file' + comm -12 --nocheck-order $temp_file_others $temp_file_untracked_copy > $temp_file_untracked + done + cat $temp_file_untracked + rm -f $temp_file_others $temp_file_untracked $temp_file_untracked_copy || fatal 'Could not delete temp files' + rm -rf $temp_repo || fatal 'Could not delete temp repo' +} + rename() { git_dir_exists [ -d "$GIT_DIR_NEW" ] && fatal "'$GIT_DIR_NEW' exists" 54 @@ -463,6 +497,7 @@ elif [ x"$VCSH_COMMAND" = x'delete' ] || elif [ x"$VCSH_COMMAND" = x'commit' ] || [ x"$VCSH_COMMAND" = x'list' ] || [ x"$VCSH_COMMAND" = x'list-tracked' ] || + [ x"$VCSH_COMMAND" = x'list-untracked' ] || [ x"$VCSH_COMMAND" = x'pull' ] || [ x"$VCSH_COMMAND" = x'push' ]; then :