2018-07-28 21:42:35 +02:00
|
|
|
ClassFinder
|
|
|
|
===========
|
|
|
|
|
2020-10-11 17:39:05 +02:00
|
|
|
A dead simple utility to identify classes, traits and interfaces in a given namespace.
|
2019-09-08 17:04:46 +02:00
|
|
|
|
|
|
|
This package is an improved implementation of an [answer on Stack Overflow](https://stackoverflow.com/a/40229665/3000068)
|
|
|
|
and provides additional features with less configuration required.
|
2018-07-28 21:42:35 +02:00
|
|
|
|
|
|
|
Requirements
|
|
|
|
------------
|
|
|
|
|
2019-09-08 17:04:46 +02:00
|
|
|
* Application is using Composer.
|
|
|
|
* Classes can be autoloaded with Composer.
|
|
|
|
* PHP >= 5.3.0
|
2018-08-05 02:18:02 +02:00
|
|
|
|
2018-07-28 21:42:35 +02:00
|
|
|
Installing
|
|
|
|
----------
|
|
|
|
|
|
|
|
Installing is done by requiring it with Composer.
|
|
|
|
|
|
|
|
```
|
|
|
|
$ composer require haydenpierce/class-finder
|
|
|
|
```
|
|
|
|
|
|
|
|
No other installation methods are currently supported.
|
|
|
|
|
2018-11-24 17:56:55 +01:00
|
|
|
Supported Autoloading Methods
|
|
|
|
--------------------------------
|
|
|
|
|
2019-01-01 02:52:49 +01:00
|
|
|
| Method | Supported | with `ClassFinder::RECURSIVE_MODE` |
|
|
|
|
| ---------- | --------- | ---------------------------------- |
|
|
|
|
| PSR-4 | ✔️ | ✔️ |
|
|
|
|
| PSR-0 | ❌️* | ❌️* |
|
|
|
|
| Classmap | ✔️ | ✔️ |
|
|
|
|
| Files | ✔️^ | ❌️** |
|
2018-11-24 17:56:55 +01:00
|
|
|
|
2019-01-01 02:52:49 +01:00
|
|
|
\^ Experimental.
|
2018-11-24 17:56:55 +01:00
|
|
|
|
2019-01-01 02:52:49 +01:00
|
|
|
\* Planned.
|
|
|
|
|
|
|
|
\** Not planned. Open an issue if you need this feature.
|
|
|
|
|
|
|
|
Examples
|
|
|
|
--------
|
|
|
|
|
|
|
|
**Standard Mode**
|
2018-07-28 21:42:35 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
<?php
|
|
|
|
|
|
|
|
require_once __DIR__ . '/vendor/autoload.php';
|
|
|
|
|
2020-10-11 17:39:05 +02:00
|
|
|
// Will default to ClassFinder::ALLOW_CLASSES
|
2018-07-28 21:42:35 +02:00
|
|
|
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo');
|
2020-10-11 17:39:05 +02:00
|
|
|
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::ALLOW_CLASSES);
|
|
|
|
$interfaces = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::ALLOW_INTERFACES);
|
|
|
|
$traits = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::ALLOW_TRAITS);
|
|
|
|
|
|
|
|
// You can combine any of the flags
|
|
|
|
$interfacesTraits = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::ALLOW_TRAITS | ClassFinder::ALLOW_INTERFACES);
|
2018-07-28 21:42:35 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* array(
|
|
|
|
* 'TestApp1\Foo\Bar',
|
|
|
|
* 'TestApp1\Foo\Baz',
|
|
|
|
* 'TestApp1\Foo\Foo'
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
var_dump($classes);
|
2020-10-11 17:39:05 +02:00
|
|
|
/**
|
|
|
|
* array(
|
|
|
|
* 'TestApp1\Foo\BarInterface',
|
|
|
|
* 'TestApp1\Foo\FooInterface'
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
var_dump($interfaces);
|
|
|
|
/**
|
|
|
|
* array(
|
|
|
|
* 'TestApp1\Foo\BazTrait',
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
var_dump($traits);
|
|
|
|
/**
|
|
|
|
* array(
|
|
|
|
* 'TestApp1\Foo\BarInterface',
|
|
|
|
* 'TestApp1\Foo\FooInterface',
|
|
|
|
* 'TestApp1\Foo\BazTrait',
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
var_dump($interfacesTraits);
|
2018-07-28 21:42:35 +02:00
|
|
|
```
|
2019-01-01 02:52:49 +01:00
|
|
|
|
|
|
|
**Recursive Mode** *(in v0.3-beta)*
|
|
|
|
|
|
|
|
```
|
|
|
|
<?php
|
|
|
|
|
|
|
|
require_once __DIR__ . '/vendor/autoload.php';
|
|
|
|
|
2020-10-11 17:39:05 +02:00
|
|
|
// As before, will default to ClassFinder::ALLOW_CLASSES
|
2019-01-01 02:52:49 +01:00
|
|
|
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE);
|
2020-10-11 17:39:05 +02:00
|
|
|
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE | ClassFinder::ALLOW_CLASSES);
|
|
|
|
$interfaces = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE | ClassFinder::ALLOW_INTERFACES);
|
|
|
|
$traits = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE | ClassFinder::ALLOW_TRAITS);
|
|
|
|
|
|
|
|
|
|
|
|
// You can combine any of the flags
|
|
|
|
$classesTraits = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE | ClassFinder::ALLOW_CLASSS | ClassFinder::ALLOW_TRAITS);
|
2019-01-01 02:52:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* array(
|
|
|
|
* 'TestApp1\Foo\Bar',
|
|
|
|
* 'TestApp1\Foo\Baz',
|
|
|
|
* 'TestApp1\Foo\Foo',
|
|
|
|
* 'TestApp1\Foo\Box\Bar',
|
|
|
|
* 'TestApp1\Foo\Box\Baz',
|
|
|
|
* 'TestApp1\Foo\Box\Foo',
|
|
|
|
* 'TestApp1\Foo\Box\Lon\Bar',
|
|
|
|
* 'TestApp1\Foo\Box\Lon\Baz',
|
|
|
|
* 'TestApp1\Foo\Box\Lon\Foo',
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
var_dump($classes);
|
2020-10-11 17:39:05 +02:00
|
|
|
|
|
|
|
// You get the idea :)
|
|
|
|
var_dump($interfaces);
|
|
|
|
var_dump($traits);
|
|
|
|
var_dump($classesTraits);
|
2019-01-01 02:52:49 +01:00
|
|
|
```
|
2018-08-05 02:39:28 +02:00
|
|
|
|
|
|
|
Documentation
|
|
|
|
-------------
|
|
|
|
|
2018-09-03 02:47:08 +02:00
|
|
|
[Changelog](docs/changelog.md)
|
|
|
|
|
2018-08-05 02:39:28 +02:00
|
|
|
**Exceptions**:
|
|
|
|
|
2019-09-08 17:02:52 +02:00
|
|
|
* [Files could not locate PHP](docs/exceptions/filesCouldNotLocatePHP.md)
|
|
|
|
* [Files exec not available](docs/exceptions/filesExecNotAvailable.md)
|
2018-08-05 03:06:24 +02:00
|
|
|
* [Missing composer.json](docs/exceptions/missingComposerConfig.md)
|
2018-08-05 03:22:43 +02:00
|
|
|
|
|
|
|
**Internals**
|
|
|
|
|
2018-09-03 23:48:35 +02:00
|
|
|
* [How Testing Works](docs/testing.md)
|
2018-09-16 19:34:30 +02:00
|
|
|
* [Continuous Integration Notes](docs/ci.md)
|
|
|
|
|
2019-09-15 16:32:40 +02:00
|
|
|
Future Work
|
|
|
|
-----------
|
2018-09-16 19:34:30 +02:00
|
|
|
|
|
|
|
> **WARNING**: Before 1.0.0, expect that bug fixes _will not_ be backported to older versions. Backwards incompatible changes
|
|
|
|
may be introduced in minor 0.X.Y versions, where X changes.
|
|
|
|
|
2019-09-15 16:32:40 +02:00
|
|
|
* `psr0` support
|
2018-09-16 19:34:30 +02:00
|
|
|
|
2019-09-15 16:32:40 +02:00
|
|
|
* Additional features:
|
2018-09-16 19:34:30 +02:00
|
|
|
|
|
|
|
Various ideas:
|
|
|
|
|
2019-01-01 02:52:49 +01:00
|
|
|
* ~~`ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE)`.
|
|
|
|
Providing classes multiple namespaces deep.~~ (included v0.3-beta)
|
2018-09-16 19:34:30 +02:00
|
|
|
|
2019-01-01 02:52:49 +01:00
|
|
|
* `ClassFinder::getClassesImplementingInterface('TestApp1\Foo', 'TestApp1\FooInterface', ClassFinder::RECURSIVE_MODE)`.
|
2018-09-16 19:34:30 +02:00
|
|
|
Filtering classes to only classes that implement a namespace.
|
|
|
|
|
|
|
|
* `ClassFinder::debugRenderReport('TestApp1\Foo\Baz')`
|
|
|
|
Guidance for solving "class not found" errors resulting from typos in namespaces, missing directories, etc. Would print
|
|
|
|
an HTML report. Not intended for production use, but debugging.
|