From: Zeev Suraski Date: Wed, 29 Jan 2003 08:55:12 +0000 (+0000) Subject: Fix assignments to $this. X-Git-Tag: RELEASE_0_5~1378 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8f52bf68354fe45478014255089cdf89ff643aee;p=php Fix assignments to $this. Fixes the 'make install' problem reported on php-dev --- diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c index 87a3023431..dedc2e53fd 100644 --- a/Zend/zend_execute.c +++ b/Zend/zend_execute.c @@ -310,8 +310,18 @@ static inline void zend_assign_to_object(znode *result, znode *op1, znode *op2, SEPARATE_ZVAL_IF_NOT_REF(object_ptr); object = *object_ptr; } + /* by now, property is a string */ - /* here property is a string */ + + /* separate our value if necessary */ + if (value_op->op_type == IS_TMP_VAR) { + zval *orig_value = value; + + ALLOC_ZVAL(value); + *value = *orig_value; + value->is_ref = 0; + value->refcount = 0; + } Z_OBJ_HT_P(object)->write_property(object, property, value TSRMLS_CC); if (property == &tmp) { zval_dtor(property); diff --git a/Zend/zend_object_handlers.c b/Zend/zend_object_handlers.c index 4720a8bfba..ff5764e6b0 100644 --- a/Zend/zend_object_handlers.c +++ b/Zend/zend_object_handlers.c @@ -220,7 +220,9 @@ static void zend_std_write_property(zval *object, zval *member, zval *value TSRM /* To check: can't *variable_ptr be some system variable like error_zval here? */ (*variable_ptr)->type = value->type; (*variable_ptr)->value = value->value; - zval_copy_ctor(*variable_ptr); + if (value->refcount>0) { + zval_copy_ctor(*variable_ptr); + } setter_done = 1; } }