mirror of
https://github.com/php/php-src.git
synced 2025-01-10 04:54:47 +08:00
Merge branch 'PHP-7.4'
This commit is contained in:
commit
200f5b407e
@ -1132,8 +1132,7 @@ static void sccp_visit_instr(scdf_ctx *scdf, zend_op *opline, zend_ssa_op *ssa_o
|
|||||||
if (op2 && IS_BOT(op2)) {
|
if (op2 && IS_BOT(op2)) {
|
||||||
/* Update of unknown index */
|
/* Update of unknown index */
|
||||||
SET_RESULT_BOT(result);
|
SET_RESULT_BOT(result);
|
||||||
if (ssa_op->op1_def >= 0
|
if (ssa_op->op1_def >= 0) {
|
||||||
&& ctx->scdf.ssa->vars[ssa_op->op1_def].escape_state == ESCAPE_STATE_NO_ESCAPE) {
|
|
||||||
empty_partial_array(&zv);
|
empty_partial_array(&zv);
|
||||||
SET_RESULT(op1, &zv);
|
SET_RESULT(op1, &zv);
|
||||||
zval_ptr_dtor_nogc(&zv);
|
zval_ptr_dtor_nogc(&zv);
|
||||||
@ -1150,8 +1149,7 @@ static void sccp_visit_instr(scdf_ctx *scdf, zend_op *opline, zend_ssa_op *ssa_o
|
|||||||
|| Z_TYPE_P(op1) == IS_NULL
|
|| Z_TYPE_P(op1) == IS_NULL
|
||||||
|| Z_TYPE_P(op1) == IS_FALSE
|
|| Z_TYPE_P(op1) == IS_FALSE
|
||||||
|| Z_TYPE_P(op1) == IS_ARRAY)
|
|| Z_TYPE_P(op1) == IS_ARRAY)
|
||||||
&& ssa_op->op1_def >= 0
|
&& ssa_op->op1_def >= 0) {
|
||||||
&& ctx->scdf.ssa->vars[ssa_op->op1_def].escape_state == ESCAPE_STATE_NO_ESCAPE) {
|
|
||||||
|
|
||||||
if (Z_TYPE_P(op1) == IS_NULL || Z_TYPE_P(op1) == IS_FALSE) {
|
if (Z_TYPE_P(op1) == IS_NULL || Z_TYPE_P(op1) == IS_FALSE) {
|
||||||
empty_partial_array(&zv);
|
empty_partial_array(&zv);
|
||||||
@ -1330,8 +1328,7 @@ static void sccp_visit_instr(scdf_ctx *scdf, zend_op *opline, zend_ssa_op *ssa_o
|
|||||||
if (op2 && IS_BOT(op2)) {
|
if (op2 && IS_BOT(op2)) {
|
||||||
/* Update of unknown index */
|
/* Update of unknown index */
|
||||||
SET_RESULT_BOT(op1);
|
SET_RESULT_BOT(op1);
|
||||||
if (ssa_op->result_def >= 0
|
if (ssa_op->result_def >= 0) {
|
||||||
&& ctx->scdf.ssa->vars[ssa_op->result_def].escape_state == ESCAPE_STATE_NO_ESCAPE) {
|
|
||||||
empty_partial_array(&zv);
|
empty_partial_array(&zv);
|
||||||
SET_RESULT(result, &zv);
|
SET_RESULT(result, &zv);
|
||||||
zval_ptr_dtor_nogc(&zv);
|
zval_ptr_dtor_nogc(&zv);
|
||||||
@ -1345,8 +1342,7 @@ static void sccp_visit_instr(scdf_ctx *scdf, zend_op *opline, zend_ssa_op *ssa_o
|
|||||||
|| (opline->extended_value & ZEND_ARRAY_ELEMENT_REF)) {
|
|| (opline->extended_value & ZEND_ARRAY_ELEMENT_REF)) {
|
||||||
|
|
||||||
SET_RESULT_BOT(op1);
|
SET_RESULT_BOT(op1);
|
||||||
if (ssa_op->result_def >= 0
|
if (ssa_op->result_def >= 0) {
|
||||||
&& ctx->scdf.ssa->vars[ssa_op->result_def].escape_state == ESCAPE_STATE_NO_ESCAPE) {
|
|
||||||
if (!result) {
|
if (!result) {
|
||||||
empty_partial_array(&zv);
|
empty_partial_array(&zv);
|
||||||
} else {
|
} else {
|
||||||
@ -1502,9 +1498,7 @@ static void sccp_visit_instr(scdf_ctx *scdf, zend_op *opline, zend_ssa_op *ssa_o
|
|||||||
}
|
}
|
||||||
} else if (opline->extended_value == ZEND_ASSIGN_DIM) {
|
} else if (opline->extended_value == ZEND_ASSIGN_DIM) {
|
||||||
if ((IS_PARTIAL_ARRAY(op1) || Z_TYPE_P(op1) == IS_ARRAY)
|
if ((IS_PARTIAL_ARRAY(op1) || Z_TYPE_P(op1) == IS_ARRAY)
|
||||||
&& ssa_op->op1_def >= 0
|
&& ssa_op->op1_def >= 0 && op2) {
|
||||||
&& ctx->scdf.ssa->vars[ssa_op->op1_def].escape_state == ESCAPE_STATE_NO_ESCAPE
|
|
||||||
&& op2) {
|
|
||||||
zval tmp;
|
zval tmp;
|
||||||
zval *data = get_op1_value(ctx, opline+1, ssa_op+1);
|
zval *data = get_op1_value(ctx, opline+1, ssa_op+1);
|
||||||
|
|
||||||
@ -2123,7 +2117,7 @@ static void join_phi_values(zval *a, zval *b, zend_bool escape) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (IS_PARTIAL_ARRAY(a) || IS_PARTIAL_ARRAY(b)) {
|
if (IS_PARTIAL_ARRAY(a) || IS_PARTIAL_ARRAY(b)) {
|
||||||
if (escape || join_partial_arrays(a, b) != SUCCESS) {
|
if (join_partial_arrays(a, b) != SUCCESS) {
|
||||||
zval_ptr_dtor_nogc(a);
|
zval_ptr_dtor_nogc(a);
|
||||||
MAKE_BOT(a);
|
MAKE_BOT(a);
|
||||||
}
|
}
|
||||||
@ -2133,7 +2127,7 @@ static void join_phi_values(zval *a, zval *b, zend_bool escape) {
|
|||||||
MAKE_BOT(a);
|
MAKE_BOT(a);
|
||||||
}
|
}
|
||||||
} else if (!zend_is_identical(a, b)) {
|
} else if (!zend_is_identical(a, b)) {
|
||||||
if (escape || join_partial_arrays(a, b) != SUCCESS) {
|
if (join_partial_arrays(a, b) != SUCCESS) {
|
||||||
zval_ptr_dtor_nogc(a);
|
zval_ptr_dtor_nogc(a);
|
||||||
MAKE_BOT(a);
|
MAKE_BOT(a);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user