2010-01-02 10:35:18 +02:00
|
|
|
# mount(8) completion. This will pull a list of possible mounts out of
|
|
|
|
# /etc/{,v}fstab, unless the word being completed contains a ':', which
|
|
|
|
# would indicate the specification of an NFS server. In that case, we
|
|
|
|
# query the server for a list of all available exports and complete on
|
|
|
|
# that instead.
|
|
|
|
#
|
|
|
|
have mount &&
|
|
|
|
{
|
|
|
|
|
2010-02-04 16:31:51 +02:00
|
|
|
# Just like COMPREPLY=(`compgen -W "${COMPREPLY[*]}" -- "$cur"`), only better!
|
2010-02-04 16:47:44 +02:00
|
|
|
#
|
2010-02-04 16:31:51 +02:00
|
|
|
# This will correctly escape special characters in COMPREPLY.
|
|
|
|
_reply_compgen_array()
|
|
|
|
{
|
|
|
|
# Create the argument for compgen -W by escaping twice.
|
|
|
|
#
|
|
|
|
# One round of escape is because we want to reply with escaped arguments. A
|
|
|
|
# second round is required because compgen -W will helpfully expand it's
|
|
|
|
# argument.
|
2010-02-04 19:18:14 +02:00
|
|
|
local i wlist
|
2010-02-04 16:31:51 +02:00
|
|
|
for i in ${!COMPREPLY[*]}; do
|
|
|
|
local q=`printf %q "${COMPREPLY[$i]}"`
|
|
|
|
wlist+=$(quote "$q")$'\n'
|
|
|
|
done
|
|
|
|
|
|
|
|
# We also have to add another round of escaping to $cur.
|
|
|
|
local ecur="$cur"
|
|
|
|
ecur="${ecur//\\/\\\\}"
|
|
|
|
ecur="${ecur/#$\'/\$\'}"
|
|
|
|
|
|
|
|
# Actually generate completions.
|
|
|
|
IFS=$'\n' eval 'COMPREPLY=(`compgen -W "$wlist" -- "${ecur}"`)'
|
|
|
|
|
|
|
|
# Strip starting $' in reply if present in cur.
|
|
|
|
# This is necesarry because readline interprets everything after ' as a
|
|
|
|
# separate word for completion.
|
2010-02-04 16:47:44 +02:00
|
|
|
if [[ $cur == $\'* ]]; then #'
|
2010-02-04 16:31:51 +02:00
|
|
|
COMPREPLY=( "${COMPREPLY[@]/#$\'}" )
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2010-02-04 16:47:44 +02:00
|
|
|
# Complete linux fstab entries.
|
|
|
|
#
|
|
|
|
# Reads a file from stdin in the linux fstab(5) format; as used by /etc/fstab
|
|
|
|
# and /proc/mounts.
|
|
|
|
_linux_fstab()
|
|
|
|
{
|
|
|
|
COMPREPLY=()
|
|
|
|
|
|
|
|
# Read and unescape values into COMPREPLY
|
|
|
|
while read -r fs_spec fs_file fs_other; do
|
|
|
|
if [[ $fs_spec = [#]* ]]; then continue; fi
|
|
|
|
[[ $fs_spec = */* ]] && { IFS=$'\0' eval "COMPREPLY+=( $'$fs_spec' )"; }
|
|
|
|
[[ $fs_file = */* ]] && { IFS=$'\0' eval "COMPREPLY+=( $'$fs_file' )"; }
|
|
|
|
done
|
|
|
|
|
|
|
|
_reply_compgen_array
|
|
|
|
}
|
|
|
|
|
2010-01-02 10:35:18 +02:00
|
|
|
_mount()
|
|
|
|
{
|
2010-01-24 19:43:16 +02:00
|
|
|
local cur sm host prev
|
2010-01-02 10:35:18 +02:00
|
|
|
|
|
|
|
COMPREPLY=()
|
2010-01-24 19:25:16 +02:00
|
|
|
cur=`_get_cword ':'`
|
|
|
|
prev=`_get_pword ':'`
|
2010-01-02 10:35:18 +02:00
|
|
|
[[ "$cur" == \\ ]] && cur="/"
|
|
|
|
|
2010-01-24 19:43:16 +02:00
|
|
|
if [[ "$cur" == *:* ]]; then
|
|
|
|
for sm in $(type -P showmount) {,/usr}/{,s}bin/showmount; do
|
2010-01-26 23:17:48 +02:00
|
|
|
[ -x "$sm" ] || continue
|
|
|
|
COMPREPLY=( $( compgen -W "$( "$sm" -e ${cur%%:*} | \
|
2010-01-24 19:43:16 +02:00
|
|
|
awk 'NR>1 {print $1}' )" -- "${cur#*:}" ) )
|
|
|
|
return 0
|
|
|
|
done
|
|
|
|
fi
|
2010-01-02 10:35:18 +02:00
|
|
|
|
2010-01-24 19:43:16 +02:00
|
|
|
if [[ "$cur" == //* ]]; then
|
2010-01-02 10:35:18 +02:00
|
|
|
host=${cur#//}
|
|
|
|
host=${host%%/*}
|
|
|
|
if [ -n "$host" ]; then
|
|
|
|
COMPREPLY=( $( compgen -P "//$host" -W \
|
|
|
|
"$( smbclient -d 0 -NL $host 2>/dev/null |
|
|
|
|
sed -ne '/^['"$'\t '"']*Sharename/,/^$/p' |
|
|
|
|
sed -ne '3,$s|^[^A-Za-z]*\([^'"$'\t '"']*\).*$|/\1|p' )" \
|
|
|
|
-- "${cur#//$host}" ) )
|
|
|
|
fi
|
|
|
|
elif [ -r /etc/vfstab ]; then
|
|
|
|
# Solaris
|
|
|
|
COMPREPLY=( $( compgen -W "$( awk '! /^[ \t]*#/ {if ($3 ~ /\//) print $3}' /etc/vfstab )" -- "$cur" ) )
|
|
|
|
elif [ ! -e /etc/fstab ]; then
|
|
|
|
# probably Cygwin
|
|
|
|
COMPREPLY=( $( compgen -W "$( mount | awk '! /^[ \t]*#/ {if ($3 ~ /\//) print $3}' )" -- "$cur" ) )
|
|
|
|
else
|
|
|
|
# probably Linux
|
|
|
|
if [ $prev = -L ]; then
|
|
|
|
COMPREPLY=( $( compgen -W '$(sed -ne "s/^[[:space:]]*LABEL=\([^[:space:]]*\).*/\1/p" /etc/fstab )' -- "$cur" ) )
|
|
|
|
elif [ $prev = -U ]; then
|
|
|
|
COMPREPLY=( $( compgen -W '$(sed -ne "s/^[[:space:]]*UUID=\([^[:space:]]*\).*/\1/p" /etc/fstab )' -- "$cur" ) )
|
|
|
|
else
|
2010-02-04 16:47:44 +02:00
|
|
|
_linux_fstab < /etc/fstab
|
2010-01-02 10:35:18 +02:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
} &&
|
|
|
|
complete -F _mount -o default -o dirnames mount
|
|
|
|
|
|
|
|
# umount(8) completion. This relies on the mount point being the third
|
|
|
|
# space-delimited field in the output of mount(8)
|
|
|
|
#
|
|
|
|
have umount &&
|
|
|
|
_umount()
|
|
|
|
{
|
|
|
|
local cur IFS=$'\n'
|
|
|
|
|
|
|
|
COMPREPLY=()
|
|
|
|
cur=`_get_cword`
|
|
|
|
|
|
|
|
COMPREPLY=( $( compgen -W '$( mount | cut -d" " -f 3 )' -- "$cur" ) )
|
|
|
|
|
|
|
|
return 0
|
|
|
|
} &&
|
|
|
|
complete -F _umount -o dirnames umount
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
# Local variables:
|
|
|
|
# mode: shell-script
|
|
|
|
# sh-basic-offset: 4
|
|
|
|
# sh-indent-comment: t
|
|
|
|
# indent-tabs-mode: nil
|
|
|
|
# End:
|
|
|
|
# ex: ts=4 sw=4 et filetype=sh
|