From bcd8637b318f71d83fdbc4d008e1174f45d9c317 Mon Sep 17 00:00:00 2001 From: Benex254 Date: Tue, 16 Jul 2024 21:32:22 +0300 Subject: [PATCH] feat(cli): add script to generate shell completions --- completions/fastanime.bash | 29 +++++++++++++++++++++++++++ completions/fastanime.fish | 18 +++++++++++++++++ completions/fastanime.zsh | 41 ++++++++++++++++++++++++++++++++++++++ generate_completions.sh | 14 +++++++++++++ 4 files changed, 102 insertions(+) create mode 100644 completions/fastanime.bash create mode 100644 completions/fastanime.fish create mode 100644 completions/fastanime.zsh create mode 100755 generate_completions.sh diff --git a/completions/fastanime.bash b/completions/fastanime.bash new file mode 100644 index 0000000..8e1929f --- /dev/null +++ b/completions/fastanime.bash @@ -0,0 +1,29 @@ +_fastanime_completion() { + local IFS=$'\n' + local response + + response=$(env COMP_WORDS="${COMP_WORDS[*]}" COMP_CWORD=$COMP_CWORD _FASTANIME_COMPLETE=bash_complete $1) + + for completion in $response; do + IFS=',' read type value <<< "$completion" + + if [[ $type == 'dir' ]]; then + COMPREPLY=() + compopt -o dirnames + elif [[ $type == 'file' ]]; then + COMPREPLY=() + compopt -o default + elif [[ $type == 'plain' ]]; then + COMPREPLY+=($value) + fi + done + + return 0 +} + +_fastanime_completion_setup() { + complete -o nosort -F _fastanime_completion fastanime +} + +_fastanime_completion_setup; + diff --git a/completions/fastanime.fish b/completions/fastanime.fish new file mode 100644 index 0000000..6139239 --- /dev/null +++ b/completions/fastanime.fish @@ -0,0 +1,18 @@ +function _fastanime_completion; + set -l response (env _FASTANIME_COMPLETE=fish_complete COMP_WORDS=(commandline -cp) COMP_CWORD=(commandline -t) fastanime); + + for completion in $response; + set -l metadata (string split "," $completion); + + if test $metadata[1] = "dir"; + __fish_complete_directories $metadata[2]; + else if test $metadata[1] = "file"; + __fish_complete_path $metadata[2]; + else if test $metadata[1] = "plain"; + echo $metadata[2]; + end; + end; +end; + +complete --no-files --command fastanime --arguments "(_fastanime_completion)"; + diff --git a/completions/fastanime.zsh b/completions/fastanime.zsh new file mode 100644 index 0000000..5fdc101 --- /dev/null +++ b/completions/fastanime.zsh @@ -0,0 +1,41 @@ +#compdef fastanime + +_fastanime_completion() { + local -a completions + local -a completions_with_descriptions + local -a response + (( ! $+commands[fastanime] )) && return 1 + + response=("${(@f)$(env COMP_WORDS="${words[*]}" COMP_CWORD=$((CURRENT-1)) _FASTANIME_COMPLETE=zsh_complete fastanime)}") + + for type key descr in ${response}; do + if [[ "$type" == "plain" ]]; then + if [[ "$descr" == "_" ]]; then + completions+=("$key") + else + completions_with_descriptions+=("$key":"$descr") + fi + elif [[ "$type" == "dir" ]]; then + _path_files -/ + elif [[ "$type" == "file" ]]; then + _path_files -f + fi + done + + if [ -n "$completions_with_descriptions" ]; then + _describe -V unsorted completions_with_descriptions -U + fi + + if [ -n "$completions" ]; then + compadd -U -V unsorted -a completions + fi +} + +if [[ $zsh_eval_context[-1] == loadautofunc ]]; then + # autoload from fpath, call function directly + _fastanime_completion "$@" +else + # eval/source/. command, register function for later + compdef _fastanime_completion fastanime +fi + diff --git a/generate_completions.sh b/generate_completions.sh new file mode 100755 index 0000000..bdcb94a --- /dev/null +++ b/generate_completions.sh @@ -0,0 +1,14 @@ +#!/usr/bin/env bash +APP_DIR="$( + cd -- "$(dirname "$0")" >/dev/null 2>&1 + pwd -P +)" + +# fish shell completions +_FASTANIME_COMPLETE=fish_source fastanime >"$APP_DIR/completions/fastanime.fish" + +# zsh completions +_FASTANIME_COMPLETE=zsh_source fastanime >"$APP_DIR/completions/fastanime.zsh" + +# bash completions +_FASTANIME_COMPLETE=bash_source fastanime >"$APP_DIR/completions/fastanime.bash"