znode class_node, prop_node;
zend_op *opline;
+ uint32_t fetch_type = class_ast->kind == ZEND_AST_ZVAL ? zend_get_class_fetch_type_ast(class_ast) : -1;
- if (zend_is_const_default_class_ref(class_ast)) {
+ if (fetch_type == ZEND_FETCH_CLASS_DEFAULT) {
class_node.op_type = IS_CONST;
ZVAL_STR(&class_node.u.constant, zend_resolve_class_name_ast(class_ast));
} else {
- zend_compile_class_ref(&class_node, class_ast, 1);
+ /* we do not have any reference to the extends_ast/name of parent at compile-time, hence only resolving self:: for now */
+ if (zend_is_scope_known() && fetch_type == ZEND_FETCH_CLASS_SELF) {
+ zend_ensure_valid_class_fetch_type(fetch_type);
+
+ class_node.op_type = IS_CONST;
+ ZVAL_STR_COPY(&class_node.u.constant, CG(active_class_entry)->name);
+ } else {
+ zend_compile_class_ref(&class_node, class_ast, 1);
+ }
}
zend_compile_expr(&prop_node, prop_ast);
class_node.op_type = IS_CONST;
ZVAL_STR_COPY(&class_node.u.constant, CG(active_class_entry)->name);
} else {
- opline = zend_compile_class_ref(&class_node, class_ast, 1);
+ zend_compile_class_ref(&class_node, class_ast, 1);
}
}