readline_callback_handler_install

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

readline_callback_handler_installInicializa a interface de chamada de retorno e o terminal de readline, mostra o prompt e retorna imediatamente

Descrição

readline_callback_handler_install(string $prompt, callable $callback): bool

Configura uma interface de chamada de retorno readline, mostra o prompt e retorna imediatamente. Chamar esta função duas vezes sem remover a interface de chamada anterior irá automaticamente e convenientemente sobrescrever a interface antiga.

O recurso de chamada de retorno é útil quando combinada com stream_select() já que permite as it allows intercalação de E/S e de entrada de usuário, diferentemente da função readline().

Parâmetros

prompt

A mensagem do prompt.

callback

A função definida em callback leva um parâmetro; a entrada do usuário retornada.

Valor Retornado

Retorna true em caso de sucesso ou false em caso de falha.

Exemplos

Example #1 Exemplo de Interface de Chamada de Retorno de Readline

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

    echo "Você digitou: $ret\n";
    $c++;

    if ($c > 10) {
        $prompting = false;
        readline_callback_handler_remove();
    } else {
        readline_callback_handler_install("[$c] Digite algo: ", 'rl_callback');
    }
}

$c = 1;
$prompting = true;

readline_callback_handler_install("[$c] Digite algo: ", 'rl_callback');

while ($prompting) {
    $w = NULL;
    $e = NULL;
    $n = stream_select($r = array(STDIN), $w, $e, null);
    if ($n && in_array(STDIN, $r)) {
        // lê um caractere, irá chamar a função de retorno quando uma nova linha for lida
        readline_callback_read_char();
    }
}

echo "Prompt desabilitado. Tudo pronto.\n";
?>

Veja Também

  • readline_callback_handler_remove() - Remove um manipulador de chamada de retorno previamente instalado e restaura a configuração do terminal
  • readline_callback_read_char() - Lê um caractere e informa a interface de chamada de retorno de readline quando uma linha é recebida
  • stream_select() - Executa o equivalente à chamada de sistema select() nos arrays de fluxos informados com um limite de tempo especificado por segundos e microssegundos