Пакет: readline-devel

Версия
8.2.13
Релиз
1.niceos5
Архитектура
x86_64
Хэш GOST
a6381f7369c8d9914dd4f76198acf0105bfdb3ee9382cea9a8dc80d1586dbdf5
Хэш MD5
69f5d4b8bba8b5ab2e948a8f84caf2b3
Хэш SHA256
d5c7c9f555086d6de5406a99160f27729c0dca94c45ba9dfb607e303e64d7abd
Лицензия
GPLv3+
Дата сборки
12 мая 2025 г.
Размер
1,061 ГиБ
Совместимые ОС
rpm файл:
readline-devel-8.2.13-1.niceos5.x86_64.rpm
Основной пакет

Этот подпакет входит в состав основного пакета: readline

Зависимости
Имя Тип Версия
pkgconfig(tinfo) runtime -
readline runtime -
Граф зависимостей
Файлы пакета
        • /usr/include/readline/chardefs.h 4,584 КиБ
        • /usr/include/readline/history.h 10,413 КиБ
        • /usr/include/readline/keymaps.h 3,126 КиБ
        • /usr/include/readline/readline.h 37,253 КиБ
        • /usr/include/readline/rlconf.h 2,763 КиБ
        • /usr/include/readline/rlstdc.h 1,792 КиБ
        • /usr/include/readline/rltypedefs.h 2,95 КиБ
        • /usr/include/readline/tilde.h 2,59 КиБ
      • /usr/lib/libhistory.a 67,379 КиБ
      • /usr/lib/libhistory.so 15 Б
      • /usr/lib/libreadline.a 655,428 КиБ
      • /usr/lib/libreadline.so 16 Б
        • /usr/lib/pkgconfig/history.pc 277 Б
        • /usr/lib/pkgconfig/readline.pc 291 Б
          • /usr/share/doc/readline-8.2.13/CHANGES 79,458 КиБ
          • /usr/share/doc/readline-8.2.13/INSTALL 13,044 КиБ
          • /usr/share/doc/readline-8.2.13/README 7,841 КиБ
        • /usr/share/info/history.info.gz 17,611 КиБ
        • /usr/share/info/readline.info.gz 59,712 КиБ
        • /usr/share/info/rluserman.info.gz 26,067 КиБ
          • /usr/share/man/man3/history.3.gz 7,599 КиБ
          • /usr/share/man/man3/readline.3.gz 15,438 КиБ
        • /usr/share/readline/excallback.c 5,721 КиБ
        • /usr/share/readline/fileman.c 11,38 КиБ
        • /usr/share/readline/hist_erasedups.c 2,669 КиБ
        • /usr/share/readline/hist_purgecmd.c 3,289 КиБ
        • /usr/share/readline/histexamp.c 2,864 КиБ
        • /usr/share/readline/manexamp.c 3,223 КиБ
        • /usr/share/readline/rl-callbacktest.c 2,492 КиБ
        • /usr/share/readline/rl-fgets.c 10,886 КиБ
        • /usr/share/readline/rl-timeout.c 5,973 КиБ
        • /usr/share/readline/rl.c 3,229 КиБ
        • /usr/share/readline/rlbasic.c 565 Б
        • /usr/share/readline/rlcat.c 3,328 КиБ
        • /usr/share/readline/rlevent.c 3,418 КиБ
        • /usr/share/readline/rlkeymaps.c 1,302 КиБ
        • /usr/share/readline/rlptytest.c 6,573 КиБ
        • /usr/share/readline/rltest.c 2,204 КиБ
        • /usr/share/readline/rlversion.c 1,261 КиБ
Документация (man-страницы)

READLINE(3)		   Руководство по библиотечным функциям		   READLINE(3)



NAME
       readline - получить строку от пользователя с редактированием

SYNOPSIS
       #include <stdio.h>
       #include <readline/readline.h>
       #include <readline/history.h>

       char *
       readline (const char *prompt);

COPYRIGHT
       Readline является объектом авторского права (C) 1989-2020 Free Software Foundation,  Inc.

DESCRIPTION
       readline читает строку из терминала и возвращает её, используя prompt
       в качестве подсказки. Если prompt равен NULL или пустой строке, подсказка
       не выводится. Возвращаемая строка выделяется с помощью malloc(3); вызывающая
       сторона должна освободить её после использования. В возвращаемой строке
       удаляется конечный символ новой строки, так что остаётся только текст строки.

       readline предоставляет возможности редактирования во время ввода строки.
       По умолчанию, команды редактирования строки похожи на те, что в
       emacs. Доступен также интерфейс редактирования в стиле vi.

       Эта страница руководства описывает только самый базовый способ использования readline. Доступно
       гораздо больше функциональности; см. The GNU Readline Library и The
       GNU History Library для дополнительной информации.

RETURN VALUE
       readline возвращает текст прочитанной строки. Пустая строка возвращается
       как пустая строка. Если EOF встречается при чтении строки и строка
       пуста, возвращается NULL. Если EOF прочитан с непустой строкой,
       он обрабатывается как символ новой строки.

NOTATION
       Используется нотация в стиле Emacs для обозначения клавиш. Клавиши Control обозначаются
       как C-key, например, C-n означает Control-N. Аналогично, клавиши meta обозначаются
       как M-key, так что M-x означает Meta-X. (На клавиатурах без клавиши meta
       M-x означает ESC x, т.е., нажмите клавишу Escape, затем клавишу x. Это
       делает ESC префиксом meta. Комбинация M-C-x означает ESC-Control-x,
       или нажмите клавишу Escape, затем удерживайте клавишу Control при нажатии клавиши x.)

       Команды readline могут принимать числовые аргументы, которые обычно действуют как
       счётчик повторений. Иногда, однако, значимым является знак аргумента. Передача отрицательного аргумента
       команде, которая действует в прямом направлении (например, kill-line), заставляет эту команду
       действовать в обратном направлении. Команды, поведение которых с аргументами
       отличается от этого, отмечаются ниже.

       Когда команда описывается как удаляющая текст, удалённый текст сохраняется
       для возможного будущего извлечения (yanking). Удалённый текст сохраняется в
       kill ring. Последовательные удаления приводят к накоплению текста в
       одну единицу, которую можно извлечь целиком. Команды, которые не удаляют текст,
       разделяют фрагменты текста в kill ring.

INITIALIZATION FILE
       Readline настраивается путём размещения команд в файле инициализации
       (файл inputrc). Имя этого файла берётся из значения
       переменной окружения INPUTRC. Если эта переменная не установлена, по умолчанию используется ~/.inputrc.
       Если этот файл не существует или не может быть прочитан,
       конечным значением по умолчанию является /etc/inputrc. Когда программа, использующая
       библиотеку readline, запускается, файл инициализации читается, и связывания клавиш
       и переменные устанавливаются. В файле инициализации readline разрешены
       только несколько базовых конструкций. Пустые строки игнорируются. Строки, начинающиеся
       с #, являются комментариями. Строки, начинающиеся с $, указывают условные
       конструкции. Другие строки обозначают связывания клавиш и установки переменных.
       Каждая программа, использующая эту библиотеку, может добавлять свои собственные команды и связывания.

       Например, размещение

	      M-Control-u: universal-argument
       или
	      C-Meta-u: universal-argument

       в inputrc заставит M-C-u выполнять команду readline universal-argument.

       При обработке связываний клавиш распознаются следующие символические имена символов: DEL, ESC, ESCAPE,
       LFD, NEWLINE, RET, RETURN, RUBOUT, SPACE, SPC и TAB.

       Кроме имён команд, readline позволяет связывать клавиши со
       строкой, которая вставляется при нажатии клавиши (макрос).

   Key Bindings
       Синтаксис для управления связываниями клавиш в файле inputrc прост.
       Требуется только имя команды или текст макроса
       и последовательность клавиш, с которой оно должно быть связано. Имя может быть указано
       одним из двух способов: как символическое имя клавиши, возможно с префиксами Meta- или
       Control-, или как последовательность клавиш. Имя и последовательность клавиш разделяются двоеточием.
       Между именем и двоеточием не должно быть пробелов.

       При использовании формы keyname:function-name или macro, keyname — это имя
       клавиши, написанное на английском языке. Например:

	      Control-u: universal-argument
	      Meta-Rubout: backward-kill-word
	      Control-o: "> output"

       В приведённом выше примере, C-u связано с функцией universal-argument,
       M-DEL связано с функцией backward-kill-word, а C-o связано с
       выполнением макроса, выраженного справа (т.е., вставкой текста ``> output'' в строку).

       Во второй форме, "keyseq":function-name или macro, keyseq отличается
       от keyname выше тем, что строки, обозначающие полную последовательность клавиш, могут
       быть указаны путём размещения последовательности в двойных кавычках. Некоторые
       escape-последовательности в стиле GNU Emacs можно использовать, как в следующем
       примере, но символические имена символов не распознаются.

	      "\C-u": universal-argument
	      "\C-x\C-r": re-read-init-file
	      "\e[11~": "Function Key 1"

       В этом примере, C-u снова связано с функцией universal-argument.
       C-x C-r связано с функцией re-read-init-file, а ESC [ 1 1 ~
       связано с вставкой текста ``Function Key 1''.

       Полный набор escape-последовательностей в стиле GNU Emacs, доступных при указании
       последовательностей клавиш, следующий:
	      \C-    префикс control
	      \M-    префикс meta
	      \e     символ escape
	      \\     обратный слеш
	      "     буквальная ", двойная кавычка
	      \'     буквальная ', одинарная кавычка

       Кроме escape-последовательностей в стиле GNU Emacs, доступен второй набор
       escape-последовательностей с обратным слешем:
	      \a     сигнал тревоги (звонок)
	      \b     backspace
	      \d     delete
	      \f     form feed
	      \n     новая строка
	      \r     carriage return
	      \t     горизонтальная табуляция
	      \v     вертикальная табуляция
	      \nnn   восьмибитный символ, значение которого равно октанальному значению
		     nnn (один, два или три цифры)
	      \xHH   восьмибитный символ, значение которого равно шестнадцатеричному значению
		     HH (одна или две шестнадцатеричные цифры)

       При вводе текста макроса, одинарные или двойные кавычки должны использоваться
       для указания определения макроса. Неохватанный текст предполагается как имя
       функции. В теле макроса расширяются escape-последовательности, описанные
       выше. Обратный слеш экранирует любой другой символ в тексте макроса,
       включая " и '.

       Bash позволяет отображать или изменять текущие связывания клавиш readline с помощью
       встроенной команды bind. Режим редактирования может быть переключён
       во время интерактивного использования с помощью опции -o команды set. Другие программы,
       использующие эту библиотеку, предоставляют похожие механизмы.
       Файл inputrc может быть отредактирован и перечитан, если программа не предоставляет
       других способов включения новых связываний.

   Variables
       Readline имеет переменные, которые можно использовать для дальнейшей настройки его поведения.
       Переменная может быть установлена в файле inputrc с помощью инструкции вида

	      set variable-name value

       За исключением случаев, когда указано иное, переменные readline могут принимать значения On или Off
       (без учёта регистра). Неузнанные имена переменных игнорируются.
       При чтении значения переменной, пустые или нулевые значения, "on" (без учёта регистра)
       и "1" эквивалентны On. Все другие значения эквивалентны Off. Переменные и их значения по умолчанию:

       active-region-start-color
	      Строка переменной, которая управляет цветом текста
	      и фоном при отображении текста в активной области (см. описание
	      enable-active-region ниже). Эта строка не должна занимать
	      никаких физических позиций символов на экране, так что она должна
	      состоять только из последовательностей escape терминала. Она выводится в терминал
	      перед отображением текста в активной области. Эта переменная сбрасывается
	      в значение по умолчанию при изменении типа терминала.
	      Значение по умолчанию — строка, которая переводит терминал в режим выделения,
	      как указано в описании терминала terminfo. Пример значения может быть "\e[01;33m".
       active-region-end-color
	      Строка переменной, которая "отменяет" эффекты active-region-start-color
	      и восстанавливает "нормальный" вид отображения терминала
	      после отображения текста в активной области. Эта строка не должна занимать
	      никаких физических позиций символов на экране, так что она должна
	      состоять только из последовательностей escape терминала. Она выводится в терминал
	      после отображения текста в активной области. Эта переменная сбрасывается
	      в значение по умолчанию при изменении типа терминала. Значение по умолчанию — строка,
	      которая восстанавливает терминал из режима выделения, как указано
	      в описании терминала terminfo. Пример значения может быть "\e[0m".
       bell-style (audible)
	      Управляет тем, что происходит, когда readline хочет подать сигнал терминала.
	      Если установлено в none, readline никогда не подаёт сигнал. Если установлено в
	      visible, readline использует видимый сигнал, если он доступен. Если
	      установлено в audible, readline пытается подать сигнал терминала.
       bind-tty-special-chars (On)
	      Если установлено в On (значение по умолчанию), readline пытается связать
	      специальные управляющие символы, обрабатываемые драйвером терминала ядра,
	      с их эквивалентами в readline.
       blink-matching-paren (Off)
	      Если установлено в On, readline пытается кратковременно переместить курсор к открывающей
	      скобке при вставке закрывающей скобки.
       colored-completion-prefix (Off)
	      Если установлено в On, при перечислении дополнений, readline отображает
	      общий префикс набора возможных дополнений в другом
	      цвете. Определения цветов берутся из значения переменной окружения
	      LS_COLORS. Если в $LS_COLORS есть определение цвета для пользовательского суффикса "readline-colored-completion-prefix",
	      readline использует этот цвет для общего префикса вместо значения по умолчанию.
       colored-stats (Off)
	      Если установлено в On, readline отображает возможные дополнения с использованием
	      разных цветов для указания их типа файла. Определения цветов
	      берутся из значения переменной окружения LS_COLORS.
       comment-begin (``#'')
	      Строка, которая вставляется в режиме vi при выполнении команды
	      insert-comment. Эта команда связана с M-# в режиме emacs
	      и с # в режиме команд vi.
       completion-display-width (-1)
	      Количество столбцов экрана, используемых для отображения возможных
	      совпадений при выполнении дополнения. Значение игнорируется, если оно меньше
	      0 или больше ширины экрана терминала. Значение 0
	      заставит отображать совпадения по одному на строке. Значение по умолчанию — -1.
       completion-ignore-case (Off)
	      Если установлено в On, readline выполняет сопоставление имён файлов и дополнение
	      без учёта регистра.
       completion-map-case (Off)
	      Если установлено в On и completion-ignore-case включено, readline
	      рассматривает дефисы (-) и подчёркивания (_) как эквивалентные при
	      выполнении сопоставления имён файлов без учёта регистра и дополнения.
       completion-prefix-display-length (0)
	      Длина в символах общего префикса списка возможных
	      дополнений, который отображается без изменений. Когда установлено
	      в значение больше нуля, общие префиксы длиннее этого значения
	      заменяются многоточием при отображении возможных дополнений.
       completion-query-items (100)
	      Это определяет, когда пользователь запрашивается об отображении количества
	      возможных дополнений, генерируемых командой possible-completions.
	      Оно может быть установлено в любое целое значение, большее или равное нулю. Если количество
	      возможных дополнений больше или равно значению этой переменной, readline
	      спросит, желает ли пользователь просмотреть их; в противном случае
	      они просто перечисляются в терминале. Отрицательное значение заставляет
	      readline никогда не спрашивать.
       convert-meta (On)
	      Если установлено в On, readline будет преобразовывать символы с установленным
	      восьмым битом в последовательность ASCII-ключей путём удаления восьмого бита и
	      добавления префикса escape (в efekte, используя escape как
	      префикс meta). Значение по умолчанию — On, но readline установит его в Off, если
	      локаль содержит восьмибитные символы. Эта переменная зависит от категории локали
	      LC_CTYPE и может измениться, если локаль изменяется.
       disable-completion (Off)
	      Если установлено в On, readline запретит дополнение слов. Символы
	      дополнения будут вставляться в строку, как если бы они были
	      связаны с self-insert.
       echo-control-characters (On)
	      Когда установлено в On, на операционных системах, которые указывают, что они
	      поддерживают это, readline выводит символ, соответствующий сигналу,
	      генерируемому с клавиатуры.
       editing-mode (emacs)
	      Управляет тем, начинает ли readline с набора связываний клавиш,
	      похожего на Emacs или vi. editing-mode может быть установлено в emacs или
	      vi.
       emacs-mode-string (@)
	      Если переменная show-mode-in-prompt включена, эта строка
	      отображается сразу перед последней строкой основной подсказки,
	      когда активен режим редактирования emacs. Значение расширяется как связывание клавиш,
	      так что стандартный набор префиксов meta- и control, а также
	      escape-последовательностей с обратным слешем доступен. Используйте escape \1 и \2
	      для начала и конца последовательностей непечатаемых символов,
	      которые можно использовать для встраивания последовательности управления терминалом в
	      строку режима.
       enable-active-region (On)
	      Точка — это текущая позиция курсора, а mark относится к
	      сохранённой позиции курсора. Текст между точкой и mark
	      называется регионом. Когда эта переменная установлена в On,
	      readline позволяет некоторым командам обозначать регион как
	      активный. Когда регион активен, readline выделяет текст
	      в регионе с использованием значения active-region-start-color,
	      которое по умолчанию является строкой, включающей режим выделения терминала.
	      Активный регион показывает текст, вставленный bracketed-paste
	      и любой совпадающий текст, найденный инкрементальными и неинкрементальными
	      поисками в истории.
       enable-bracketed-paste (On)
	      Когда установлено в On, readline настраивает терминал для вставки каждого
	      вставленного блока в буфер редактирования как единую строку символов,
	      вместо обработки каждого символа как если бы он был прочитан с клавиатуры.
	      Это предотвращает выполнение readline любых команд редактирования,
	      связанных с последовательностями клавиш, появляющимися в вставленном тексте.
       enable-keypad (Off)
	      Когда установлено в On, readline попытается включить
	      цифровую клавиатуру при вызове. Некоторые системы нуждаются в этом для включения
	      стрелочных клавиш.
       enable-meta-key (On)
	      Когда установлено в On, readline попытается включить любой модификатор meta,
	      который терминал заявляет, что поддерживает, при вызове. На многих
	      терминалах клавиша meta используется для отправки восьмибитных символов.
       expand-tilde (Off)
	      Если установлено в On, расширение тильды выполняется, когда readline
	      пытается выполнить дополнение слова.
       history-preserve-point (Off)
	      Если установлено в On, код истории пытается установить точку в
	      той же позиции на каждой строке истории, извлечённой с помощью previous-history
	      или next-history.
       history-size (unset)
	      Устанавливает максимальное количество записей истории, сохранённых в списке
	      истории. Если установлено в ноль, все существующие записи истории удаляются
	      и новые записи не сохраняются. Если установлено в значение меньше нуля,
	      количество записей истории не ограничивается. По умолчанию, количество записей
	      истории не ограничивается. Если попытка установить history-size в нечисловое значение,
	      максимальное количество записей истории будет установлено в 500.
       horizontal-scroll-mode (Off)
	      Когда установлено в On, заставляет readline использовать одну строку для отображения,
	      прокручивая ввод горизонтально на одной строке экрана, когда он
	      становится длиннее ширины экрана, вместо переноса на новую
	      строку. Эта настройка автоматически включается для терминалов
	      высотой 1.
       input-meta (Off)
	      Если установлено в On, readline включит восьмибитный ввод (т.е., он
	      не будет сбрасывать восьмой бит в читаемых символах), независимо
	      от того, что терминал заявляет, что может поддерживать. Имя meta-flag является синонимом
	      этой переменной. Значение по умолчанию — Off, но readline установит его в On, если
	      локаль содержит восьмибитные символы. Эта переменная зависит от категории локали
	      LC_CTYPE и может измениться, если локаль изменяется.
       isearch-terminators (``C-[ C-J'')
	      Строка символов, которая должна завершать инкрементальный
	      поиск без последующего выполнения символа как команды.
	      Если эта переменная не получила значения, символы ESC и C-J завершат
	      инкрементальный поиск.
       keymap (emacs)
	      Устанавливает текущий keymap readline. Набор допустимых имён keymap
	      — emacs, emacs-standard, emacs-meta, emacs-ctlx, vi, vi-move,
	      vi-command и vi-insert. vi эквивалентно vi-command;
	      emacs эквивалентно emacs-standard. Значение по умолчанию — emacs. Значение
	      editing-mode также влияет на keymap по умолчанию.
       keyseq-timeout (500)
	      Указывает продолжительность, в течение которой readline будет ждать символа при
	      чтении неоднозначной последовательности клавиш (той, которая может сформировать полную
      последовательность клавиш с использованием введённого на данный момент ввода, или может принять дополнительный
      ввод для завершения более длинной последовательности клавиш). Если ввод не получен
      в течение времени ожидания, readline использует более короткую, но полную последовательность клавиш.
      Значение указывается в миллисекундах, так что значение 1000 означает, что readline будет ждать одну секунду
      дополнительного ввода. Если эта переменная установлена в значение меньше или равное нулю,
      или в нечисловое значение, readline будет ждать, пока не будет нажата другая клавиша,
      чтобы решить, какую последовательность клавиш завершить.
       mark-directories (On)
       Если установлено в On, завершённые имена каталогов имеют слеш в конце.
       mark-modified-lines (Off)
       Если установлено в On, строки истории, которые были изменены, отображаются
       с предыдущим звёздочкой (*).
       mark-symlinked-directories (Off)
       Если установлено в On, завершённые имена, которые являются символическими ссылками на каталоги,
       имеют слеш в конце (с учётом значения mark-directories).
       match-hidden-files (On)
       Эта переменная, когда установлена в On, заставляет readline сопоставлять файлы,
       имена которых начинаются с `.` (скрытые файлы), при выполнении
       дополнения имён файлов. Если установлено в Off, ведущий `.` должен быть
       предоставлен пользователем в имени файла для дополнения.
       menu-complete-display-prefix (Off)
       Если установлено в On, меню дополнения отображает общий префикс списка
       возможных дополнений (который может быть пустым) перед циклом
       по списку.
       output-meta (Off)
       Если установлено в On, readline будет отображать символы с установленным
       восьмым битом напрямую, а не как последовательность escape с префиксом meta.
       Значение по умолчанию — Off, но readline установит его в On, если
       локаль содержит восьмибитные символы. Эта переменная зависит от
       категории локали LC_CTYPE и может измениться, если локаль изменяется.
       page-completions (On)
       Если установлено в On, readline использует внутренний pager, похожий на more, для
       отображения экрана возможных дополнений за раз.
       print-completions-horizontally (Off)
       Если установлено в On, readline будет отображать дополнения с совпадениями,
       отсортированными горизонтально в алфавитном порядке, а не вниз по экрану.
       revert-all-at-newline (Off)
       Если установлено в On, readline отменит все изменения строк истории
       перед возвратом при выполнении accept-line. По умолчанию, строки
       истории могут быть изменены и сохранять отдельные списки отмены
       между вызовами readline.
       show-all-if-ambiguous (Off)
       Это изменяет поведение функций дополнения по умолчанию.
       Если установлено в On, слова, у которых более одного возможного дополнения,
       заставляют перечислить совпадения немедленно вместо подачи сигнала.
       show-all-if-unmodified (Off)
       Это изменяет поведение функций дополнения по умолчанию, похожим образом
       на show-all-if-ambiguous. Если установлено в On, слова, у которых более одного
       возможного дополнения без какого-либо возможного частичного дополнения (возможные дополнения не
       делят общего префикса), заставляют перечислить совпадения немедленно вместо подачи
       сигнала.
       show-mode-in-prompt (Off)
       Если установлено в On, добавляет строку в начало подсказки, указывающую
       режим редактирования: emacs, vi command или vi insertion.
       Строки режимов настраиваются пользователем (например, emacs-mode-string).
       skip-completed-text (Off)
       Если установлено в On, это изменяет поведение дополнения по умолчанию при
       вставке единственного совпадения в строку. Это активно только при
       выполнении дополнения в середине слова. Если включено,
       readline не вставляет символы из дополнения, которые
       совпадают с символами после точки в слова, которое дополняется, так
       что порции слова после курсора не дублируются.
       vi-cmd-mode-string ((cmd))
       Если переменная show-mode-in-prompt включена, эта строка
       отображается сразу перед последней строкой основной подсказки,
       когда активен режим редактирования vi и в режиме команд. Значение
       расширяется как связывание клавиш, так что стандартный набор префиксов meta- и control,
       а также escape-последовательностей с обратным слешем доступен.
       Используйте escape \1 и \2 для начала и конца последовательностей непечатаемых символов,
       которые можно использовать для встраивания последовательности управления терминалом в
       строку режима.
       vi-ins-mode-string ((ins))
       Если переменная show-mode-in-prompt включена, эта строка
       отображается сразу перед последней строкой основной подсказки,
       когда активен режим редактирования vi и в режиме вставки. Значение
       расширяется как связывание клавиш, так что стандартный набор префиксов meta- и control,
       а также escape-последовательностей с обратным слешем доступен.
       Используйте escape \1 и \2 для начала и конца последовательностей непечатаемых символов,
       которые можно использовать для встраивания последовательности управления терминалом в
       строку режима.
       visible-stats (Off)
       Если установлено в On, символ, обозначающий тип файла, как сообщено
       stat(2), добавляется к имени файла при перечислении возможных
       дополнений.

   Conditional Constructs
       Readline реализует механизм, похожий по духу на возможности условной
       компиляции препроцессора C, который позволяет выполнять связывания клавиш
       и установки переменных в результате тестов. Используются четыре директивы парсера.

       $if    Конструкция $if позволяет выполнять связывания на основе
	      режима редактирования, используемого терминала или приложения, использующего
	      readline. Текст теста, после любого оператора сравнения,
	      простирается до конца строки; если не указано иное, никакие символы
	      не требуются для его изоляции.

	      mode   Форма mode= директивы $if используется для проверки,
		     находится ли readline в режиме emacs или vi. Это может быть
		     использовано в сочетании с командой set keymap, например,
		     для установки связываний в keymap emacs-standard и emacs-ctlx
		     только если readline запускается в режиме emacs.

	      term   Форма term= может быть использована для включения связываний клавиш,
		     специфичных для терминала, возможно для связывания последовательностей клавиш,
		     выводимых функциональными клавишами терминала. Слово справа от
		     = сравнивается с полным именем терминала и частью имени терминала
		     перед первым -. Это позволяет sun совпадать как с sun, так и с sun-cmd,
		     например.

	      version
		     Тест version может быть использован для выполнения сравнений
		     с конкретными версиями readline. Version расширяется
		     до текущей версии readline. Набор операторов сравнения включает =, (и ==), !=, <=,
		     >=, < и >. Номер версии, указанный справа от оператора,
		     состоит из основного номера версии, необязательной десятичной точки и необязательного
		     дополнительного номера (например, 7.1). Если дополнительный номер omitted, предполагается,
		     что он равен 0. Оператор может быть разделён от строки version и
		     от аргумента номера версии пробелами.

	      application
		     Конструкция application используется для включения настроек,
		     специфичных для приложения. Каждая программа, использующая библиотеку readline,
		     устанавливает имя приложения, и файл инициализации может проверить на конкретное значение.
		     Это может быть использовано для связывания последовательностей клавиш с функциями,
		     полезными для конкретной программы. Например, следующая команда добавляет последовательность клавиш,
		     которая заключает текущее или предыдущее слово в bash:

		     $if Bash
		     # Заключить текущее или предыдущее слово
		     "\C-xq": "\eb"\ef""
		     $endif

	      variable
		     Конструкция variable предоставляет простые тесты равенства для
		     переменных readline и значений. Допустимые операторы сравнения
		     — =, == и !=. Имя переменной должно быть разделено от оператора сравнения
		     пробелом; оператор может быть разделён от значения справа
		     пробелом. Как строковые, так и логические переменные
		     могут быть протестированы. Логические переменные должны тестироваться
		     против значений on и off.

       $endif Эта команда, как видно в предыдущем примере, завершает команду $if.

       $else  Команды в этой ветви директивы $if выполняются, если
	      тест не проходит.

       $include
	      Эта директива принимает одно имя файла в качестве аргумента и читает
	      команды и связывания из этого файла. Например, следующая
	      директива прочитала бы /etc/inputrc:

	      $include	/etc/inputrc

SEARCHING
       Readline предоставляет команды для поиска в истории команд
       строк, содержащих указанную строку. Существует два режима поиска:
       инкрементальный и неинкрементальный.

       Инкрементальные поиски начинаются до того, как пользователь закончил ввод
       строки поиска. По мере ввода каждого символа строки поиска readline
       отображает следующую запись из истории, совпадающую со строкой, введённой
       на данный момент. Инкрементальный поиск требует только столько символов,
       сколько нужно для поиска нужной записи истории. Чтобы искать назад в
       истории конкретную строку, нажмите C-r. Нажатие C-s ищет вперёд
       через историю. Символы, присутствующие в значении переменной
       isearch-terminators, используются для завершения инкрементального
       поиска. Если эта переменная не получила значения, символы Escape и C-J завершат
       инкрементальный поиск. C-G прервёт инкрементальный поиск и восстановит
       исходную строку. Когда поиск завершается, запись истории,
       содержащая строку поиска, становится текущей строкой.

       Чтобы найти другие совпадающие записи в списке истории, нажмите C-s или C-r
       соответственно. Это будет искать назад или вперёд в истории для
       следующей строки, совпадающей со строкой поиска, введённой на данный момент. Любая другая последовательность клавиш,
       связанная с командой readline, завершит поиск и выполнит
       эту команду. Например, новая строка завершит поиск и примет
       строку, тем самым выполнив команду из списка истории.
       Команда перемещения завершит поиск, сделает последнюю найденную строку
       текущей строкой и начнёт редактирование.

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

EDITING COMMANDS
       Ниже приведён список имён команд и последовательностей клавиш по умолчанию,
       с которыми они связаны. Имена команд без сопровождающей последовательности клавиш
       по умолчанию не связаны.

       В следующих описаниях, point относится к текущей позиции курсора,
       а mark — к позиции курсора, сохранённой командой set-mark.
       Текст между point и mark называется регионом.

   Commands for Moving
       beginning-of-line (C-a)
	      Переместить к началу текущей строки.
       end-of-line (C-e)
	      Переместить к концу строки.
       forward-char (C-f)
	      Переместить вперёд на символ.
       backward-char (C-b)
	      Переместить назад на символ.
       forward-word (M-f)
	      Переместить вперёд к концу следующего слова. Слова состоят из
	      алфавитно-цифровых символов (букв и цифр).
       backward-word (M-b)
	      Переместить назад к началу текущего или предыдущего слова. Слова состоят из
	      алфавитно-цифровых символов (букв и цифр).
       previous-screen-line
	      Пытается переместить point в тот же физический столбец экрана на
	      предыдущей физической строке экрана. Это не даст желаемого
	      эффекта, если текущая строка readline не занимает более
	      одной физической строки или если point не больше длины
	      подсказки плюс ширина экрана.
       next-screen-line
	      Пытается переместить point в тот же физический столбец экрана на
	      следующей физической строке экрана. Это не даст желаемого эффекта,
	      если текущая строка readline не занимает более
	      одной физической строки или если длина текущей строки readline
	      не больше длины подсказки плюс ширина экрана.
       clear-display (M-C-l)
	      Очистить экран и, если возможно, буфер прокрутки терминала,
	      затем перерисовать текущую строку, оставляя текущую строку
	      вверху экрана.
       clear-screen (C-l)
	      Очистить экран, затем перерисовать текущую строку, оставляя текущую строку
	      вверху экрана. С аргументом, обновить текущую строку без очистки экрана.
       redraw-current-line
	      Обновить текущую строку.

   Commands for Manipulating the History
       accept-line (Newline, Return)
	      Принять строку независимо от позиции курсора. Если эта строка
	      непуста, она может быть добавлена в список истории для будущего вызова
	      с add_history(). Если строка — изменённая строка истории,
	      строка истории восстанавливается в исходное состояние.
       previous-history (C-p)
	      Извлечь предыдущую команду из списка истории, перемещаясь назад в
	      списке.
       next-history (C-n)
	      Извлечь следующую команду из списка истории, перемещаясь вперёд в
	      списке.
       beginning-of-history (M-<)
	      Переместить к первой строке в истории.
       end-of-history (M->)
	      Переместить к концу ввода истории, т.е., к строке, которая
	      в данный момент вводится.
       operate-and-get-next (C-o)
	      Принять текущую строку для возврата вызывающему приложению, как если бы
	      была введена новая строка, и извлечь следующую строку относительно
	      текущей строки из истории для редактирования. Числовой аргумент, если предоставлен,
	      указывает запись истории для использования вместо текущей строки.
       fetch-history
	      С числовым аргументом, извлечь эту запись из списка истории
	      и сделать её текущей строкой. Без аргумента, переместить назад к
	      первой записи в списке истории.
       reverse-search-history (C-r)
	      Искать назад, начиная с текущей строки и перемещаясь 'вверх'
	      по истории по необходимости. Это инкрементальный поиск.
       forward-search-history (C-s)
	      Искать вперёд, начиная с текущей строки и перемещаясь 'вниз'
	      по истории по необходимости. Это инкрементальный поиск.
       non-incremental-reverse-search-history (M-p)
	      Искать назад по истории, начиная с текущей строки,
	      используя неинкрементальный поиск для строки, предоставленной пользователем.
       non-incremental-forward-search-history (M-n)
	      Искать вперёд по истории, используя неинкрементальный
	      поиск для строки, предоставленной пользователем.
       history-search-backward
	      Искать назад по истории для строки символов
	      между началом текущей строки и текущей позицией курсора
	      (point). Строка поиска должна совпадать в начале строки истории.
	      Это неинкрементальный поиск.
       history-search-forward
	      Искать вперёд по истории для строки символов
	      между началом текущей строки и point. Строка поиска
	      должна совпадать в начале строки истории. Это неинкрементальный поиск.
       history-substring-search-backward
	      Искать назад по истории для строки символов
	      между началом текущей строки и point. Строка поиска может совпадать
	      в любом месте строки истории. Это неинкрементальный поиск.
       history-substring-search-forward
	      Искать вперёд по истории для строки символов
	      между началом текущей строки и point. Строка поиска может совпадать
	      в любом месте строки истории. Это неинкрементальный поиск.
       yank-nth-arg (M-C-y)
	      Вставить первый аргумент предыдущей команды (обычно второе слово
	      на предыдущей строке) в point. С аргументом n,
	      вставить n-ое слово из предыдущей команды (слова в предыдущей
	      команде начинаются с слова 0). Отрицательный аргумент вставляет
	      n-ое слово с конца предыдущей команды. Как только аргумент n
	      вычислен, аргумент извлекается, как если бы была указана
	      экспансия истории "!n".
       yank-last-arg (M-., M-_)
	      Вставить последний аргумент предыдущей команды (последнее слово
	      записи истории). С числовым аргументом, вести себя
	      точно как yank-nth-arg. Последовательные вызовы yank-last-arg
	      перемещаются назад по списку истории, вставляя последнее слово (или
	      слово, указанное аргументом для первого вызова) каждой
	      строки по очереди. Любая числовая добавка, предоставленная этим последовательным
	      вызовам, определяет направление перемещения по истории. Отрицательный аргумент
	      переключает направление по истории (назад или вперёд). Удобства
	      экспансии истории используются для извлечения последнего аргумента, как если бы была указана
	      экспансия истории "!$".

   Commands for Changing Text
       end-of-file (usually C-d)
	      Символ, указывающий конец файла, как установлено, например,
	      ``stty''. Если этот символ прочитан, когда в строке нет символов,
	      и point в начале строки, readline интерпретирует его как конец
	      ввода и возвращает EOF.
       delete-char (C-d)
	      Удалить символ в point. Если эта функция связана с
	      тем же символом, что и символ EOF терминала, как обычно C-d,
	      см. выше для эффектов.
       backward-delete-char (Rubout)
	      Удалить символ за курсором. С числовым
	      аргументом, сохранить удалённый текст в kill ring.
       forward-backward-delete-char
	      Удалить символ под курсором, если курсор не в конце
	      строки, в противном случае удалить символ за курсором.
       quoted-insert (C-q, C-v)
	      Добавить следующий введённый символ в строку дословно. Это
	      способ вставить символы, такие как C-q, например.
       tab-insert (M-TAB)
	      Вставить символ табуляции.
       self-insert (a, b, A, 1, !, ...)
	      Вставить введённый символ.
       transpose-chars (C-t)
	      Перетащить символ перед point вперёд через символ в
	      point, перемещая point вперёд. Если point в конце
	      строки, это переставляет два символа перед point.
	      Отрицательные аргументы не имеют эффекта.
       transpose-words (M-t)
	      Перетащить слово перед point мимо слова после point,
	      перемещая point через это слово. Если point в конце строки,
	      это переставляет последние два слова на строке.
       upcase-word (M-u)
	      Перевести в верхний регистр текущее (или следующее) слово. С отрицательным аргументом,
	      перевести в верхний регистр предыдущее слово, но не перемещать point.
       downcase-word (M-l)
	      Перевести в нижний регистр текущее (или следующее) слово. С отрицательным аргументом,
	      перевести в нижний регистр предыдущее слово, но не перемещать point.
       capitalize-word (M-c)
	      Сделать заглавным текущее (или следующее) слово. С отрицательным аргументом,
	      сделать заглавным предыдущее слово, но не перемещать point.
       overwrite-mode
	      Переключить режим перезаписи. С явным положительным числовым аргументом,
	      переключает в режим перезаписи. С явным неположительным
	      числовым аргументом, переключает в режим вставки. Эта команда влияет
	      только на режим emacs; vi режим перезаписывает по-другому. Каждый вызов
	      readline() начинается в режиме вставки. В режиме перезаписи символы,
	      связанные с self-insert, заменяют текст в point, а не
	      сдвигают текст вправо. Символы, связанные с backward-delete-char,
	      заменяют символ перед point пробелом. По умолчанию, эта команда не связана.

   Killing and Yanking
       kill-line (C-k)
	      Удалить текст от point до конца строки.
       backward-kill-line (C-x Rubout)
	      Удалить назад до начала строки.
       unix-line-discard (C-u)
	      Удалить назад от point до начала строки. Удалённый
	      текст сохраняется в kill-ring.
       kill-whole-line
	      Удалить все символы на текущей строке, независимо от позиции point.
       kill-word (M-d)
	      Удалить от point до конца текущего слова, или если между
	      словами, до конца следующего слова. Границы слов те же,
	      что и у forward-word.
       backward-kill-word (M-Rubout)
	      Удалить слово за point. Границы слов те же,
	      что и у backward-word.
       unix-word-rubout (C-w)
	      Удалить слово за point, используя пробелы как границу слова.
	      Удалённый текст сохраняется в kill-ring.
       unix-filename-rubout
	      Удалить слово за point, используя пробелы и символ
	      слэш как границы слова. Удалённый текст сохраняется в kill-ring.
       delete-horizontal-space (M-\)
	      Удалить все пробелы и табуляции вокруг point.
       kill-region
	      Удалить текст между point и mark (сохранённой позицией курсора).
	      Этот текст называется регионом.
       copy-region-as-kill
	      Скопировать текст в регионе в буфер kill.
       copy-backward-word
	      Скопировать слово перед point в буфер kill. Границы слов те же,
	      что и у backward-word.
       copy-forward-word
	      Скопировать слово после point в буфер kill. Границы слов те же,
	      что и у forward-word.
       yank (C-y)
	      Извлечь вершину kill ring в буфер в point.
       yank-pop (M-y)
	      Повернуть kill ring и извлечь новую вершину. Работает только
	      после yank или yank-pop.

   Numeric Arguments
       digit-argument (M-0, M-1, ..., M--)
	      Добавить эту цифру к накапливающемуся аргументу или начать
	      новый аргумент. M-- начинает отрицательный аргумент.
       universal-argument
	      Это другой способ указать аргумент. Если эта команда
	      за ней следует одна или несколько цифр, необязательно с ведущим минусом,
	      эти цифры определяют аргумент. Если команда за ней следует цифрами,
	      выполнение universal-argument снова завершает числовой аргумент,
	      но в противном случае игнорируется. Как специальный случай, если
	      эта команда немедленно за ней следует символом, который не является
	      цифрой или минусом, счётчик аргументов для следующей команды
	      умножается на четыре. Счётчик аргументов изначально один, так что
	      выполнение этой функции в первый раз делает счётчик аргументов четырьмя,
	      во второй раз — шестнадцатью и так далее.

   Completing
       complete (TAB)
	      Пытается выполнить дополнение текста перед point. Фактическое
	      дополнение, выполняемое, зависит от приложения. Bash, например,
	      пытается выполнить дополнение, рассматривая текст как переменную
	      (если текст начинается с $), имя пользователя (если текст начинается с
	      ~), имя хоста (если текст начинается с @) или команду (включая
	      алиасы и функции) по порядку. Если ни одно из них не производит
	      совпадение, выполняется дополнение имён файлов. Gdb, с другой стороны,
	      позволяет дополнение функций и переменных программы и
	      выполняет дополнение имён файлов только в определённых обстоятельствах.
       possible-completions (M-?)
	      Перечислить возможные дополнения текста перед point. При
	      отображении дополнений, readline устанавливает количество столбцов, используемых
	      для отображения, в значение completion-display-width, значение
	      переменной окружения COLUMNS или ширину экрана, в
	      том порядке.
       insert-completions (M-*)
	      Вставить все дополнения текста перед point, которые были бы
	      сгенерированы possible-completions.
       menu-complete
	      Похоже на complete, но заменяет слово для дополнения
	      на одно совпадение из списка возможных дополнений. Повторное
	      выполнение menu-complete проходит по списку возможных
	      дополнений, вставляя каждое совпадение по очереди. В конце списка
	      дополнений подаётся сигнал (с учётом настройки bell-style) и
	      исходный текст восстанавливается. Аргумент n перемещает n позиций вперёд
	      в списке совпадений; отрицательный аргумент может быть использован для перемещения назад
	      по списку. Эта команда предназначена для связывания с TAB, но по умолчанию не связана.
       menu-complete-backward
	      Идентично menu-complete, но перемещает назад по списку
	      возможных дополнений, как если бы menu-complete был дан с
	      отрицательным аргументом. Эта команда по умолчанию не связана.
       delete-char-or-list
	      Удаляет символ под курсором, если не в начале
	      или конце строки (как delete-char). Если в конце строки,
	      ведёт себя идентично possible-completions.

   Keyboard Macros
       start-kbd-macro (C-x ())
	      Начать сохранение введённых символов в текущий макрос клавиатуры.
       end-kbd-macro (C-x ))
	      Остановить сохранение введённых символов в текущий макрос клавиатуры
	      и сохранить определение.
       call-last-kbd-macro (C-x e)
	      Перевыполнить последний определённый макрос клавиатуры, заставляя символы
	      в макросе появляться, как если бы они были введены с клавиатуры.
       print-last-kbd-macro ()
	      Вывести последний определённый макрос клавиатуры в формате, подходящем для
	      файла inputrc.

   Miscellaneous
       re-read-init-file (C-x C-r)
	      Прочитать содержимое файла inputrc и включить любые
	      связывания или присваивания переменных, найденные там.
       abort (C-g)
	      Прервать текущую команду редактирования и подать сигнал терминала
	      (с учётом настройки bell-style).
       do-lowercase-version (M-A, M-B, M-x, ...)
	      Если метафицированный символ x в верхнем регистре, выполнить команду,
	      которая связана с соответствующим метафицированным символом в нижнем регистре. Поведение
	      не определено, если x уже в нижнем регистре.
       prefix-meta (ESC)
	      Сделать мета из следующего введённого символа. ESC f эквивалентно Meta-f.
       undo (C-_, C-x C-u)
	      Инкрементальная отмена, отдельно запоминаемая для каждой строки.
       revert-line (M-r)
	      Отменить все изменения, сделанные в этой строке. Это похоже на выполнение команды
	      undo достаточно раз, чтобы вернуть строку в исходное состояние.
       tilde-expand (M-&)
	      Выполнить расширение тильды для текущего слова.
       set-mark (C-@, M-<space>)
	      Установить mark в point. Если предоставлен числовой аргумент,
	      mark устанавливается в эту позицию.
       exchange-point-and-mark (C-x C-x)
	      Поменять point с mark. Текущая позиция курсора устанавливается
	      в сохранённую позицию, а старая позиция курсора сохраняется
	      как mark.
       character-search (C-])
	      Читается символ и point перемещается к следующему вхождению
	      этого символа. Отрицательный аргумент ищет предыдущие вхождения.
       character-search-backward (M-C-])
	      Читается символ и point перемещается к предыдущему вхождению
	      этого символа. Отрицательный аргумент ищет последующие вхождения.
       skip-csi-sequence
	      Прочитать достаточно символов, чтобы потребить последовательность из нескольких клавиш, такую как
	      те, которые определяются для клавиш, таких как Home и End. Такие последовательности начинаются
	      с Control Sequence Indicator (CSI), обычно ESC-[. Если эта
	      последовательность связана с "\[", клавиши, производящие такие последовательности,
	      не будут иметь эффекта, если они явно не связаны с командой readline,
	      вместо вставки случайных символов в буфер редактирования.
	      Это по умолчанию не связано, но обычно связано с ESC-[.
       insert-comment (M-#)
	      Без числового аргумента, значение переменной readline comment-begin
	      вставляется в начало текущей строки. Если предоставлен числовой аргумент,
	      эта команда действует как переключатель: если символы в начале строки не
	      совпадают со значением comment-begin, значение вставляется, в противном случае
	      символы в comment-begin удаляются из начала строки. В любом случае,
	      строка принимается, как если бы была введена новая строка. Значение по умолчанию comment-begin
	      делает текущую строку комментарием оболочки. Если числовой аргумент
	      вызывает удаление символа комментария, строка будет выполнена
	      оболочкой.
       dump-functions
	      Вывести все функции и их связывания клавиш в поток вывода readline.
	      Если предоставлен числовой аргумент, вывод форматируется так,
	      чтобы он мог быть частью файла inputrc.
       dump-variables
	      Вывести все настраиваемые переменные и их значения в поток вывода readline.
	      Если предоставлен числовой аргумент, вывод форматируется так,
	      чтобы он мог быть частью файла inputrc.
       dump-macros
	      Вывести все последовательности клавиш readline, связанные с макросами, и
	      строки, которые они выводят. Если предоставлен числовой аргумент, вывод
	      форматируется так, чтобы он мог быть частью файла inputrc.
       emacs-editing-mode (C-e)
	      В режиме команд vi, это вызывает переключение в режим редактирования emacs.
       vi-editing-mode (M-C-j)
	      В режиме редактирования emacs, это вызывает переключение в режим редактирования vi.

DEFAULT KEY BINDINGS
       Ниже приведён список связываний по умолчанию для emacs и vi. Символы
       с установленным восьмым битом записываются как M-<character> и называются
       метафицированными символами. Печатаемые символы ASCII, не упомянутые
       в списке стандартных связываний emacs, связаны с функцией
       self-insert, которая просто вставляет данный символ в строку ввода.
       В режиме вставки vi, все символы, не упомянутые специально, связаны с self-insert.
       Символы, назначенные для генерации сигналов stty(1) или драйвером терминала,
       такие как C-Z или C-C, сохраняют эту функцию. Верхние и нижние
       метафицированные символы связаны с той же функцией в keymap meta режима emacs.
       Оставшиеся символы не связаны, что заставляет readline подавать сигнал
       (с учётом настройки bell-style).

   Emacs Mode
	     Emacs Standard bindings

	     "C-@"  set-mark
	     "C-A"  beginning-of-line
	     "C-B"  backward-char
	     "C-D"  delete-char
	     "C-E"  end-of-line
	     "C-F"  forward-char
	     "C-G"  abort
	     "C-H"  backward-delete-char
	     "C-I"  complete
	     "C-J"  accept-line
	     "C-K"  kill-line
	     "C-L"  clear-screen
	     "C-M"  accept-line
	     "C-N"  next-history
	     "C-P"  previous-history
	     "C-Q"  quoted-insert
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-]"  character-search
	     "C-_"  undo
	     " " to "/"	 self-insert
	     "0"  to "9"  self-insert
	     ":"  to "~"  self-insert
	     "C-?"  backward-delete-char

	     Emacs Meta bindings

	     "M-C-G"  abort
	     "M-C-H"  backward-kill-word
	     "M-C-I"  tab-insert
	     "M-C-J"  vi-editing-mode
	     "M-C-L"  clear-display
	     "M-C-M"  vi-editing-mode
	     "M-C-R"  revert-line
	     "M-C-Y"  yank-nth-arg
	     "M-C-["  complete
	     "M-C-]"  character-search-backward
	     "M-space"	set-mark
	     "M-#"  insert-comment
	     "M-&"  tilde-expand
	     "M-*"  insert-completions
	     "M--"  digit-argument
	     "M-."  yank-last-arg
	     "M-0"  digit-argument
	     "M-1"  digit-argument
	     "M-2"  digit-argument
	     "M-3"  digit-argument
	     "M-4"  digit-argument
	     "M-5"  digit-argument
	     "M-6"  digit-argument
	     "M-7"  digit-argument
	     "M-8"  digit-argument
	     "M-9"  digit-argument
	     "M-<"  beginning-of-history
	     "M-="  possible-completions
	     "M->"  end-of-history
	     "M-?"  possible-completions
	     "M-B"  backward-word
	     "M-C"  capitalize-word
	     "M-D"  kill-word
	     "M-F"  forward-word
	     "M-L"  downcase-word
	     "M-N"  non-incremental-forward-search-history
	     "M-P"  non-incremental-reverse-search-history
	     "M-R"  revert-line
	     "M-T"  transpose-words
	     "M-U"  upcase-word
	     "M-Y"  yank-pop
	     "M-"  delete-horizontal-space
	     "M-~"  tilde-expand
	     "M-C-?"  backward-kill-word
	     "M-_"  yank-last-arg

	     Emacs Control-X bindings

	     "C-XC-G"  abort
	     "C-XC-R"  re-read-init-file
	     "C-XC-U"  undo
	     "C-XC-X"  exchange-point-and-mark
	     "C-X("  start-kbd-macro
	     "C-X)"  end-kbd-macro
	     "C-XE"  call-last-kbd-macro
	     "C-XC-?"  backward-kill-line


   VI Mode bindings
	     VI Insert Mode functions

	     "C-D"  vi-eof-maybe
	     "C-H"  backward-delete-char
	     "C-I"  complete
	     "C-J"  accept-line
	     "C-M"  accept-line
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-["  vi-movement-mode
	     "C-_"  undo
	     " " to "~"	 self-insert
	     "C-?"  backward-delete-char

	     VI Command Mode functions

	     "C-D"  vi-eof-maybe
	     "C-E"  emacs-editing-mode
	     "C-G"  abort
	     "C-H"  backward-char
	     "C-J"  accept-line
	     "C-K"  kill-line
	     "C-L"  clear-screen
	     "C-M"  accept-line
	     "C-N"  next-history
	     "C-P"  previous-history
	     "C-Q"  quoted-insert
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-_"  vi-undo
	     " "  forward-char
	     "#"  insert-comment
	     "$"  end-of-line
	     "%"  vi-match
	     "&"  vi-tilde-expand
	     "*"  vi-complete
	     "+"  next-history
	     ","  vi-char-search
	     "-"  previous-history
	     "."  vi-redo
	     "/"  vi-search
	     "0"  beginning-of-line
	     "1" to "9"	 vi-arg-digit
	     ";"  vi-char-search
	     "="  vi-complete
	     "?"  vi-search
	     "A"  vi-append-eol
	     "B"  vi-prev-word
	     "C"  vi-change-to
	     "D"  vi-delete-to
	     "E"  vi-end-word
	     "F"  vi-char-search
	     "G"  vi-fetch-history
	     "I"  vi-insert-beg
	     "N"  vi-search-again
	     "P"  vi-put
	     "R"  vi-replace
	     "S"  vi-subst
	     "T"  vi-char-search
	     "U"  revert-line
	     "W"  vi-next-word
	     "X"  backward-delete-char
	     "Y"  vi-yank-to
	     ""  vi-complete
	     "^"  vi-first-print
	     "_"  vi-yank-arg
	     "`"  vi-goto-mark
	     "a"  vi-append-mode
	     "b"  vi-prev-word
	     "c"  vi-change-to
	     "d"  vi-delete-to
	     "e"  vi-end-word
	     "f"  vi-char-search
	     "h"  backward-char
	     "i"  vi-insertion-mode
	     "j"  next-history
	     "k"  prev-history
	     "l"  forward-char
	     "m"  vi-set-mark
	     "n"  vi-search-again
	     "p"  vi-put
	     "r"  vi-change-char
	     "s"  vi-subst
	     "t"  vi-char-search
	     "u"  vi-undo
	     "w"  vi-next-word
	     "x"  vi-delete
	     "y"  vi-yank-to
	     "|"  vi-column
	     "~"  vi-change-case

SEE ALSO
       The Gnu Readline Library, Brian Fox and Chet Ramey
       The Gnu History Library, Brian Fox and Chet Ramey
       bash(1)

FILES
       ~/.inputrc
	      Индивидуальный файл инициализации readline

AUTHORS
       Brian Fox, Free Software Foundation
       bfox@gnu.org

       Chet Ramey, Case Western Reserve University
       chet.ramey@case.edu

BUG REPORTS
       Если вы найдёте ошибку в readline, вы должны сообщить о ней. Но сначала убедитесь,
       что это действительно ошибка и что она появляется в последней версии
       библиотеки readline, которой вы обладаете.

       Как только вы убедились, что ошибка действительно существует, отправьте отчёт об ошибке
       по адресу bug-readline@gnu.org. Если у вас есть исправление, вы можете отправить его
       тоже! Предложения и 'философские' отчёты об ошибках могут быть
       отправлены по адресу bug-readline@gnu.org или опубликованы в Usenet-группе
       gnu.bash.bug.

       Комментарии и отчёты об ошибках, касающиеся этой страницы руководства, должны быть направлены
       по адресу chet.ramey@case.edu.

BUGS
       Это слишком большое и слишком медленное.



GNU Readline 8.2	       2022 сентября 19		   READLINE(3)
READLINE(3)		   Library Functions Manual		   READLINE(3)



NAME
       readline - get a line from a user with editing

SYNOPSIS
       #include <stdio.h>
       #include <readline/readline.h>
       #include <readline/history.h>

       char *
       readline (const char *prompt);

COPYRIGHT
       Readline is Copyright (C) 1989-2020 Free Software Foundation,  Inc.

DESCRIPTION
       readline will read a line from the terminal and return it, using prompt
       as a prompt.  If prompt is NULL or the empty string, no prompt  is  is‐
       sued.   The  line returned is allocated with malloc(3); the caller must
       free it when finished.  The line returned has  the  final  newline  re‐
       moved, so only the text of the line remains.

       readline	 offers	 editing  capabilities	while the user is entering the
       line.  By default, the line editing commands are similar	 to  those  of
       emacs.  A vi-style line editing interface is also available.

       This  manual  page describes only the most basic use of readline.  Much
       more functionality is available; see The GNU Readline Library  and  The
       GNU History Library for additional information.

RETURN VALUE
       readline	 returns  the text of the line read.  A blank line returns the
       empty string.  If EOF is encountered while reading a line, and the line
       is  empty,  NULL is returned.  If an EOF is read with a non-empty line,
       it is treated as a newline.

NOTATION
       An Emacs-style notation is used to denote keystrokes.  Control keys are
       denoted	by C-key, e.g., C-n means Control-N.  Similarly, meta keys are
       denoted by M-key, so M-x means Meta-X.  (On keyboards  without  a  meta
       key,  M-x means ESC x, i.e., press the Escape key then the x key.  This
       makes ESC the meta prefix.  The combination M-C-x means	ESC-Control-x,
       or  press the Escape key then hold the Control key while pressing the x
       key.)

       Readline commands may be given numeric arguments, which normally act as
       a  repeat  count.   Sometimes,  however, it is the sign of the argument
       that is significant.  Passing a negative argument  to  a	 command  that
       acts  in the forward direction (e.g., kill-line) causes that command to
       act in a backward direction.  Commands whose  behavior  with  arguments
       deviates from this are noted below.

       When  a command is described as killing text, the text deleted is saved
       for possible future retrieval (yanking).	 The killed text is saved in a
       kill ring.  Consecutive kills cause the text to be accumulated into one
       unit, which can be yanked all at once.  Commands which do not kill text
       separate the chunks of text on the kill ring.

INITIALIZATION FILE
       Readline	 is  customized	 by putting commands in an initialization file
       (the inputrc file).  The name of this file is taken from the  value  of
       the  INPUTRC  environment variable.  If that variable is unset, the de‐
       fault is ~/.inputrc.  If that file  does not exist or cannot  be	 read,
       the  ultimate  default  is /etc/inputrc.	 When a program which uses the
       readline library starts up, the init file is read, and the key bindings
       and  variables  are set.	 There are only a few basic constructs allowed
       in the readline init file.  Blank lines are ignored.   Lines  beginning
       with  a	# are comments.	 Lines beginning with a $ indicate conditional
       constructs.  Other lines denote key  bindings  and  variable  settings.
       Each program using this library may add its own commands and bindings.

       For example, placing

	      M-Control-u: universal-argument
       or
	      C-Meta-u: universal-argument

       into  the inputrc would make M-C-u execute the readline command univer‐
       sal-argument.

       The following symbolic character names are recognized while  processing
       key  bindings:  DEL,  ESC,  ESCAPE,  LFD, NEWLINE, RET, RETURN, RUBOUT,
       SPACE, SPC, and TAB.

       In addition to command names, readline allows keys to  be  bound	 to  a
       string that is inserted when the key is pressed (a macro).

   Key Bindings
       The  syntax for controlling key bindings in the inputrc file is simple.
       All that is required is the name of the command or the text of a	 macro
       and a key sequence to which it should be bound.	The name may be speci‐
       fied in one of two ways: as a symbolic key name, possibly with Meta- or
       Control- prefixes, or as a key sequence.	 The name and key sequence are
       separated by a colon.  There can be no whitespace between the name  and
       the colon.

       When using the form keyname:function-name or macro, keyname is the name
       of a key spelled out in English.	 For example:

	      Control-u: universal-argument
	      Meta-Rubout: backward-kill-word
	      Control-o: "> output"

       In the above example, C-u is bound to the function  universal-argument,
       M-DEL  is bound to the function backward-kill-word, and C-o is bound to
       run the macro expressed on the right hand side (that is, to insert  the
       text ``> output'' into the line).

       In  the	second	form,  "keyseq":function-name or macro, keyseq differs
       from keyname above in that strings denoting an entire key sequence  may
       be  specified  by  placing the sequence within double quotes.  Some GNU
       Emacs style key escapes can be used, as in the following	 example,  but
       the symbolic character names are not recognized.

	      "\C-u": universal-argument
	      "\C-x\C-r": re-read-init-file
	      "\e[11~": "Function Key 1"

       In this example, C-u is again bound to the function universal-argument.
       C-x C-r is bound to the function re-read-init-file, and ESC [ 1 1 ~  is
       bound to insert the text ``Function Key 1''.

       The  full set of GNU Emacs style escape sequences available when speci‐
       fying key sequences is
	      \C-    control prefix
	      \M-    meta prefix
	      \e     an escape character
	      \\     backslash
	      \"     literal ", a double quote
	      \'     literal ', a single quote

       In addition to the GNU Emacs style escape sequences, a  second  set  of
       backslash escapes is available:
	      \a     alert (bell)
	      \b     backspace
	      \d     delete
	      \f     form feed
	      \n     newline
	      \r     carriage return
	      \t     horizontal tab
	      \v     vertical tab
	      \nnn   the  eight-bit  character	whose value is the octal value
		     nnn (one to three digits)
	      \xHH   the eight-bit character whose value  is  the  hexadecimal
		     value HH (one or two hex digits)

       When  entering  the  text of a macro, single or double quotes should be
       used to indicate a macro definition.  Unquoted text is assumed to be  a
       function	 name.	 In  the  macro	 body, the backslash escapes described
       above are expanded.  Backslash will quote any other  character  in  the
       macro text, including " and '.

       Bash  allows the current readline key bindings to be displayed or modi‐
       fied with the bind builtin command.  The editing mode may  be  switched
       during  interactive  use by using the -o option to the set builtin com‐
       mand.  Other programs using this library	 provide  similar  mechanisms.
       The  inputrc  file may be edited and re-read if a program does not pro‐
       vide any other means to incorporate new bindings.

   Variables
       Readline has variables that can be used to further customize its behav‐
       ior.  A variable may be set in the inputrc file with a statement of the
       form

	      set variable-name value

       Except where noted, readline variables can take the values  On  or  Off
       (without	 regard	 to  case).   Unrecognized variable names are ignored.
       When a variable value is read, empty or null values, "on"  (case-insen‐
       sitive), and "1" are equivalent to On.  All other values are equivalent
       to Off.	The variables and their default values are:

       active-region-start-color
	      A string variable that controls the text	color  and  background
	      when  displaying the text in the active region (see the descrip‐
	      tion of enable-active-region below).  This string must not  take
	      up any physical character positions on the display, so it should
	      consist only of terminal escape sequences.  It is output to  the
	      terminal	before displaying the text in the active region.  This
	      variable is reset to the default	value  whenever	 the  terminal
	      type  changes.   The  default  value is the string that puts the
	      terminal in standout mode, as obtained from the terminal's  ter‐
	      minfo description.  A sample value might be "\e[01;33m".
       active-region-end-color
	      A	 string	 variable  that	 "undoes"  the	effects	 of active-re‐
	      gion-start-color and restores "normal" terminal display  appear‐
	      ance  after  displaying  text in the active region.  This string
	      must not take up any physical character positions	 on  the  dis‐
	      play,  so	 it  should consist only of terminal escape sequences.
	      It is output to the terminal after displaying the	 text  in  the
	      active  region.	This  variable	is  reset to the default value
	      whenever the terminal type changes.  The default	value  is  the
	      string  that  restores  the  terminal from standout mode, as ob‐
	      tained from the terminal's terminfo description.	A sample value
	      might be "\e[0m".
       bell-style (audible)
	      Controls	what  happens when readline wants to ring the terminal
	      bell.  If set to none, readline never rings the bell.  If set to
	      visible,	readline  uses a visible bell if one is available.  If
	      set to audible, readline attempts to ring the terminal's bell.
       bind-tty-special-chars (On)
	      If set to On (the default), readline attempts to bind  the  con‐
	      trol  characters	  treated  specially  by the kernel's terminal
	      driver to their readline equivalents.
       blink-matching-paren (Off)
	      If set to On, readline attempts to briefly move the cursor to an
	      opening parenthesis when a closing parenthesis is inserted.
       colored-completion-prefix (Off)
	      If  set  to  On, when listing completions, readline displays the
	      common prefix of the set of possible completions using a differ‐
	      ent  color.   The	 color definitions are taken from the value of
	      the LS_COLORS environment variable.  If there is a color defini‐
	      tion  in $LS_COLORS for the custom suffix "readline-colored-com‐
	      pletion-prefix", readline uses this color for the common	prefix
	      instead of its default.
       colored-stats (Off)
	      If  set to On, readline displays possible completions using dif‐
	      ferent colors to indicate their file type.   The	color  defini‐
	      tions  are  taken	 from  the  value of the LS_COLORS environment
	      variable.
       comment-begin (``#'')
	      The string that is inserted in vi mode when  the	insert-comment
	      command is executed.  This command is bound to M-# in emacs mode
	      and to # in vi command mode.
       completion-display-width (-1)
	      The number of screen columns used to  display  possible  matches
	      when  performing completion.  The value is ignored if it is less
	      than 0 or greater than the terminal screen width.	 A value of  0
	      will  cause  matches  to be displayed one per line.  The default
	      value is -1.
       completion-ignore-case (Off)
	      If set to On, readline performs filename matching and completion
	      in a case-insensitive fashion.
       completion-map-case (Off)
	      If  set  to  On, and completion-ignore-case is enabled, readline
	      treats hyphens (-) and underscores (_) as equivalent  when  per‐
	      forming case-insensitive filename matching and completion.
       completion-prefix-display-length (0)
	      The  length in characters of the common prefix of a list of pos‐
	      sible completions that is displayed without modification.	  When
	      set  to  a  value greater than zero, common prefixes longer than
	      this value are replaced with an ellipsis when displaying	possi‐
	      ble completions.
       completion-query-items (100)
	      This  determines when the user is queried about viewing the num‐
	      ber of possible completions generated  by	 the  possible-comple‐
	      tions  command.  It may be set to any integer value greater than
	      or equal to zero.	 If the	 number	 of  possible  completions  is
	      greater  than  or	 equal to the value of this variable, readline
	      will ask whether or not the user wishes to view them;  otherwise
	      they are simply listed on the terminal.  A negative value causes
	      readline to never ask.
       convert-meta (On)
	      If set to On, readline will convert characters with  the	eighth
	      bit set to an ASCII key sequence by stripping the eighth bit and
	      prefixing it with an escape character (in effect,	 using	escape
	      as  the  meta prefix).  The default is On, but readline will set
	      it to Off if the locale  contains	 eight-bit  characters.	  This
	      variable	is  dependent on the LC_CTYPE locale category, and may
	      change if the locale is changed.
       disable-completion (Off)
	      If set to On, readline will inhibit word completion.  Completion
	      characters  will	be  inserted into the line as if they had been
	      mapped to self-insert.
       echo-control-characters (On)
	      When set to On, on operating systems that indicate they  support
	      it, readline echoes a character corresponding to a signal gener‐
	      ated from the keyboard.
       editing-mode (emacs)
	      Controls whether readline begins with a set of key bindings sim‐
	      ilar to Emacs or vi.  editing-mode can be set to either emacs or
	      vi.
       emacs-mode-string (@)
	      If the show-mode-in-prompt variable is enabled, this  string  is
	      displayed immediately before the last line of the primary prompt
	      when emacs editing mode is active.  The value is expanded like a
	      key  binding,  so the standard set of meta- and control prefixes
	      and backslash escape sequences is available.  Use the \1 and  \2
	      escapes  to  begin and end sequences of non-printing characters,
	      which can be used to embed a terminal control sequence into  the
	      mode string.
       enable-active-region (On)
	      The  point  is the current cursor position, and mark refers to a
	      saved cursor position.  The text between the point and  mark  is
	      referred	to  as	the  region.  When this variable is set to On,
	      readline allows certain commands to designate the region as  ac‐
	      tive.   When  the region is active, readline highlights the text
	      in the region using the value of the  active-region-start-color,
	      which  defaults to the string that enables the terminal's stand‐
	      out mode.	 The active region shows the text inserted  by	brack‐
	      eted-paste  and  any matching text found by incremental and non-
	      incremental history searches.
       enable-bracketed-paste (On)
	      When set to On, readline configures the terminal to insert  each
	      paste  into the editing buffer as a single string of characters,
	      instead of treating each character as if it had been  read  from
	      the keyboard.  This prevents readline from executing any editing
	      commands bound to key sequences appearing in the pasted text.
       enable-keypad (Off)
	      When set to On, readline will try to enable the application key‐
	      pad when it is called.  Some systems need this to enable the ar‐
	      row keys.
       enable-meta-key (On)
	      When set to On, readline will try to enable  any	meta  modifier
	      key  the	terminal claims to support when it is called.  On many
	      terminals, the meta key is used to send eight-bit characters.
       expand-tilde (Off)
	      If set to On, tilde expansion is	performed  when	 readline  at‐
	      tempts word completion.
       history-preserve-point (Off)
	      If  set  to  On, the history code attempts to place point at the
	      same location on each history line retrieved with	 previous-his‐
	      tory or next-history.
       history-size (unset)
	      Set  the	maximum number of history entries saved in the history
	      list.  If set to zero, any existing history entries are  deleted
	      and no new entries are saved.  If set to a value less than zero,
	      the number of history entries is not limited.  By	 default,  the
	      number of history entries is not limited.	 If an attempt is made
	      to set history-size to a non-numeric value, the  maximum	number
	      of history entries will be set to 500.
       horizontal-scroll-mode (Off)
	      When  set	 to  On, makes readline use a single line for display,
	      scrolling the input horizontally on a single screen line when it
	      becomes  longer  than the screen width rather than wrapping to a
	      new line.	 This setting is automatically enabled	for  terminals
	      of height 1.
       input-meta (Off)
	      If  set to On, readline will enable eight-bit input (that is, it
	      will not clear the eighth bit in the characters it  reads),  re‐
	      gardless	of  what the terminal claims it can support.  The name
	      meta-flag is a synonym for this variable.	 The default  is  Off,
	      but  readline will set it to On if the locale contains eight-bit
	      characters.  This variable is dependent on the  LC_CTYPE	locale
	      category, and may change if the locale is changed.
       isearch-terminators (``C-[ C-J'')
	      The  string  of  characters that should terminate an incremental
	      search without subsequently executing the character  as  a  com‐
	      mand.   If this variable has not been given a value, the charac‐
	      ters ESC and C-J will terminate an incremental search.
       keymap (emacs)
	      Set the current readline keymap.	The set of legal keymap	 names
	      is  emacs,  emacs-standard, emacs-meta, emacs-ctlx, vi, vi-move,
	      vi-command, and vi-insert.   vi  is  equivalent  to  vi-command;
	      emacs  is	 equivalent  to	 emacs-standard.  The default value is
	      emacs.  The value	 of  editing-mode  also	 affects  the  default
	      keymap.
       keyseq-timeout (500)
	      Specifies	 the  duration readline will wait for a character when
	      reading an ambiguous key sequence (one that can form a  complete
	      key sequence using the input read so far, or can take additional
	      input to complete a longer key sequence).	 If no	input  is  re‐
	      ceived  within  the  timeout,  readline will use the shorter but
	      complete key sequence.  The value is specified in	 milliseconds,
	      so  a value of 1000 means that readline will wait one second for
	      additional input.	 If this variable is set to a value less  than
	      or  equal to zero, or to a non-numeric value, readline will wait
	      until another key is pressed to decide  which  key  sequence  to
	      complete.
       mark-directories (On)
	      If set to On, completed directory names have a slash appended.
       mark-modified-lines (Off)
	      If  set  to  On,	history lines that have been modified are dis‐
	      played with a preceding asterisk (*).
       mark-symlinked-directories (Off)
	      If set to On, completed names which are symbolic links to direc‐
	      tories  have  a slash appended (subject to the value of mark-di‐
	      rectories).
       match-hidden-files (On)
	      This variable, when set to On, causes readline  to  match	 files
	      whose  names  begin  with	 a  `.' (hidden files) when performing
	      filename completion.  If set to Off, the	leading	 `.'  must  be
	      supplied by the user in the filename to be completed.
       menu-complete-display-prefix (Off)
	      If  set to On, menu completion displays the common prefix of the
	      list of possible completions (which may be empty) before cycling
	      through the list.
       output-meta (Off)
	      If  set  to On, readline will display characters with the eighth
	      bit set directly rather than as a meta-prefixed escape sequence.
	      The default is Off, but readline will set it to On if the locale
	      contains eight-bit characters.  This variable  is	 dependent  on
	      the  LC_CTYPE  locale  category, and may change if the locale is
	      changed.
       page-completions (On)
	      If set to On, readline uses an internal more-like pager to  dis‐
	      play a screenful of possible completions at a time.
       print-completions-horizontally (Off)
	      If  set  to  On,	readline will display completions with matches
	      sorted horizontally in alphabetical order, rather than down  the
	      screen.
       revert-all-at-newline (Off)
	      If  set  to  On, readline will undo all changes to history lines
	      before returning when accept-line is executed.  By default, his‐
	      tory  lines  may	be  modified  and retain individual undo lists
	      across calls to readline.
       show-all-if-ambiguous (Off)
	      This alters the default behavior of  the	completion  functions.
	      If set to On, words which have more than one possible completion
	      cause the matches to be listed immediately  instead  of  ringing
	      the bell.
       show-all-if-unmodified (Off)
	      This  alters the default behavior of the completion functions in
	      a fashion similar to show-all-if-ambiguous.  If set to On, words
	      which  have more than one possible completion without any possi‐
	      ble partial completion (the possible completions don't  share  a
	      common  prefix)  cause  the matches to be listed immediately in‐
	      stead of ringing the bell.
       show-mode-in-prompt (Off)
	      If set to On, add a string to the beginning of the prompt	 indi‐
	      cating  the  editing  mode:  emacs, vi command, or vi insertion.
	      The mode strings are user-settable (e.g., emacs-mode-string).
       skip-completed-text (Off)
	      If set to On, this alters the default completion	behavior  when
	      inserting	 a  single match into the line.	 It's only active when
	      performing completion in the middle  of  a  word.	  If  enabled,
	      readline	does  not  insert  characters from the completion that
	      match characters after point in the  word	 being	completed,  so
	      portions of the word following the cursor are not duplicated.
       vi-cmd-mode-string ((cmd))
	      If  the  show-mode-in-prompt variable is enabled, this string is
	      displayed immediately before the last line of the primary prompt
	      when  vi	editing mode is active and in command mode.  The value
	      is expanded like a key binding, so the standard set of meta- and
	      control  prefixes	 and  backslash escape sequences is available.
	      Use the \1 and \2 escapes to begin and  end  sequences  of  non-
	      printing	characters, which can be used to embed a terminal con‐
	      trol sequence into the mode string.
       vi-ins-mode-string ((ins))
	      If the show-mode-in-prompt variable is enabled, this  string  is
	      displayed immediately before the last line of the primary prompt
	      when vi editing mode is active and in insertion mode.  The value
	      is expanded like a key binding, so the standard set of meta- and
	      control prefixes and backslash escape  sequences	is  available.
	      Use  the	\1  and	 \2 escapes to begin and end sequences of non-
	      printing characters, which can be used to embed a terminal  con‐
	      trol sequence into the mode string.
       visible-stats (Off)
	      If  set to On, a character denoting a file's type as reported by
	      stat(2) is appended to the filename when listing	possible  com‐
	      pletions.

   Conditional Constructs
       Readline	 implements  a	facility  similar in spirit to the conditional
       compilation features of the C preprocessor which	 allows	 key  bindings
       and  variable  settings	to be performed as the result of tests.	 There
       are four parser directives used.

       $if    The $if construct allows bindings to be made based on the	 edit‐
	      ing  mode,  the  terminal	 being	used, or the application using
	      readline.	 The text of the test, after any comparison  operator,
	      extends to the end of the line; unless otherwise noted, no char‐
	      acters are required to isolate it.

	      mode   The mode= form of the  $if	 directive  is	used  to  test
		     whether  readline	is  in	emacs or vi mode.  This may be
		     used in conjunction with the set keymap command, for  in‐
		     stance,  to set bindings in the emacs-standard and emacs-
		     ctlx keymaps only if readline is starting	out  in	 emacs
		     mode.

	      term   The  term=	 form may be used to include terminal-specific
		     key bindings, perhaps to bind the key sequences output by
		     the terminal's function keys.  The word on the right side
		     of the = is tested against the full name of the  terminal
		     and  the portion of the terminal name before the first -.
		     This allows sun to match both sun and  sun-cmd,  for  in‐
		     stance.

	      version
		     The  version  test	 may  be  used	to perform comparisons
		     against specific readline versions.  The version  expands
		     to	 the  current readline version.	 The set of comparison
		     operators includes =, (and ==), !=, <=,  >=,  <,  and  >.
		     The  version number supplied on the right side of the op‐
		     erator consists of a major version	 number,  an  optional
		     decimal point, and an optional minor version (e.g., 7.1).
		     If the minor version is omitted, it is assumed to	be  0.
		     The operator may be separated from the string version and
		     from the version number argument by whitespace.

	      application
		     The application construct is used to include application-
		     specific  settings.   Each program using the readline li‐
		     brary sets the application name,  and  an	initialization
		     file can test for a particular value.  This could be used
		     to bind key sequences to functions useful for a  specific
		     program.	For instance, the following command adds a key
		     sequence that quotes the  current	or  previous  word  in
		     bash:

		     $if Bash
		     # Quote the current or previous word
		     "\C-xq": "\eb\"\ef\""
		     $endif

	      variable
		     The variable construct provides simple equality tests for
		     readline variables and values.  The permitted  comparison
		     operators	are  =, ==, and !=.  The variable name must be
		     separated from the comparison operator by whitespace; the
		     operator  may  be	separated  from the value on the right
		     hand side by whitespace.  Both string and	boolean	 vari‐
		     ables  may	 be  tested.  Boolean variables must be tested
		     against the values on and off.

       $endif This command, as seen in the previous example, terminates an $if
	      command.

       $else  Commands in this branch of the $if directive are executed if the
	      test fails.

       $include
	      This directive takes a single filename as an argument and	 reads
	      commands	and bindings from that file.  For example, the follow‐
	      ing directive would read /etc/inputrc:

	      $include	/etc/inputrc

SEARCHING
       Readline provides commands for searching through	 the  command  history
       for  lines  containing a specified string.  There are two search modes:
       incremental and non-incremental.

       Incremental searches begin before the  user  has	 finished  typing  the
       search  string.	As each character of the search string is typed, read‐
       line displays the next entry from the history matching the string typed
       so  far.	  An  incremental  search  requires only as many characters as
       needed to find the desired history entry.  To search  backward  in  the
       history for a particular string, type C-r.  Typing C-s searches forward
       through the history.  The  characters  present  in  the	value  of  the
       isearch-terminators  variable  are  used	 to  terminate	an incremental
       search.	If that variable has not been assigned a value the Escape  and
       C-J characters will terminate an incremental search.  C-G will abort an
       incremental search and restore the original line.  When the  search  is
       terminated,  the history entry containing the search string becomes the
       current line.

       To find other matching entries in the history list, type C-s or C-r  as
       appropriate.   This  will search backward or forward in the history for
       the next line matching the search string typed so far.  Any  other  key
       sequence bound to a readline command will terminate the search and exe‐
       cute that command.  For instance, a newline will terminate  the	search
       and  accept  the	 line,	thereby executing the command from the history
       list.  A movement command will terminate the search, make the last line
       found the current line, and begin editing.

       Non-incremental	searches read the entire search string before starting
       to search for matching history lines.  The search string may  be	 typed
       by the user or be part of the contents of the current line.

EDITING COMMANDS
       The  following  is  a list of the names of the commands and the default
       key sequences to which they are bound.  Command names without an accom‐
       panying key sequence are unbound by default.

       In the following descriptions, point refers to the current cursor posi‐
       tion, and mark refers to a cursor position saved by the	set-mark  com‐
       mand.   The  text  between the point and mark is referred to as the re‐
       gion.

   Commands for Moving
       beginning-of-line (C-a)
	      Move to the start of the current line.
       end-of-line (C-e)
	      Move to the end of the line.
       forward-char (C-f)
	      Move forward a character.
       backward-char (C-b)
	      Move back a character.
       forward-word (M-f)
	      Move forward to the end of the next word.	 Words are composed of
	      alphanumeric characters (letters and digits).
       backward-word (M-b)
	      Move  back  to the start of the current or previous word.	 Words
	      are composed of alphanumeric characters (letters and digits).
       previous-screen-line
	      Attempt to move point to the same physical screen column on  the
	      previous	physical  screen  line. This will not have the desired
	      effect if the current readline line does not take up  more  than
	      one  physical line or if point is not greater than the length of
	      the prompt plus the screen width.
       next-screen-line
	      Attempt to move point to the same physical screen column on  the
	      next physical screen line. This will not have the desired effect
	      if the current readline line does not  take  up  more  than  one
	      physical	line  or if the length of the current readline line is
	      not greater than the length of the prompt plus the screen width.
       clear-display (M-C-l)
	      Clear the screen and, if	possible,  the	terminal's  scrollback
	      buffer,  then  redraw the current line, leaving the current line
	      at the top of the screen.
       clear-screen (C-l)
	      Clear the screen, then redraw the current line, leaving the cur‐
	      rent  line  at the top of the screen.  With an argument, refresh
	      the current line without clearing the screen.
       redraw-current-line
	      Refresh the current line.

   Commands for Manipulating the History
       accept-line (Newline, Return)
	      Accept the line regardless of where the cursor is.  If this line
	      is non-empty, it may be added to the history list for future re‐
	      call with add_history().	If the	line  is  a  modified  history
	      line, the history line is restored to its original state.
       previous-history (C-p)
	      Fetch the previous command from the history list, moving back in
	      the list.
       next-history (C-n)
	      Fetch the next command from the history list, moving forward  in
	      the list.
       beginning-of-history (M-<)
	      Move to the first line in the history.
       end-of-history (M->)
	      Move  to	the end of the input history, i.e., the line currently
	      being entered.
       operate-and-get-next (C-o)
	      Accept the current line for return to the calling application as
	      if  a newline had been entered, and fetch the next line relative
	      to the current line from the history for editing.	 A numeric ar‐
	      gument,  if supplied, specifies the history entry to use instead
	      of the current line.
       fetch-history
	      With a numeric argument, fetch that entry from the history  list
	      and make it the current line.  Without an argument, move back to
	      the first entry in the history list.
       reverse-search-history (C-r)
	      Search backward starting at the current  line  and  moving  `up'
	      through  the  history  as	 necessary.   This  is	an incremental
	      search.
       forward-search-history (C-s)
	      Search forward starting at the current line  and	moving	`down'
	      through  the  history  as	 necessary.   This  is	an incremental
	      search.
       non-incremental-reverse-search-history (M-p)
	      Search backward through the history starting at the current line
	      using  a	non-incremental	 search	 for  a string supplied by the
	      user.
       non-incremental-forward-search-history (M-n)
	      Search forward  through  the  history  using  a  non-incremental
	      search for a string supplied by the user.
       history-search-backward
	      Search backward through the history for the string of characters
	      between the start of the current line and the current cursor po‐
	      sition  (the point).  The search string must match at the begin‐
	      ning of a history line.  This is a non-incremental search.
       history-search-forward
	      Search forward through the history for the string of  characters
	      between the start of the current line and the point.  The search
	      string must match at the beginning of a history line.  This is a
	      non-incremental search.
       history-substring-search-backward
	      Search backward through the history for the string of characters
	      between the start of the current line and the current cursor po‐
	      sition  (the  point).  The search string may match anywhere in a
	      history line.  This is a non-incremental search.
       history-substring-search-forward
	      Search forward through the history for the string of  characters
	      between the start of the current line and the point.  The search
	      string may match anywhere in a history line.  This is a  non-in‐
	      cremental search.
       yank-nth-arg (M-C-y)
	      Insert  the  first argument to the previous command (usually the
	      second word on the previous line) at point.  With an argument n,
	      insert  the nth word from the previous command (the words in the
	      previous command begin with word 0).  A  negative	 argument  in‐
	      serts  the  nth word from the end of the previous command.  Once
	      the argument n is computed, the argument is extracted as if  the
	      "!n" history expansion had been specified.
       yank-last-arg (M-., M-_)
	      Insert  the last argument to the previous command (the last word
	      of the previous history entry).  With a numeric argument, behave
	      exactly  like  yank-nth-arg.   Successive calls to yank-last-arg
	      move back through the history list, inserting the last word  (or
	      the  word	 specified  by the argument to the first call) of each
	      line in turn.  Any numeric argument supplied to these successive
	      calls  determines	 the direction to move through the history.  A
	      negative argument switches the  direction	 through  the  history
	      (back or forward).  The history expansion facilities are used to
	      extract the last argument, as if the "!$" history expansion  had
	      been specified.

   Commands for Changing Text
       end-of-file (usually C-d)
	      The  character  indicating  end-of-file  as set, for example, by
	      ``stty''.	 If this character is read when there are  no  charac‐
	      ters  on	the  line,  and point is at the beginning of the line,
	      readline interprets it as the end of input and returns EOF.
       delete-char (C-d)
	      Delete the character at point.  If this function is bound to the
	      same character as the tty EOF character, as C-d commonly is, see
	      above for the effects.
       backward-delete-char (Rubout)
	      Delete the character behind the cursor.  When  given  a  numeric
	      argument, save the deleted text on the kill ring.
       forward-backward-delete-char
	      Delete  the  character under the cursor, unless the cursor is at
	      the end of the line, in which case the character behind the cur‐
	      sor is deleted.
       quoted-insert (C-q, C-v)
	      Add the next character that you type to the line verbatim.  This
	      is how to insert characters like C-q, for example.
       tab-insert (M-TAB)
	      Insert a tab character.
       self-insert (a, b, A, 1, !, ...)
	      Insert the character typed.
       transpose-chars (C-t)
	      Drag the character before point forward over  the	 character  at
	      point,  moving point forward as well.  If point is at the end of
	      the line, then this transposes the two characters before	point.
	      Negative arguments have no effect.
       transpose-words (M-t)
	      Drag  the	 word  before  point past the word after point, moving
	      point over that word as well.  If point is at  the  end  of  the
	      line, this transposes the last two words on the line.
       upcase-word (M-u)
	      Uppercase	 the current (or following) word.  With a negative ar‐
	      gument, uppercase the previous word, but do not move point.
       downcase-word (M-l)
	      Lowercase the current (or following) word.  With a negative  ar‐
	      gument, lowercase the previous word, but do not move point.
       capitalize-word (M-c)
	      Capitalize the current (or following) word.  With a negative ar‐
	      gument, capitalize the previous word, but do not move point.
       overwrite-mode
	      Toggle overwrite mode.  With an explicit positive numeric	 argu‐
	      ment, switches to overwrite mode.	 With an explicit non-positive
	      numeric argument, switches to insert mode.  This command affects
	      only  emacs mode; vi mode does overwrite differently.  Each call
	      to readline() starts in insert mode.  In overwrite mode, charac‐
	      ters  bound to self-insert replace the text at point rather than
	      pushing the text	to  the	 right.	  Characters  bound  to	 back‐
	      ward-delete-char	replace	 the  character	 before	 point	with a
	      space.  By default, this command is unbound.

   Killing and Yanking
       kill-line (C-k)
	      Kill the text from point to the end of the line.
       backward-kill-line (C-x Rubout)
	      Kill backward to the beginning of the line.
       unix-line-discard (C-u)
	      Kill backward from point to the  beginning  of  the  line.   The
	      killed text is saved on the kill-ring.
       kill-whole-line
	      Kill  all	 characters on the current line, no matter where point
	      is.
       kill-word (M-d)
	      Kill from point the end of  the  current	word,  or  if  between
	      words,  to  the  end  of the next word.  Word boundaries are the
	      same as those used by forward-word.
       backward-kill-word (M-Rubout)
	      Kill the word behind point.  Word boundaries  are	 the  same  as
	      those used by backward-word.
       unix-word-rubout (C-w)
	      Kill  the	 word behind point, using white space as a word bound‐
	      ary.  The killed text is saved on the kill-ring.
       unix-filename-rubout
	      Kill the word behind point, using	 white	space  and  the	 slash
	      character	 as  the word boundaries.  The killed text is saved on
	      the kill-ring.
       delete-horizontal-space (M-\)
	      Delete all spaces and tabs around point.
       kill-region
	      Kill the text between the point and  mark	 (saved	 cursor	 posi‐
	      tion).  This text is referred to as the region.
       copy-region-as-kill
	      Copy the text in the region to the kill buffer.
       copy-backward-word
	      Copy  the word before point to the kill buffer.  The word bound‐
	      aries are the same as backward-word.
       copy-forward-word
	      Copy the word following point to	the  kill  buffer.   The  word
	      boundaries are the same as forward-word.
       yank (C-y)
	      Yank the top of the kill ring into the buffer at point.
       yank-pop (M-y)
	      Rotate  the kill ring, and yank the new top.  Only works follow‐
	      ing yank or yank-pop.

   Numeric Arguments
       digit-argument (M-0, M-1, ..., M--)
	      Add this digit to the argument already accumulating, or start  a
	      new argument.  M-- starts a negative argument.
       universal-argument
	      This  is another way to specify an argument.  If this command is
	      followed by one or more digits, optionally with a leading	 minus
	      sign,  those digits define the argument.	If the command is fol‐
	      lowed by digits, executing universal-argument again ends the nu‐
	      meric argument, but is otherwise ignored.	 As a special case, if
	      this command is immediately followed by a character that is nei‐
	      ther a digit or minus sign, the argument count for the next com‐
	      mand is multiplied by four.  The	argument  count	 is  initially
	      one,  so	executing this function the first time makes the argu‐
	      ment count four, a second time makes the argument count sixteen,
	      and so on.

   Completing
       complete (TAB)
	      Attempt to perform completion on the text before point.  The ac‐
	      tual completion performed is  application-specific.   Bash,  for
	      instance,	 attempts  completion  treating the text as a variable
	      (if the text begins with $), username (if the text  begins  with
	      ~),  hostname (if the text begins with @), or command (including
	      aliases and functions) in turn.  If none	of  these  produces  a
	      match,  filename	completion  is	attempted.   Gdb, on the other
	      hand, allows completion of program functions and variables,  and
	      only attempts filename completion under certain circumstances.
       possible-completions (M-?)
	      List  the	 possible  completions of the text before point.  When
	      displaying completions, readline sets the number of columns used
	      for  display to the value of completion-display-width, the value
	      of the environment variable COLUMNS, or  the  screen  width,  in
	      that order.
       insert-completions (M-*)
	      Insert  all completions of the text before point that would have
	      been generated by possible-completions.
       menu-complete
	      Similar to complete, but replaces the word to be completed  with
	      a	 single match from the list of possible completions.  Repeated
	      execution of menu-complete steps through the  list  of  possible
	      completions,  inserting  each  match in turn.  At the end of the
	      list of completions, the bell is rung (subject to the setting of
	      bell-style) and the original text is restored.  An argument of n
	      moves n positions forward in the list of matches; a negative ar‐
	      gument may be used to move backward through the list.  This com‐
	      mand is intended to be bound to TAB, but is unbound by default.
       menu-complete-backward
	      Identical to menu-complete, but moves backward through the  list
	      of  possible  completions,  as if menu-complete had been given a
	      negative argument.  This command is unbound by default.
       delete-char-or-list
	      Deletes the character under the cursor if not at	the  beginning
	      or  end  of  the	line (like delete-char).  If at the end of the
	      line, behaves identically to possible-completions.

   Keyboard Macros
       start-kbd-macro (C-x ()
	      Begin saving the characters  typed  into	the  current  keyboard
	      macro.
       end-kbd-macro (C-x ))
	      Stop saving the characters typed into the current keyboard macro
	      and store the definition.
       call-last-kbd-macro (C-x e)
	      Re-execute the last keyboard macro defined, by making the	 char‐
	      acters in the macro appear as if typed at the keyboard.
       print-last-kbd-macro ()
	      Print  the  last keyboard macro defined in a format suitable for
	      the inputrc file.

   Miscellaneous
       re-read-init-file (C-x C-r)
	      Read in the contents of the inputrc file,	 and  incorporate  any
	      bindings or variable assignments found there.
       abort (C-g)
	      Abort  the  current editing command and ring the terminal's bell
	      (subject to the setting of bell-style).
       do-lowercase-version (M-A, M-B, M-x, ...)
	      If the metafied character x is uppercase, run the	 command  that
	      is bound to the corresponding metafied lowercase character.  The
	      behavior is undefined if x is already lowercase.
       prefix-meta (ESC)
	      Metafy the next character typed.	ESC f is equivalent to Meta-f.
       undo (C-_, C-x C-u)
	      Incremental undo, separately remembered for each line.
       revert-line (M-r)
	      Undo all changes made to this line.  This is like executing  the
	      undo  command  enough  times  to	return the line to its initial
	      state.
       tilde-expand (M-&)
	      Perform tilde expansion on the current word.
       set-mark (C-@, M-<space>)
	      Set the mark to the point.  If a numeric argument	 is  supplied,
	      the mark is set to that position.
       exchange-point-and-mark (C-x C-x)
	      Swap  the	 point	with the mark.	The current cursor position is
	      set to the saved position, and the old cursor position is	 saved
	      as the mark.
       character-search (C-])
	      A character is read and point is moved to the next occurrence of
	      that character.  A negative argument searches for	 previous  oc‐
	      currences.
       character-search-backward (M-C-])
	      A	 character  is	read and point is moved to the previous occur‐
	      rence of that character.	A negative argument searches for  sub‐
	      sequent occurrences.
       skip-csi-sequence
	      Read  enough  characters to consume a multi-key sequence such as
	      those defined for keys like Home and End.	 Such sequences	 begin
	      with a Control Sequence Indicator (CSI), usually ESC-[.  If this
	      sequence is bound to "\[", keys producing	 such  sequences  will
	      have  no	effect	unless explicitly bound to a readline command,
	      instead of inserting stray characters into the  editing  buffer.
	      This is unbound by default, but usually bound to ESC-[.
       insert-comment (M-#)
	      Without  a  numeric  argument,  the  value  of the readline com‐
	      ment-begin variable is inserted at the beginning of the  current
	      line.  If a numeric argument is supplied, this command acts as a
	      toggle: if the characters at the beginning of the	 line  do  not
	      match  the value of comment-begin, the value is inserted, other‐
	      wise the characters in comment-begin are deleted from the begin‐
	      ning  of the line.  In either case, the line is accepted as if a
	      newline had been typed.	The  default  value  of	 comment-begin
	      makes  the  current line a shell comment.	 If a numeric argument
	      causes the comment character to be removed, the line will be ex‐
	      ecuted by the shell.
       dump-functions
	      Print  all  of the functions and their key bindings to the read‐
	      line output stream.  If a numeric argument is supplied, the out‐
	      put  is  formatted  in such a way that it can be made part of an
	      inputrc file.
       dump-variables
	      Print all of the settable variables  and	their  values  to  the
	      readline	output stream.	If a numeric argument is supplied, the
	      output is formatted in such a way that it can be made part of an
	      inputrc file.
       dump-macros
	      Print  all of the readline key sequences bound to macros and the
	      strings they output.  If a numeric  argument  is	supplied,  the
	      output is formatted in such a way that it can be made part of an
	      inputrc file.
       emacs-editing-mode (C-e)
	      When in vi command mode, this causes a switch to	emacs  editing
	      mode.
       vi-editing-mode (M-C-j)
	      When  in	emacs editing mode, this causes a switch to vi editing
	      mode.

DEFAULT KEY BINDINGS
       The following is a list of the default emacs and vi bindings.   Charac‐
       ters  with the eighth bit set are written as M-<character>, and are re‐
       ferred to as metafied characters.  The printable ASCII  characters  not
       mentioned  in  the  list	 of  emacs  standard bindings are bound to the
       self-insert function, which just inserts the given character  into  the
       input line.  In vi insertion mode, all characters not specifically men‐
       tioned are bound to self-insert.	 Characters assigned to signal genera‐
       tion by stty(1) or the terminal driver, such as C-Z or C-C, retain that
       function.  Upper and lower case metafied characters are	bound  to  the
       same  function in the emacs mode meta keymap.  The remaining characters
       are unbound, which causes readline to ring the  bell  (subject  to  the
       setting of the bell-style variable).

   Emacs Mode
	     Emacs Standard bindings

	     "C-@"  set-mark
	     "C-A"  beginning-of-line
	     "C-B"  backward-char
	     "C-D"  delete-char
	     "C-E"  end-of-line
	     "C-F"  forward-char
	     "C-G"  abort
	     "C-H"  backward-delete-char
	     "C-I"  complete
	     "C-J"  accept-line
	     "C-K"  kill-line
	     "C-L"  clear-screen
	     "C-M"  accept-line
	     "C-N"  next-history
	     "C-P"  previous-history
	     "C-Q"  quoted-insert
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-]"  character-search
	     "C-_"  undo
	     " " to "/"	 self-insert
	     "0"  to "9"  self-insert
	     ":"  to "~"  self-insert
	     "C-?"  backward-delete-char

	     Emacs Meta bindings

	     "M-C-G"  abort
	     "M-C-H"  backward-kill-word
	     "M-C-I"  tab-insert
	     "M-C-J"  vi-editing-mode
	     "M-C-L"  clear-display
	     "M-C-M"  vi-editing-mode
	     "M-C-R"  revert-line
	     "M-C-Y"  yank-nth-arg
	     "M-C-["  complete
	     "M-C-]"  character-search-backward
	     "M-space"	set-mark
	     "M-#"  insert-comment
	     "M-&"  tilde-expand
	     "M-*"  insert-completions
	     "M--"  digit-argument
	     "M-."  yank-last-arg
	     "M-0"  digit-argument
	     "M-1"  digit-argument
	     "M-2"  digit-argument
	     "M-3"  digit-argument
	     "M-4"  digit-argument
	     "M-5"  digit-argument
	     "M-6"  digit-argument
	     "M-7"  digit-argument
	     "M-8"  digit-argument
	     "M-9"  digit-argument
	     "M-<"  beginning-of-history
	     "M-="  possible-completions
	     "M->"  end-of-history
	     "M-?"  possible-completions
	     "M-B"  backward-word
	     "M-C"  capitalize-word
	     "M-D"  kill-word
	     "M-F"  forward-word
	     "M-L"  downcase-word
	     "M-N"  non-incremental-forward-search-history
	     "M-P"  non-incremental-reverse-search-history
	     "M-R"  revert-line
	     "M-T"  transpose-words
	     "M-U"  upcase-word
	     "M-Y"  yank-pop
	     "M-\"  delete-horizontal-space
	     "M-~"  tilde-expand
	     "M-C-?"  backward-kill-word
	     "M-_"  yank-last-arg

	     Emacs Control-X bindings

	     "C-XC-G"  abort
	     "C-XC-R"  re-read-init-file
	     "C-XC-U"  undo
	     "C-XC-X"  exchange-point-and-mark
	     "C-X("  start-kbd-macro
	     "C-X)"  end-kbd-macro
	     "C-XE"  call-last-kbd-macro
	     "C-XC-?"  backward-kill-line


   VI Mode bindings
	     VI Insert Mode functions

	     "C-D"  vi-eof-maybe
	     "C-H"  backward-delete-char
	     "C-I"  complete
	     "C-J"  accept-line
	     "C-M"  accept-line
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-["  vi-movement-mode
	     "C-_"  undo
	     " " to "~"	 self-insert
	     "C-?"  backward-delete-char

	     VI Command Mode functions

	     "C-D"  vi-eof-maybe
	     "C-E"  emacs-editing-mode
	     "C-G"  abort
	     "C-H"  backward-char
	     "C-J"  accept-line
	     "C-K"  kill-line
	     "C-L"  clear-screen
	     "C-M"  accept-line
	     "C-N"  next-history
	     "C-P"  previous-history
	     "C-Q"  quoted-insert
	     "C-R"  reverse-search-history
	     "C-S"  forward-search-history
	     "C-T"  transpose-chars
	     "C-U"  unix-line-discard
	     "C-V"  quoted-insert
	     "C-W"  unix-word-rubout
	     "C-Y"  yank
	     "C-_"  vi-undo
	     " "  forward-char
	     "#"  insert-comment
	     "$"  end-of-line
	     "%"  vi-match
	     "&"  vi-tilde-expand
	     "*"  vi-complete
	     "+"  next-history
	     ","  vi-char-search
	     "-"  previous-history
	     "."  vi-redo
	     "/"  vi-search
	     "0"  beginning-of-line
	     "1" to "9"	 vi-arg-digit
	     ";"  vi-char-search
	     "="  vi-complete
	     "?"  vi-search
	     "A"  vi-append-eol
	     "B"  vi-prev-word
	     "C"  vi-change-to
	     "D"  vi-delete-to
	     "E"  vi-end-word
	     "F"  vi-char-search
	     "G"  vi-fetch-history
	     "I"  vi-insert-beg
	     "N"  vi-search-again
	     "P"  vi-put
	     "R"  vi-replace
	     "S"  vi-subst
	     "T"  vi-char-search
	     "U"  revert-line
	     "W"  vi-next-word
	     "X"  backward-delete-char
	     "Y"  vi-yank-to
	     "\"  vi-complete
	     "^"  vi-first-print
	     "_"  vi-yank-arg
	     "`"  vi-goto-mark
	     "a"  vi-append-mode
	     "b"  vi-prev-word
	     "c"  vi-change-to
	     "d"  vi-delete-to
	     "e"  vi-end-word
	     "f"  vi-char-search
	     "h"  backward-char
	     "i"  vi-insertion-mode
	     "j"  next-history
	     "k"  prev-history
	     "l"  forward-char
	     "m"  vi-set-mark
	     "n"  vi-search-again
	     "p"  vi-put
	     "r"  vi-change-char
	     "s"  vi-subst
	     "t"  vi-char-search
	     "u"  vi-undo
	     "w"  vi-next-word
	     "x"  vi-delete
	     "y"  vi-yank-to
	     "|"  vi-column
	     "~"  vi-change-case

SEE ALSO
       The Gnu Readline Library, Brian Fox and Chet Ramey
       The Gnu History Library, Brian Fox and Chet Ramey
       bash(1)

FILES
       ~/.inputrc
	      Individual readline initialization file

AUTHORS
       Brian Fox, Free Software Foundation
       bfox@gnu.org

       Chet Ramey, Case Western Reserve University
       chet.ramey@case.edu

BUG REPORTS
       If  you	find  a bug in readline, you should report it.	But first, you
       should make sure that it really is a bug, and that it  appears  in  the
       latest version of the readline library that you have.

       Once  you have determined that a bug actually exists, mail a bug report
       to bug-readline@gnu.org.	 If you have a fix, you are  welcome  to  mail
       that  as	 well!	 Suggestions  and  `philosophical'  bug reports may be
       mailed to  bug-readline@gnu.org	or  posted  to	the  Usenet  newsgroup
       gnu.bash.bug.

       Comments and bug reports concerning this manual page should be directed
       to chet.ramey@case.edu.

BUGS
       It's too big and too slow.



GNU Readline 8.2	       2022 September 19		   READLINE(3)

HISTORY(3)		   Руководство по библиотечным функциям		    HISTORY(3)



NAME
       history - Библиотека истории GNU

COPYRIGHT
       Библиотека истории GNU защищена авторским правом (C) 1989-2020 Free Software Foundation, Inc.

DESCRIPTION
       Многие программы читают ввод от пользователя построчно. Библиотека истории GNU способна отслеживать эти строки, ассоциировать произвольные данные с каждой строкой и использовать информацию из предыдущих строк при составлении новых.

HISTORY EXPANSION
       Библиотека истории поддерживает функцию расширения истории, идентичную расширению истории в bash. В этом разделе описываются доступные синтаксические возможности.

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

       Расширение истории обычно выполняется сразу после чтения полной строки. Оно происходит в двух частях. Первая — определение, какая строка из списка истории должна использоваться для подстановки. Вторая — выбор частей этой строки для включения в текущую. Строка, выбранная из истории, называется событием, а части этой строки, на которые действуют, — словами. Доступны различные модификаторы для манипуляции выбранными словами. Строка разбивается на слова так же, как bash делает при чтении ввода, поэтому несколько слов, которые в противном случае были бы разделены, считаются одним словом, если они заключены в кавычки (см. описание history_tokenize() ниже). Расширения истории вводятся появлением символа расширения истории, по умолчанию это !. Только обратная косая черта (\) и одинарные кавычки могут экранировать символ расширения истории.

   Event Designators
       Event designator — это ссылка на запись командной строки в списке истории. Если ссылка не абсолютная, события относительно текущей позиции в списке истории.

       !      Начинает подстановку истории, кроме случаев, когда за ней следует пробел, новая строка, = или (.
       !n     Ссылка на командную строку n.
       !-n    Ссылка на текущую команду минус n.
       !!     Ссылка на предыдущую команду. Это синоним для `!-1'.
       !string
	      Ссылка на наиболее недавнюю команду перед текущей позицией в списке истории, начинающуюся с string.
       !?string[?]
	      Ссылка на наиболее недавнюю команду перед текущей позицией в списке истории, содержащую string. Завершающий ? можно опустить, если string сразу следует новая строка. Если string отсутствует, используется строка из наиболее недавнего поиска; это ошибка, если нет предыдущей строки поиска.
       ^string1^string2^
	      Быстрая подстановка. Повторить последнюю команду, заменяя string1 на string2. Эквивалентно ``!!:s^string1^string2^'' (см. Модификаторы ниже).
       !#     Вся командная строка, набранная до сих пор.

   Word Designators
       Word designators используются для выбора желаемых слов из события. : отделяет спецификацию события от word designator. Его можно опустить, если word designator начинается с ^, $, *, -, или %. Слова нумеруются с начала строки, с первым словом, обозначаемым 0 (ноль). Слова вставляются в текущую строку, разделенные одиночными пробелами.

       0 (zero)
	      Нулевое слово. Для оболочки это слово команды.
       n      N-ое слово.
       ^      Первый аргумент. То есть, слово 1.
       $      Последнее слово. Это обычно последний аргумент, но расширится до нулевого слова, если в строке только одно слово.
       %      Первое слово, совпавшее с наиболее недавним поиском `?string?', если строка поиска начинается с символа, который является частью слова.
       x-y    Диапазон слов; `-y' сокращает `0-y'.
       *      Все слова, кроме нулевого. Это синоним для `1-$'. Не является ошибкой использовать *, если в событии только одно слово; в этом случае возвращается пустая строка.
       x*     Сокращает x-$.
       x-     Сокращает x-$ как x*, но пропускает последнее слово. Если x отсутствует, оно по умолчанию равно 0.

       Если word designator указан без спецификации события, используется предыдущая команда как событие.

   Modifiers
       После необязательного word designator может появиться последовательность из одного или нескольких следующих модификаторов, каждый из которых предшествует :. Эти модификаторы изменяют или редактируют выбранное слово или слова из события истории.

       h      Удалить конечный компонент имени файла, оставив только заголовок.
       t      Удалить все начальные компоненты имени файла, оставив хвост.
       r      Удалить конечный суффикс вида .xxx, оставив базовое имя.
       e      Удалить все, кроме конечного суффикса.
       p      Вывести новую команду, но не выполнять её.
       q      Экранировать подставленные слова, предотвращая дальнейшие подстановки.
       x      Экранировать подставленные слова как q, но разбивать на слова по пробелам и новым строкам. Модификаторы q и x взаимоисключающие; используется последний указанный.
       s/old/new/
	      Подставить new на первое вхождение old в строке события. Любой символ можно использовать в качестве разделителя вместо /. Финальный разделитель необязателен, если он является последним символом строки события. Разделитель можно экранировать в old и new с помощью одиночной обратной косой черты. Если & появляется в new, оно заменяется на old. Одиночная обратная косая черта экранирует &. Если old пусто, оно устанавливается на последнее подставленное old, или, если не было предыдущих подстановок истории, на последнюю строку в !?string[?] поиске. Если new пусто, каждое совпавшее old удаляется.
       &      Повторить предыдущую подстановку.
       g      Применить изменения ко всей строке события. Это используется в сочетании с `:s' (например, `:gs/old/new/') или `:&'. Если используется с `:s', любой разделитель можно использовать вместо /, и финальный разделитель необязателен, если он является последним символом строки события. A может использоваться как синоним для g.
       G      Применить следующий модификатор `s' или `&' один раз к каждому слову в строке события.

PROGRAMMING WITH HISTORY FUNCTIONS
       В этом разделе описывается, как использовать функции истории в других программах.

   Introduction to History
       Программист, использующий библиотеку истории, имеет доступ к функциям для запоминания строк в списке истории, ассоциирования произвольных данных с строкой, удаления строк из списка, поиска в списке строки, содержащей произвольную текстовую строку, и ссылки на любую строку в списке напрямую. Кроме того, доступна функция расширения истории, которая обеспечивает последовательный пользовательский интерфейс в разных программах.

       Пользователь, использующий программы, написанные с помощью библиотеки истории, имеет преимущество последовательного пользовательского интерфейса с набором хорошо известных команд для манипуляции текстом предыдущих строк и использования этого текста в новых командах. Основные команды манипуляции историей идентичны подстановке истории, предоставляемой bash.

       Программист также может использовать библиотеку readline, которая по умолчанию включает некоторую манипуляцию историей, и имеет дополнительное преимущество редактирования командной строки.

       Перед объявлением любых функций с использованием функциональности, предоставляемой библиотекой истории, в другом коде, автор приложения должен включить файл <readline/history.h> в любой файл, который использует возможности библиотеки истории. Он предоставляет extern объявления для всех публичных функций и переменных библиотеки, а также объявляет все публичные структуры данных.

   History Storage
       Список истории — это массив записей истории. Запись истории объявлена следующим образом:

       typedef void * histdata_t;

       typedef struct _hist_entry {
	 char *line;
	 char *timestamp;
	 histdata_t data;
       } HIST_ENTRY;

       Сам список истории может быть объявлен как

       HIST_ENTRY ** the_history_list;

       Состояние библиотеки истории инкапсулировано в одну структуру:

       /*
	* Структура, используемая для передачи текущего состояния истории.
	*/
       typedef struct _hist_state {
	 HIST_ENTRY **entries; /* Указатель на сами записи. */
	 int offset;	       /* Указатель позиции в этом массиве. */
	 int length;	       /* Количество элементов в этом массиве. */
	 int size;	       /* Количество слотов, выделенных для этого массива. */
	 int flags;
       } HISTORY_STATE;

       Если флаг flags включает HS_STIFLED, история была подавлена.

History Functions
       В этом разделе описывается последовательность вызовов для различных функций, экспортируемых библиотекой истории GNU.

   Initializing History and State Management
       В этом разделе описываются функции, используемые для инициализации и управления состоянием библиотеки истории, когда вы хотите использовать функции истории в своей программе.

       void using_history (void)
       Начать сеанс, в котором могут использоваться функции истории. Это инициализирует интерактивные переменные.

       HISTORY_STATE * history_get_history_state (void)
       Возвратить структуру, описывающую текущее состояние списка ввода истории.

       void history_set_history_state (HISTORY_STATE *state)
       Установить состояние списка истории в соответствии с state.


   History List Management
       Эти функции управляют отдельными записями в списке истории или устанавливают параметры, управляющие самим списком.

       void add_history (const char *string)
       Поместить string в конец списка истории. Связанное поле данных (если есть) устанавливается в NULL. Если максимальное количество записей истории было установлено с помощью stifle_history(), и новое количество записей истории превысит этот максимум, самая старая запись истории удаляется.

       void add_history_time (const char *string)
       Изменить временную метку, связанную с наиболее недавней записью истории, на string.

       HIST_ENTRY * remove_history (int which)
       Удалить запись истории по смещению which из истории. Удаленный элемент возвращается, чтобы вы могли освободить строку, данные и содержащую структуру.

       histdata_t free_history_entry (HIST_ENTRY *histent)
       Освободить запись истории histent и любые частные данные библиотеки истории, связанные с ней. Возвращает специфические для приложения данные, чтобы вызывающий мог избавиться от них.

       HIST_ENTRY * replace_history_entry (int which, const char *line, histdata_t data)
       Сделать так, чтобы запись истории по смещению which имела line и data. Это возвращает старую запись, чтобы вызывающий мог избавиться от любых специфических для приложения данных. В случае недопустимого which возвращается NULL-указатель.

       void clear_history (void)
       Очистить список истории, удалив все записи.

       void stifle_history (int max)
       Подавить список истории, запоминая только последние max записей. Список истории будет содержать только max записей за раз.

       int unstifle_history (void)
       Прекратить подавление истории. Это возвращает ранее установленное максимальное количество записей истории (как установлено stifle_history()). Значение положительное, если история была подавлена, отрицательное — если нет.

       int history_is_stifled (void)
       Возвращает ненулевое значение, если история подавлена, ноль — если нет.


   Information About the History List
       Эти функции возвращают информацию о всем списке истории или отдельных записях списка.

       HIST_ENTRY ** history_list (void)
       Возвратить NULL-терминированный массив HIST_ENTRY *, который является текущим списком ввода истории. Элемент 0 этого списка — начало времен. Если истории нет, возвращается NULL.

       int where_history (void)
       Возвращает смещение текущего элемента истории.

       HIST_ENTRY * current_history (void)
       Возвратить запись истории на текущей позиции, как определено where_history(). Если там нет записи, возвращается NULL-указатель.

       HIST_ENTRY * history_get (int offset)
       Возвратить запись истории на позиции offset. Диапазон допустимых значений offset начинается с history_base и заканчивается history_length - 1. Если там нет записи или offset вне допустимого диапазона, возвращается NULL-указатель.

       time_t history_get_time (HIST_ENTRY *)
       Возвратить временную метку, связанную с записью истории, переданной в качестве аргумента.

       int history_total_bytes (void)
       Возвратить количество байт, которые используют основные записи истории. Эта функция возвращает сумму длин всех строк в истории.


   Moving Around the History List
       Эти функции позволяют устанавливать или изменять текущий индекс в списке истории.

       int history_set_pos (int pos)
       Установить текущее смещение истории на pos, абсолютный индекс в списке. Возвращает 1 при успешном выполнении, 0, если pos меньше нуля или больше количества записей истории.

       HIST_ENTRY * previous_history (void)
       Откатить текущее смещение истории к предыдущей записи истории и вернуть указатель на эту запись. Если предыдущей записи нет, возвращается NULL-указатель.

       HIST_ENTRY * next_history (void)
       Если текущее смещение истории относится к допустимой записи истории, увеличить текущее смещение истории. Если возможно увеличенное смещение истории относится к допустимой записи истории, вернуть указатель на эту запись; в противном случае вернуть NULL-указатель.


   Searching the History List
       Эти функции позволяют искать в списке истории записи, содержащие определенную строку. Поиск может выполняться как вперед, так и назад от текущей позиции истории. Поиск может быть закрепленным, что означает, что строка должна совпадать в начале записи истории.

       int history_search (const char *string, int direction)
       Искать string в истории, начиная с текущего смещения истории. Если direction меньше 0, то поиск через предыдущие записи, иначе через последующие. Если string найдена, то текущее смещение истории устанавливается на эту запись истории, и возвращается значение смещения в строке записи, где была найдена string. В противном случае ничего не изменяется, и возвращается -1.

       int history_search_prefix (const char *string, int direction)
       Искать string в истории, начиная с текущего смещения истории. Поиск закреплен: совпадающие строки должны начинаться с string. Если direction меньше 0, то поиск через предыдущие записи, иначе через последующие. Если string найдена, то текущее смещение истории устанавливается на эту запись, и возвращается значение 0. В противном случае ничего не изменяется, и возвращается -1.

       int history_search_pos (const char *string, int direction, int pos)
       Искать string в списке истории, начиная с pos, абсолютного индекса в списке. Если direction отрицательное, поиск назад от pos, иначе вперед. Возвращает абсолютный индекс элемента истории, где была найдена string, или -1 в противном случае.


   Managing the History File
       Библиотека истории может читать историю из файла и записывать в него. В этом разделе документируются функции для управления файлом истории.

       int read_history (const char *filename)
       Добавить содержимое filename в список истории, построчно. Если filename равно NULL, то читать из ~/.history. Возвращает 0 при успешном выполнении или errno в случае неудачи.

       int read_history_range (const char *filename, int from, int to)
       Прочитать диапазон строк из filename и добавить их в список истории. Начать чтение со строки from и закончить to. Если from равно нулю, начать с начала. Если to меньше from, то читать до конца файла. Если filename равно NULL, то читать из ~/.history. Возвращает 0 при успешном выполнении или errno в случае неудачи.

       int write_history (const char *filename)
       Записать текущую историю в filename, перезаписав filename, если необходимо. Если filename равно NULL, то записать список истории в ~/.history. Возвращает 0 при успешном выполнении или errno при ошибке чтения или записи.

       int append_history (int nelements, const char *filename)
       Добавить последние nelements записей списка истории в filename. Если filename равно NULL, то добавить в ~/.history. Возвращает 0 при успешном выполнении или errno при ошибке чтения или записи.

       int history_truncate_file (const char *filename, int nlines)
       Усечь файл истории filename, оставив только последние nlines строк. Если filename равно NULL, то усечь ~/.history. Возвращает 0 при успешном выполнении или errno при неудаче.


   History Expansion
       Эти функции реализуют расширение истории.

       int history_expand (char *string, char **output)
       Расширить string и поместить результат в output, указатель на строку. Возвращает:
	      0	     Если никаких расширений не произошло (или, если единственное изменение в тексте было удаление escape-символов перед символом расширения истории);
	      1	     если расширения произошли;
	      -1     если произошла ошибка в расширении;
	      2	     если возвращенная строка должна быть отображена, но не выполнена, как с модификатором :p.
       Если произошла ошибка в расширении, то output содержит описательное сообщение об ошибке.

       char * get_history_event (const char *string, int *cindex, int qchar)
       Возвратить текст события истории, начинающегося в string + *cindex. *cindex модифицируется для указания на позицию после спецификатора события. При входе в функцию cindex указывает на индекс в string, где начинается спецификация события истории. qchar — символ, который разрешается использовать для завершения спецификации события помимо «нормальных» завершающих символов.

       char ** history_tokenize (const char *string)
       Возвратить массив токенов, разобранных из string, как это может сделать оболочка. Токены разделяются символами в переменной history_word_delimiters, и соблюдаются соглашения об оболочке по поводу кавычек.

       char * history_arg_extract (int first, int last, const char *string)
       Извлечь сегмент строки, состоящий из первых через последние аргументы, присутствующие в string. Аргументы разделяются с помощью history_tokenize().


   History Variables
       В этом разделе описываются внешние переменные, экспортируемые библиотекой истории GNU.

       int history_base
       Логическое смещение первой записи в списке истории.

       int history_length
       Количество записей, хранящихся в списке истории в настоящее время.

       int history_max_entries
       Максимальное количество записей истории. Это должно изменяться с помощью stifle_history().

       int history_write_timestamps
       Если ненулевое, временные метки записываются в файл истории, чтобы они могли быть сохранены между сеансами. Значение по умолчанию — 0, что означает, что временные метки не сохраняются. Текущий формат временных меток использует значение history_comment_char для разграничения записей временных меток в файле истории. Если эта переменная не имеет значения (значение по умолчанию), временные метки не будут записаны.

       char history_expansion_char
       Символ, который вводит событие истории. Значение по умолчанию — !. Установка этого в 0 подавляет расширение истории.

       char history_subst_char
       Символ, который вызывает подстановку слов, если найден в начале строки. Значение по умолчанию — ^.

       char history_comment_char
       При токенизации, если этот символ виден как первый символ слова, то он и все последующие символы до новой строки игнорируются, подавляя расширение истории для остатка строки. Это по умолчанию отключено.

       char * history_word_delimiters
       Символы, которые разделяют токены для history_tokenize(). Значение по умолчанию — " \t\n()<>;&|".

       char * history_no_expand_chars
       Список символов, которые подавляют расширение истории, если найдены сразу после history_expansion_char. Значение по умолчанию — пробел, табуляция, новая строка, \r и =.

       char * history_search_delimiter_chars
       Список дополнительных символов, которые могут разграничивать строку поиска истории, помимо пробела, табуляции, : и ? в случае поиска подстроки. Значение по умолчанию — пусто.

       int history_quotes_inhibit_expansion
       Если ненулевое, слова в двойных кавычках не сканируются на наличие символа расширения истории или символа комментария истории. Значение по умолчанию — 0.

       rl_linebuf_func_t * history_inhibit_expansion_function
       Это должно быть установлено на адрес функции, которая принимает два аргумента: char * (string) и int индекс в эту строку (i). Она должна возвращать ненулевое значение, если расширение истории, начинающееся в string[i], не должно выполняться; ноль, если расширение должно быть выполнено. Предназначается для использования приложениями, такими как bash, которые используют символ расширения истории для дополнительных целей. По умолчанию эта переменная установлена в NULL.

FILES
       ~/.history
	      Файл по умолчанию для чтения и записи сохраненной истории

SEE ALSO
       The Gnu Readline Library, Brian Fox and Chet Ramey
       The Gnu History Library, Brian Fox and Chet Ramey
       bash(1)
       readline(3)

AUTHORS
       Brian Fox, Free Software Foundation
       bfox@gnu.org

       Chet Ramey, Case Western Reserve University
       chet.ramey@case.edu

BUG REPORTS
       Если вы найдете ошибку в библиотеке истории, вы должны сообщить о ней. Но сначала убедитесь, что это действительно ошибка и что она присутствует в последней версии библиотеки истории, которой вы обладаете.

       Как только вы убедитесь, что ошибка действительно существует, отправьте отчет об ошибке на bug-readline@gnu.org. Если у вас есть исправление, вы можете отправить его тоже! Предложения и «философские» отчеты об ошибках можно отправить на bug-readline@gnu.org или опубликовать в Usenet-группе gnu.bash.bug.

       Комментарии и отчеты об ошибках, касающиеся этой страницы руководства, должны быть направлены на chet.ramey@case.edu.



GNU History 8.1			 2020 July 17			    HISTORY(3)
HISTORY(3)		   Library Functions Manual		    HISTORY(3)



NAME
       history - GNU History Library

COPYRIGHT
       The GNU History Library is Copyright (C) 1989-2020 by the Free Software
       Foundation, Inc.

DESCRIPTION
       Many programs read input from the user a line at a time.	 The GNU  His‐
       tory  library is able to keep track of those lines, associate arbitrary
       data with each line, and utilize information  from  previous  lines  in
       composing new ones.

HISTORY EXPANSION
       The  history library supports a history expansion feature that is iden‐
       tical to the history expansion in bash.	This  section  describes  what
       syntax features are available.

       History expansions introduce words from the history list into the input
       stream, making it easy to repeat commands, insert the  arguments	 to  a
       previous command into the current input line, or fix errors in previous
       commands quickly.

       History expansion is usually performed  immediately  after  a  complete
       line  is read.  It takes place in two parts.  The first is to determine
       which line from the history list to use during substitution.  The  sec‐
       ond  is	to select portions of that line for inclusion into the current
       one.  The line selected from the history is the event, and the portions
       of  that	 line  that  are  acted upon are words.	 Various modifiers are
       available to manipulate the selected words.  The line  is  broken  into
       words in the same fashion as bash does when reading input, so that sev‐
       eral words that would otherwise be separated are	 considered  one  word
       when  surrounded	 by  quotes (see the description of history_tokenize()
       below).	History expansions are introduced by  the  appearance  of  the
       history expansion character, which is ! by default.  Only backslash (\)
       and single quotes can quote the history expansion character.

   Event Designators
       An event designator is a reference to a command line entry in the  his‐
       tory  list.   Unless  the reference is absolute, events are relative to
       the current position in the history list.

       !      Start a history substitution, except when followed by  a	blank,
	      newline, = or (.
       !n     Refer to command line n.
       !-n    Refer to the current command minus n.
       !!     Refer to the previous command.  This is a synonym for `!-1'.
       !string
	      Refer  to the most recent command preceding the current position
	      in the history list starting with string.
       !?string[?]
	      Refer to the most recent command preceding the current  position
	      in  the  history	list containing string.	 The trailing ? may be
	      omitted if string is followed  immediately  by  a	 newline.   If
	      string  is  missing,  the	 string from the most recent search is
	      used; it is an error if there is no previous search string.
       ^string1^string2^
	      Quick substitution.  Repeat the last command, replacing  string1
	      with string2.  Equivalent to ``!!:s^string1^string2^'' (see Mod‐
	      ifiers below).
       !#     The entire command line typed so far.

   Word Designators
       Word designators are used to select desired words from the event.  A  :
       separates  the event specification from the word designator.  It may be
       omitted if the word designator begins with a ^, $, *, -, or  %.	 Words
       are  numbered from the beginning of the line, with the first word being
       denoted by 0 (zero).  Words are inserted into the  current  line	 sepa‐
       rated by single spaces.

       0 (zero)
	      The zeroth word.	For the shell, this is the command word.
       n      The nth word.
       ^      The first argument.  That is, word 1.
       $      The  last word.  This is usually the last argument, but will ex‐
	      pand to the zeroth word if there is only one word in the line.
       %      The first word matched by the most recent `?string?' search,  if
	      the  search  string  begins  with	 a character that is part of a
	      word.
       x-y    A range of words; `-y' abbreviates `0-y'.
       *      All of the words but the zeroth.	This is a synonym  for	`1-$'.
	      It  is  not  an  error to use * if there is just one word in the
	      event; the empty string is returned in that case.
       x*     Abbreviates x-$.
       x-     Abbreviates x-$ like x*, but omits the last word.	 If x is miss‐
	      ing, it defaults to 0.

       If  a  word  designator is supplied without an event specification, the
       previous command is used as the event.

   Modifiers
       After the optional word designator, there may appear a sequence of  one
       or more of the following modifiers, each preceded by a `:'.  These mod‐
       ify, or edit, the word or words selected from the history event.

       h      Remove a trailing file name component, leaving only the head.
       t      Remove all leading file name components, leaving the tail.
       r      Remove a trailing suffix of the form .xxx, leaving the basename.
       e      Remove all but the trailing suffix.
       p      Print the new command but do not execute it.
       q      Quote the substituted words, escaping further substitutions.
       x      Quote the substituted words as with q, but break into  words  at
	      blanks  and newlines.  The q and x modifiers are mutually exclu‐
	      sive; the last one supplied is used.
       s/old/new/
	      Substitute new for the first occurrence  of  old	in  the	 event
	      line.  Any character may be used as the delimiter in place of /.
	      The final delimiter is optional if it is the last	 character  of
	      the event line.  The delimiter may be quoted in old and new with
	      a single backslash.  If & appears in new, it is replaced by old.
	      A	 single backslash will quote the &.  If old is null, it is set
	      to the last old substituted, or, if no previous history  substi‐
	      tutions  took  place,  the last string in a !?string[?]  search.
	      If new is null, each matching old is deleted.
       &      Repeat the previous substitution.
       g      Cause changes to be applied over the entire event line.  This is
	      used  in	conjunction  with `:s' (e.g., `:gs/old/new/') or `:&'.
	      If used with `:s', any delimiter can be used in place of /,  and
	      the  final  delimiter is optional if it is the last character of
	      the event line.  An a may be used as a synonym for g.
       G      Apply the following `s' or `&' modifier once to each word in the
	      event line.

PROGRAMMING WITH HISTORY FUNCTIONS
       This  section  describes	 how  to use the History library in other pro‐
       grams.

   Introduction to History
       A programmer using the History library has available functions for  re‐
       membering  lines	 on  a history list, associating arbitrary data with a
       line, removing lines from the list, searching through the  list	for  a
       line  containing	 an arbitrary text string, and referencing any line in
       the list directly.  In addition, a history expansion function is avail‐
       able  which  provides  for a consistent user interface across different
       programs.

       The user using programs written with the History library has the	 bene‐
       fit  of	a  consistent user interface with a set of well-known commands
       for manipulating the text of previous lines and using that text in  new
       commands.  The basic history manipulation commands are identical to the
       history substitution provided by bash.

       The programmer can also use the readline library, which	includes  some
       history manipulation by default, and has the added advantage of command
       line editing.

       Before declaring any functions using any functionality the History  li‐
       brary  provides in other code, an application writer should include the
       file <readline/history.h> in any file that uses the  History  library's
       features.   It  supplies	 extern	 declarations for all of the library's
       public functions and variables, and declares all	 of  the  public  data
       structures.

   History Storage
       The  history  list  is an array of history entries.  A history entry is
       declared as follows:

       typedef void * histdata_t;

       typedef struct _hist_entry {
	 char *line;
	 char *timestamp;
	 histdata_t data;
       } HIST_ENTRY;

       The history list itself might therefore be declared as

       HIST_ENTRY ** the_history_list;

       The state of the History library is encapsulated into a	single	struc‐
       ture:

       /*
	* A structure used to pass around the current state of the history.
	*/
       typedef struct _hist_state {
	 HIST_ENTRY **entries; /* Pointer to the entries themselves. */
	 int offset;	       /* The location pointer within this array. */
	 int length;	       /* Number of elements within this array. */
	 int size;	       /* Number of slots allocated to this array. */
	 int flags;
       } HISTORY_STATE;

       If the flags member includes HS_STIFLED, the history has been stifled.

History Functions
       This  section  describes the calling sequence for the various functions
       exported by the GNU History library.

   Initializing History and State Management
       This section describes functions used  to  initialize  and  manage  the
       state of the History library when you want to use the history functions
       in your program.

       void using_history (void)
       Begin a session in which the history functions  might  be  used.	  This
       initializes the interactive variables.

       HISTORY_STATE * history_get_history_state (void)
       Return a structure describing the current state of the input history.

       void history_set_history_state (HISTORY_STATE *state)
       Set the state of the history list according to state.


   History List Management
       These  functions	 manage individual entries on the history list, or set
       parameters managing the list itself.

       void add_history (const char *string)
       Place string at the end of the history list.  The associated data field
       (if  any) is set to NULL.  If the maximum number of history entries has
       been set using stifle_history(), and the new number of history  entries
       would exceed that maximum, the oldest history entry is removed.

       void add_history_time (const char *string)
       Change  the time stamp associated with the most recent history entry to
       string.

       HIST_ENTRY * remove_history (int which)
       Remove history entry at offset which from the history.  The removed el‐
       ement is returned so you can free the line, data, and containing struc‐
       ture.

       histdata_t free_history_entry (HIST_ENTRY *histent)
       Free the history entry histent and any history library private data as‐
       sociated	 with it.  Returns the application-specific data so the caller
       can dispose of it.

       HIST_ENTRY * replace_history_entry (int which, const char *line,	 hist‐
       data_t data)
       Make  the  history  entry at offset which have line and data.  This re‐
       turns the old entry so the caller can dispose of	 any  application-spe‐
       cific  data.   In  the  case of an invalid which, a NULL pointer is re‐
       turned.

       void clear_history (void)
       Clear the history list by deleting all the entries.

       void stifle_history (int max)
       Stifle the history list, remembering only the last  max	entries.   The
       history list will contain only max entries at a time.

       int unstifle_history (void)
       Stop  stifling  the  history.   This returns the previously-set maximum
       number of history entries (as set by  stifle_history()).	  history  was
       stifled.	 The value is positive if the history was stifled, negative if
       it wasn't.

       int history_is_stifled (void)
       Returns non-zero if the history is stifled, zero if it is not.


   Information About the History List
       These functions return information about the entire history list or in‐
       dividual list entries.

       HIST_ENTRY ** history_list (void)
       Return a NULL terminated array of HIST_ENTRY * which is the current in‐
       put history.  Element 0 of this list is	the  beginning	of  time.   If
       there is no history, return NULL.

       int where_history (void)
       Returns the offset of the current history element.

       HIST_ENTRY * current_history (void)
       Return  the  history  entry  at	the current position, as determined by
       where_history().	 If there is no entry there, return a NULL pointer.

       HIST_ENTRY * history_get (int offset)
       Return the history entry at position offset.  The range of valid values
       of  offset  starts  at history_base and ends at history_length - 1.  If
       there is no entry there, or if offset is outside the valid  range,  re‐
       turn a NULL pointer.

       time_t history_get_time (HIST_ENTRY *)
       Return  the  time stamp associated with the history entry passed as the
       argument.

       int history_total_bytes (void)
       Return the number of bytes that the primary history entries are	using.
       This  function  returns	the sum of the lengths of all the lines in the
       history.


   Moving Around the History List
       These functions allow the current index into the history list to be set
       or changed.

       int history_set_pos (int pos)
       Set the current history offset to pos, an absolute index into the list.
       Returns 1 on success, 0 if pos is less than zero or  greater  than  the
       number of history entries.

       HIST_ENTRY * previous_history (void)
       Back  up	 the current history offset to the previous history entry, and
       return a pointer to that entry.	If there is no previous entry,	return
       a NULL pointer.

       HIST_ENTRY * next_history (void)
       If  the	current history offset refers to a valid history entry, incre‐
       ment the current history offset.	 If the	 possibly-incremented  history
       offset refers to a valid history entry, return a pointer to that entry;
       otherwise, return a NULL pointer.


   Searching the History List
       These functions allow searching of the history list  for	 entries  con‐
       taining a specific string.  Searching may be performed both forward and
       backward from the current history position.   The  search  may  be  an‐
       chored, meaning that the string must match at the beginning of the his‐
       tory entry.

       int history_search (const char *string, int direction)
       Search the history for string, starting at the current history  offset.
       If  direction  is  less than 0, then the search is through previous en‐
       tries, otherwise through subsequent entries.  If string is found,  then
       the  current  history index is set to that history entry, and the value
       returned is the offset in the line of the entry where string was found.
       Otherwise, nothing is changed, and a -1 is returned.

       int history_search_prefix (const char *string, int direction)
       Search  the history for string, starting at the current history offset.
       The search is anchored: matching lines must begin with string.  If  di‐
       rection	is  less  than 0, then the search is through previous entries,
       otherwise through subsequent entries.  If string	 is  found,  then  the
       current	history index is set to that entry, and the return value is 0.
       Otherwise, nothing is changed, and a -1 is returned.

       int history_search_pos (const char *string, int direction, int pos)
       Search for string in the history list, starting at pos, an absolute in‐
       dex into the list.  If direction is negative, the search proceeds back‐
       ward from pos, otherwise forward.  Returns the absolute	index  of  the
       history element where string was found, or -1 otherwise.


   Managing the History File
       The  History  library can read the history from and write it to a file.
       This section documents the functions for managing a history file.

       int read_history (const char *filename)
       Add the contents of filename to the history list, a line at a time.  If
       filename	 is NULL, then read from ~/.history.  Returns 0 if successful,
       or errno if not.

       int read_history_range (const char *filename, int from, int to)
       Read a range of lines from filename, adding them to the	history	 list.
       Start  reading  at  line from and end at to.  If from is zero, start at
       the beginning.  If to is less than from, then read until the end of the
       file.   If  filename  is NULL, then read from ~/.history.  Returns 0 if
       successful, or errno if not.

       int write_history (const char *filename)
       Write the current history to filename, overwriting filename  if	neces‐
       sary.   If filename is NULL, then write the history list to ~/.history.
       Returns 0 on success, or errno on a read or write error.


       int append_history (int nelements, const char *filename)
       Append the last nelements of the history list to filename.  If filename
       is  NULL, then append to ~/.history.  Returns 0 on success, or errno on
       a read or write error.

       int history_truncate_file (const char *filename, int nlines)
       Truncate the history file filename, leaving only the last nlines lines.
       If  filename  is NULL, then ~/.history is truncated.  Returns 0 on suc‐
       cess, or errno on failure.


   History Expansion
       These functions implement history expansion.

       int history_expand (char *string, char **output)
       Expand string, placing the result into output, a pointer to  a  string.
       Returns:
	      0	     If	 no  expansions	 took place (or, if the only change in
		     the text was the removal of escape	 characters  preceding
		     the history expansion character);
	      1	     if expansions did take place;
	      -1     if there was an error in expansion;
	      2	     if	 the  returned	line should be displayed, but not exe‐
		     cuted, as with the :p modifier.
       If an error occurred in expansion, then output contains	a  descriptive
       error message.

       char * get_history_event (const char *string, int *cindex, int qchar)
       Returns	the  text  of the history event beginning at string + *cindex.
       *cindex is modified to point to after the event specifier.  At function
       entry,  cindex  points to the index into string where the history event
       specification begins.  qchar is a character that is allowed to end  the
       event  specification  in addition to the ``normal'' terminating charac‐
       ters.

       char ** history_tokenize (const char *string)
       Return an array of tokens parsed out  of	 string,  much	as  the	 shell
       might.	The tokens are split on the characters in the history_word_de‐
       limiters variable, and shell quoting conventions are obeyed.

       char * history_arg_extract (int first, int last, const char *string)
       Extract a string segment consisting of the first through last arguments
       present in string.  Arguments are split using history_tokenize().


   History Variables
       This section describes the externally-visible variables exported by the
       GNU History Library.

       int history_base
       The logical offset of the first entry in the history list.

       int history_length
       The number of entries currently stored in the history list.

       int history_max_entries
       The maximum number of history entries.  This must be changed using sti‐
       fle_history().

       int history_write_timestamps
       If non-zero, timestamps are written to the history file, so they can be
       preserved between sessions.  The default value is 0, meaning that time‐
       stamps  are  not saved.	The current timestamp format uses the value of
       history_comment_char to delimit timestamp entries in the history	 file.
       If  that	 variable does not have a value (the default), timestamps will
       not be written.

       char history_expansion_char
       The character that introduces a history event.  The default is !.  Set‐
       ting this to 0 inhibits history expansion.

       char history_subst_char
       The character that invokes word substitution if found at the start of a
       line.  The default is ^.

       char history_comment_char
       During tokenization, if this character is seen as the  first  character
       of  a  word,  then it and all subsequent characters up to a newline are
       ignored, suppressing history expansion for the remainder of  the	 line.
       This is disabled by default.

       char * history_word_delimiters
       The  characters	that  separate tokens for history_tokenize().  The de‐
       fault value is " \t\n()<>;&|".

       char * history_no_expand_chars
       The list of characters which inhibit history expansion if found immedi‐
       ately  following	 history_expansion_char.   The	default is space, tab,
       newline, \r, and =.

       char * history_search_delimiter_chars
       The list of additional characters which can delimit  a  history	search
       string,	in  addition to space, tab, : and ? in the case of a substring
       search.	The default is empty.

       int history_quotes_inhibit_expansion
       If non-zero, double-quoted words are not scanned for the history expan‐
       sion  character or the history comment character.  The default value is
       0.

       rl_linebuf_func_t * history_inhibit_expansion_function
       This should be set to the address of a function that  takes  two	 argu‐
       ments:  a  char	*  (string) and an int index into that string (i).  It
       should return a non-zero value if the  history  expansion  starting  at
       string[i]  should  not  be  performed;  zero if the expansion should be
       done.  It is intended for use by applications like bash	that  use  the
       history	expansion character for additional purposes.  By default, this
       variable is set to NULL.

FILES
       ~/.history
	      Default filename for reading and writing saved history

SEE ALSO
       The Gnu Readline Library, Brian Fox and Chet Ramey
       The Gnu History Library, Brian Fox and Chet Ramey
       bash(1)
       readline(3)

AUTHORS
       Brian Fox, Free Software Foundation
       bfox@gnu.org

       Chet Ramey, Case Western Reserve University
       chet.ramey@case.edu

BUG REPORTS
       If you find a bug in the history library, you should  report  it.   But
       first,  you  should  make sure that it really is a bug, and that it ap‐
       pears in the latest version of the history library that you have.

       Once you have determined that a bug actually exists, mail a bug	report
       to  bug-readline@gnu.org.   If  you have a fix, you are welcome to mail
       that as well!  Suggestions  and	`philosophical'	 bug  reports  may  be
       mailed  to  bug-readline@gnu.org	 or  posted  to	 the  Usenet newsgroup
       gnu.bash.bug.

       Comments and bug reports concerning this manual page should be directed
       to chet.ramey@case.edu.



GNU History 8.1			 2020 July 17			    HISTORY(3)