Library for lazy class aliasing.
Via Composer
$ composer require fuelphp/alias
Within FuelPHP class aliases are used to provide easy access to namespaced classes and facilitate class inheritance injection.
The package exposes an alias manager which lets you create 3 types of aliases:
- Literal
A one-to-one translation. Class "Namespaced\Classname" translates to "Another\Classname". - Namespace
Namespace aliases allow you to alias an entire namespace with one call. - Replacement
A pattern is matched an through replacements a new class is generated. "Namespace\*" maps to "Alias\$1".
When registering the alias manager append or prepends itself to the autoload stack to act as a pre-processor or fallback. Depending on the amount of aliases and it could be beneficial to alternate between pre- or appending.
By default the manager will prepend itself to the autoloader stack.
// Create a new alias manager
$manager = new Fuel\Alias\Manager;
// Register the manager
$manager->register();
// Alias one class
$manager->alias('Alias\Me', 'To\This');
// Or alias many
$manager->alias([
'Alias\This' => 'To\Me',
'AndAlias\This' => 'To\SomethingElse',
]);
//
// alias to a less deep namespace
$manager->aliasNamespace('Less\Deep', 'Some\Super\Deep\Name\Space');
// alias a namespace to global
$manager->aliasNamespace('Some\Space', '');
$manager = new Fuel\Alias\Manager;
// Alias with wildcards
$manager->aliasPattern('Namespaced\*', 'Other\\$1');
$otherThing = new Namespaced\Thing;
This can result into class resolving that doesn't exists. Luckily the package is smart enough the check wether the class exists and will continue to look for the correct class if the resolved class does not exist. This is also taken into account when it comes to caching. Only resolved classes that exist will be cached.
Thank you for considering contribution to FuelPHP framework. Please see CONTRIBUTING for details.
The MIT License (MIT). Please see License File for more information.