configuration: --write-ddl, --write-dml, --write-column-names, --insert-mode, --type-cast
# Relational pipes
# Copyright © 2022 František Kučera (Frantovo.cz, GlobalCode.info)
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, version 3 of the License.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
_relpipe_out_sql_completion() {
local w0 w1 w2 w3
COMPREPLY=()
w0=${COMP_WORDS[COMP_CWORD]}
w1=${COMP_WORDS[COMP_CWORD-1]}
w2=${COMP_WORDS[COMP_CWORD-2]}
w3=${COMP_WORDS[COMP_CWORD-3]}
BOOLEAN_VALUES=(
"true"
"false"
)
INSERT_MODES=(
"single"
"multi"
)
RELPIPE_TYPES=(
"boolean"
"integer"
"string"
)
SQL_TYPES=(
"text"
"integer"
"bigint"
"numeric"
"varchar(20)"
"bit"
"date"
"time"
"timestamp"
)
if [[ "$w1" == "--relation" && "x$w0" == "x" ]]; then COMPREPLY=("'.*'")
elif [[ "$w1" == "--write-ddl" ]]; then COMPREPLY=($(compgen -W "${BOOLEAN_VALUES[*]}" -- "$w0"))
elif [[ "$w1" == "--write-dml" ]]; then COMPREPLY=($(compgen -W "${BOOLEAN_VALUES[*]}" -- "$w0"))
elif [[ "$w1" == "--write-column-names" ]]; then COMPREPLY=($(compgen -W "${BOOLEAN_VALUES[*]}" -- "$w0"))
elif [[ "$w1" == "--insert-mode" ]]; then COMPREPLY=($(compgen -W "${INSERT_MODES[*]}" -- "$w0"))
elif [[ "$w1" == "--type-cast" && "x$w0" == "x" ]]; then COMPREPLY=("'.*'")
elif [[ "$w2" == "--type-cast" ]]; then COMPREPLY=($(compgen -W "${RELPIPE_TYPES[*]}" -- "$w0"))
elif [[ "$w3" == "--type-cast" ]]; then COMPREPLY=($(compgen -W "${SQL_TYPES[*]}" -- "$w0"))
else
OPTIONS=(
"--relation"
"--write-ddl"
"--write-dml"
"--write-column-names"
"--insert-mode"
"--type-cast"
)
COMPREPLY=($(compgen -W "${OPTIONS[*]}" -- "$w0"))
fi
}
complete -F _relpipe_out_sql_completion relpipe-out-sql