(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.
execute
Specifies 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
pri
Prioritatea cererii: EIO_PRI_DEFAULT
, EIO_PRI_MIN
, EIO_PRI_MAX
sau null
.
Dacă este transmis null
, pri
este stabilit intern la
valoarea EIO_PRI_DEFAULT
.
callback
Funcția callback
este apelată atunci când o interpelare este încheiată. Ea trebuie să corespundă
următorului prototip:
void callback(mixed $data, int $result[, resource $req]);
data
sunt niște date personalizate transmise în cerere.
result
conține rezultatul specific cererii; în esență, valoarea întoarsă de apelul de sistem corespunzător.
req
este o resursă a cererii opțională ce poate fi utilizată cu funcții precum eio_get_last_error()
data
Arbitrary variable passed to callback
.
eio_custom() returns request resource on success or false
on error.
Example #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();
?>
Exemplul de mai sus va afișa ceva similar cu:
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)