Как я могу найти документацию / знания / наставничество / древние фолианты для определений терминалов? (получение настроек заголовка терминала vim для работы с tmux) - PullRequest
2 голосов
/ 09 ноября 2019

У меня поиск интернет для объяснения, но загадочная краткость t_ts и t_fs делает невозможным поиск полезной информации окак я могу ожидать, что системы будут работать.

Вот краткий обзор моих существующих знаний, и я был бы рад, если бы кто-то мудрый мог заполнить последние несколько точек ...

Я "начал" где-то здесь: http://tldp.org/HOWTO/Xterm-Title-3.html

Я подтвердил выполнение этого в моей оболочке bash (где ^[ создается Ctrl + V , Esc ):

printf "^[]0;testTITLEzzz"

Это работает. Он работает, чтобы установить заголовок на необработанном терминале, и он работает, чтобы установить заголовок для панели в tmux.

Примечание! Мне не нужно было использовать конечный "\007" символ.

Внутри моего .vimrc, когда я использую set title и установить titlestring, он всегда правильно устанавливает необработанный заголовок терминала, ноне удалось установить заголовок панели tmux.

Как только я установил это, хотя (то же самое с ^[, это необработанный символ ESC):

if &term == "tmux-256color-italic"
  set t_ts=^[]0;                
  set t_fs=                     
endif                             

Это начало работатьдля установки заголовка панели tmux. Я радовался.

Теперь у меня проблема в том, как превратить эти процедурные знания в практические знания, которые я смогу использовать в будущем.

Вопрос 1

Я посмотрел справку в vim, я получил это:

   t_ts    set window title start (to status line)         t_ts 't_ts'   
   t_fs    set window title end (from status line)         t_fs 't_fs'  

Я не знаю, что здесь означает "строка состояния".

Вопрос 2

Я хочу знать, как эти коды терминала-выхода, описанные в vim, соответствуют остальному миру xterm, или как я его назову.

Например, я могу запросить infocmp, чтобы получить мою текущую конфигурацию терминала и xterm значения конфигурации терминала:

$ infocmp xterm
#   Reconstructed via infocmp from file: /lib/terminfo/x/xterm
xterm|xterm-debian|X11 terminal emulator,
    am, bce, km, mc5i, mir, msgr, npc, xenl,
    colors#8, cols#80, it#8, lines#24, pairs#64,
    acsc=``aaffggiijjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
    bel=^G, blink=\E[5m, bold=\E[1m, cbt=\E[Z, civis=\E[?25l,
    clear=\E[H\E[2J, cnorm=\E[?12l\E[?25h, cr=\r,
    csr=\E[%i%p1%d;%p2%dr, cub=\E[%p1%dD, cub1=^H,
    cud=\E[%p1%dB, cud1=\n, cuf=\E[%p1%dC, cuf1=\E[C,
    cup=\E[%i%p1%d;%p2%dH, cuu=\E[%p1%dA, cuu1=\E[A,
    cvvis=\E[?12;25h, dch=\E[%p1%dP, dch1=\E[P, dim=\E[2m,
    dl=\E[%p1%dM, dl1=\E[M, ech=\E[%p1%dX, ed=\E[J, el=\E[K,
    el1=\E[1K, flash=\E[?5h$<100/>\E[?5l, home=\E[H,
    hpa=\E[%i%p1%dG, ht=^I, hts=\EH, ich=\E[%p1%d@,
    il=\E[%p1%dL, il1=\E[L, ind=\n, indn=\E[%p1%dS,
    invis=\E[8m, is2=\E[!p\E[?3;4l\E[4l\E>, kDC=\E[3;2~,
    kEND=\E[1;2F, kHOM=\E[1;2H, kIC=\E[2;2~, kLFT=\E[1;2D,
    kNXT=\E[6;2~, kPRV=\E[5;2~, kRIT=\E[1;2C, kb2=\EOE, kbs=^?,
    kcbt=\E[Z, kcub1=\EOD, kcud1=\EOB, kcuf1=\EOC, kcuu1=\EOA,
    kdch1=\E[3~, kend=\EOF, kent=\EOM, kf1=\EOP, kf10=\E[21~,
    kf11=\E[23~, kf12=\E[24~, kf13=\E[1;2P, kf14=\E[1;2Q,
    kf15=\E[1;2R, kf16=\E[1;2S, kf17=\E[15;2~, kf18=\E[17;2~,
    kf19=\E[18;2~, kf2=\EOQ, kf20=\E[19;2~, kf21=\E[20;2~,
    kf22=\E[21;2~, kf23=\E[23;2~, kf24=\E[24;2~,
    kf25=\E[1;5P, kf26=\E[1;5Q, kf27=\E[1;5R, kf28=\E[1;5S,
    kf29=\E[15;5~, kf3=\EOR, kf30=\E[17;5~, kf31=\E[18;5~,
    kf32=\E[19;5~, kf33=\E[20;5~, kf34=\E[21;5~,
    kf35=\E[23;5~, kf36=\E[24;5~, kf37=\E[1;6P, kf38=\E[1;6Q,
    kf39=\E[1;6R, kf4=\EOS, kf40=\E[1;6S, kf41=\E[15;6~,
    kf42=\E[17;6~, kf43=\E[18;6~, kf44=\E[19;6~,
    kf45=\E[20;6~, kf46=\E[21;6~, kf47=\E[23;6~,
    kf48=\E[24;6~, kf49=\E[1;3P, kf5=\E[15~, kf50=\E[1;3Q,
    kf51=\E[1;3R, kf52=\E[1;3S, kf53=\E[15;3~, kf54=\E[17;3~,
    kf55=\E[18;3~, kf56=\E[19;3~, kf57=\E[20;3~,
    kf58=\E[21;3~, kf59=\E[23;3~, kf6=\E[17~, kf60=\E[24;3~,
    kf61=\E[1;4P, kf62=\E[1;4Q, kf63=\E[1;4R, kf7=\E[18~,
    kf8=\E[19~, kf9=\E[20~, khome=\EOH, kich1=\E[2~,
    kind=\E[1;2B, kmous=\E[M, knp=\E[6~, kpp=\E[5~,
    kri=\E[1;2A, mc0=\E[i, mc4=\E[4i, mc5=\E[5i, meml=\El,
    memu=\Em, op=\E[39;49m, rc=\E8, rep=%p1%c\E[%p2%{1}%-%db,
    rev=\E[7m, ri=\EM, rin=\E[%p1%dT, ritm=\E[23m, rmacs=\E(B,
    rmam=\E[?7l, rmcup=\E[?1049l\E[23;0;0t, rmir=\E[4l,
    rmkx=\E[?1l\E>, rmm=\E[?1034l, rmso=\E[27m, rmul=\E[24m,
    rs1=\Ec, rs2=\E[!p\E[?3;4l\E[4l\E>, sc=\E7,
    setab=\E[4%p1%dm, setaf=\E[3%p1%dm,
    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=%?%p9%t\E(0%e\E(B%;\E[0%?%p6%t;1%;%?%p5%t;2%;%?%p2%t;4%;%?%p1%p3%|%t;7%;%?%p4%t;5%;%?%p7%t;8%;m,
    sgr0=\E(B\E[m, sitm=\E[3m, smacs=\E(0, smam=\E[?7h,
    smcup=\E[?1049h\E[22;0;0t, smir=\E[4h, smkx=\E[?1h\E=,
    smm=\E[?1034h, smso=\E[7m, smul=\E[4m, tbc=\E[3g,
    u6=\E[%i%d;%dR, u7=\E[6n, u8=\E[?%[;0123456789]c,
    u9=\E[c, vpa=\E[%i%p1%dd,
$ infocmp
#   Reconstructed via infocmp from file: /home/slu/.terminfo/t/tmux-256color-italic
tmux-256color-italic|screen with 256 colors and italic,
    am, km, mir, msgr, xenl,
    colors#0x100, cols#80, it#8, lines#24, pairs#0x7fff,
    acsc=++\,\,--..00``aaffgghhiijjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
    bel=^G, blink=\E[5m, bold=\E[1m, cbt=\E[Z, civis=\E[?25l,
    clear=\E[H\E[J, cnorm=\E[34h\E[?25h, cr=\r,
    csr=\E[%i%p1%d;%p2%dr, cub=\E[%p1%dD, cub1=^H,
    cud=\E[%p1%dB, cud1=\n, cuf=\E[%p1%dC, cuf1=\E[C,
    cup=\E[%i%p1%d;%p2%dH, cuu=\E[%p1%dA, cuu1=\EM,
    cvvis=\E[34l, dch=\E[%p1%dP, dch1=\E[P, dim=\E[2m,
    dl=\E[%p1%dM, dl1=\E[M, ed=\E[J, el=\E[K, el1=\E[1K,
    enacs=\E(B\E)0, flash=\Eg, home=\E[H, hpa=\E[%i%p1%dG,
    ht=^I, hts=\EH, ich=\E[%p1%d@, il=\E[%p1%dL, il1=\E[L,
    ind=\n, indn=\E[%p1%dS, is2=\E)0, kbs=^?, kcbt=\E[Z,
    kcub1=\EOD, kcud1=\EOB, kcuf1=\EOC, kcuu1=\EOA,
    kdch1=\E[3~, kend=\E[4~, kf1=\EOP, kf10=\E[21~,
    kf11=\E[23~, kf12=\E[24~, kf2=\EOQ, kf3=\EOR, kf4=\EOS,
    kf5=\E[15~, kf6=\E[17~, kf7=\E[18~, kf8=\E[19~, kf9=\E[20~,
    khome=\E[1~, kich1=\E[2~, kmous=\E[M, knp=\E[6~, kpp=\E[5~,
    nel=\EE, op=\E[39;49m, rc=\E8, rev=\E[7m, ri=\EM,
    ritm=\E[23m, rmacs=^O, rmcup=\E[?1049l, rmir=\E[4l,
    rmkx=\E[?1l\E>, rmso=\E[27m, rmul=\E[24m,
    rs2=\Ec\E[?1000l\E[?25h, sc=\E7,
    setab=\E[%?%p1%{8}%<%t4%p1%d%e%p1%{16}%<%t10%p1%{8}%-%d%e48;5;%p1%d%;m,
    setaf=\E[%?%p1%{8}%<%t3%p1%d%e%p1%{16}%<%t9%p1%{8}%-%d%e38;5;%p1%d%;m,
    sgr=\E[0%?%p6%t;1%;%?%p1%t;3%;%?%p2%t;4%;%?%p3%t;7%;%?%p4%t;5%;%?%p5%t;2%;m%?%p9%t\016%e\017%;,
    sgr0=\E[m\017, sitm=\E[3m, smacs=^N, smcup=\E[?1049h,
    smir=\E[4h, smkx=\E[?1h\E=, smso=\E[7m, smul=\E[4m,
    tbc=\E[3g, vpa=\E[%i%p1%dd,

Кажется, что ничего не совпадает с ts илиfs.

На данный момент я не думаю, что двухбуквенные коды отображаются вместе, что я подозревал годами.

Более того, поскольку я узнал, что испускание <Esc>]0;, за которым следует строка, работает для установки заголовка, в ходе моего тестирования я вижу, что это всегда работает независимо от возможностей терминала, указанных в $TERM. Это заставляет меня задаться вопросом, смотрю ли я на infocmp и задаюсь вопросом, относится ли что-то указанное здесь к моей способности контролировать заголовок.

Хотя, если честно, я едва понимаю, каково значение $TERM env var, кроме того, что такие программы, как vim и less жалуются, если у меня нет tic 'daфайл terminfo, соответствующий текущему значению $TERM. Опять же, процедурные знания, и я ищу что-то более глубокое и значимое.

Вопрос 3

Теперь, когда я нашел комбинацию конфигурации, которая позволяет заголовкам панелей tmux правильно настраиваться vim, мне интересно, что именно отправлял vim до моей настройкиt_ts, который работал на сырых терминалах, но не работал для tmux. Я знаю, что есть способ обмануть vim, заставив его думать, что я запускаю его в интерактивном режиме, пока все данные выводятся в двоичном файле, а затем приступаю к шестнадцатеричному написанию для разницы в кодах, но я забыл, как это делается, и подозреваючто есть менее болезненный способ выяснить.

Вопрос 4

Совершенно неясно, что я должен установить, если что-нибудь, для t_fs, и это касается также вопросапочему символ \007 BEL не нужен для завершения последовательности заголовков. Почему это не нужно, и что я должен ожидать, прервет последовательность? Новая строка?

1 Ответ

3 голосов
/ 09 ноября 2019

Вам определенно нужен трейлинг \ 007 (или \ 033 \\), иначе некоторые терминалы перестанут отвечать, ожидая конца последовательности. Ты пробовал это внутри tmux? У tmux есть тайм-аут для предотвращения зависания панелей, но большинство других терминалов этого не делают. Если вы попробуете его в xterm без \ 007, он будет зависать.

Для получения информации о самих последовательностях установки заголовка, посмотрите https://invisible -island.net / xterm / ctlseqs / ctlseqs.html (настройка заголовка: OSC 0 и 2 - см. «Команды операционной системы»).

ts и fs - это имена termcap (terminfo - tsl / fsl), что означает «в строку состояния» и «из состояния»line "(как видно из названия, infocmp показывает вам terminfo, а не termcap). Это несколько исторически сложилось в те времена, когда аппаратные терминалы имели отдельную строку состояния, но в последние годы иногда использовались для названия X-терминала. Посмотрите на раздел «Строки состояния» в terminfo (5), чтобы узнать о возможностях строки состояния. На практике tsl и fsl не часто предоставляются или используются, и вместо этого большинство приложений рассматривают возможность XT («заголовки xterm»), чтобы определить, следует ли им использовать последовательности OSC. XT - это расширение возможностей - вам нужно использовать "infocmp -x", чтобы увидеть его.

Вы всегда можете установить заголовок внутри tmux, используя последовательности OSC, по умолчанию заголовок (# # pane_title} формат)показано в кавычках в статусе справа. tmux также не будет устанавливать заголовок внешнего терминала (терминал, в котором запущен tmux), если не включена опция set-title. Параметр set-title-string управляет форматом наборов заголовков tmux (по умолчанию он включает заголовок активной панели и некоторую другую информацию). set-title будет работать только в том случае, если TERM за пределами tmux указывает запись, содержащую XT или tsl / fsl (xterm имеет XT).

Я не знаю, как настроить vim для установки заголовка, но похоже, чтовы находитесь на правильном пути с t_ts и t_fs - кажется, что vim использует tsl / fsl, но использует имена termcap (вероятно, наследие от vi, которое было запущено задолго до появления terminfo).

Я могукратко опишем, как это работает:

  • termcap изначально был написан в 70-х годах, чтобы позволить vi работать на разных (аппаратных) терминалах;

  • terminfo был написан в качестве замены в 80-х годах для исправления ряда проблем и ограничений с помощью termcap;

  • оба они по-прежнему используются (гораздо чаще термин для Termfo) как для программного, так и для аппаратного обеспечениятерминалы;

  • они оба работают одинаково - есть база данных именованных записей (например, "xterm" или "tmux-256color"), которые предоставляют набор именованных возможностей Терминал;некоторые возможности - это флаги (например, «XT») или числа (например, «цвета»), но большинство - это строки, которые задают последовательность, которую приложение должно отправить на терминал, чтобы что-то произошло (например, «cuu1» заставляет курсор двигаться на одну строку вверх -«\ 033 [A» на терминалах, совместимых с vt100);

  • termcap имеет самые короткие двухсимвольные имена, terminfo обычно длиннее;У termcap есть небольшое ограничение в 1024 байта на длину записи базы данных, поэтому он часто пропускает многие возможности, которые есть у terminfo;

  • TERM установлен на имя записи termcap или terminfoприложение должно искать в базе данных;

  • база данных terminfo поддерживается и поставляется как часть ncurses (библиотека для рисования на терминал, которая используется многими терминальными приложениями);база данных termcap генерируется из terminfo с использованием tic.

На самом деле нет единого источника со всей информацией, собранной вместе. Что касается escape-последовательностей, https://vt100.net/ имеет множество руководств для старых аппаратных терминалов (однако большая часть из них сейчас не имеет отношения) и ссылку, которую я дал выше для xterm, документирует escape-последовательности, поддерживаемые xterm и большинством других современных эмуляторов терминалов. поддерживает их подмножество (почти все терминалы, которые все еще существуют, совместимы с vt100, а xterm является стандартным терминалом де-факто)У ncurses есть несколько руководств: terminfo (5) и termcap (5). Существует книга О'Рейли под названием «termcap and terminfo», которая также охватывает многое, но она была написана в конце 80-х годов, поэтому некоторые из них устарели.

...