From 68037c567f3c8d9bf5fda429a5542182d20891bf Mon Sep 17 00:00:00 2001 From: Richard Burke Date: Tue, 11 Oct 2016 22:25:25 +0100 Subject: File completion updates --- vis-complete | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'vis-complete') diff --git a/vis-complete b/vis-complete index 43b080f..4a3ee57 100755 --- a/vis-complete +++ b/vis-complete @@ -28,21 +28,27 @@ while [ $# -gt 0 ]; do esac done -if [ $COMPLETE_WORD = 1 ]; then - tr -cs '[:alnum:]_' '\n' | - grep "^$(basic_regex_quote "$PATTERN")." | - sort -u -else +if [ $COMPLETE_WORD = 0 ]; then case $PATTERN in /*) # An absolute path. This is fine. ;; + '~'|'~/'*) + # Expand tilde to $HOME + PATTERN=$HOME$(echo $PATTERN | tail -c +2) + ;; *) # A relaive path. Let's make it absolute. PATTERN=$PWD/$PATTERN ;; esac +fi +if [ $COMPLETE_WORD = 1 ]; then + tr -cs '[:alnum:]_' '\n' | + grep "^$(basic_regex_quote "$PATTERN")." | + sort -u +else START=$(dirname "$PATTERN") # The first path condition rules out paths that start with "." unless # they start with "..". That way, hidden paths should stay hidden, but -- cgit v1.2.3