mirror of
https://github.com/php/php-src.git
synced 2024-09-22 02:17:32 +00:00
- Changed zend_resolve_class_name() prototype
# No needed to pass fetch_type as pointer here
This commit is contained in:
parent
5cb1602aab
commit
0fe6fd9e89
@ -699,9 +699,7 @@ void zend_do_fetch_static_member(znode *result, znode *class_name TSRMLS_DC) /*
|
||||
|
||||
if (class_name->op_type == IS_CONST &&
|
||||
ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
|
||||
ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
|
||||
|
||||
zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
|
||||
class_node = *class_name;
|
||||
} else {
|
||||
zend_do_fetch_class(&class_node, class_name TSRMLS_CC);
|
||||
@ -1856,7 +1854,7 @@ void zend_do_receive_arg(zend_uchar op, znode *varname, const znode *offset, con
|
||||
if (class_type->u.constant.type != IS_NULL) {
|
||||
cur_arg_info->type_hint = IS_OBJECT;
|
||||
if (ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_type->u.constant), Z_STRLEN(class_type->u.constant))) {
|
||||
zend_resolve_class_name(class_type, &opline->extended_value, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_type, opline->extended_value, 1 TSRMLS_CC);
|
||||
}
|
||||
class_type->u.constant.value.str.val = zend_new_interned_string(class_type->u.constant.value.str.val, class_type->u.constant.value.str.len + 1, 1 TSRMLS_CC);
|
||||
cur_arg_info->class_name = class_type->u.constant.value.str.val;
|
||||
@ -2063,7 +2061,7 @@ void zend_resolve_non_class_name(znode *element_name, zend_bool check_namespace
|
||||
}
|
||||
/* }}} */
|
||||
|
||||
void zend_resolve_class_name(znode *class_name, ulong *fetch_type, int check_ns_name TSRMLS_DC) /* {{{ */
|
||||
void zend_resolve_class_name(znode *class_name, ulong fetch_type, int check_ns_name TSRMLS_DC) /* {{{ */
|
||||
{
|
||||
char *compound;
|
||||
char *lcname;
|
||||
@ -2171,7 +2169,7 @@ void zend_do_fetch_class(znode *result, znode *class_name TSRMLS_DC) /* {{{ */
|
||||
zval_dtor(&class_name->u.constant);
|
||||
break;
|
||||
default:
|
||||
zend_resolve_class_name(class_name, &opline->extended_value, 0 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_name, opline->extended_value, 0 TSRMLS_CC);
|
||||
opline->op2_type = IS_CONST;
|
||||
opline->op2.constant =
|
||||
zend_add_class_name_literal(CG(active_op_array), &class_name->u.constant TSRMLS_CC);
|
||||
@ -2329,7 +2327,6 @@ int zend_do_begin_class_member_function_call(znode *class_name, znode *method_na
|
||||
znode class_node;
|
||||
unsigned char *ptr = NULL;
|
||||
zend_op *opline;
|
||||
ulong fetch_type = 0;
|
||||
|
||||
if (method_name->op_type == IS_CONST) {
|
||||
char *lcname = zend_str_tolower_dup(Z_STRVAL(method_name->u.constant), Z_STRLEN(method_name->u.constant));
|
||||
@ -2343,8 +2340,7 @@ int zend_do_begin_class_member_function_call(znode *class_name, znode *method_na
|
||||
|
||||
if (class_name->op_type == IS_CONST &&
|
||||
ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
|
||||
fetch_type = ZEND_FETCH_CLASS_GLOBAL;
|
||||
zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
|
||||
class_node = *class_name;
|
||||
opline = get_next_op(CG(active_op_array) TSRMLS_CC);
|
||||
} else {
|
||||
@ -2687,9 +2683,7 @@ void zend_do_begin_catch(znode *try_token, znode *class_name, znode *catch_var,
|
||||
|
||||
if (class_name->op_type == IS_CONST &&
|
||||
ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
|
||||
ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
|
||||
|
||||
zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
|
||||
catch_class = *class_name;
|
||||
} else {
|
||||
zend_error(E_COMPILE_ERROR, "Bad class name in the catch statement");
|
||||
@ -4042,8 +4036,7 @@ void zend_prepare_reference(znode *result, znode *class_name, znode *method_name
|
||||
/* REM: There should not be a need for copying,
|
||||
zend_do_begin_class_declaration is also just using that string */
|
||||
if (class_name) {
|
||||
ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
|
||||
zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
|
||||
method_ref->class_name = Z_STRVAL(class_name->u.constant);
|
||||
method_ref->cname_len = Z_STRLEN(class_name->u.constant);
|
||||
} else {
|
||||
@ -4735,7 +4728,7 @@ void zend_do_implements_interface(znode *interface_name TSRMLS_DC) /* {{{ */
|
||||
opline = get_next_op(CG(active_op_array) TSRMLS_CC);
|
||||
opline->opcode = ZEND_ADD_INTERFACE;
|
||||
SET_NODE(opline->op1, &CG(implementing_class));
|
||||
zend_resolve_class_name(interface_name, &opline->extended_value, 0 TSRMLS_CC);
|
||||
zend_resolve_class_name(interface_name, opline->extended_value, 0 TSRMLS_CC);
|
||||
opline->extended_value = (opline->extended_value & ~ZEND_FETCH_CLASS_MASK) | ZEND_FETCH_CLASS_INTERFACE;
|
||||
opline->op2_type = IS_CONST;
|
||||
opline->op2.constant = zend_add_class_name_literal(CG(active_op_array), &interface_name->u.constant TSRMLS_CC);
|
||||
@ -4760,7 +4753,7 @@ void zend_do_implements_trait(znode *trait_name TSRMLS_DC) /* {{{ */
|
||||
opline = get_next_op(CG(active_op_array) TSRMLS_CC);
|
||||
opline->opcode = ZEND_ADD_TRAIT;
|
||||
SET_NODE(opline->op1, &CG(implementing_class));
|
||||
zend_resolve_class_name(trait_name, &opline->extended_value, 0 TSRMLS_CC);
|
||||
zend_resolve_class_name(trait_name, opline->extended_value, 0 TSRMLS_CC);
|
||||
opline->extended_value = ZEND_FETCH_CLASS_TRAIT;
|
||||
opline->op2_type = IS_CONST;
|
||||
opline->op2.constant = zend_add_class_name_literal(CG(active_op_array), &trait_name->u.constant TSRMLS_CC);
|
||||
@ -5109,7 +5102,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_container, znode *con
|
||||
if (ZEND_FETCH_CLASS_STATIC == type) {
|
||||
zend_error(E_ERROR, "\"static::\" is not allowed in compile-time constants");
|
||||
} else if (ZEND_FETCH_CLASS_DEFAULT == type) {
|
||||
zend_resolve_class_name(constant_container, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(constant_container, fetch_type, 1 TSRMLS_CC);
|
||||
}
|
||||
zend_do_build_full_name(NULL, constant_container, constant_name, 1 TSRMLS_CC);
|
||||
*result = *constant_container;
|
||||
@ -5118,7 +5111,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_container, znode *con
|
||||
case ZEND_RT:
|
||||
if (constant_container->op_type == IS_CONST &&
|
||||
ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(constant_container->u.constant), Z_STRLEN(constant_container->u.constant))) {
|
||||
zend_resolve_class_name(constant_container, &fetch_type, 1 TSRMLS_CC);
|
||||
zend_resolve_class_name(constant_container, fetch_type, 1 TSRMLS_CC);
|
||||
} else {
|
||||
zend_do_fetch_class(&tmp, constant_container TSRMLS_CC);
|
||||
constant_container = &tmp;
|
||||
|
@ -414,7 +414,7 @@ ZEND_API int zend_get_compiled_lineno(TSRMLS_D);
|
||||
ZEND_API size_t zend_get_scanned_file_offset(TSRMLS_D);
|
||||
|
||||
void zend_resolve_non_class_name(znode *element_name, zend_bool check_namespace TSRMLS_DC);
|
||||
void zend_resolve_class_name(znode *class_name, ulong *fetch_type, int check_ns_name TSRMLS_DC);
|
||||
void zend_resolve_class_name(znode *class_name, ulong fetch_type, int check_ns_name TSRMLS_DC);
|
||||
ZEND_API char* zend_get_compiled_variable_name(const zend_op_array *op_array, zend_uint var, int* name_len);
|
||||
|
||||
#ifdef ZTS
|
||||
|
@ -612,8 +612,8 @@ trait_precedence:
|
||||
;
|
||||
|
||||
trait_reference_list:
|
||||
fully_qualified_class_name { ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL; zend_resolve_class_name(&$1, &fetch_type, 1 TSRMLS_CC); zend_init_list(&$$.u.op.ptr, Z_STRVAL($1.u.constant) TSRMLS_CC); }
|
||||
| trait_reference_list ',' fully_qualified_class_name { ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL; zend_resolve_class_name(&$3, &fetch_type, 1 TSRMLS_CC); zend_add_to_list(&$1.u.op.ptr, Z_STRVAL($3.u.constant) TSRMLS_CC); $$ = $1; }
|
||||
fully_qualified_class_name { zend_resolve_class_name(&$1, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC); zend_init_list(&$$.u.op.ptr, Z_STRVAL($1.u.constant) TSRMLS_CC); }
|
||||
| trait_reference_list ',' fully_qualified_class_name { zend_resolve_class_name(&$3, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC); zend_add_to_list(&$1.u.op.ptr, Z_STRVAL($3.u.constant) TSRMLS_CC); $$ = $1; }
|
||||
;
|
||||
|
||||
trait_method_reference:
|
||||
|
Loading…
Reference in New Issue
Block a user