From aaab8ec92315bfcd0d3dad9cabaf7d381c5a107b Mon Sep 17 00:00:00 2001 From: Ondrej Mirtes Date: Wed, 11 Dec 2024 11:04:44 +0100 Subject: [PATCH] Add `PropertyHook::isFinal()` helper method with tests --- lib/PhpParser/Node/PropertyHook.php | 8 +++++ test/PhpParser/Node/PropertyHookTest.php | 45 ++++++++++++++++++++++++ 2 files changed, 53 insertions(+) create mode 100644 test/PhpParser/Node/PropertyHookTest.php diff --git a/lib/PhpParser/Node/PropertyHook.php b/lib/PhpParser/Node/PropertyHook.php index 9ae77a2b6e..fab0e9d39a 100644 --- a/lib/PhpParser/Node/PropertyHook.php +++ b/lib/PhpParser/Node/PropertyHook.php @@ -2,6 +2,7 @@ namespace PhpParser\Node; +use PhpParser\Modifiers; use PhpParser\Node\Stmt\Return_; use PhpParser\NodeAbstract; @@ -58,6 +59,13 @@ public function getReturnType() { return null; } + /** + * Whether the property hook is final. + */ + public function isFinal(): bool { + return (bool) ($this->flags & Modifiers::FINAL); + } + public function getStmts(): ?array { if ($this->body instanceof Expr) { return [new Return_($this->body)]; diff --git a/test/PhpParser/Node/PropertyHookTest.php b/test/PhpParser/Node/PropertyHookTest.php new file mode 100644 index 0000000000..b0cf04689d --- /dev/null +++ b/test/PhpParser/Node/PropertyHookTest.php @@ -0,0 +1,45 @@ + constant(Modifiers::class . '::' . strtoupper($modifier)), + ] + ); + + $this->assertTrue($node->{'is' . $modifier}()); + } + + public function testNoModifiers(): void { + $node = new PropertyHook('get', null); + + $this->assertFalse($node->isFinal()); + } + + public static function provideModifiers() { + return [ + ['final'], + ]; + } + + public function testIsFinal() { + $node = new PropertyHook( + 'get', + null, + [ + 'flags' => Modifiers::FINAL, + ] + ); + $this->assertTrue($node->isFinal()); + } +}