diff options
author | Joe Watkins <krakjoe@php.net> | 2016-03-29 09:36:46 +0100 |
---|---|---|
committer | Joe Watkins <krakjoe@php.net> | 2016-03-29 09:36:46 +0100 |
commit | bdd05e7483830c5c032ff26972fc708315aa78be (patch) | |
tree | 49f899e8eac0d3bd87e5e54dca55c1943b3cb245 | |
parent | 34d8fea1a810e48e7cc93ae22b6119525298a37a (diff) | |
parent | 3f56dfe8660b45c72dee7adcd856dd9a7049cf5b (diff) | |
download | php-git-bdd05e7483830c5c032ff26972fc708315aa78be.tar.gz |
Merge branch 'PHP-7.0'
* PHP-7.0:
Bug #71428 work ... hopefully, fix drupal 8
-rw-r--r-- | Zend/tests/bug71428.2.phpt | 23 | ||||
-rw-r--r-- | Zend/zend_inheritance.c | 14 |
2 files changed, 30 insertions, 7 deletions
diff --git a/Zend/tests/bug71428.2.phpt b/Zend/tests/bug71428.2.phpt new file mode 100644 index 0000000000..3d8b257a16 --- /dev/null +++ b/Zend/tests/bug71428.2.phpt @@ -0,0 +1,23 @@ +--TEST-- +bug #71428.2: inheritance of ye olde dynamic interfaces +--SKIPIF-- +<?php if (!extension_loaded('pdo')) ?> +--FILE-- +<?php +interface StatementInterface { + public function fetch($first = null, $second, $third); +} + +class Statement extends PDOStatement implements StatementInterface {} + +interface StatementInterface1 { + public function fetch($first = null, $second = null, $third = null); +} + +class Statement1 extends PDOStatement implements StatementInterface1 {} + +echo "ok"; +?> +--EXPECT-- +ok + diff --git a/Zend/zend_inheritance.c b/Zend/zend_inheritance.c index ca9757eced..5fd86c974f 100644 --- a/Zend/zend_inheritance.c +++ b/Zend/zend_inheritance.c @@ -167,7 +167,7 @@ char *zend_visibility_string(uint32_t fn_flags) /* {{{ */ } /* }}} */ -static int zend_do_perform_type_hint_check(const zend_function *fe, zend_arg_info *fe_arg_info, const zend_function *proto, zend_arg_info *proto_arg_info) /* {{{ */ +static int zend_do_perform_type_hint_check(const zend_function *fe, uint32_t arg_num, zend_arg_info *fe_arg_info, const zend_function *proto, zend_arg_info *proto_arg_info) /* {{{ */ { if (ZEND_LOG_XOR(fe_arg_info->class_name, proto_arg_info->class_name)) { /* Only one has a type declaration and the other one doesn't */ @@ -238,13 +238,13 @@ static int zend_do_perform_type_hint_check(const zend_function *fe, zend_arg_inf zend_string_release(fe_class_name); } - if (proto_arg_info->allow_null && !fe_arg_info->allow_null) { - /* incompatible nullability */ + if (fe_arg_info->type_hint != proto_arg_info->type_hint) { + /* Incompatible type */ return 0; } - if (fe_arg_info->type_hint != proto_arg_info->type_hint) { - /* Incompatible type */ + if (proto_arg_info->type_hint && proto_arg_info->allow_null && !fe_arg_info->allow_null) { + /* incompatible nullability */ return 0; } @@ -320,7 +320,7 @@ static zend_bool zend_do_perform_implementation_check(const zend_function *fe, c proto_arg_info = &proto->common.arg_info[proto->common.num_args]; } - if (!zend_do_perform_type_hint_check(fe, fe_arg_info, proto, proto_arg_info)) { + if (!zend_do_perform_type_hint_check(fe, i, fe_arg_info, proto, proto_arg_info)) { return 0; } @@ -338,7 +338,7 @@ static zend_bool zend_do_perform_implementation_check(const zend_function *fe, c return 0; } - if (!zend_do_perform_type_hint_check(fe, fe->common.arg_info - 1, proto, proto->common.arg_info - 1)) { + if (!zend_do_perform_type_hint_check(fe, i, fe->common.arg_info - 1, proto, proto->common.arg_info - 1)) { return 0; } } |