summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorThies C. Arntzen <thies@php.net>1999-10-20 14:34:16 +0000
committerThies C. Arntzen <thies@php.net>1999-10-20 14:34:16 +0000
commit41b87a238eb5b9a33c46d8d264d4e97c5d4acffa (patch)
tree8bfe873a2bd1b5f10704683850f5f1f7e9af843b /ext
parentaf8f84a27c3e01edadff8b37e9418e4b7c129b54 (diff)
downloadphp-git-41b87a238eb5b9a33c46d8d264d4e97c5d4acffa.tar.gz
(PHP var_dump, serialize) fixed mem_leak.
Diffstat (limited to 'ext')
-rw-r--r--ext/standard/var.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/ext/standard/var.c b/ext/standard/var.c
index abcf81f06a..1f087e10e3 100644
--- a/ext/standard/var.c
+++ b/ext/standard/var.c
@@ -87,8 +87,11 @@ void php_var_dump(pval **struc, int level)
PHPWRITE(buf, strlen(buf));
}
c++;
- if (zend_hash_get_current_data(myht, (void **) (&data)) != SUCCESS || !data || (data == struc))
+ if (zend_hash_get_current_data(myht, (void **) (&data)) != SUCCESS || !data || (data == struc)) {
+ if (i == HASH_KEY_IS_STRING)
+ efree(key);
continue;
+ }
switch (i) {
case HASH_KEY_IS_LONG:{
pval *d = emalloc(sizeof(pval));
@@ -238,8 +241,9 @@ void php_var_serialize(pval *buf, pval **struc)
if ((i = zend_hash_get_current_key(myht, &key, &index)) == HASH_KEY_NON_EXISTANT) {
break;
}
- if (zend_hash_get_current_data(myht, (void **) (&data)) !=
- SUCCESS || !data || ((*data) == (*struc))) {
+ if (zend_hash_get_current_data(myht, (void **) (&data)) != SUCCESS || !data || ((*data) == (*struc))) {
+ if (i == HASH_KEY_IS_STRING)
+ efree(key);
continue;
}