I think what you're doing is effectively the same as doing:

$fb = new Part .''. SubPart();

So basically concatenating a new instance of Part, with the results
from the function SubPart. Try defining Part as a class and see what
error you get. If I'm right, you'll get an undefined function error.

2009/2/26 Robin Burchell <virot...@viroteck.net>:
> On Thu, Feb 26, 2009 at 8:48 PM, Guilherme Blanco
> <guilhermebla...@gmail.com> wrote:
>> I doubt you'll find a patch to it.
>>
>> Mainly, the patch will be against this principle:
>>
> <snip>
>
> Hmm, that wouldn't actually have an impact, as (at least, what I'm
> aiming for/wanting to do) is not to introduce periods as valid in
> actual class names, but to allow them to be used for autoloading - so
> I can have something like this (abbreviated terribly, apologies):
>
> function __autoload($sFoo)
> {
>    include(str_replace(".", "/", $sFoo));
> }
>
> .. so, your example would expand to Foo.Bar, which given that periods
> aren't allowed in a class name doesn't exist as a class, and won't
> work. Unless I'm missing something?
>
>
>
> Actually, I don't believe that expanding is even done - i.e. it
> doesn't respect defines there
>
> Seems that way on testing, too:
>
> class FooBar
> {
>        // ...
> }
>
> define('Part',  'Foo');
> define('SubPart',  'Bar');
>
> $fb = new Part.SubPart();
>
>
> gives: Fatal error: Class 'Part' not found
>
> .. but that part of things is a going off on a bit of a tangent.
>
> --
> PHP Internals - PHP Runtime Development Mailing List
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>

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

Reply via email to