From a04672532138a560caf68b7ab5f110134f6c30fb Mon Sep 17 00:00:00 2001 From: Roeland Jago Douma Date: Wed, 24 Aug 2016 13:22:21 +0200 Subject: Dark autoloader magic for ThemingDefaults --- lib/private/Server.php | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/lib/private/Server.php b/lib/private/Server.php index d3da028a27c..55fe71d50a2 100644 --- a/lib/private/Server.php +++ b/lib/private/Server.php @@ -642,10 +642,16 @@ class Server extends ServerContainer implements IServerContainer { return $factory->getManager(); }); $this->registerService('ThemingDefaults', function(Server $c) { - try { - $classExists = class_exists('OCA\Theming\ThemingDefaults'); - } catch (\OCP\AutoloadNotAllowedException $e) { - // App disabled or in maintenance mode + /* + * Dark magic for autoloader. + * If we do a class_exists it will try to load the class which will + * make composer cache the result. Resulting in errors when enabling + * the theming app. + */ + $prefixes = \OC::$composerAutoloader->getPrefixesPsr4(); + if (isset($prefixes['OCA\\Theming\\'])) { + $classExists = true; + } else { $classExists = false; } -- cgit v1.2.3 From b59f5fc72517ce7f89d5b9955bca8200c1582c8a Mon Sep 17 00:00:00 2001 From: Roeland Jago Douma Date: Wed, 24 Aug 2016 13:22:44 +0200 Subject: Require a ThemingDefaults class again --- apps/theming/lib/Settings/Admin.php | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/apps/theming/lib/Settings/Admin.php b/apps/theming/lib/Settings/Admin.php index d0a9f554084..1f79449e658 100644 --- a/apps/theming/lib/Settings/Admin.php +++ b/apps/theming/lib/Settings/Admin.php @@ -29,21 +29,20 @@ use OCP\IConfig; use OCP\IL10N; use OCP\IURLGenerator; use OCP\Settings\ISettings; -use \OC_Defaults; class Admin implements ISettings { /** @var IConfig */ private $config; /** @var IL10N */ private $l; - /** @var ThemingDefaults|OC_Defaults */ + /** @var ThemingDefaults */ private $themingDefaults; /** @var IURLGenerator */ private $urlGenerator; public function __construct(IConfig $config, IL10N $l, - OC_Defaults $themingDefaults, + ThemingDefaults $themingDefaults, IURLGenerator $urlGenerator) { $this->config = $config; $this->l = $l; -- cgit v1.2.3