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();
|
|
|
|
*
|
2017-05-17 17:40:13 +12:00
|
|
|
* @param array $args
|
2016-11-29 12:31:16 +13:00
|
|
|
* @return static
|
|
|
|
*/
|
2017-05-17 17:40:13 +12:00
|
|
|
public static function create(...$args)
|
2016-11-29 12:31:16 +13:00
|
|
|
{
|
2017-05-17 17:40:13 +12:00
|
|
|
// Class to create should be the calling class
|
2016-11-29 12:31:16 +13:00
|
|
|
$class = get_called_class();
|
|
|
|
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
|
|
|
}
|