(PECL eio >= 0.0.1dev)
eio_custom — Execute custom request like any other eio_* call
eio_custom() executes custom function specified by
execute processing it just like any other eio_* call.
executeSpecifies the request function that should match the following prototype:
mixed execute(mixed data);
callback is event completion callback that should match the following
prototype:
void callback(mixed data, mixed result);
data is the data passed to
execute via data argument
without modifications
result value returned by execute
priThe request priority: EIO_PRI_DEFAULT, EIO_PRI_MIN, EIO_PRI_MAX, or null.
If null passed, pri internally is set to
EIO_PRI_DEFAULT.
callback
Die callback-Funktion wird aufgerufen, wenn die Anfrage abgeschlossen ist.
Sie muss dem folgenden Prototyp entsprechen:
void callback(mixed $data, int $result[, resource $req]);datasind die benutzerdefinierten Daten, die an die Anfrage übergeben werden.
resultder anfragespezifische Ergebniswert; im Grunde der Wert, der vom entsprechenden Systemaufruf zurückgegeben wird.
reqist eine optionale Anfrage-Ressource, die in Funktionen wie eio_get_last_error() verwendet werden kann.
data
Arbitrary variable passed to callback.
eio_custom() returns request resource on success,Bei einem Fehler wird false zurückgegeben..
Beispiel #1 eio_custom() example
<?php
/* Callback for the custom callback */
function my_custom_callback($data, $result) {
var_dump($data);
var_dump(count($result));
var_dump($result['data_modified']);
var_dump($result['result']);
}
/* The custom request */
function my_custom($data) {
var_dump($data);
$result = array(
'result' => 1001,
'data_modified' => "my custom data",
);
return $result;
}
$data = "my_custom_data";
$req = eio_custom("my_custom", EIO_PRI_DEFAULT, "my_custom_callback", $data);
var_dump($req);
eio_event_loop();
?>Das oben gezeigte Beispiel erzeugt eine ähnliche Ausgabe wie:
resource(4) of type (EIO Request Descriptor) string(14) "my_custom_data" string(14) "my_custom_data" int(2) string(14) "my custom data" int(1001)