Krautoload is a pluggable PHP class autoloader library. In addition, it can do class discovery based on the same mappings registered in the class loader.
The class loader has native support for
- Class maps.
- The proposed PSR-X, which is a shallow-dir variation of PSR-0 without the special underscore handling.
- PSR-0
- PEAR (that is the old-school pattern with underscores instead of namespaces)
(yes, this is just a subset of PSR-0, but Krautoload has explicit support for it) - Variations of PSR-0 with different levels of "safety" (to avoid duplicate file inclusion, etc)
It also supports some "non-standard" stuff, just because we can, and it was too tempting not to do it:
- Variation of PSR-0 which allows shallow directory structures.
- Variation of PEAR which allows shallow directory structures.
Besides that, custom plugins can be mapped to any namespaces and prefixes, to allow the most wonky logical mappings.
E.g. there is an example plugin "CamelSwap", that would map a class ".._TinyPetShop" to "../shop/pet/tiny.php".
(the idea is to support old-school libraries which still have some logic in where they put their classes)
The basic Krautoload "pluggable" class loader is designed to have a decent performance, that does no have to be afraid of competition. Especially, the main lookup algorithm is designed to perform equally well no matter how many namespaces are registered. (even if most of these namespaces all share the same prefix)
If that is not enough, there are different cache decorators, mostly equivalent with those you find in Symfony2:
- APC cache
- XCache
- WinCache
- Generated class maps
- Note: That's not a decorator, but can still speed you up.
- Krautoload can't generate its own class maps, but there are enough tools out there which can.
The project has changed a lot in recent days and weeks, but it is now probably quite close to a stable shape.
Still, some API details may still change based on community feedback.
Especially, the term "PSR-X" may change in the future, if it gets accepted.
The project is a spin-off of the "xautoload" module for Drupal, with some changes.
Unlike xautoload, Krautoload is written in anticipation of the hopefully upcoming PSR-X.
It is optimized for PSR-X, and needs a tiny-tiny extra operation if wired up with PSR-0, for the special underscore handling.
Modern PHP projects typically use class loading solutions shipped with the framework, or provided by Composer. Thus, Krautoload is mainly aimed at framework developers, for full inclusion, copying, or inspiration.
Krautoload provides a start-off class with static methods, for those who want to avoid a lengthy bootstrap.
Alternative bootstrap helpers may be provided based on community feedback.
require_once "$path_to_krautoload/src/Krautoload.php";
// Create the class loader and register it.
$krautoload = Krautoload::start();
// Register additional namespaces
$krautoload->addNamespacePSR0('FooVendor\FooPackage', "$path_to_foo_package/src");
new FooVendor\FooPackage\Foo\Bar\Baz();
See Krautoload\RegistrationHub to see all the available registration methods.
Krautoload can be used instead of the autoload.php generated by Composer.
Boot Krautoload like above, and then
// Let Krautoload look for the files defining the namespace map and class map.
$krautoload->composerVendorDir($vendor_dir);
You need
- a "NamespaceInspector" object (which is a more powerful version of the ClassLoader)
- a "SearchableNamespaces" object, using the namespace inspector.
- Then you can do class discovery within those namespaces.
// Start Krautoload with discovery capabilities.
// This means, it will create a NamespaceInspector instead of a ClassLoader.
// The only overhead this adds is *two* additional files being loaded (one class, one interface).
// So, no reason not to.
$krautoload = Krautoload::start(array('introspection' => TRUE));
// Register your stuff
$krautoload->addPrefix...
$krautoload->addNamespace...
// Class loading should work now.
new MyVendor\MyPackage\Foo\Bar();
// Create searchable namespaces object.
$searchableNamespaces = $krautoload->buildSearchableNamespaces(array(
'MyVendor\MyPackage\Foo1',
'MyVendor\MyPackage\Foo2',
));
// Scan those namespaces
$recursive = TRUE;
$classes = $searchableNamespaces->discoverExistingClasses($recursive);
Tests exist, but coverage is still not fully acceptable. This is why Travis complains.
https://travis-ci.org/donquixote/krautoload
Any help is appreciated.
Benchmarks would be nice to have, but they do not exist yet. Any help appreciated.
Like Tests, benchmarks can be programmed with a mocked-out filesystem, where instead of actually doing file inclusion or file_exists(), we simply count the number of times this would happen.
This will not tell us the real duration in a live environment, but it will determine the time used for the actual class finding much more accurately than with the natural variations of filesystem operations.