From: Dmitry Stogov Date: Thu, 15 Feb 2007 17:01:29 +0000 (+0000) Subject: Fixed memory leak X-Git-Tag: php-5.2.2RC1~393 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=ea278e8566a9e32068747ed9f30579a3d6e40785;p=php Fixed memory leak --- diff --git a/ext/soap/php_schema.c b/ext/soap/php_schema.c index fd66f3eed7..9ba4f81604 100644 --- a/ext/soap/php_schema.c +++ b/ext/soap/php_schema.c @@ -681,7 +681,9 @@ static int schema_restriction_simpleContent(sdlPtr sdl, xmlAttrPtr tns, xmlNodeP cur_type->restrictions->enumeration = emalloc(sizeof(HashTable)); zend_hash_init(cur_type->restrictions->enumeration, 0, NULL, delete_restriction_var_char, 0); } - zend_hash_add(cur_type->restrictions->enumeration, enumval->value, strlen(enumval->value)+1, &enumval, sizeof(sdlRestrictionCharPtr), NULL); + if (zend_hash_add(cur_type->restrictions->enumeration, enumval->value, strlen(enumval->value)+1, &enumval, sizeof(sdlRestrictionCharPtr), NULL) == FAILURE) { + delete_restriction_var_char(&enumval); + } } else { break; } @@ -2313,6 +2315,7 @@ void delete_model_persistent(void *handle) void delete_type(void *data) { sdlTypePtr type = *((sdlTypePtr*)data); + if (type->name) { efree(type->name); }