diff options
author | Dmitry Stogov <dmitry@php.net> | 2006-01-19 07:23:32 +0000 |
---|---|---|
committer | Dmitry Stogov <dmitry@php.net> | 2006-01-19 07:23:32 +0000 |
commit | c447acf8632dd22d53e5498372f718e6e241c27a (patch) | |
tree | 4bc65f3c65a2a30ba55554bb1a39087f842aca65 /Zend/zend_execute.c | |
parent | 82d5901664436fd63cf319b33e2938aa7fcbce35 (diff) | |
download | php-git-c447acf8632dd22d53e5498372f718e6e241c27a.tar.gz |
Fixed bug #36071 (Engine Crash related with 'clone')
Diffstat (limited to 'Zend/zend_execute.c')
-rw-r--r-- | Zend/zend_execute.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c index 5ccdf67b70..046a9b1b0d 100644 --- a/Zend/zend_execute.c +++ b/Zend/zend_execute.c @@ -545,6 +545,16 @@ static inline void zend_assign_to_object(znode *result, zval **object_ptr, znode zval *value = get_zval_ptr(value_op, Ts, &free_value, BP_VAR_R); zval **retval = &T(result->u.var).var.ptr; + if (*object_ptr == EG(error_zval_ptr)) { + FREE_OP(free_op2); + if (!RETURN_VALUE_UNUSED(result)) { + *retval = EG(uninitialized_zval_ptr); + PZVAL_LOCK(*retval); + } + FREE_OP(free_value); + return; + } + make_real_object(object_ptr TSRMLS_CC); /* this should modify object only if it's empty */ object = *object_ptr; |