1
0
Fork 0

refix fix leak in decompiler/disassembler, was broken for older PHP

git-svn-id: svn://svn.lighttpd.net/xcache/trunk@1523 c26eb9a1-5813-0410-bd6c-c2e55f420ca7
This commit is contained in:
Xuefer 2014-09-11 16:31:11 +00:00
parent 21a895a4c6
commit 293e6ab44a
2 changed files with 9 additions and 13 deletions

View File

@ -354,21 +354,24 @@ static unsigned char arginfo_xcache_get_special_value[] = { 1, BYREF_NONE };
PHP_FUNCTION(xcache_get_special_value)
{
zval *value;
zval value_copied;
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &value) == FAILURE) {
return;
}
value_copied = *value;
value = &value_copied;
switch ((Z_TYPE_P(value) & IS_CONSTANT_TYPE_MASK)) {
case IS_CONSTANT:
MAKE_COPY_ZVAL(&value, return_value)
return_value->type = UNISW(IS_STRING, UG(unicode) ? IS_UNICODE : IS_STRING);
value->type = UNISW(IS_STRING, UG(unicode) ? IS_UNICODE : IS_STRING);
RETURN_ZVAL(value, 1, 0);
break;
#ifdef IS_CONSTANT_ARRAY
case IS_CONSTANT_ARRAY:
MAKE_COPY_ZVAL(&value, return_value)
return_value->type = IS_ARRAY;
value->type = IS_ARRAY;
RETURN_ZVAL(value, 1, 0);
break;
#endif
@ -380,8 +383,8 @@ PHP_FUNCTION(xcache_get_special_value)
default:
if ((Z_TYPE_P(value) & ~IS_CONSTANT_TYPE_MASK)) {
MAKE_COPY_ZVAL(&value, return_value);
return_value->type &= IS_CONSTANT_TYPE_MASK;
value->type &= IS_CONSTANT_TYPE_MASK;
RETURN_ZVAL(value, 1, 0);
}
else {
RETURN_NULL();

View File

@ -219,13 +219,6 @@ typedef const zstr const_zstr;
#endif
/* }}} */
#ifndef MAKE_COPY_ZVAL
# define MAKE_COPY_ZVAL(ppzv, pzv) \
*(pzv) = **(ppzv); \
zval_copy_ctor((pzv)); \
INIT_PZVAL((pzv));
#endif
/* the class entry type to be stored in class_table */
typedef ZESW(zend_class_entry, zend_class_entry*) xc_cest_t;