On Wed, 2003-07-02 at 10:11, Timm Friebe wrote: > On Wed, 2003-07-02 at 06:34, Sterling Hughes wrote: > [...] > > $t = new test; > > var_dump($t->filter('hello world')); > ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ > Changing this line to: > var_dump(call_user_func(array($t, 'filter'), 'hello world')); > > or even > $t= new Reflection_Method('test', 'filter'); > var_dump($t->invoke(new test(), 'hello world')); > > yields the same bug. > > ZE1 outputs "int(1)". ZE2 does so, too, if I rename "test" to anything > else (except "__construct", which causes the same problem). > > The same problem arises for other array functions such as usort, > array_map etc., but _not_ for call_user_func(_array). > > After short investigation it looks like all of these use > fast_call_user_function() but do not pass an object_pp. Either this > should be patched in ext/standard/array.c or fast_call_user_function > shoud check for the callback being an array($obj, $func) / array($class, > $func) *even* when a function pointer is passed.
Then why would it work if test() is undefined? Further, why would it work when no array functions are used (as with my original example). I think you might be right that this is a separate bug, but its certainly not the same bug that I'm talking about. -Sterling > > - Timm -- "Nothing is particularly hard if you divide it into small jobs." - Henry Ford -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php