2016-01-27 13:46:43 +13:00
|
|
|
<?php
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
namespace SilverStripe\Core\Injector;
|
2016-01-27 13:46:43 +13:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A class that can be instantiated or replaced via DI
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
trait Injectable
|
|
|
|
{
|
2016-01-27 13:46:43 +13:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* An implementation of the factory method, allows you to create an instance of a class
|
|
|
|
*
|
|
|
|
* This method will defer class substitution to the Injector API, which can be customised
|
|
|
|
* via the Config API to declare substitution classes.
|
|
|
|
*
|
|
|
|
* This can be called in one of two ways - either calling via the class directly,
|
|
|
|
* or calling on Object and passing the class name as the first parameter. The following
|
|
|
|
* are equivalent:
|
|
|
|
* $list = DataList::create('SiteTree');
|
|
|
|
* $list = SiteTree::get();
|
|
|
|
*
|
|
|
|
* @param string $classOrArgument The first argument, or class name (if called directly
|
|
|
|
* on Object).
|
|
|
|
* @param mixed $argument,... arguments to pass to the constructor
|
|
|
|
* @return static
|
|
|
|
*/
|
|
|
|
public static function create($classOrArgument = null, $argument = null)
|
|
|
|
{
|
|
|
|
$args = func_get_args();
|
2016-01-27 13:46:43 +13:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
// Class to create should be the calling class if not Object,
|
|
|
|
// otherwise the first parameter
|
|
|
|
$class = get_called_class();
|
|
|
|
if ($class == 'SilverStripe\\Core\\Object') {
|
|
|
|
$class = array_shift($args);
|
|
|
|
}
|
2016-01-27 13:46:43 +13:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
return Injector::inst()->createWithArgs($class, $args);
|
|
|
|
}
|
2016-01-27 13:46:43 +13:00
|
|
|
|
2016-11-29 12:31:16 +13:00
|
|
|
/**
|
|
|
|
* Creates a class instance by the "singleton" design pattern.
|
|
|
|
* It will always return the same instance for this class,
|
|
|
|
* which can be used for performance reasons and as a simple
|
|
|
|
* way to access instance methods which don't rely on instance
|
|
|
|
* data (e.g. the custom SilverStripe static handling).
|
|
|
|
*
|
|
|
|
* @param string $class Optional classname to create, if the called class should not be used
|
|
|
|
* @return static The singleton instance
|
|
|
|
*/
|
|
|
|
public static function singleton($class = null)
|
|
|
|
{
|
|
|
|
if (!$class) {
|
|
|
|
$class = get_called_class();
|
|
|
|
}
|
|
|
|
return Injector::inst()->get($class);
|
|
|
|
}
|
2016-01-27 13:46:43 +13:00
|
|
|
}
|