Hi,
I didn't receive and emails regarding to my discovery of the bug. If it
wasn't because the mailing list or my email server's problem, it would
turned out to be that nobody cares about it.
Then what if, according to my own debugging, the problem is related
to zend hash?
I guess the answer to the following error is that unset($a) freed the
object but not the all the hash tables (aggretated methods) associated
with it.
So a new object after the unset will reuse the same memory location and
zend_hash_add will return a failure.
zend_hash.c: in function zend_hash_add_or_update
while (p != NULL) {
if ((p->h == h) && (p->nKeyLength == nKeyLength)) {
if (!memcmp(p->arKey, arKey, nKeyLength)) {
if (flag & HASH_ADD) {
return FAILURE;
}
HANDLE_BLOCK_INTERRUPTIONS();
Can anyone understading zend hash functions well check why
this would happen?
Shouldn't unset($a) clean everything related to it?
Please! I can't live without aggregation and I can't
work any longer due to the bug.
If you really don't think it a bug. Would anyone kindly reply
me a message so that at least I know you guys have received my
report?
Wei He
On Fri, 23 May 2003, Wei He wrote:
> Hi,
>
> This short script can reproduce the aggregation bug I reported above.
>
> class bar {
>
> function doit()
> {
> print " Doing...\n";
> }
> }
>
> class foo {
>
> function foo()
> {
> print_r(aggregation_info($this));
> aggregate($this, "bar");
> }
>
> function spawn()
> {
> return new foo();
> }
> }
>
> $a = new foo();
> $a->doit();
> $b = $a->spawn();
> $b->doit();
> unset($a);
> $c = $b->spawn();
> $c->doit();
>
> Besides 'unset($a)', '$a = new foo()' will also cause the same problem.
>
> Wei He
>
>
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php