diff --git a/src/Support/ReflectionClosure.php b/src/Support/ReflectionClosure.php index 9c5f3b0d..8bf13ac0 100644 --- a/src/Support/ReflectionClosure.php +++ b/src/Support/ReflectionClosure.php @@ -508,7 +508,7 @@ public function getCode() break; case 'id_name': switch ($token[0]) { - case $token[0] === ':' && $context !== 'instanceof': + case $token[0] === ':' && ! in_array($context, ['instanceof', 'new'], true): if ($lastState === 'closure' && $context === 'root') { $state = 'closure'; $code .= $id_start.$token; diff --git a/tests/ReflectionClosure5Test.php b/tests/ReflectionClosure5Test.php index 2919d45b..cbf411ac 100644 --- a/tests/ReflectionClosure5Test.php +++ b/tests/ReflectionClosure5Test.php @@ -5,6 +5,7 @@ use Foo\Baz\Qux\Forest; use Laravel\SerializableClosure\Support\ReflectionClosure; use Tests\Fixtures\Model; +use Tests\Fixtures\RegularClass; test('is short closure', function () { $f1 = fn () => 1; @@ -243,6 +244,21 @@ public function qux(\Foo\Bar\Qux $qux): \Foo\Bar\Qux expect($f)->toBeCode($e); }); +test('ternanry operator new without constructor', function () { + $f = function () { + $flag = true; + + return $flag ? new RegularClass : new RegularClass; + }; + $e = 'function () { + $flag = true; + + return $flag ? new \Tests\Fixtures\RegularClass : new \Tests\Fixtures\RegularClass; + }'; + + expect($f)->toBeCode($e); +}); + // Helpers function c(Closure $closure) {