readline_callback_handler_install

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

readline_callback_handler_installInitialisiert das readline-Callback-Interface und das Terminal, gibt den Prompt aus und springt direkt zurück

Beschreibung

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

Initialisiert ein readline-Callback-Interface, gibt danach den prompt aus und springt direkt zurück. Der doppelte Aufruf der Funktion ohne Zurücksetzen des verwendeten Callback-Interfaces wird automatisch und in geeigneter Weise das alte Interface überschreiben.

Die Callback-Fähigkeiten sind hilfreich, wenn sie mit stream_select() kombiniert werden, da dies eine Verschränkung von IO und Benutzereingaben wie mittels readline() ermöglicht.

Parameter-Liste

prompt

Die Prompt-Message.

callback

Die callback-Funktion benötigt einen Parameter; die Benutzereingabe wird zurückgegeben.

Rückgabewerte

Gibt bei Erfolg true zurück. Bei einem Fehler wird false zurückgegeben.

Beispiele

Beispiel #1 Readline-Callback-Interface-Beispiel

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

    echo 
"Sie haben eingegeben: $ret\n";
    
$c++;

    if (
$c 10) {
        
$prompting false;
        
readline_callback_handler_remove();
    } else {
        
readline_callback_handler_install("[$c] Geben Sie etwas ein: "'rl_callback');
    }
}

$c 1;
$prompting true;

readline_callback_handler_install("[$c] Geben Sie etwas ein: "'rl_callback');

while (
$prompting) {
    
$w NULL;
    
$e NULL;
    
$n stream_select($r = array(STDIN), $w$enull);
    if (
$n && in_array(STDIN$r)) {
        
// Liest das aktuelle Zeichen und ruft die Callbackfunktion auf, wenn ein
        // Newline-Zeichen eingegeben wurde
        
readline_callback_read_char();
    }
}

echo 
"Eingabe deaktiviert. Komplett ausgeführt.\n";
?>

Siehe auch

  • readline_callback_handler_remove() - Entfernt den letztdefinierten Callbackhandler und setzt die Terminalumgebung auf die Ursprungswerte zurück
  • readline_callback_read_char() - Liest ein Zeichen und informiert das readline-Callback-Interface, wenn die Eingabezeile abgeschlossen wurde
  • stream_select() - Runs the equivalent of the select() system call on the given arrays of streams with a timeout specified by seconds and microseconds

Hier Kannst Du einen Kommentar verfassen


Bitte gib mindestens 10 Zeichen ein.
Wird geladen... Bitte warte.
* Pflichtangabe
Es sind noch keine Kommentare vorhanden.

Was genau bedeutet "Vibe Coding"? Ein tiefgehender Blick für Entwickler

In der Welt der Softwareentwicklung gibt es unzählige Wege, wie man an ein Projekt herangeht. Manche schwören auf strikte Planung, andere auf bewährte Algorithmen und wieder andere lassen sich von etwas ganz anderem leiten: ihrem Gefühl. ...

admin

Autor : admin
Kategorie: Software & Web-Development

PHP cURL-Tutorial: Verwendung von cURL zum Durchführen von HTTP-Anfragen

cURL ist eine leistungsstarke PHP-Erweiterung, die es Ihnen ermöglicht, mit verschiedenen Servern über verschiedene Protokolle wie HTTP, HTTPS, FTP und mehr zu kommunizieren. ...

TheMax

Autor : TheMax
Kategorie: PHP-Tutorials

Midjourney Tutorial - Anleitung für Anfänger

Über Midjourney, dem Tool zur Erstellung digitaler Bilder mithilfe von künstlicher Intelligenz, gibt es ein informatives Video mit dem Titel "Midjourney Tutorial auf Deutsch - Anleitung für Anfänger" ...

Mike94

Autor : Mike94
Kategorie: KI Tutorials

Tutorial veröffentlichen

Tutorial veröffentlichen

Teile Dein Wissen mit anderen Entwicklern weltweit

Du bist Profi in deinem Bereich und möchtest dein Wissen teilen, dann melde dich jetzt an und teile es mit unserer PHP-Community

mehr erfahren

Tutorial veröffentlichen

PHP Prepared statements

Hi Frosch, dein Code-Ansatz ist grundsätzlich richtig, aber für viele Parameter ist die Named-Variante (:name) oft übersichtlicher als die ?-Pl ...

Geschrieben von lunahart63 am 21.11.2025 05:58:10
Forum: PHP Developer Forum
Überhang in MySql Datenbank

Frage: wenn ich "Optimize table tabellenname" ausführe wird aber inhaltlich nichts in der Tabelle verändert oder? Nein

Geschrieben von scatello am 19.11.2025 13:44:10
Forum: SQL / Datenbanken
Überhang in MySql Datenbank

OK, danke für die Antwort. Frage: wenn ich "Optimize table tabellenname" ausführe wird aber inhaltlich nichts in der Tabelle verändert oder?

Geschrieben von Falke07 am 19.11.2025 12:57:09
Forum: SQL / Datenbanken
Überhang in MySql Datenbank

Zu 1: Ein "Optimize table tabellenname" entfernt den Überhang Zu 2: Der Überhang kann beim Löschen von Datensätzen entstehen und dadurch kann ...

Geschrieben von scatello am 19.11.2025 12:47:25
Forum: SQL / Datenbanken