summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2016-05-03 08:24:22 +0200
committerMorris Jobke <hey@morrisjobke.de>2016-05-03 08:24:22 +0200
commita72e6a2dac82c90582d478ead1f5518fc7299f80 (patch)
tree233970891ace12f1fadb99456d4c5a7259b6a23a
parent1974ae8da7dd23f2abfc70ae84b6c8a349fe94ae (diff)
parentd879354ccb19278a45fc28ac9fcf12ec4c0876ea (diff)
downloadnextcloud-server-a72e6a2dac82c90582d478ead1f5518fc7299f80.tar.gz
nextcloud-server-a72e6a2dac82c90582d478ead1f5518fc7299f80.zip
Merge pull request #24386 from owncloud/psr4-for-apps
PSR-4 for apps
-rw-r--r--lib/base.php5
-rw-r--r--lib/private/legacy/app.php23
2 files changed, 25 insertions, 3 deletions
diff --git a/lib/base.php b/lib/base.php
index fb58177a432..badbe3cd1f8 100644
--- a/lib/base.php
+++ b/lib/base.php
@@ -103,6 +103,9 @@ class OC {
*/
public static $loader = null;
+ /** @var \Composer\Autoload\ClassLoader $composerAutoloader */
+ public static $composerAutoloader = null;
+
/**
* @var \OC\Server
*/
@@ -493,7 +496,7 @@ class OC {
self::$CLI = (php_sapi_name() == 'cli');
// Add default composer PSR-4 autoloader
- require_once OC::$SERVERROOT . '/lib/composer/autoload.php';
+ self::$composerAutoloader = require_once OC::$SERVERROOT . '/lib/composer/autoload.php';
try {
self::initPaths();
diff --git a/lib/private/legacy/app.php b/lib/private/legacy/app.php
index 41b1b79e4f6..fe590e4159e 100644
--- a/lib/private/legacy/app.php
+++ b/lib/private/legacy/app.php
@@ -108,7 +108,7 @@ class OC_App {
foreach($apps as $app) {
$path = self::getAppPath($app);
if($path !== false) {
- \OC::$loader->addValidRoot($path);
+ self::registerAutoloading($app, $path);
}
}
@@ -137,7 +137,10 @@ class OC_App {
if($appPath === false) {
return;
}
- \OC::$loader->addValidRoot($appPath); // in case someone calls loadApp() directly
+
+ // in case someone calls loadApp() directly
+ self::registerAutoloading($app, $appPath);
+
if (is_file($appPath . '/appinfo/app.php')) {
\OC::$server->getEventLogger()->start('load_app_' . $app, 'Load app: ' . $app);
if ($checkUpgrade and self::shouldUpgrade($app)) {
@@ -156,6 +159,22 @@ class OC_App {
}
/**
+ * @param string $app
+ * @param string $path
+ */
+ protected static function registerAutoloading($app, $path) {
+ // Register on PSR-4 composer autoloader
+ $appNamespace = \OC\AppFramework\App::buildAppNamespace($app);
+ \OC::$composerAutoloader->addPsr4($appNamespace . '\\', $path . '/lib/', true);
+ if (defined('PHPUNIT_RUN')) {
+ \OC::$composerAutoloader->addPsr4($appNamespace . '\\Tests\\', $path . '/tests/', true);
+ }
+
+ // Register on legacy autoloader
+ \OC::$loader->addValidRoot($path);
+ }
+
+ /**
* Load app.php from the given app
*
* @param string $app app name