diff options
| author | Andi Gutmans <andi@php.net> | 1999-04-13 17:03:10 +0000 |
|---|---|---|
| committer | Andi Gutmans <andi@php.net> | 1999-04-13 17:03:10 +0000 |
| commit | 3fcc6511f6555ca6af5f26ee6313097c42aee9ba (patch) | |
| tree | c8da32143a45e05d40bb22b42f0ade09164aa52a /Zend/zend_API.c | |
| parent | 533f135987738074fab0ac17560274d89f33584c (diff) | |
| download | php-git-3fcc6511f6555ca6af5f26ee6313097c42aee9ba.tar.gz | |
* Optimize argument_stack top lookup
* Fix a nasty bug in zend_ptr_stack_clean()
Diffstat (limited to 'Zend/zend_API.c')
| -rw-r--r-- | Zend/zend_API.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/Zend/zend_API.c b/Zend/zend_API.c index 9a31fc5edc..caf097b01b 100644 --- a/Zend/zend_API.c +++ b/Zend/zend_API.c @@ -33,7 +33,7 @@ HashTable list_destructors, module_registry; /* this function doesn't check for too many parameters */ int getParameters(int ht, int param_count,...) { - void **p = EG(argument_stack).elements+EG(argument_stack).top-1; + void **p = EG(argument_stack).top_element-1; int arg_count = (ulong) *p; va_list ptr; zval **param, *param_ptr; @@ -57,6 +57,7 @@ int getParameters(int ht, int param_count,...) new_tmp->refcount = 1; new_tmp->is_ref = 0; param_ptr = new_tmp; + ((zval *) *(p-param_count))->refcount--; *(p-param_count) = param_ptr; } *param = param_ptr; @@ -70,7 +71,7 @@ int getParameters(int ht, int param_count,...) int getParametersArray(int ht, int param_count, zval **argument_array) { - void **p = EG(argument_stack).elements+EG(argument_stack).top-1; + void **p = EG(argument_stack).top_element-1; int arg_count = (ulong) *p; zval *param_ptr; ELS_FETCH(); @@ -91,6 +92,7 @@ int getParametersArray(int ht, int param_count, zval **argument_array) new_tmp->refcount = 1; new_tmp->is_ref = 0; param_ptr = new_tmp; + ((zval *) *(p-param_count))->refcount--; *(p-param_count) = param_ptr; } *(argument_array++) = param_ptr; |
