Клавиша удаления не работает в командной строке

10

** Примечание: я задавал этот же вопрос в SuperUser, но не получил никакого ответа. Теперь я понимаю, что это более подходящий форум для этого конкретного вопроса. *

В оболочке ksh клавиша Delete не работает должным образом в командной строке. Я получаю ~ когда я нажимаю Удалить.

Как я:

  1. привязать функциональность «Удалить символ у курсора» к кнопке «Удалить клавиатуру»? (Control-D ведет себя так, как будто я ожидаю, что кнопка удаления будет работать, и мои попытки использовать псевдоним были неудачными и, вероятно, наивными.)
  2. привязать функциональность « Перейти к первой строке» к кнопке «Домашняя клавиатура»? (Control A делает это сейчас, но я хочу, чтобы Home сделал это.)
  3. привязать функциональность « Перейти к концу строки » к кнопке «Завершить»? (Control E делает это сейчас, но я хочу, чтобы конец это сделал.)

Окончательное (?) Обновление

Я наткнулся на то, что работает, но я не совсем понимаю, почему. Это работает:

bind '^[[3'=prefix-2
bind '^[[3~'=delete-char-forward

Согласно http://www.qnx.com/developers/docs/6.3.2/neutrino/utilities/k/ksh.html#bind ,

prefix-2
Key binding: ^X, ^[[
Introduces a 2-character command sequence.

Итак, мой обновленный вопрос: зачем мне это использовать prefix-2? Пожалуйста, переведите для меня, чтобы я мог понять, чтобы мне больше не приходилось обижать всех по этому поводу.

СТАРЫЙ ПЕРСОНАЛ СЛЕДУЕТ

ОБНОВИТЬ

Оказывается, ESC в QNX есть ^[. Используя команду, bind '^[[3~'='delete-char-backward'я могу заставить курсор перезаписывать символ под курсором с помощью ~. По крайней мере, это некоторый прогресс - теперь я знаю, как пишется Delete Key для оболочки. Большинство вещей, которые я видел в Интернете, говорят, что ключ удаления есть ^?, но это, похоже, не работает для меня. Кроме того, я должен отметить, что я получаю доступ к этому через PuTTy.

Я не понимаю, потому что Control D делает то, что я хочу, чтобы ключ удаления делал. Я попытался связать это eot-or-deleteснова безрезультатно.

Это должно быть просто, верно?

ОБНОВЛЕНИЕ 2:

 bind | grep prefix
^X = prefix-2
^[ = prefix-1
ÿ = prefix-3
^[O = prefix-2
^[[ = prefix-2


bind | grep '[^ -~]'
ÿ = prefix-3
à  = beginning-of-line
à¡ = up-history
ठ= backward-char
ঠ= forward-char
ਠ= end-of-line
à© = down-history
ଠ= delete-char-forward
à´ = backward-word
ච= forward-word

ОБНОВЛЕНИЕ 3: Больше моих настроек

Настройка ENV

 echo $ENV
/etc/kshrc

BIND Полный вывод

bind
^A = beginning-of-line
^B = backward-char
^C = abort
^D = eot-or-delete
^E = end-of-line
^F = forward-char
^G = abort
^H = delete-char-backward
^I = complete
^J = newline
^K = kill-to-eol
^L = redraw
^M = newline
^N = down-history
^O = newline-and-next
^P = up-history
^R = search-history
^T = transpose-chars
^U = kill-line
^V = version
^W = kill-region
^X = prefix-2
^Y = yank
^[ = prefix-1
^\ = no-op
^] = search-character-forward
^^ = quote
^_ = eot
^? = delete-char-backward
ÿ = prefix-3
^[^H = delete-word-backward
^[^X = complete-file
^[^[ = complete
^[^] = search-character-backward
^[  = set-mark-command
^[# = comment
^[* = expand-file
^[. = prev-hist-word
^[0 = set-arg
^[1 = set-arg
^[2 = set-arg
^[3 = set-arg
^[4 = set-arg
^[5 = set-arg
^[6 = set-arg
^[7 = set-arg
^[8 = set-arg
^[9 = set-arg
^[< = beginning-of-history
^[= = complete-list
^[> = end-of-history
^[? = list
^[C = capitalize-word
^[L = downcase-word
^[O = prefix-2
^[U = upcase-word
^[[ = prefix-2
^[_ = prev-hist-word
^[b = backward-word
^[c = capitalize-word
^[d = delete-word-forward
^[f = forward-word
^[g = goto-history
^[h = delete-word-backward
^[l = downcase-word
^[u = upcase-word
^[y = yank-pop
^[^? = delete-word-backward
^X^X = exchange-point-and-mark
^X^Y = list-file
^X^[ = complete-command
^X? = list-command
^XA = up-history
^XB = down-history
^XC = forward-char
^XD = backward-char
^XH = beginning-of-line
^XP = delete-char-forward
^XY = end-of-line
^Xc = forward-word
^Xd = backward-word
^Xw = end-of-line
à  = beginning-of-line
à¡ = up-history
ठ= backward-char
ঠ= forward-char
ਠ= end-of-line
à© = down-history
ଠ= delete-char-forward
à´ = backward-word
ච= forward-word

/ И т.д. / kshrc

/etc # cat kshrc
case $- in
*i*)
    export SHELL_COLOR_BLUE="print -n \\033[0;34m"
    export SHELL_COLOR_GREEN="print -n \\033[0;32m"
    export SHELL_COLOR_RED="print -n \\033[0;31m"
    export SHELL_COLOR_LIGHTGRAY="print -n \\033[0;37m"
    export SHELL_COLOR_YELLOW="print -n \\033[1;33m"

    export COLOR_BLACK="\\033[0;30m"
    export COLOR_BLUE="\\033[0;34m"
    export COLOR_GREEN="\\033[0;32m"
    export COLOR_CYAN="\\033[0;36m"
    export COLOR_RED="\\033[0;31m"
    export COLOR_PURPLE="\\033[0;35m"
    export COLOR_BROWN="\\033[0;33m"
    export COLOR_LIGHTGRAY="\\033[0;37m"
    export COLOR_DARKGRAY="\\033[1;30m"
    export COLOR_LIGHTBLUE="\\033[1;34m"
    export COLOR_LIGHTGREEN="\\033[1;32m"
    export COLOR_LIGHTCYAN="\\033[1;36m"
    export COLOR_LIGHTRED="\\033[1;31m"
    export COLOR_LIGHTPURPLE="\\033[1;35m"
    export COLOR_YELLOW="\\033[1;33m"
    export COLOR_WHITE="\\033[1;37m"

    if [[ `id -u` -eq 0 ]]; then
        export PS1=`$SHELL_COLOR_RED`'$(hostname -s):'`$SHELL_COLOR_YELLOW`'$(pwd) # '`$SHELL_COLOR_LIGHTGRAY`
    else
        export PS1=`$SHELL_COLOR_BLUE`'$(hostname -s):'`$SHELL_COLOR_GREEN`'$(pwd) $ '`$SHELL_COLOR_LIGHTGRAY`
    fi

esac

Настройки PuTTy:

введите описание изображения здесь

Примечания, которые могут иметь или не иметь значения, но могут служить основой:

Оболочка "PD KSH v5.2.14 99/07 / 13.2". Да, у меня нет возможности обновить ... это встроенная система. «Получить современную оболочку» не является жизнеспособным ответом. Операционная система QNX Neutrino 6.4.1.

bind показывает следующее:

 bind | grep del
^D = eot-or-delete
^H = delete-char-backward
^? = delete-char-backward
^[^H = delete-word-backward
^[d = delete-word-forward
^[h = delete-word-backward
^[^? = delete-word-backward
^XP = delete-char-forward
ଠ= delete-char-forward

infocmp показывает следующее:

infocmp  #      Reconstructed via infocmp from file:
/usr/lib/terminfo/x/xterm xterm|vs100|xterm terminal emulator,
        am, km, mir, msgr, xenl, xon,
        cols#80, it#8, lines#65, vt@,
        acsc=Oa``aaffggjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
        bel=^G, blink=@, bold=\E[1m, clear=\E[H\E[2J, cr=^M,
        csr=\E[%i%p1%d;%p2%dr, cub=\E[%p1%dD, cub1=^H,
        cud=\E[%p1%dB, cud1=\E[B, cuf=\E[%p1%dC, cuf1=\E[C,
        cup=\E[%i%p1%d;%p2%dH, cuu=\E[%p1%dA, cuu1=\E[A,
        dch=\E[%p1%dP, dch1=\E[P, dl=\E[%p1%dM, dl1=\E[M, ed=\E[J,
        el=\E[K, el1=\E[1K$<3>, enacs=\E(B\E)0, home=\E[H, ht=^I,
        hts=\EH, ich=\E[%p1%d@, ich1=\E[2~, il=\E[%p1%dL, il1=\E[L,
        ind=^J, is1=\E=\E[?1l, kBEG=\ENn, kCPY=\ENs, kCRT=\ENt,
        kDL=\ENv, kEXT=\ENw, kFND=\ENx, kHLP=\ENy, kOPT=\ENz,
        ka3=\EOs, kb2=\EOr, kbs=^H, kc1=\EOq, kcan=\EOm, kclo=\ENc,
        kclr=\ENa, kcmd=\EOu, kcub1=\E[D, kcud1=\E[B, kcuf1=\E[C,
        kcuu1=\E[A, kdch1=\E[P, kend=\E[9, kf1=\E[11~, kf10=\E[21~,
        kf11=\E[23~, kf12=\E[24~, kf2=\E[12~, kf3=\E[13~,
        kf4=\E[14~, kf5=\E[15~, kf6=\E[17~, kf7=\E[18~, kf8=\E[19~,
        kf9=\E[20~, kfnd=\ENf, khlp=\ENh, khome=\E[8, khts=\ENb,
        kich1=\E[2~, kmov=\ENi, kmrk=\ENm, kmsg=\ENe, knp=\E[6~,
        kopn=\ENo, kopt=\ENk, kpp=\E[5~, kref=\ENl, kres=\ENp,
        krfr=\ENg, krpl=\ENr, krst=\ENj, ksav=\ENq, kslt=\EOM,
        ktbc=\ENd, kund=\ENu, rc=\E8, rev=\E[7m, ri=\EM, rmacs=^O,
        rmam=\E[?7l, rmkx=\E>, rmso=\E[m,
        rs1=\E>\E[1;3;4;5;6l\E[?7h\E[m\E[r\E[2J\E[H, rs2=@,
        sc=\E7,
        setb=\E[4%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
        setf=\E[3%?%p1%{1}%=%t4%e%p1%{3}%=%t6%e%p1%{4}%=%t1%e%p1%{6}%=%t3%e%p1%d%;m,
        sgr=\E[0%?%p1%p6%|%t;1%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;m,
        sgr0=\E[m, smacs=^N, smam=\E[?7h, smkx=\E=, smso=\E[7m,
        tbc=\E[3g,

stty показывает следующее:

stty Name:  /dev/ttyp0 Type:  pseudo Opens: 2
+edit +echok +echonl
+osflow  intr=^C  quit=^\ erase=^?  kill=^U   eof=^D start=^Q  stop=^S  susp=^Z lnext=^V   min=01  time=00   pr1=^[   pr2=5B  left=44 right=43
up=41  down=42   ins=40   del=50  home=48   end=59
kmort
источник
Помогает ли unix.stackexchange.com/questions/23041/… или unix.stackexchange.com/questions/42753/… ?
Жиль "ТАК - перестань быть злым"
Я на самом деле уже видел обе эти ссылки, и я пытался изменить kshrcбезрезультатно. У sh: /etc/kshrc[21]: trap: bad signal KEYBDменя нет другого варианта оболочки, к сожалению. Я не знаю, если это проблема с PDKSH или с QNX или с обоими. Я знаю, какие комбинации клавиш будут вызывать то, что я хочу. Мне просто нужно знать синтаксис, чтобы сопоставить их с соответствующими ключами.
kmort
Ключ Delete работает для меня с Pdksh (та же версия, которая не поддерживалась с прошлого века) в Linux. Что bind | grep prefixпоказывает для вас? А bind | grep '[^ -~]'?
Жиль "ТАК - перестань быть злым"
@ Жиль Я обновил результаты ваших команд связывания. Это могут быть мои настройки PuTTy? Я ценю вашу помощь. :-)
kmort
AFAIK bind '^[[3~'='delete-char-forward'должен был работать. Я не понимаю, откуда берутся эти не-ASCII символы (это не последовательности ESC + foo с установленным 8-м битом, ни их путаница в latin1 / utf8). Работает ли `bind '^ X3 ~ = delete-char-forward'?
Жиль "ТАК - перестань быть злым"

Ответы:

6

Для гуглеров:

Уф. Для чего-то, что должно быть так просто, это было трудно.

Короткое решение , это использовать следующие параметры для удаления ключа (в kshrcили где),

bind '^[[3'=prefix-2
bind '^[[3~'=delete-char-forward

И установите настройки терминала PuTTy rxvtвместо Standard.

Настройки PuTTy

Вот что действительно помогло мне получить эту работу: http://www.mail-archive.com/misc@openbsd.org/msg81796.html

ksh делает глупости с ключами home и end. По сути, я не мог определить разницу между Home, End и Delete одновременно. Что бы ни связывалось в последний раз, подойдут все три ключа. Изменение того, что PuTTy отправил для этих ключей, очень помогло.

Примечание: некоторые люди предлагают, если вы хотите увидеть, какой код получает оболочка, когда вы нажимаете клавишу, печатаете cat, нажимаете ввод, а затем нажимаете клавишу. Для моей оболочки это не сработало. Я получил ~за все ключи управления. Вместо этого я нажал Escодин раз, затем нажал клавишу. Контрольный код будет показан, а затем появится. Используйте этот контрольный код, bindи все готово.

kmort
источник
Я могу подтвердить, что это работает и в Conemu + Cygwin.
Янак Мина
2

[Хотя у нас несколько иная настройка, я надеюсь, что кому-то может пригодиться следующее, так как я думаю, что применяются одни и те же общие принципы. Это оказалось хорошим опытом для меня о том, как Linux обрабатывает базовые операции ввода-вывода.]

Если оболочка работает внутри окна терминала gnome , то под Preferences| Profilesвыберите профиль, а затем выберите , Editа затем Compatibilityвкладку, и изменил Delete key generatesк Automatic. (Или, если это не удастся, попробуйте другие варианты там.)

[Я на Debian Stretch.]


Я не знаю как, или даже когда именно мой Del сломался, но он начал удалять влево, а не вправо!

Эта статья очень помогла мне понять, как все работает.


Я использовал предложенные стратегии отладки в связанной статье выше:

Введите ^v Delи ^v Backspace, [control-v затем удалите ключ ...], чтобы найти возвращенные коды последовательности клемм.

А использование showkey -s, showkey -k, showkey -aа затем Delи Backspaceключи , чтобы осмотреть три слоя (сырье с клавиатуры, в качестве выходного сигнала от драйвера терминала, а также символьной строка заданной на клемму).

Из этого я заметил, что при использовании stty (например, stty1) мое поведение оболочки отличалось от использования xterm (из терминала Graphical X). Дель удалил правильно вперед (справа) в stty1, но назад (слева) в моем xterm.

Эллиптический вид
источник
Статья мертвая ссылка
Молоко
1

Существующие два ответа не сработали, переходя от Linux (Ubuntu 18.10) bash, через SSH к Solaris 11.3 bash, используя терминал gnome.

Я обнаружил, что мне нужно использовать bindкоманду, но с обходным приемом, так как я не мог заставить натив Deleteработать.

Таким образом, обходной путь заключается в том, что при Deleteнажатии имитировать удаление путем сопоставления нажатия клавиши удаления с и Backspace.

bind '"^[[3~":"^[[C^?"'

Чтобы ввести это, используйте нажатия клавиш:

CTRL-vDeleteдля первой части
и CTRL-vCTRL-vBackspaceдля второй.
(или использовать \eдля побега вместо того, чтобы , например "\e[3~")

Это не идеально, если вы Deleteв конце строки, это все еще забой. Но это избавляет меня от необходимости забрасывать ~персонажа множество раз в день.

Кингсли
источник