forked from phpstan/phpstan-src
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbug-14362.php
More file actions
84 lines (67 loc) · 1.35 KB
/
bug-14362.php
File metadata and controls
84 lines (67 loc) · 1.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php // lint >= 8.1
declare(strict_types = 1);
namespace Bug14362;
use function PHPStan\Testing\assertType;
interface A
{
public function __invoke(B $b): int;
}
interface B
{
}
class C {
public static function u(): A&B {
return new class() implements A, B {
public function __invoke(B $b): int {
return 1;
}
};
}
}
class D {
public static function u(): A {
return new class() implements A {
public function __invoke(B $b): int {
return 1;
}
};
}
}
interface E
{
public function __invoke(B $b, bool $option = true): int;
}
interface F
{
}
class G {
public static function u(): A&E {
return new class() implements A, E {
public function __invoke(B $b, bool $option = true): int {
return 1;
}
};
}
}
class H {
public static function u(): B&F {
return new class() implements B, F {
};
}
}
function doBar() : void {
assertType('Closure(Bug14362\B): int', C::u()(...));
assertType('Closure(Bug14362\B): int', D::u()(...));
// Intersection with two yes-callable compatible
assertType('Closure(Bug14362\B, bool=): int', G::u()(...));
// Intersection with only maybe-callable types (neither has __invoke)
assertType('Closure', H::u()(...));
}
function doFoo(string $c):void {
if (is_callable($c)) {
$a = $c;
} else {
$a = C::u()(...);
}
assertType('callable-string|(Closure(Bug14362\B): int)', $a);
}