2011-06-11 22:29:26 +02:00
|
|
|
# mysql(1) completion
|
|
|
|
|
|
|
|
have mysql || return
|
|
|
|
|
|
|
|
_mysql()
|
|
|
|
{
|
2011-06-13 14:34:25 +02:00
|
|
|
local cur prev words cword split
|
|
|
|
_init_completion -s || return
|
2011-06-11 22:29:26 +02:00
|
|
|
|
|
|
|
case $prev in
|
|
|
|
-u|--user)
|
|
|
|
COMPREPLY=( $( compgen -u -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-D|--database)
|
2011-06-13 13:48:18 +02:00
|
|
|
COMPREPLY=( $( compgen -W "$(mysqlshow 2>/dev/null|sed -ne '2d' -e 's/^|.\([^|]*\)|.*/\1/p')" -- "$cur" ) )
|
2011-06-11 22:29:26 +02:00
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
|
|
|
|
-h|--host)
|
|
|
|
_known_hosts_real "$cur"
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
--default-character-set)
|
|
|
|
[ -d /usr/share/mysql/charsets ] && \
|
|
|
|
COMPREPLY=( $( compgen -W "$(command ls /usr/share/mysql/charsets|sed -e '/^\(README\|Index\.xml\)$/d' -e 's/.xml$//') utf8" -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
|
|
|
|
--character-sets-dir|--ssl-capath)
|
|
|
|
_filedir -d
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-S|--socket)
|
|
|
|
_filedir sock
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
--protocol)
|
|
|
|
COMPREPLY=( $( compgen -W 'tcp socket pipe memory' -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
--defaults-file|--defaults-extra-file|--tee)
|
|
|
|
_filedir
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
--default-character-set|-P|--port|--set-variable|\
|
|
|
|
--ssl-ca|--ssl-cert|--ssl-cipher|--ssl-key|\
|
2011-06-13 14:34:25 +02:00
|
|
|
--connect_timeout|--max_allowed_packet|--prompt|\
|
2011-06-11 22:29:26 +02:00
|
|
|
--net_buffer_length|--select_limit|--max_join_size|\
|
2011-06-18 15:34:20 +03:00
|
|
|
--server-arg|--debug|--delimiter|--execute|-e|--pager)
|
2011-06-11 22:29:26 +02:00
|
|
|
# Argument required but no completions available
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
'-?'|-I|--help|-V|--version)
|
|
|
|
# All other options are noop with these
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2011-06-13 14:34:25 +02:00
|
|
|
case $cur in
|
|
|
|
--*)
|
2011-06-18 15:44:43 +03:00
|
|
|
local help=$(_parse_help "$1")
|
2011-06-18 15:45:47 +03:00
|
|
|
help+=" --skip-comments --skip-ssl"
|
2011-06-11 22:29:26 +02:00
|
|
|
|
2011-06-13 14:34:25 +02:00
|
|
|
COMPREPLY=( $( compgen -W "$help" -- "$cur" ) )
|
|
|
|
[[ $COMPREPLY == *= ]] && compopt -o nospace
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
|
|
|
|
# only complete long options
|
|
|
|
-)
|
|
|
|
compopt -o nospace
|
|
|
|
COMPREPLY=( -- )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2011-06-18 15:27:15 +03:00
|
|
|
COMPREPLY=( $( compgen -W \
|
|
|
|
"$(mysqlshow 2>/dev/null|sed -ne '2d' -e 's/^|.\([^|]*\)|.*/\1/p')" \
|
2011-06-13 14:34:25 +02:00
|
|
|
-- "$cur" ) )
|
2011-06-11 22:29:26 +02:00
|
|
|
} &&
|
|
|
|
complete -F _mysql mysql
|
|
|
|
|
|
|
|
# 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
|