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