From: Dmitry Stogov Date: Fri, 7 Mar 2014 12:45:32 +0000 (+0400) Subject: Fixed pass by reference special cases X-Git-Tag: POST_PHPNG_MERGE~412^2~367 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e9855b199263c452c0be2d32752c848da54a95fd;p=php Fixed pass by reference special cases --- diff --git a/Zend/zend_vm_def.h b/Zend/zend_vm_def.h index 375df48ae3..c18a5a8196 100644 --- a/Zend/zend_vm_def.h +++ b/Zend/zend_vm_def.h @@ -3097,9 +3097,10 @@ ZEND_VM_HANDLER(106, ZEND_SEND_VAR_NO_REF, VAR|CV, ANY) varptr = GET_OP1_ZVAL_PTR(BP_VAR_R); if ((!(opline->extended_value & ZEND_ARG_SEND_FUNCTION) || (varptr->var_flags & IS_VAR_RET_REF)) && - (!Z_REFCOUNTED_P(varptr) || + ((!Z_REFCOUNTED_P(varptr) && Z_TYPE_P(varptr) != IS_STRING) || Z_ISREF_P(varptr) || - Z_REFCOUNT_P(varptr) == 1)) { + Z_TYPE_P(varptr) == IS_OBJECT || + (Z_REFCOUNTED_P(varptr) && Z_REFCOUNT_P(varptr) == 1))) { if (Z_ISREF_P(varptr)) { if (OP1_TYPE == IS_CV) { diff --git a/Zend/zend_vm_execute.h b/Zend/zend_vm_execute.h index f842079ffd..8bc684870d 100644 --- a/Zend/zend_vm_execute.h +++ b/Zend/zend_vm_execute.h @@ -12909,9 +12909,10 @@ static int ZEND_FASTCALL ZEND_SEND_VAR_NO_REF_SPEC_VAR_HANDLER(ZEND_OPCODE_HAND varptr = _get_zval_ptr_var(opline->op1.var, execute_data, &free_op1 TSRMLS_CC); if ((!(opline->extended_value & ZEND_ARG_SEND_FUNCTION) || (varptr->var_flags & IS_VAR_RET_REF)) && - (!Z_REFCOUNTED_P(varptr) || + ((!Z_REFCOUNTED_P(varptr) && Z_TYPE_P(varptr) != IS_STRING) || Z_ISREF_P(varptr) || - Z_REFCOUNT_P(varptr) == 1)) { + Z_TYPE_P(varptr) == IS_OBJECT || + (Z_REFCOUNTED_P(varptr) && Z_REFCOUNT_P(varptr) == 1))) { if (Z_ISREF_P(varptr)) { if (IS_VAR == IS_CV) { @@ -30292,9 +30293,10 @@ static int ZEND_FASTCALL ZEND_SEND_VAR_NO_REF_SPEC_CV_HANDLER(ZEND_OPCODE_HANDL varptr = _get_zval_ptr_cv_BP_VAR_R(execute_data, opline->op1.var TSRMLS_CC); if ((!(opline->extended_value & ZEND_ARG_SEND_FUNCTION) || (varptr->var_flags & IS_VAR_RET_REF)) && - (!Z_REFCOUNTED_P(varptr) || + ((!Z_REFCOUNTED_P(varptr) && Z_TYPE_P(varptr) != IS_STRING) || Z_ISREF_P(varptr) || - Z_REFCOUNT_P(varptr) == 1)) { + Z_TYPE_P(varptr) == IS_OBJECT || + (Z_REFCOUNTED_P(varptr) && Z_REFCOUNT_P(varptr) == 1))) { if (Z_ISREF_P(varptr)) { if (IS_CV == IS_CV) {