1
0
mirror of https://github.com/danog/class-finder.git synced 2025-01-23 06:11:26 +01:00
class-finder/README.md

135 lines
3.3 KiB
Markdown
Raw Normal View History

2018-07-28 14:42:35 -05:00
ClassFinder
===========
2018-09-16 12:34:30 -05:00
A dead simple utility to identify classes in a given namespace. This package is an improved implementation of an
2018-07-28 14:42:35 -05:00
[answer on Stack Overflow](https://stackoverflow.com/a/40229665/3000068) that provides additional features with less
configuration required.
Requirements
------------
* Application is using Composer.
2018-11-24 10:56:55 -06:00
* Classes can be autoloaded with Composer.
2018-07-28 14:42:35 -05:00
* PHP >= 5.3.0
2018-08-04 19:18:02 -05:00
2018-07-28 14:42:35 -05: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 10:56:55 -06:00
Supported Autoloading Methods
--------------------------------
2018-12-31 19:52:49 -06:00
| Method | Supported | with `ClassFinder::RECURSIVE_MODE` |
| ---------- | --------- | ---------------------------------- |
| PSR-4 | ✔️ | ✔️ |
| PSR-0 | ❌️* | ❌️* |
| Classmap | ✔️ | ✔️ |
| Files | ✔️^ | ❌️** |
2018-11-24 10:56:55 -06:00
2018-12-31 19:52:49 -06:00
\^ Experimental.
2018-11-24 10:56:55 -06:00
2018-12-31 19:52:49 -06:00
\* Planned.
\** Not planned. Open an issue if you need this feature.
Examples
--------
**Standard Mode**
2018-07-28 14:42:35 -05:00
```
<?php
require_once __DIR__ . '/vendor/autoload.php';
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo');
/**
* array(
* 'TestApp1\Foo\Bar',
* 'TestApp1\Foo\Baz',
* 'TestApp1\Foo\Foo'
* )
*/
var_dump($classes);
```
2018-12-31 19:52:49 -06:00
**Recursive Mode** *(in v0.3-beta)*
```
<?php
require_once __DIR__ . '/vendor/autoload.php';
$classes = ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE);
/**
* 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);
```
Documentation
-------------
2018-09-02 19:47:08 -05:00
[Changelog](docs/changelog.md)
**Exceptions**:
* [Unknown namespace - (Unregistered)](docs/exceptions/unregisteredRoot.md)
* [Unknown namespace - (Registered)](docs/exceptions/unknownSubNamespace.md)
* [Missing composer.json](docs/exceptions/missingComposerConfig.md)
**Internals**
2018-09-03 16:48:35 -05:00
* [How Testing Works](docs/testing.md)
2018-09-16 12:34:30 -05:00
* [Continuous Integration Notes](docs/ci.md)
Roadmap
-------
> **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.
0.0.1 - First party `psr4` classes
0.1.0 - Third party `psr4` classes
0.2.0 - `classmap` support.
0.3.0 - `files` support
0.4.0 - `psr0` support
0.5.0 - Additional features:
Various ideas:
2018-12-31 19:52:49 -06:00
* ~~`ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE)`.
Providing classes multiple namespaces deep.~~ (included v0.3-beta)
2018-09-16 12:34:30 -05:00
2018-12-31 19:52:49 -06:00
* `ClassFinder::getClassesImplementingInterface('TestApp1\Foo', 'TestApp1\FooInterface', ClassFinder::RECURSIVE_MODE)`.
2018-09-16 12:34:30 -05: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.
1.0.0 - Better compliance with semantic versioning.