summaryrefslogtreecommitdiff
path: root/Zend/zend_execute_API.c
diff options
context:
space:
mode:
authorZeev Suraski <zeev@php.net>2000-01-24 17:29:15 +0000
committerZeev Suraski <zeev@php.net>2000-01-24 17:29:15 +0000
commitadec56938e407fd2b3f380c4ccd4fa89d0ea564b (patch)
tree0d1189902c82a14fab0c17d427cb47d6dc2a2d24 /Zend/zend_execute_API.c
parente6ba28b680dc3e8d118e7a350e27fc26b11e4e50 (diff)
downloadphp-git-adec56938e407fd2b3f380c4ccd4fa89d0ea564b.tar.gz
Fixes
Diffstat (limited to 'Zend/zend_execute_API.c')
-rw-r--r--Zend/zend_execute_API.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/Zend/zend_execute_API.c b/Zend/zend_execute_API.c
index c56a876f16..8c610ef301 100644
--- a/Zend/zend_execute_API.c
+++ b/Zend/zend_execute_API.c
@@ -487,7 +487,7 @@ ZEND_API inline void zend_assign_to_variable_reference(znode *result, zval **var
if (variable_ptr == EG(error_zval_ptr) || value_ptr==EG(error_zval_ptr)) {
variable_ptr_ptr = &EG(uninitialized_zval_ptr);
/* } else if (variable_ptr==&EG(uninitialized_zval) || variable_ptr!=value_ptr) { */
- } else if (*variable_ptr_ptr != *value_ptr_ptr) {
+ } else if (variable_ptr_ptr != value_ptr_ptr) {
variable_ptr->refcount--;
if (variable_ptr->refcount==0) {
zendi_zval_dtor(*variable_ptr);
@@ -510,7 +510,10 @@ ZEND_API inline void zend_assign_to_variable_reference(znode *result, zval **var
*variable_ptr_ptr = value_ptr;
value_ptr->refcount++;
} else {
- /* nothing to do */
+ if (variable_ptr->refcount>1) { /* we need to break away */
+ SEPARATE_ZVAL(variable_ptr_ptr);
+ }
+ (*variable_ptr_ptr)->is_ref = 1;
}
if (result && (result->op_type != IS_UNUSED)) {