A seguir, o manual com os requisitos obrigatórios que devem ser seguidos para a interoperabilidade de autocarregamento (autoloading).
- Uma namespace totalmente qualificada e as classes devem seguir a seguinte estrutura
\<Nome de Fornecedor>\(<Namespace>\)*<Nome da Classe>
- Cada namespace deve ter uma namespace de nível superior ("Nome de Fornecedor").
- Cada namespace pode ter quantos sub-namespaces que quiser.
- Cada separador de namespace é convertido para
DIRECTORY_SEPARATOR
durante o carregamento do sistema de arquivos. - Cada caractere
_
no nome da classe é convertido paraDIRECTORY_SEPARATOR
. O caractere_
não tem nenhum significado especial na namespace. - A namespace totalmente qualificada e a classe é sufixada com
.php
durante o carregamento do sistema de arquivos. - Caracteres alfabéticos em nomes de fornecedor, namespaces e nomes de classe podem ser de qualquer combinação de letras maiúsculas ("upper case") e minúsculas ("lower case").
\Doctrine\Common\IsolatedClassLoader
=>/caminho/para/projeto/lib/vendor/Doctrine/Common/IsolatedClassLoader.php
\Symfony\Core\Request
=>/caminho/para/projeto/lib/vendor/Symfony/Core/Request.php
\Zend\Acl
=>/caminho/para/projeto/lib/vendor/Zend/Acl.php
\Zend\Mail\Message
=>/caminho/para/projeto/lib/vendor/Zend/Mail/Message.php
\namespace\package\Class_Name
=>/caminho/para/projeto/lib/vendor/namespace/package/Class/Name.php
\namespace\package_name\Class_Name
=>/caminho/para/projeto/lib/vendor/namespace/package_name/Class/Name.php
Os padrões que definimos aqui devem ser o menor denominador comum para uma indolor interoperabilidade de autocarregamento. Você pode testar se está seguindo esses padrões utilizando esta amostra da implementação da SplClassLoader que é capaz de carregar classes do PHP 5.3.
Abaixo está uma função de exemplo para simplesmente demonstrar como os padrões propostos acima são autocarregados.
<?php
function autoload($className)
{
$className = ltrim($className, '\\');
$fileName = '';
$namespace = '';
if ($lastNsPos = strrpos($className, '\\')) {
$namespace = substr($className, 0, $lastNsPos);
$className = substr($className, $lastNsPos + 1);
$fileName = str_replace('\\', DIRECTORY_SEPARATOR, $namespace) . DIRECTORY_SEPARATOR;
}
$fileName .= str_replace('_', DIRECTORY_SEPARATOR, $className) . '.php';
require $fileName;
}
O seguinte gist é um exemplo de implementação da SplClassLoader que pode carregar suas classes se você seguir as propostas de interoperabilidade de autocarregamento citadas acima. Essa é a forma recomendada atual para carregar classes de PHP 5.3 que seguem estes padrões.