Зависимое завершение Zsh с пробелом в аргументах

Я пытаюсь реализовать завершение функции, где завершение второго аргумента зависит от первого.

function test_so() {
  echo "$1" "$2"
}
function _test_so() {
  local state

  _arguments '1: :->arg1' '2: :->arg2'

  case $state in
    arg1) compadd foo 'bar baz' ;;
    arg2)
      echo " - first arg: ${words[2]} - "
      if [[ ${words[2]} == 'bar baz' ]]; then
        compadd bar-1 bar-2
      else
        compadd foo-1 foo-2
      fi
    ;;
  esac
}
compdef _test_so test_so

Однако кажется, что он передает литералы \ и 's в ${words[2]} для аргумента с пробелами:

$ test_so foo <tab> ... - first arg: foo -
foo-1
foo-2

$ test_so bar\ baz <tab> ... - first arg: bar\ baz - # <- Should be - first arg: bar baz -
foo-1
foo-2
# These should be bar-1 & bar-2

# Same thing for quotes
$ test_so 'bar baz' <tab> ... - first arg: 'bar baz' -
foo-1
foo-2

person Halil Özgür    schedule 17.11.2020    source источник


Ответы (1)


Вы можете избавиться от \, раскатив слово с помощью Q флаг расширения параметра:

${(Q)words[2]}

Теперь и bar\ baz, и 'bar baz' в командной строке приведут к одной и той же строке в вашем коде: bar baz.

person Marlon Richert    schedule 28.11.2020