summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2005-06-21 12:05:15 +0000
committerDmitry Stogov <dmitry@php.net>2005-06-21 12:05:15 +0000
commit1098ec03c170c948abda5ed55eb8f08ca1c09bf0 (patch)
tree08a38f3b2ff4d8dbea0525f3a27dc62463a924de
parent9f2c906e80e908b2b97c88412973bad760557835 (diff)
downloadphp-git-1098ec03c170c948abda5ed55eb8f08ca1c09bf0.tar.gz
Remove unnecessary ZEND_FETCH_CLASS together with ZEND_DECLARE_INHERITED_CLASS in case of early binding
-rw-r--r--Zend/zend_compile.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c
index 8d741604b2..b407dd4dbd 100644
--- a/Zend/zend_compile.c
+++ b/Zend/zend_compile.c
@@ -2298,6 +2298,19 @@ void zend_do_early_binding(TSRMLS_D)
if (do_bind_inherited_class(opline, CG(class_table), *pce, 1 TSRMLS_CC) == NULL) {
return;
}
+ /* clear unnecessary ZEND_FETCH_CLASS opcode */
+ if (opline > CG(active_op_array)->opcodes &&
+ (opline-1)->opcode == ZEND_FETCH_CLASS) {
+ zend_op *fetch_class_opline = opline-1;
+
+ zval_dtor(&fetch_class_opline->op2.u.constant);
+ fetch_class_opline->opcode = ZEND_NOP;
+ memset(&fetch_class_opline->op1, 0, sizeof(znode));
+ memset(&fetch_class_opline->op2, 0, sizeof(znode));
+ SET_UNUSED(fetch_class_opline->op1);
+ SET_UNUSED(fetch_class_opline->op2);
+ SET_UNUSED(fetch_class_opline->result);
+ }
} else {
/* We currently don't early-bind classes that implement interfaces */
return;