mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
- MFH: Fixed bug #45765 (ReflectionObject with default parameters of self::xxx cause an error)
This commit is contained in:
parent
157ad7764e
commit
18d07065c0
2 changed files with 83 additions and 1 deletions
|
@ -642,7 +642,7 @@ static void _parameter_string(string *str, zend_function *fptr, struct _zend_arg
|
|||
*zv = precv->op2.u.constant;
|
||||
zval_copy_ctor(zv);
|
||||
INIT_PZVAL(zv);
|
||||
zval_update_constant(&zv, (void*)1 TSRMLS_CC);
|
||||
zval_update_constant_ex(&zv, (void*)1, fptr->common.scope TSRMLS_CC);
|
||||
if (Z_TYPE_P(zv) == IS_BOOL) {
|
||||
if (Z_LVAL_P(zv)) {
|
||||
string_write(str, "true", sizeof("true")-1);
|
||||
|
|
82
ext/reflection/tests/bug45765.phpt
Normal file
82
ext/reflection/tests/bug45765.phpt
Normal file
|
@ -0,0 +1,82 @@
|
|||
--TEST--
|
||||
Fixed bug #45765 (ReflectionObject with default parameters of self::xxx cause an error)
|
||||
--FILE--
|
||||
<?php
|
||||
|
||||
class foo2 {
|
||||
const BAR = 'foobar';
|
||||
}
|
||||
|
||||
class foo extends foo2 {
|
||||
const BAR = "foo's bar";
|
||||
|
||||
function test($a = self::BAR) {
|
||||
}
|
||||
|
||||
function test2($a = parent::BAR) {
|
||||
}
|
||||
|
||||
function test3($a = foo::BAR) {
|
||||
}
|
||||
|
||||
function test4($a = foo2::BAR) {
|
||||
}
|
||||
}
|
||||
|
||||
ReflectionObject::export(new foo);
|
||||
|
||||
?>
|
||||
--EXPECTF--
|
||||
Object of class [ <user> class foo extends foo2 ] {
|
||||
@@ %s 7-21
|
||||
|
||||
- Constants [1] {
|
||||
Constant [ string BAR ] { foo's bar }
|
||||
}
|
||||
|
||||
- Static properties [0] {
|
||||
}
|
||||
|
||||
- Static methods [0] {
|
||||
}
|
||||
|
||||
- Properties [0] {
|
||||
}
|
||||
|
||||
- Dynamic properties [0] {
|
||||
}
|
||||
|
||||
- Methods [4] {
|
||||
Method [ <user> public method test ] {
|
||||
@@ %s 10 - 11
|
||||
|
||||
- Parameters [1] {
|
||||
Parameter #0 [ <optional> $a = 'foo's bar' ]
|
||||
}
|
||||
}
|
||||
|
||||
Method [ <user> public method test2 ] {
|
||||
@@ %s 13 - 14
|
||||
|
||||
- Parameters [1] {
|
||||
Parameter #0 [ <optional> $a = 'foobar' ]
|
||||
}
|
||||
}
|
||||
|
||||
Method [ <user> public method test3 ] {
|
||||
@@ %s 16 - 17
|
||||
|
||||
- Parameters [1] {
|
||||
Parameter #0 [ <optional> $a = 'foo's bar' ]
|
||||
}
|
||||
}
|
||||
|
||||
Method [ <user> public method test4 ] {
|
||||
@@ %s 19 - 20
|
||||
|
||||
- Parameters [1] {
|
||||
Parameter #0 [ <optional> $a = 'foobar' ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue