diff options
| author | Dmitry Stogov <dmitry@php.net> | 2005-06-21 12:05:15 +0000 |
|---|---|---|
| committer | Dmitry Stogov <dmitry@php.net> | 2005-06-21 12:05:15 +0000 |
| commit | 1098ec03c170c948abda5ed55eb8f08ca1c09bf0 (patch) | |
| tree | 08a38f3b2ff4d8dbea0525f3a27dc62463a924de /Zend/zend_compile.c | |
| parent | 9f2c906e80e908b2b97c88412973bad760557835 (diff) | |
| download | php-git-1098ec03c170c948abda5ed55eb8f08ca1c09bf0.tar.gz | |
Remove unnecessary ZEND_FETCH_CLASS together with ZEND_DECLARE_INHERITED_CLASS in case of early binding
Diffstat (limited to 'Zend/zend_compile.c')
| -rw-r--r-- | Zend/zend_compile.c | 13 |
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; |
