streamWrapper::dir_readdir
Lee un archivo en un directorio
&reftitle.description;
public stringboolstreamWrapper::dir_readdir
Este método se llama en respuesta a readdir.
&reftitle.parameters;
&no.function.parameters;
&reftitle.returnvalues;
Debe devolver una &string; que representa el próximo nombre de archivo,
o &false; si no hay más archivos.
Devolver true o false tendrá el mismo
efecto de señalar que no hay un siguiente fichero. Sin embargo,
devolver true está desaconsejado y false
debe ser utilizado para señalar esta condición en su lugar.
Un valor de retorno no booleano se convertirá en &string;.
&reftitle.errors;
&userstream.not.implemented.warning;
&reftitle.examples;
Lista de archivos de un archivo tar
fp = fopen($path, "rb");
return true;
}
public function dir_readdir() {
// Extrae el encabezado para esta entrada
$header = fread($this->fp, 512);
$data = unpack("a100filename/a8mode/a8uid/a8gid/a12size/a12mtime/a8checksum/a1filetype/a100link/a100linkedfile", $header);
// Recorta el nombre del archivo y el tamaño del archivo
$filename = trim($data["filename"]);
// No hay archivo, estamos al final del archivo
if (!$filename) {
return false;
}
$octal_bytes = trim($data["size"]);
// El tamaño del archivo está definido en octetos
$bytes = octdec($octal_bytes);
// tar redondea los tamaños de archivos al múltiplo de 512 siguiente
$rest = $bytes % 512;
if ($rest > 0) {
$bytes += 512 - $rest;
}
// Lectura del archivo
fseek($this->fp, $bytes, SEEK_CUR);
return $filename;
}
public function dir_closedir() {
return fclose($this->fp);
}
public function dir_rewinddir() {
return fseek($this->fp, 0, SEEK_SET);
}
}
stream_wrapper_register("tar", "streamWrapper");
$handle = opendir("tar://example.tar");
while (false !== ($file = readdir($handle))) {
var_dump($file);
}
echo "Reinicio...\n";
rewind($handle);
var_dump(readdir($handle));
closedir($handle);
?>
]]>
&example.outputs.similar;
&reftitle.seealso;
readdir