mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Revert "BUGFIX Versioned's constructor doesn't provide suitable defaults. Previously a bug/feature in singleton, where it would pass null,true as params to strong_create, which would then get passed through as params to Versioned's constructor, meant that the code still executed fine (as was set to something that wasn't an array, so the null and true were instead taken as args). The fact that the usage of singleton(Versioned) never really used the classes code, purely for value lookup, meant that this never propagated errors. I've now switched singleton() to use the injector for retrieving values, which means these dud values are no longer passed through"
This reverts commit 5eaca340b486a2a29d7096220c3d1cabb2d6645f.
This commit is contained in:
parent
627def6be3
commit
29e04a1049
@ -118,7 +118,7 @@ class Config {
|
||||
* @return Config
|
||||
*/
|
||||
static public function inst() {
|
||||
if (!self::$instance) self::$instance = new Config();
|
||||
if (!self::$instance) self::$instance = singleton('Config');
|
||||
return self::$instance;
|
||||
}
|
||||
|
||||
|
@ -367,7 +367,7 @@ function singleton($className) {
|
||||
if(!is_string($className)) user_error("singleton() passed bad class_name: " . var_export($className,true), E_USER_ERROR);
|
||||
if(!isset($_SINGLETONS[$className])) {
|
||||
if(!class_exists($className)) user_error("Bad class to singleton() - $className", E_USER_ERROR);
|
||||
$_SINGLETONS[$className] = Injector::inst()->get($className);
|
||||
$_SINGLETONS[$className] = Object::strong_create($className,null, true);
|
||||
if(!$_SINGLETONS[$className]) user_error("singleton() Unknown class '$className'", E_USER_ERROR);
|
||||
}
|
||||
return $_SINGLETONS[$className];
|
||||
|
@ -235,7 +235,8 @@ abstract class Object {
|
||||
$class = self::$strong_classes[$class];
|
||||
}
|
||||
|
||||
return Injector::inst()->createWithArgs($class, $args);
|
||||
$reflector = new ReflectionClass($class);
|
||||
return $reflector->newInstanceArgs($args);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -92,7 +92,7 @@ class Versioned extends DataExtension {
|
||||
* The first stage is consiedered the 'default' stage, the last stage is
|
||||
* considered the 'live' stage.
|
||||
*/
|
||||
function __construct($stages=array('Stage','Live')) {
|
||||
function __construct($stages) {
|
||||
parent::__construct();
|
||||
|
||||
if(!is_array($stages)) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user