Вопрос по – Как сделать поведение zsh вперед-таким же, как в bash / emacs

12

zsh forward-word действует немного иначе, чем bash / emacs, и я бы хотел это изменить.

Вместо описания всех отличий, позвольте мне показать вам пошаговое поведение bash. Я пометил курсор как символ «^».

foo bar --non-needed-param --needed-param^

М-б

foo bar --non-needed-param --needed-^param

М-б

foo bar --non-needed-param --^needed-param

М-б

foo bar --non-needed-^param --needed-param

М-б

foo bar --non-^needed-param --needed-param

М-б

foo bar --^non-needed-param --needed-param

М-б

foo ^bar --non-needed-param --needed-param

M-F

foo bar^ --non-needed-param --needed-param

М-д

foo bar^-needed-param --needed-param

М-д

foo bar^-param --needed-param

М-д

foo bar^ --needed-param

Этот алгоритм является гибким для перемещения по словам, удаления их частей для меня. Также это в Emacs, так что я привык к этому. Я хотел бы видеть это в Zsh тоже. Благодарность

Ваш Ответ

1   ответ
15

У меня есть это в моем.zshrc именно для этой цели:

# Bash-like navigation
autoload -U select-word-style
select-word-style bash

Редактировать: Ах, я помню, чего не хватало, чтобы все работало так, как я хотел. Я тоже переписforward-word-match поместив следующий контент в$ZDOTDIR/functions/forward-word-match (при условии, что ваш$ZDOTDIR/functions каталог находится в$fpath; иначе поместите это в один или измените$fpath тоже массив):

emulate -L zsh
setopt extendedglob

autoload match-words-by-style

local curcontext=":zle:$WIDGET" word
local -a matched_words
integer count=${NUMERIC:-1}

if (( count < 0 )); then
    (( NUMERIC = -count ))
    zle ${WIDGET/forward/backward}
    return
fi

while (( count-- )); do

    match-words-by-style

    # For some reason forward-word doesn't work like the other word
    # commands; it skips whitespace only after any matched word
    # characters.

    if [[ -n $matched_words[4] ]]; then
        # just skip the whitespace and the following word
  word=$matched_words[4]$matched_words[5]
    else
        # skip the word but not the trailing whitespace
  word=$matched_words[5]
    fi

    if [[ -n $word ]]; then
  (( CURSOR += ${#word} ))
    else
  return 1
    fi
done

return 0
Если я не поставлюZDOTDIR (тогда по умолчанию это $ HOME) и я использую oh-my-zsh, тогда как я могу применить это решение? Forethinker
Hmm. Если я выберу bash в стиле select word и затем установлю WORDCHARS - WORDCHARS не имеет значения. Похоже, что bash в стиле select-word имеет некоторые другие параметры конфигурации. Kostiantyn Rybnikov
Благодарность! Но на самом деле он действует не так, как bash (я сделал что-то не так?). В этой ситуации: «fo ^ ooo --bar», если вы нажмете «Mf», он должен сразу перейти к концу foooo, например: «foooo ^ --bar», но я включил, как вы показали, он будет перейти к этому: "foooo - ^ bar". На самом деле похоже, что этот плагин просто экспортирует WORDCHARS = ''. Kostiantyn Rybnikov
Хорошо, вспомнил, что заставило его работать, и соответственно обновил мой ответ. Moritz Bunkus
Моя полная конфигурация zsh работает так, как вы хотите - поэтому я думаю, что я сделал что-то большее, чем я указал в своем ответе. Мои WORDCHARS содержат еще несколько символов, хотя я не могу понять, где они на самом деле установлены: ($ WORDCHARS is*?_-.[]~=/&;!#$%^(){}<>) Moritz Bunkus

Похожие вопросы