1
0
mirror of https://github.com/danog/class-finder.git synced 2024-11-26 20:14:59 +01:00
Go to file
2019-02-18 17:48:35 -06:00
ci Remove another hardcoded hpierce1102 2019-02-03 09:55:04 -06:00
docs Updated changelog for v0.3.0 2019-02-18 17:46:24 -06:00
src Attempt to check more directories if an app root isn't found. 2019-02-18 17:38:36 -06:00
test Downgrade components to get 5.3 compatibility again 2019-02-03 09:41:28 -06:00
.gitignore Fix to remove warnings if classmap is empty 2019-01-15 00:52:22 +00:00
.gitlab-ci.yml Remove another hardcoded hpierce1102 2019-02-03 09:55:04 -06:00
composer.json Add a description to composer.json 2019-02-18 17:48:35 -06:00
composer.lock Update composer lock files. 2018-09-22 15:24:53 -05:00
LICENSE Add license 2018-07-28 14:45:27 -05:00
phpunit.xml Include file integration tests in all test suites 2018-10-21 15:34:30 -05:00
README.md Update docs 2018-12-31 19:52:49 -06:00

ClassFinder

A dead simple utility to identify classes in a given namespace. This package is an improved implementation of an answer on Stack Overflow that provides additional features with less configuration required.

Requirements

  • Application is using Composer.
  • Classes can be autoloaded with Composer.
  • PHP >= 5.3.0

Installing

Installing is done by requiring it with Composer.

$ composer require haydenpierce/class-finder

No other installation methods are currently supported.

Supported Autoloading Methods

Method Supported with ClassFinder::RECURSIVE_MODE
PSR-4 ✔️ ✔️
PSR-0 * *
Classmap ✔️ ✔️
Files ✔️^ **

^ Experimental.

* Planned.

** Not planned. Open an issue if you need this feature.

Examples

Standard Mode

<?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);

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

Changelog

Exceptions:

Internals

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:

  • ClassFinder::getClassesInNamespace('TestApp1\Foo', ClassFinder::RECURSIVE_MODE). Providing classes multiple namespaces deep. (included v0.3-beta)

  • ClassFinder::getClassesImplementingInterface('TestApp1\Foo', 'TestApp1\FooInterface', ClassFinder::RECURSIVE_MODE). 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.