eio_grp

(PECL eio >= 0.0.1dev)

eio_grpCrear un grupo de peticiones

Descripción

eio_grp ( callable $callback [, string $data = NULL ] ) : resource

eio_grp() crea un grupo de peticiones.

Parámetros

callback

La función callback es llamada cuando la petición está hecha. Debería seguir el siguiente prototipo:

void callback(mixed $data, int $result[, resource $req]);
data

son datos personalizados pasados a la petición.

result

es el valor del resultado específico de la petición; básicamente, el valor devuelto por la correspondiente llamada al sistema.

req

es el recurso de petición opcional que puede usarse con funciones como eio_get_last_error()

data

Variable arbitraria pasada a callback.

Valores devueltos

eio_grp() devuelve un recurso de grupo de peticiones en caso de éxito o FALSE en caso de error.

Ejemplos

Ejemplo #1 Ejemplo de eio_grp()

<?php
$nombre_fichero_temp 
dirname(__FILE__) ."/fichero-eio.tmp";
$fp fopen($nombre_fichero_temp"w");
fwrite($fp"algunos datos");
fclose($fp);
$mi_df_fichero NULL;

/* Es llamada cuando el grupo de peticiones está hecho */
function mi_grupo_hecho($datos$resultado) {
 
// Eliminar el fichero, si aún existe
 
@unlink($datos);
}

/* Es llamada al abrir el fichero temporal */
function mi_llamada_retorno_grupo_fichero_abierto($datos$resultado) {
 global 
$mi_df_fichero$grupo;

 
$mi_df_fichero $resultado;

 
$petición eio_read($mi_df_fichero40,
   
EIO_PRI_DEFAULT"mi_llamada_retorno_grupo_fichero_leído");
 
eio_grp_add($grupo$petición);
}

/* Es llamada cuando el fichero es leído */
function mi_llamada_retorno_grupo_fichero_leído($datos$resultado) {
 global 
$mi_df_fichero$grupo;

 
var_dump($resultado);

 
// Crear una petición para cerrar el fichero
 
$petición eio_close($mi_df_fichero);

 
// Añadir la petición al grupo
 
eio_grp_add($grupo$petición);
}

// Crear un grupo de peticiones
$grupo eio_grp("mi_grupo_hecho"$nombre_fichero_temp);

// Crear una petición
$petición eio_open($nombre_fichero_tempEIO_O_RDWR EIO_O_APPEND NULL,
  
EIO_PRI_DEFAULT"mi_llamada_retorno_grupo_fichero_abierto"NULL);

// Añadir la petición al grupo
eio_grp_add($grupo$petición);

// Procesar las peticiones
eio_event_loop();
?>

El resultado del ejemplo sería algo similar a:

string(7) "algunos"

Ver también

  • eio_grp_cancel
  • eio_grp_add