readline_callback_handler_install

(PHP 5 >= 5.1.0, PHP 7)

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

Описание

bool readline_callback_handler_install ( string $prompt , callable $callback )

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

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

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

prompt

Строка приглашения.

callback

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

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

Возвращает TRUE в случае успешного завершения или FALSE в случае возникновения ошибки.

Примеры

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

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

    echo 
"You entered: $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] Enter something: "'rl_callback');

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

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

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

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