From 55666d0f67bb94d5654a9389031fa9269cf512a5 Mon Sep 17 00:00:00 2001 From: Tim Allen Date: Sat, 8 Oct 2016 16:02:50 +1100 Subject: Handle completing absolute paths, not just relative ones. --- vis-complete | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) (limited to 'vis-complete') diff --git a/vis-complete b/vis-complete index 278bf40..52dd464 100755 --- a/vis-complete +++ b/vis-complete @@ -28,5 +28,23 @@ done if [ $COMPLETE_WORD = 1 ]; then tr -cs '[:alnum:]_' '\n' | grep "^$PATTERN." | sort -u else - find . ! -path '*/\.*' -a -path "./$PATTERN*" 2>/dev/null | head -n $FIND_FILE_LIMIT | cut -b 3- | sort -fi | vis-menu -b | sed "s/^$(printf "%s" "$PATTERN" | sed 's:/:\\/:g' )//" | tr -d '\n' + case $PATTERN in + /*) + # An absolute path. This is fine. + ;; + *) + # A relaive path. Let's make it absolute. + PATTERN=$PWD/$PATTERN + ;; + esac + + START=$(dirname "$PATTERN") + find "$START" \ + ! -path '*/\.*' \ + -a -path "$PATTERN*" 2>/dev/null | + head -n $FIND_FILE_LIMIT | + sort +fi | + vis-menu -b | + cut -b $(( ${#PATTERN} + 1 ))- | + tr -d '\n' -- cgit v1.2.3