Termcap - Termcap

Termapi.svg

Termcap (возможность терминала) это программное обеспечение библиотека и база данных используется на Unix-подобный компьютеры. Это позволяет программам использовать дисплей компьютерные терминалы независимым от устройства способом, что значительно упрощает процесс написания портативных текстовый режим Приложения. Билл Джой написал первую библиотеку termcap в 1978 г.[1][2] для Беркли Unix Операционная система; с тех пор он был перенесен в большинство Unix и Unix-подобных сред, даже Мультики.[3][обсудить] Сообщается, что на дизайн Джой повлиял дизайн хранилища данных терминала в более ранней версии. Несовместимая система разделения времени.[4]

База данных termcap может описать возможности сотен различных терминалов. Это позволяет программам иметь символьный дисплей выход независимо от типа терминала. Экранные текстовые редакторы, такие как vi и emacs являются примерами программ, которые могут использовать termcap. Другие программы перечислены в Termcap категория.

Примеры того, что описывает база данных:

  • сколько столбцов шириной дисплей
  • какую строку отправить, чтобы переместить курсор в произвольную позицию (в том числе как кодировать номера строк и столбцов)
  • как пролистать экран вверх на одну или несколько строк
  • сколько заполнения необходимо для такой операции прокрутки.

Модель данных

Базы данных Termcap состоят из одного или нескольких описаний терминалов.

Индексы

Каждое описание должно содержать канонический название терминала. Он также может содержать один или несколько псевдонимов для имени терминала. Каноническое имя или псевдонимы - это ключи, по которым библиотека выполняет поиск в базе данных termcap.

Значения данных

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

  • строка между именем возможности и ее значением стоит знак "=",
  • числовой между именем возможности и ее значением стоит знак "#", и
  • логический возможности не имеют ассоциированной ценности (они всегда правда если указано).

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

Иерархия

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

Модель хранения

Данные Termcap хранятся в виде текста, что упрощает их изменение. Текст может быть получен библиотекой termcap из файлов или переменных среды.

Переменные среды

В СРОК переменная окружения содержит имя типа терминала.

В TERMCAP переменная окружения может содержать базу данных termcap. Чаще всего он используется для хранения одного описания termcap, установленного эмулятором терминала для предоставления характеристик терминала оболочке и зависимым программам.

В ТЕРМПАТ Переменная среды поддерживается новыми реализациями termcap и определяет путь поиска файлов termcap.

Плоский файл

Исходная (и наиболее распространенная) реализация библиотеки termcap извлекает данные из простого текстового файла. Поиск в большом файле termcap, например, 500 КБ, может быть медленным. Для повышения производительности такая утилита, как Изменение порядка используется для размещения наиболее часто используемых записей в начале файла.

Хешированная база данных

Реализации termcap на основе BSD-4.4 хранят описание терминала в хешированной базе данных (например, что-то вроде Berkeley DB версия 1.85). В них хранятся два типа записей: псевдонимы, указывающие на каноническую запись, и саму каноническую запись. Текст записи termcap сохраняется буквально.

Ограничения и расширения

Первоначальная реализация termcap была разработана для использования небольшого объема памяти:

  • первое имя состоит из двух символов, чтобы соответствовать 16 битам
  • имена возможностей состоят из двух символов
  • описание ограничено 1023 символами.
  • может быть включена только одна запись termcap с ее определениями, и она должна быть в конце.

Более новые реализации интерфейса termcap обычно не требуют двухсимвольного имени в начале записи.

Во всех реализациях имена возможностей по-прежнему состоят из двух символов.

В tgetent Функция, используемая для чтения описания терминала, использует буфер, размер которого должен быть достаточно большим для данных, и предполагается, что он составляет 1024 символа. Более новые реализации интерфейса termcap могут ослабить это ограничение, разрешив нулевой указатель вместо фиксированного буфера,[5] или скрывая данные, которые не подходят, например, через ZZ способность в NetBSD termcap.[6] В terminfo Интерфейс библиотеки также эмулирует интерфейс termcap и фактически не использует буфер фиксированного размера.

Эмуляция termcap библиотекой terminfo позволяет включать несколько других записей без ограничения позиции. Несколько других новых реализаций библиотеки termcap также могут предоставить эту возможность, хотя она недостаточно хорошо документирована.[7]

Устаревшие функции

Специальная возможность, "hz", была определена специально для поддержки Hazeltine 1500 терминал, который имел неудачную характеристику использования ASCII символ тильды ('~') как средство представления управляющей последовательности.[8][обсудить] Чтобы поддерживать этот терминал, не только код, который использовал базу данных, должен был знать об использовании тильды для введения определенных управляющих последовательностей, но он также должен был знать, как заменять другие печатные символы на любые тильды в отображаемом тексте, поскольку тильда в тексте будет интерпретироваться терминалом как начало последовательности управления, что приведет к отсутствию текста и искажению экрана.[9] Кроме того, маркеры атрибутов (например, начало и конец подчеркивания) сами занимают место на экране.[нужна цитата ] Комментарии в исходном коде базы данных часто называют это «повреждением мозга Hazeltine».[10] Поскольку Hazeltine 1500 был широко используемым терминалом в конце 1970-х годов,[нужна цитата ] важно, чтобы приложения могли справиться с его ограничениями.

Смотрите также

использованная литература

  1. ^ Питер Х. Салус, «История Unix - это не только технология, но и сотрудничество», Byte, октябрь 1994 г.
  2. ^ Кеннет С. Р. С. Арнольд и Элан Амир, «Обновление экрана и оптимизация движения курсора: пакет библиотеки»
  3. ^ https://multician.org/mtbs/mtb767.html
  4. ^ alt.sys.pdp10 публикация
  5. ^ Библиотека GNU Termcap
  6. ^ Формат файла NetBSD termcap
  7. ^ Обсуждение termcap в vi
  8. ^ termcap (5) – BSD Форматы файлов Руководство по эксплуатации
  9. ^ Столмен, Ричард М. (1992). "Библиотека и база данных Termcap, второе издание". Gnu.org. Получено 17 мая 2014.
  10. ^ "termcap.src". Компьютер Apple. Получено 17 мая 2014.

внешние ссылки