(PECL ev >= 0.2.0)
EvEmbed::__construct — Construit un objet EvEmbed
$other
[,
callable
$callback
[,
mixed
$data
[,
int
$priority
]]] )Il s'agit d'un type de watcher avancé qui permet d'intégrer une boucle d'événement dans une autre (actuellement, seuls les événements IO sont supportés dans la boucle interne, les autres types de watcher ne doit pas être utilisés).
Voir la » documentation libev pour plus de détails.
Ce watcher est le plus utile sous les systèmes BSD où kqueue n'est pas utilisé, pour être capable de gérer un grand nombre de sockers. Voir l'exemple ci-dessous.
other
Une instance de EvLoop. La boucle à intégrer ; elle doit être encapsulable (voir la méthode Ev::embeddableBackends()).
callback
Voir les fonctions de rappel des Watcher.
data
Données personnalisées à associer avec le watcher.
priority
Retourne un objet EvEmbed en cas de succès.
Exemple #1 Encapsulage d'une boucle créée avec le gestionnaire kqueue dans la boucle par défaut
<?php
/*
* Vérifie si kqueue est disponible et crée un gestionnaire kqueue
* pour l'utiliser avec les sockets (qui fonctionne habituellement avec n'importe quelle implémentation
* de kqueue. Stocke la boucle d'événement kqueue/socket seulement, dans loop_socket.
* (optionnellement, utilisation de EVFLAG_NOENV)
*
* Exemple issue de
* http://pod.tst.eu/http://cvs.schmorp.de/libev/ev.pod#Examples_CONTENT-9
*/
$loop = EvLoop::defaultLoop();
$socket_loop = NULL;
$embed = NULL;
if (Ev::supportedBackends() & ~Ev::recommendedBackends() & Ev::BACKEND_KQUEUE) {
if (($socket_loop = new EvLoop(Ev::BACKEND_KQUEUE))) {
$embed = new EvEmbed($loop);
}
}
if (!$socket_loop) {
$socket_loop = $loop;
}
// Maintenant, on utilise $socket_loop pour tous les sockets, et $loop poour tout le reste
?>