Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
18.18% |
2 / 11 |
CRAP | |
51.52% |
17 / 33 |
Loader | |
0.00% |
0 / 1 |
|
18.18% |
2 / 11 |
45.18 | |
51.52% |
17 / 33 |
__construct | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 3 |
|||
setNamespaceSeparator | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
getNamespaceSeparator | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 1 |
|||
setIncludePath | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
getIncludePath | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 1 |
|||
setFileExtension | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
getFileExtension | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 1 |
|||
register | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
unregister | |
0.00% |
0 / 1 |
2 | |
0.00% |
0 / 2 |
|||
loadClass | |
100.00% |
1 / 1 |
5 | |
100.00% |
16 / 16 |
|||
getFullPath | |
100.00% |
1 / 1 |
2 | |
100.00% |
1 / 1 |
<?php | |
/** | |
* SplClassLoader implementation that implements the technical interoperability | |
* standards for PHP 5.3 namespaces and class names. | |
* | |
* http://groups.google.com/group/php-standards/web/final-proposal | |
* | |
* // Example which loads classes for the Doctrine Common package in the | |
* // Doctrine\Common namespace. | |
* $classLoader = new SplClassLoader('Doctrine\Common', '/path/to/doctrine'); | |
* $classLoader->register(); | |
* | |
* @author Jonathan H. Wage <jonwage@gmail.com> | |
* @author Roman S. Borschel <roman@code-factory.org> | |
* @author Matthew Weier O'Phinney <matthew@zend.com> | |
* @author Kris Wallsmith <kris.wallsmith@gmail.com> | |
* @author Fabien Potencier <fabien.potencier@symfony-project.org> | |
*/ | |
namespace Mockery; | |
class Loader | |
{ | |
private $_fileExtension = '.php'; | |
private $_namespace; | |
private $_includePath; | |
private $_namespaceSeparator = '\\'; | |
/** | |
* Creates a new <tt>Loader</tt> that loads classes of the | |
* specified namespace. | |
* | |
* @param string $ns The namespace to use. | |
*/ | |
public function __construct($ns = 'Mockery', $includePath = null) | |
{ | |
$this->_namespace = $ns; | |
$this->_includePath = $includePath; | |
} | |
/** | |
* Sets the namespace separator used by classes in the namespace of this class loader. | |
* | |
* @param string $sep The separator to use. | |
*/ | |
public function setNamespaceSeparator($sep) | |
{ | |
$this->_namespaceSeparator = $sep; | |
} | |
/** | |
* Gets the namespace seperator used by classes in the namespace of this class loader. | |
* | |
* @return void | |
*/ | |
public function getNamespaceSeparator() | |
{ | |
return $this->_namespaceSeparator; | |
} | |
/** | |
* Sets the base include path for all class files in the namespace of this class loader. | |
* | |
* @param string $includePath | |
*/ | |
public function setIncludePath($includePath) | |
{ | |
$this->_includePath = $includePath; | |
} | |
/** | |
* Gets the base include path for all class files in the namespace of this class loader. | |
* | |
* @return string $includePath | |
*/ | |
public function getIncludePath() | |
{ | |
return $this->_includePath; | |
} | |
/** | |
* Sets the file extension of class files in the namespace of this class loader. | |
* | |
* @param string $fileExtension | |
*/ | |
public function setFileExtension($fileExtension) | |
{ | |
$this->_fileExtension = $fileExtension; | |
} | |
/** | |
* Gets the file extension of class files in the namespace of this class loader. | |
* | |
* @return string $fileExtension | |
*/ | |
public function getFileExtension() | |
{ | |
return $this->_fileExtension; | |
} | |
/** | |
* Installs this class loader on the SPL autoload stack. | |
* | |
* @param bool $prepend If true, prepend autoloader on the autoload stack | |
*/ | |
public function register($prepend = false) | |
{ | |
spl_autoload_register(array($this, 'loadClass'), true, $prepend); | |
} | |
/** | |
* Uninstalls this class loader from the SPL autoloader stack. | |
*/ | |
public function unregister() | |
{ | |
spl_autoload_unregister(array($this, 'loadClass')); | |
} | |
/** | |
* Loads the given class or interface. | |
* | |
* @param string $className The name of the class to load. | |
* @return void | |
*/ | |
public function loadClass($className) | |
{ | |
if ($className === 'Mockery') { | |
require $this->getFullPath('Mockery.php'); | |
return; | |
} | |
if (null === $this->_namespace | |
|| $this->_namespace.$this->_namespaceSeparator === substr($className, 0, strlen($this->_namespace.$this->_namespaceSeparator))) { | |
$fileName = ''; | |
$namespace = ''; | |
if (false !== ($lastNsPos = strripos($className, $this->_namespaceSeparator))) { | |
$namespace = substr($className, 0, $lastNsPos); | |
$className = substr($className, $lastNsPos + 1); | |
$fileName = str_replace($this->_namespaceSeparator, DIRECTORY_SEPARATOR, $namespace) . DIRECTORY_SEPARATOR; | |
} | |
$fileName .= str_replace('_', DIRECTORY_SEPARATOR, $className) . $this->_fileExtension; | |
require $this->getFullPath($fileName); | |
} | |
} | |
/** | |
* Returns full path for $fileName if _includePath is set, or leaves as-is for PHP's internal search in 'require'. | |
* | |
* @param string $fileName relative to include path. | |
* @return string | |
*/ | |
private function getFullPath($fileName) | |
{ | |
return ($this->_includePath !== null ? $this->_includePath . DIRECTORY_SEPARATOR : '') . $fileName; | |
} | |
} |