3.0 KiB
3.0 KiB
classy
Provides a finder for classy constructs (classes, enums, interfaces, and traits).
Installation
Run
$ composer require ergebnis/classy
Usage
Collect classy constructs from source code
Use Constructs::fromSource() to collect classy constructs in source code:
<?php
use Ergebnis\Classy\Construct;
use Ergebnis\Classy\Constructs;
$source = <<<'PHP'
<?php
namespace Example;
class Foo {}
enum Bar {}
interface Baz {}
trait Qux {}
PHP;
$constructs = Constructs::fromSource($source);
$names = array_map(static function (Construct $construct): string {
return $construct->name();
}, $constructs);
var_dump($names); // ['Example\Bar', 'Example\Baz', 'Example\Foo', 'Example\Qux']
Collect classy constructs from a directory
Use Constructs::fromDirectory() to collect classy constructs in a directory:
<?php
use Ergebnis\Classy\Construct;
use Ergebnis\Classy\Constructs;
$constructs = Constructs::fromDirectory(__DIR__ . '/example');
$names = array_map(static function (Construct $construct): string {
return $construct->name();
}, $constructs);
var_dump($names); // ['Example\Bar', 'Example\Bar\Baz', 'Example\Foo\Bar\Baz']
Changelog
Please have a look at CHANGELOG.md.
Contributing
Please have a look at CONTRIBUTING.md.
Code of Conduct
Please have a look at CODE_OF_CONDUCT.md.
License
This package is licensed using the MIT License.
Please have a look at LICENSE.md.
Credits
The algorithm for finding classes in PHP files in Constructs has been adopted from Zend\File\ClassFileLocator (originally licensed under BSD-3-Clause).
Curious what I am building?
📬 Subscribe to my list, and I will occasionally send you an email to let you know what I am working on.