diff options
| author | Andi Gutmans <andi@php.net> | 1999-09-09 14:15:17 +0000 |
|---|---|---|
| committer | Andi Gutmans <andi@php.net> | 1999-09-09 14:15:17 +0000 |
| commit | 22f066e708e95debf48065563671d78619807651 (patch) | |
| tree | d26c963f7c7f09488a1cc975620e05ec868d0f0b /Zend/zend_stack.c | |
| parent | 7567b96c22734d27f12c9737deb91dcd2c4b41bd (diff) | |
| download | php-git-22f066e708e95debf48065563671d78619807651.tar.gz | |
- Add foreach() freeing code.
- Fix switch() freeing code to only free current function's switch expressions.
- I have a feeling break expr; in a switch where expr > 1 leaks because it
won't free all of the expressions. Fix is probably not trivial.
Diffstat (limited to 'Zend/zend_stack.c')
| -rw-r--r-- | Zend/zend_stack.c | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/Zend/zend_stack.c b/Zend/zend_stack.c index 0f3b0f6aac..011e8519c9 100644 --- a/Zend/zend_stack.c +++ b/Zend/zend_stack.c @@ -118,38 +118,46 @@ ZEND_API int zend_stack_count(zend_stack *stack) } -ZEND_API void zend_stack_apply(zend_stack *stack, void (*apply_function)(void *element), int type) +ZEND_API void zend_stack_apply(zend_stack *stack, int (*apply_function)(void *element), int type) { int i; switch (type) { case ZEND_STACK_APPLY_TOPDOWN: for (i=stack->top-1; i>=0; i--) { - apply_function(stack->elements[i]); + if (apply_function(stack->elements[i])) { + break; + } } break; case ZEND_STACK_APPLY_BOTTOMUP: for (i=0; i<stack->top; i++) { - apply_function(stack->elements[i]); + if (apply_function(stack->elements[i])) { + break; + } } break; } } -ZEND_API void zend_stack_apply_with_argument(zend_stack *stack, void (*apply_function)(void *element, void *arg), int type, void *arg) +ZEND_API void zend_stack_apply_with_argument(zend_stack *stack, int (*apply_function)(void *element, void *arg), int type, void *arg) { int i; switch (type) { case ZEND_STACK_APPLY_TOPDOWN: for (i=stack->top-1; i>=0; i--) { - apply_function(stack->elements[i], arg); + if (apply_function(stack->elements[i], arg)) { + break; + } } break; case ZEND_STACK_APPLY_BOTTOMUP: for (i=0; i<stack->top; i++) { - apply_function(stack->elements[i], arg); + if (apply_function(stack->elements[i], arg)) { + break; + } } break; } |
