readline_callback_handler_install
(PHP 5 >= 5.1.0, PHP 7)
readline_callback_handler_install — Инициализирует callback-интерфейс readline и терминал, печатает строку приглашения и немедленно возвращает управление
Описание
Инициализирует callback-интерфейс readline, печатает
prompt
и возвращает управление.
Повторный вызов этой функции без предварительного удаления старого
callback-интерфейса приведет к автоматической его перезаписи.
Функционал callback-функций особенно удобен в комбинации с stream_select(), поскольку он, в отличие от readline(), позволяет чередовать ввод-вывод и пользовательский ввод.
Список параметров
-
prompt
-
Строка приглашения.
-
callback
-
Функция передаваемая в параметр
callback
должна принимать один параметр - возвращенный пользовательский ввод.
Возвращаемые значения
Возвращает true
в случае успешного завершения или false
в случае возникновения ошибки.
Примеры
Пример #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() на заданных массивах потоков с таймаутом, указанным параметрами tv_sec и tv_usec