PHP.mk документација

readline_callback_handler_install

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

function.readline-callback-handler-install.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека function.readline-callback-handler-install.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
readline_callback_handler_install

Референца за `function.readline-callback-handler-install.php` со подобрена типографија и навигација.

function.readline-callback-handler-install.php

readline_callback_handler_install

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

readline_callback_handler_installЈа иницијализира readline интерфејсот за повратни повици и терминалот, го печати промпт и веднаш се враќа.

= NULL

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

Поставува readline интерфејс за повратни повици, а потоа печати prompt и веднаш се враќа. Повикувањето на оваа функција двапати без отстранување на претходниот интерфејс за повратни повици автоматски и удобно ќе го презапише стариот интерфејс.

Функцијата за повратни повици е корисна кога се комбинира со stream_select() бидејќи овозможува мешање на IO и кориснички влез, за разлика од readline().

Параметри

prompt
Пораката за промпт.
callback
На callback функцијата прима еден параметар; вратениот кориснички влез.

Вратени вредности

Секогаш враќа true.

Примери

Пример #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] Enter something: ", '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, $e, null);
if (
$n && in_array(STDIN, $r)) {
// read a character, will call the callback when a newline is entered
readline_callback_read_char();
}
}

echo
"Prompting disabled. All done.\n";
?>

Види Исто така

  • readline_callback_handler_remove() - Отстранува претходно инсталиран ракувач за враќање на повици и ги враќа поставките на терминалот
  • readline_callback_read_char() - Чита карактер и ја известува интерфејсот за повикување readline кога ќе се прими линија
  • stream_select() - Изврши надворешна програма и прикажи суров излез

Белешки од корисници 1 белешка

thflori
пред 7 години
To read byte wise and multi line you can check the line_buffer from readline_info:

<?php

function read(int $count, string $prompt = null): string
{
    $previous = '';
    readline_callback_handler_install($prompt ?? " \e[D", function ($str) use (&$previous) {
        $previous .= $str . PHP_EOL;
    });
    do {
        $r = array(STDIN);
        $n = stream_select($r, $w, $e, null);
        if ($n && in_array(STDIN, $r)) {
            readline_callback_read_char();
            $str = $previous . readline_info('line_buffer');
        }
    } while (mb_strlen($str) < $count); // use strlen if you need the exact byte count
    readline_callback_handler_remove();

    return $str;
}
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.