From 0508968fa77f37cb073786dec8111457f4d7ee7d Mon Sep 17 00:00:00 2001 From: Koichi Murase Date: Wed, 3 May 2023 15:00:01 +0900 Subject: [PATCH] fix!(_comp_{last_index,index_of}): return result through `ret` --- completions/ARRAY | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/completions/ARRAY b/completions/ARRAY index fb507d75768..9152da761f5 100644 --- a/completions/ARRAY +++ b/completions/ARRAY @@ -151,6 +151,7 @@ _comp_xfunc_ARRAY_filter() [[ ! $_unset ]] } +# @version bash-4.3 _comp_uniq() { local -n _comp_uniq__array=$1 @@ -163,36 +164,42 @@ _comp_uniq() done } +# Obtain the largest index +# @var[out] ret +# @version bash-4.3 _comp_last_index() { - local -n _comp_last_index__array=$1 _comp_last_index__ret=$2 + local -n _comp_last_index__array=$1 local -a _comp_last_index__indices=("${!_comp_last_index__array[@]}") - _comp_last_index__ret=${_comp_last_index__indices[*]: -1} + ret=${_comp_last_index__indices[*]: -1} } +# @version bash-4.3 _comp_compact() { local -n _comp_compact__array=$1 _comp_compact__array=("${_comp_compact__array[@]}") } +# Find the index of a matching element +# @var[out] ret +# @version bash-4.3 _comp_index_of() { # TODO getopts -> -r gets rightmost (last) index # TODO getopts: -R uses regex instead of glob local -n _comp_index_of__array=$1 local _comp_compact__pattern=$2 - local -n _comp_index_of__ret=$3 local -i _comp_index_of__i for _comp_index_of__i in "${!_comp_index_of__array[@]}"; do # shellcheck disable=SC2053 if [[ ${_comp_index_of__array[_comp_index_of__i]} == $_comp_compact__pattern ]]; then - _comp_index_of__ret=$_comp_index_of__i + ret=$_comp_index_of__i return 0 fi done - _comp_index_of__ret=-1 + ret=-1 return 1 }