PTSNAME(3) | Руководство программиста Linux | PTSNAME(3) |
ptsname, ptsname_r - возвращает имя подчинённого псевдо-терминала
#include <stdlib.h>
char *ptsname(int fd); int ptsname_r(int fd, char *buf, size_t buflen);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
ptsname():
ptsname_r(): _GNU_SOURCE
Функция ptsname() возвращает имя устройства подчинённого псевдо-терминала, соответствующего главному, который указан в fd.
Функция ptsname_r() является реентерабельным эквивалентном ptsname(). Она сохраняет имя устройства подчинённого псевдо-терминала в виде строки (завершающейся null) в буфер, указанный в buf. В аргументе buflen задаётся количество байт, доступных в buf.
При успешном выполнении ptsname() возвращает указатель на строку в статическом хранилище, которая будет перезаписана последующими вызовами. Данный указатель не нужно освобождать. При ошибке возвращается NULL.
При успешном выполнении ptsname_r() возвращает 0. При ошибке возвращается ненулевое значение и в errno записывается номер ошибки.
Функция ptsname() появилась в glibc версии 2.1.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
ptsname() | Безвредность в нитях | MT-Unsafe race:ptsname |
ptsname_r() | Безвредность в нитях | MT-Safe |
ptsname(): POSIX.1-2001, POSIX.1-2008.
Функция ptsname() является частью поддержки псевдо-терминалов UNIX 98 (смотрите pts(4)).
Функция ptsname_r() является расширением Linux, которую предполагается включить в следующую большую версию POSIX.1 (Issue 8). Версия этой функции описана в Tru64 и HP-UX, но в их реализациях при ошибке возвращается -1, а в errno записывается номер ошибки. Не используйте эту функцию в переносимых программах.
grantpt(3), posix_openpt(3), ttyname(3), unlockpt(3), pts(4), pty(7)
2017-09-15 |