|
@@ -49,7 +49,7 @@ class ClassLoader
|
|
|
|
|
|
public function getPrefixes()
|
|
public function getPrefixes()
|
|
{
|
|
{
|
|
- return $this->prefixes;
|
|
|
|
|
|
+ return call_user_func_array('array_merge', $this->prefixes);
|
|
}
|
|
}
|
|
|
|
|
|
public function getFallbackDirs()
|
|
public function getFallbackDirs()
|
|
@@ -98,19 +98,21 @@ class ClassLoader
|
|
|
|
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
- if (!isset($this->prefixes[$prefix])) {
|
|
|
|
- $this->prefixes[$prefix] = (array) $paths;
|
|
|
|
|
|
+
|
|
|
|
+ $first = $prefix[0];
|
|
|
|
+ if (!isset($this->prefixes[$first][$prefix])) {
|
|
|
|
+ $this->prefixes[$first][$prefix] = (array) $paths;
|
|
|
|
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
if ($prepend) {
|
|
if ($prepend) {
|
|
- $this->prefixes[$prefix] = array_merge(
|
|
|
|
|
|
+ $this->prefixes[$first][$prefix] = array_merge(
|
|
(array) $paths,
|
|
(array) $paths,
|
|
- $this->prefixes[$prefix]
|
|
|
|
|
|
+ $this->prefixes[$first][$prefix]
|
|
);
|
|
);
|
|
} else {
|
|
} else {
|
|
- $this->prefixes[$prefix] = array_merge(
|
|
|
|
- $this->prefixes[$prefix],
|
|
|
|
|
|
+ $this->prefixes[$first][$prefix] = array_merge(
|
|
|
|
+ $this->prefixes[$first][$prefix],
|
|
(array) $paths
|
|
(array) $paths
|
|
);
|
|
);
|
|
}
|
|
}
|
|
@@ -119,8 +121,8 @@ class ClassLoader
|
|
/**
|
|
/**
|
|
* Registers a set of classes, replacing any others previously set.
|
|
* Registers a set of classes, replacing any others previously set.
|
|
*
|
|
*
|
|
- * @param string $prefix The classes prefix
|
|
|
|
- * @param array|string $paths The location(s) of the classes
|
|
|
|
|
|
+ * @param string $prefix The classes prefix
|
|
|
|
+ * @param array|string $paths The location(s) of the classes
|
|
*/
|
|
*/
|
|
public function set($prefix, $paths)
|
|
public function set($prefix, $paths)
|
|
{
|
|
{
|
|
@@ -129,7 +131,7 @@ class ClassLoader
|
|
|
|
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
- $this->prefixes[$prefix] = (array) $paths;
|
|
|
|
|
|
+ $this->prefixes[substr($prefix, 0, 1)][$prefix] = (array) $paths;
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -195,6 +197,7 @@ class ClassLoader
|
|
*/
|
|
*/
|
|
public function findFile($class)
|
|
public function findFile($class)
|
|
{
|
|
{
|
|
|
|
+ // work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731
|
|
if ('\\' == $class[0]) {
|
|
if ('\\' == $class[0]) {
|
|
$class = substr($class, 1);
|
|
$class = substr($class, 1);
|
|
}
|
|
}
|
|
@@ -205,7 +208,7 @@ class ClassLoader
|
|
|
|
|
|
if (false !== $pos = strrpos($class, '\\')) {
|
|
if (false !== $pos = strrpos($class, '\\')) {
|
|
// namespaced class name
|
|
// namespaced class name
|
|
- $classPath = str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 0, $pos)) . DIRECTORY_SEPARATOR;
|
|
|
|
|
|
+ $classPath = strtr(substr($class, 0, $pos), '\\', DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR;
|
|
$className = substr($class, $pos + 1);
|
|
$className = substr($class, $pos + 1);
|
|
} else {
|
|
} else {
|
|
// PEAR-like class name
|
|
// PEAR-like class name
|
|
@@ -213,13 +216,16 @@ class ClassLoader
|
|
$className = $class;
|
|
$className = $class;
|
|
}
|
|
}
|
|
|
|
|
|
- $classPath .= str_replace('_', DIRECTORY_SEPARATOR, $className) . '.php';
|
|
|
|
|
|
+ $classPath .= strtr($className, '_', DIRECTORY_SEPARATOR) . '.php';
|
|
|
|
|
|
- foreach ($this->prefixes as $prefix => $dirs) {
|
|
|
|
- if (0 === strpos($class, $prefix)) {
|
|
|
|
- foreach ($dirs as $dir) {
|
|
|
|
- if (file_exists($dir . DIRECTORY_SEPARATOR . $classPath)) {
|
|
|
|
- return $dir . DIRECTORY_SEPARATOR . $classPath;
|
|
|
|
|
|
+ $first = $class[0];
|
|
|
|
+ if (isset($this->prefixes[$first])) {
|
|
|
|
+ foreach ($this->prefixes[$first] as $prefix => $dirs) {
|
|
|
|
+ if (0 === strpos($class, $prefix)) {
|
|
|
|
+ foreach ($dirs as $dir) {
|
|
|
|
+ if (file_exists($dir . DIRECTORY_SEPARATOR . $classPath)) {
|
|
|
|
+ return $dir . DIRECTORY_SEPARATOR . $classPath;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|