Hello Jessie,

Tuesday, July 26, 2005, 5:50:35 PM, you wrote:

> Hi Marcus,

> "Marcus Boerger" <[EMAIL PROTECTED]> wrote in message
> news:[EMAIL PROTECTED]
>>
>> > 3) Simply pass an extra argument (or pass an array or object as the
> first
>> > argument) to __autoload containing the names of the imported namespaces
> of
>> > the calling file. __autoload can then use this array against the class
> name
>> > and perform its own lookup.
>>
>> None of the above makes any sense. Look __autoload() is just bein called
> at
>> any place where a class is missing. So looking for the file first and then
>> loading __autoload(I) makes no sense whatsoever. IMO what we need here is
> a
>> default implementation for import behavior accomplished by __autoload().
> So
>> for example "import ns:cls;" leads to "__autoload('ns:cls')". Here the SPL
>> default implementation would relpace all ':' with the directory divider
> '/'
>> or '\', append '.inc' or '.php' or '.inc.php' and append the result to all
>> directories in the include_path to look for the file. If were are to
> support
>> import with '*' the the autoload implementation would need to take care of
>> this and load all matching files. A user land implementation can easily
>> achieve that by using SPLs (Recursive)DirectoryIterator and
> FilterIterator.
>>

> Regarding a fully-specified class import, such as ns:cls, if I simply remove
> my include logic, then __autoload('ns:cls') would automatically be called.
> There are no issues with this type of import.

> Now, namespace imports (wildcard imports) are a different story. Maybe I did
> not make my explanations clear enough, but you basically agreed to point #3
> in my previous email. Now, the class name cannot simply be passed to
> __autoload, because there is no way for __autoload to know to which
> namespace the class belongs to, and you only want __autoload to include the
> classes belonging to the namespaces that have been imported. That is why the
> list of imported namespaces for the __calling__ file must be accessible
> somehow to the __autoload function, either as an additional argument or by
> having the first argument be an array/object.

> So the namespace imports will work like how you described simple imports,
> but with a slight twist. To quote you:

> "Simple" Imports
> ----------------
>> So for example "import ns:cls;" leads to "__autoload('ns:cls')". Here the
> SPL
>> default implementation would relpace all ':' with the directory divider
> '/'
>> or '\', append '.inc' or '.php' or '.inc.php' and append the result to all
>> directories in the include_path to look for the file.


> By slightly modifying your sentence, we implement namespace imports:

> Namespace Imports
> -----------------
> Here the SPL default implementation would, in a loop, prefix the class name
> with each imported namespace, replace all ':' with the directory divider '/'
> or '\', append '.inc' or '.php' or '.inc.php' and append the result to all
> directories in the include_path to look for the file.


> For example, here is how the userland __autoload might look (notice that
> this code is exactly what I provided in the last post). In this example, the
> user has the directory structure as "namespace-name/class-name.php".

> <?php
> function __autoload($className, $importNamespaces)
> {
>     $paths = explode( PATH_SEPARATOR, get_include_path() );

>     foreach( $paths as $path )
>     {
>         foreach( $importNamespaces as $ns )
>         {
>             $fullPath = $path . DIRECTORY_SEPARATOR . str_replace( ':',
> DIRECTORY_SEPARATOR, $ns ) . DIRECTORY_SEPARATOR . $className . '.php';

>             if( file_exists( $fullPath ) )
>             {
>                 require_once( $fullPath );
>                 break;
>             }
>         }
>     }
> }
?>>


> Let me know if the above make sense or if you see any problems with this
> approach.

On a first sight i only see that 'break' should be 'return'.

Best regards,
 Marcus

-- 
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to