waylandace / class-finder
Utility class to help you discover other classes / namespaces based on the composer auto loader.
v1.0.4
2019-07-18 18:35 UTC
Requires
- php: ^7.0
- gears/string: ^1.1
- symfony/finder: ^2.0|^3.0|^4.0
Requires (Dev)
- consolidation/robo: ^1.0
- phpunit/phpunit: ^6.0
- satooshi/php-coveralls: ^1.0
This package is auto-updated.
Last update: 2024-10-19 06:37:11 UTC
README
Looking for maintainers, I no longer do much if any PHP dev, I have moved on, mostly work in dotnet core, node.js & golang these days. If anyone is keen to take over these projects, get in touch - brad@bjc.id.au
Class Finder, like Symfony\Finder but for classes.
Utility class to help you discover other classes / namespaces based on the composer auto loader.
How to Install
Installation via composer is easy:
composer require gears/class-finder
Examples
// Make sure you grab the composer ClassLoader instance, the class finder needs it. $composer = require('vendor/autoload.php'); // Create a new finder. You may reuse this as much as you like. // Right now caching is not performed but could be in the future. $finder = new Gears\ClassFinder($composer); // Find all classes inside a namespace $classes = $finder->namespace('Foo\\Bar')->search(); // Returns an array like: $classes = [ '/home/user/project/vendor/foo/src/Bar/Baz.php' => 'Foo\\Bar\\Baz', '/home/user/project/vendor/foo/src/Bar/Qux.php' => 'Foo\\Bar\\Qux', 'etc...' ]; // Find all classes inside a namespace that implement an interface. $classes = $finder->namespace('Foo\\Bar')->implements('SomeInterface')->search(); // OR you can use the PHP 5.5 ::class operator $classes = $finder->namespace('Foo\\Bar')->implements(SomeInterface::class)->search(); // Or filter by parent classes $classes = $finder->namespace('Foo\\Bar')->extends(SomeParent::class)->search(); // NOTE: You can't do both out of the box. $classes = $finder->namespace('Foo\\Bar') // This is now allowed! ->implements(SomeInterface::class) ->extends(SomeParent::class) ->search(); // Although you could supply your own custom filter that implemented whatever filtering you like. $classes = $finder->namespace('Foo\\Bar')->filterBy(function($rClass ReflectionClass) { /* custom logic goes here, must return true or false */ })->search(); // ClassFinder also implements the IteratorAggregate & Countable interfaces. $number = $finder->namespace('Foo\\Bar')->count(); foreach ($finder->namespace('Foo\\Bar') as $filepath => $fqcn) { }
Developed by Brad Jones - brad@bjc.id.au