From bd712db727008b0361e4aa0f5871283a1312d1d5 Mon Sep 17 00:00:00 2001 From: Jordi Boggiano Date: Thu, 3 Nov 2011 21:05:01 +0100 Subject: [PATCH] Reverse-orders namespaces by specificity --- src/Composer/Autoload/AutoloadGenerator.php | 24 +++++++++++++-------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/src/Composer/Autoload/AutoloadGenerator.php b/src/Composer/Autoload/AutoloadGenerator.php index 9b8e137ff..ea705b811 100644 --- a/src/Composer/Autoload/AutoloadGenerator.php +++ b/src/Composer/Autoload/AutoloadGenerator.php @@ -73,11 +73,9 @@ EOF; if (isset($autoloads['psr-0'])) { foreach ($autoloads['psr-0'] as $def) { - foreach ($def['mapping'] as $prefix => $path) { - $exportedPrefix = var_export($prefix, true); - $exportedPath = var_export(($def['path'] ? '/'.$def['path'] : '').'/'.$path, true); - $namespacesFile .= " $exportedPrefix => dirname(dirname(__DIR__)).$exportedPath,\n"; - } + $exportedPrefix = var_export($def['namespace'], true); + $exportedPath = var_export($def['path'], true); + $namespacesFile .= " $exportedPrefix => dirname(dirname(__DIR__)).$exportedPath,\n"; } } @@ -107,13 +105,21 @@ EOF; } foreach ($package->getAutoload() as $type => $mapping) { - $autoloads[$type][] = array( - 'mapping' => $mapping, - 'path' => $installPath, - ); + foreach ($mapping as $namespace => $path) { + $autoloads[$type][] = array( + 'namespace' => $namespace, + 'path' => ($installPath ? '/'.$installPath : '').'/'.$path, + ); + } } } + foreach ($autoloads as $type => $maps) { + usort($autoloads[$type], function ($a, $b) { + return strcmp($b['namespace'], $a['namespace']); + }); + } + return $autoloads; } }