ock / class-files-iterator
dev-main
2025-04-26 23:06 UTC
Requires
- php: >=8.3
- ext-json: *
- ock/helpers: dev-main
Requires (Dev)
- phpunit/phpunit: ^10.5.38
This package is auto-updated.
Last update: 2025-04-27 16:52:30 UTC
README
This package provides IteratorAggregate implementations to iterate through class files.
Main concepts:
ClassFilesIA*
:
IteratorAggregate that lists class names keyed by their file names.NamespaceDirectory
:
Main implementation representing a PSR-4 class files directory.
It provides additional methods to navigate to parent or child directories.
ClassNamesIA*
IteratorAggregate that lists class names by numeric keys.
This can be used if the file path is not relevant.
Benefits
There are other packages which attempt to solve the same problem in different ways.
The benefits of this package are:
- Predictable (alphabetic) order of class files.
This is thanks to internal usage ofscandir()
with sort flag, instead of directory iterators. - The "iterators" are stateless/immutable, and can be passed around as value objects.
This is thanks to them extendingIteratorAggregate
instead ofIterator
. - Code that needs a list of classes or class files can simply depend on the interfaces, and does not need to deal with directories.
Limitations
Iterators for reflection classes are not part of this package.
Usage
use Ock\ClassFilesIterator\ClassFilesIA\ClassFilesIAInterface; use Ock\ClassFilesIterator\ClassNamesIA\ClassNamesIAInterface; use Ock\ClassFilesIterator\NamespaceDirectory; use Ock\ClassFilesIterator\Tests\Fixtures\Acme\Plant\VenusFlyTrap; // Basic creation for a PSR-4 directory. $basic_namespace_dir = NamespaceDirectory::create($basedir . '/src', 'Acme\\Foo'); // Convenient creation with a "seed" class. // The directory is determined automatically with ReflectionClass::getFileName(). $namespace_dir = NamespaceDirectory::fromKnownClass(VenusFlyTrap::class); // Iterate class files. function foo(ClassFilesIAInterface $classFilesIA): void { foreach ($classFilesIA as $file => $class) { $rc = new \ReflectionClass($class); // Call realpath() to be sure. assert($rc->getFileName() === realpath($file)); } // Or do this to skip the realpath() call: foreach ($classFilesIA->withRealpathRoot() as $file => $class) { $rc = new \ReflectionClass($class); assert($rc->getFileName() === $file); } } // Iterate class names. function foo(ClassNamesIAInterface $classNamesIA): void { foreach ($classNamesIA as $class) { assert(class_exists($class)); } }