} else {
/* prevents "undefined variable opline" errors */
#if !defined(ZEND_VM_SPEC) || (OP1_TYPE != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_free_op free_op1;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = GET_OP1_ZVAL_PTR(BP_VAR_R);
+ retval_ref = retval_ptr = GET_OP1_ZVAL_PTR(BP_VAR_R);
if (OP1_TYPE == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (OP1_TYPE == IS_VAR || OP1_TYPE == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}
} else {
/* prevents "undefined variable opline" errors */
#if 0 || (IS_CONST != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = EX_CONSTANT(opline->op1);
+ retval_ref = retval_ptr = EX_CONSTANT(opline->op1);
if (IS_CONST == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (IS_CONST == IS_VAR || IS_CONST == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}
} else {
/* prevents "undefined variable opline" errors */
#if 0 || (IS_TMP_VAR != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_free_op free_op1;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = _get_zval_ptr_tmp(opline->op1.var, execute_data, &free_op1);
+ retval_ref = retval_ptr = _get_zval_ptr_tmp(opline->op1.var, execute_data, &free_op1);
if (IS_TMP_VAR == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (IS_TMP_VAR == IS_VAR || IS_TMP_VAR == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}
} else {
/* prevents "undefined variable opline" errors */
#if 0 || (IS_VAR != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_free_op free_op1;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = _get_zval_ptr_var(opline->op1.var, execute_data, &free_op1);
+ retval_ref = retval_ptr = _get_zval_ptr_var(opline->op1.var, execute_data, &free_op1);
if (IS_VAR == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (IS_VAR == IS_VAR || IS_VAR == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}
} else {
/* prevents "undefined variable opline" errors */
#if 0 || (IS_UNUSED != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = NULL;
+ retval_ref = retval_ptr = NULL;
if (IS_UNUSED == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (IS_UNUSED == IS_VAR || IS_UNUSED == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}
} else {
/* prevents "undefined variable opline" errors */
#if 0 || (IS_CV != IS_UNUSED)
- zval *retval_ptr;
+ zval *retval_ref, *retval_ptr;
zend_arg_info *ret_info = EX(func)->common.arg_info - 1;
- retval_ptr = _get_zval_ptr_cv_BP_VAR_R(execute_data, opline->op1.var);
+ retval_ref = retval_ptr = _get_zval_ptr_cv_BP_VAR_R(execute_data, opline->op1.var);
if (IS_CV == IS_CONST) {
ZVAL_COPY(EX_VAR(opline->result.var), retval_ptr);
- retval_ptr = EX_VAR(opline->result.var);
+ retval_ref = retval_ptr = EX_VAR(opline->result.var);
+ } else if (IS_CV == IS_VAR || IS_CV == IS_CV) {
+ ZVAL_DEREF(retval_ptr);
}
if (UNEXPECTED(!ret_info->class_name
if (EXPECTED((EX(func)->op_array.fn_flags & ZEND_ACC_RETURN_REFERENCE) == 0)) {
/* Does not return by reference */
- SEPARATE_ZVAL(retval_ptr);
+ if (retval_ref != retval_ptr && Z_REFCOUNT_P(retval_ref) == 1) {
+ ZVAL_UNREF(retval_ref);
+ } else {
+ SEPARATE_ZVAL(retval_ref);
+ }
+ retval_ptr = retval_ref;
} else {
- ZVAL_DEREF(retval_ptr);
SEPARATE_ZVAL_NOREF(retval_ptr);
}
}