readline_callback_handler_install

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

readline_callback_handler_installИнициализирует callback-интерфейс readline и терминал, печатает строку приглашения и немедленно возвращает управление

Описание

function readline_callback_handler_install(string $prompt, callable $callback): true

Инициализирует callback-интерфейс readline, печатает prompt и возвращает управление. Повторный вызов этой функции без предварительного удаления старого callback-интерфейса приведёт к автоматической его перезаписи.

Функционал callback-функций особенно удобен в комбинации с stream_select(), поскольку он, в отличие от readline(), позволяет чередовать ввод-вывод и пользовательский ввод.

Список параметров

prompt
Строка приглашения.
callback
Функция передаваемая в параметр callback должна принимать один параметр - возвращённый пользовательский ввод.

Возвращаемые значения

Функция возвращает логическое значение true.

Список изменений

Версия Описание
8.5.0 Вместо общего логического типа bool теперь возвращается конкретный тип true.

Примеры

Пример #1 Пример использования callback-интерфейса readline

<?php
function rl_callback($ret)
{
    global $c, $prompting;

    echo "Вы ввели: $ret\n";
    $c++;

    if ($c > 10) {
        $prompting = false;
        readline_callback_handler_remove();
    } else {
        readline_callback_handler_install("[$c] Поговори со мной: ", 'rl_callback');
    }
}

$c = 1;
$prompting = true;

readline_callback_handler_install("[$c] Введите что-нибудь: ", 'rl_callback');

while ($prompting) {
    $w = NULL;
    $e = NULL;
    $n = stream_select($r = array(STDIN), $w, $e, null);
    if ($n && in_array(STDIN, $r)) {
        // читаем символ и вызываем callback-функцию,
        // если введён символ новой строки
        readline_callback_read_char();
    }
}

echo "Ввод отключён. Спасибо за внимание.\n";
?>

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

  • readline_callback_handler_remove() - Удаляет ранее зарегистрированную callback-функцию и восстанавливает терминал
  • readline_callback_read_char() - Читает символ и информирует callback-функцию readline, что получена строка
  • stream_select() - Запускает эквивалент системного вызова select() на массивах потоков со временем ожидания в секундах и микросекундах