Shows us all files and catalogues in directory except "." and "..".
<?php
foreach (new DirectoryIterator('../moodle') as $fileInfo) {
if($fileInfo->isDot()) continue;
echo $fileInfo->getFilename() . "<br>\n";
}
?>
A classe DirectoryIterator
Introdução
...
Sinopse da classe
Índice
- DirectoryIterator::__construct — Constrói um novo iterador de diretório a partir de um caminho
- DirectoryIterator::current — Retorna $this (necessário para a interface Iterator)
- DirectoryIterator::getATime — Retorna a data de último acesso do arquivo
- DirectoryIterator::getBasename — Get base name of current DirectoryIterator item.
- DirectoryIterator::getCTime — Retorna a data de modificação do inode do arquivo
- DirectoryIterator::getFilename — Retorna o nome do arquivo do elemento atual do diretório
- DirectoryIterator::getGroup — Retorna o grupo do arquivo
- DirectoryIterator::getInode — Retorna o inode do arquivo
- DirectoryIterator::getMTime — Retorna a data da última modificação do arquivo
- DirectoryIterator::getOwner — Retorna o proprietário do arquivo
- DirectoryIterator::getPath — Retorna o caminho do diretório
- DirectoryIterator::getPathname — Retorna o caminho e o nome do arquivo do elemento atual do diretório
- DirectoryIterator::getPerms — Retorna as permissões do arquivo
- DirectoryIterator::getSize — Retorna o tamanho do arquivo
- DirectoryIterator::getType — Retorna o tipo do arquivo
- DirectoryIterator::isDir — Retorna true se o elemento atual é um diretório
- DirectoryIterator::isDot — Retorna true se o elemento atual for '.' ou '..'
- DirectoryIterator::isExecutable — Retorna true se o arquivo for executável
- DirectoryIterator::isFile — Retorna true se o elemento atual for um arquivo
- DirectoryIterator::isLink — Retorna true se o elemento atual for um link simbólico
- DirectoryIterator::isReadable — Retorna true se o arquivo pode ser lido
- DirectoryIterator::isWritable — Retorna true se o arquivo pode ser modificado
- DirectoryIterator::key — Retorna o elemento atual do diretório
- DirectoryIterator::next — Avança para o próximo elemento
- DirectoryIterator::rewind — Recomeça a iteração do diretório
- DirectoryIterator::seek — Seek to a DirectoryIterator item
- DirectoryIterator::__toString — Get file name as a string
- DirectoryIterator::valid — Verifica se o diretório possui ou não mais elementos
DirectoryIterator
krystianmularczyk at gmail dot com
25-Jan-2009 11:31
25-Jan-2009 11:31
David Lanstein
21-Jan-2009 08:50
21-Jan-2009 08:50
DirectoryIterator::getBasename() has been also been available since 5.2.2, according to the changelog (not documented yet). It takes a parameter $suffix, and is useful if, for instance, you use a naming convention for your files (e.g. ClassName.php).
The following code uses this to add recursively All*Tests.php in any subdirectory off of tests/, basically, suites of suites.
<?php
// PHPUnit boilerplate code goes here
class AllTests {
public static function main() {
$parameters = array('verbose' => true);
PHPUnit_TextUI_TestRunner::run(self::suite(), $parameters);
}
public static function suite() {
$suite = new PHPUnit_Framework_TestSuite('AllMyTests'); // this must be something different than the class name, per PHPUnit
$it = new AllTestsFilterIterator(
new RecursiveIteratorIterator(
new RecursiveDirectoryIterator(dirname(__FILE__) . '/tests')));
for ($it->rewind(); $it->valid(); $it->next()) {
require_once($it->current());
$className = $it->current()->getBasename('.php');
$suite->addTest($className::suite());
}
return $suite;
}
}
?>
Also, the AllTestsFilterIterator above extends FilterIterator, and contains one method, accept():
<?php
class AllTestsFilterIterator extends FilterIterator {
public function accept() {
if (preg_match('/All.*Tests\.php/', $this->current())) {
return true;
} else {
return false;
}
}
}
?>
Mark van Straten
09-Jul-2008 02:56
09-Jul-2008 02:56
Implements Iterator so you can foreach() over the content of the given directory
