From 9e4c621ed7fb388952c3923b7b72b534a03e31d2 Mon Sep 17 00:00:00 2001 From: Timm Friebe Date: Sat, 2 Nov 2024 12:54:47 +0100 Subject: [PATCH] Correctly support backtick-enclosed strings See https://www.php.net/manual/en/language.operators.execution.php and https://wiki.php.net/rfc/deprecate-backtick-operator --- src/main/php/lang/ast/Tokens.class.php | 4 ++-- src/test/php/lang/ast/unittest/parse/LiteralsTest.class.php | 5 +++++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/main/php/lang/ast/Tokens.class.php b/src/main/php/lang/ast/Tokens.class.php index 179b4c7..bc4303a 100755 --- a/src/main/php/lang/ast/Tokens.class.php +++ b/src/main/php/lang/ast/Tokens.class.php @@ -10,7 +10,7 @@ * @test lang.ast.unittest.TokensTest */ class Tokens { - const DELIMITERS = " \r\n\t'\$\"=,;.:?!(){}[]#+-*/|&^@%~<>"; + const DELIMITERS = " \r\n\t'\$\"`=,;.:?!(){}[]#+-*/|&^@%~<>"; const OPERATORS = [ '<' => ['<=>', '<<=', '<=', '<<', '<>', '' => ['>>=', '>=', '>>'], @@ -101,7 +101,7 @@ public function iterator($language) { $line++; } else if ("\r" === $token || "\t" === $token || ' ' === $token) { // Skip over whitespace - } else if ("'" === $token || '"' === $token) { + } else if ("'" === $token || '"' === $token || '`' === $token) { $string= $token; $end= '\\'.$token; do { diff --git a/src/test/php/lang/ast/unittest/parse/LiteralsTest.class.php b/src/test/php/lang/ast/unittest/parse/LiteralsTest.class.php index 3fd0891..1eb9273 100755 --- a/src/test/php/lang/ast/unittest/parse/LiteralsTest.class.php +++ b/src/test/php/lang/ast/unittest/parse/LiteralsTest.class.php @@ -50,6 +50,11 @@ public function non_empty_string() { $this->assertParsed([new Literal('"Test"', self::LINE)], '"Test";'); } + #[Test] + public function exec_statement() { + $this->assertParsed([new Literal('`ls -al`', self::LINE)], '`ls -al`;'); + } + #[Test, Values(['[];', ['array();']])] public function empty_array($declaration) { $this->assertParsed([new ArrayLiteral([], self::LINE)], $declaration);