From 097aa4c02954dabe9d508229be86213723973ac0 Mon Sep 17 00:00:00 2001 From: Nicolas Grekas Date: Tue, 9 Apr 2019 12:03:18 +0200 Subject: [PATCH] [VarExporter] fix exporting some strings --- Internal/Exporter.php | 37 +++++++++++++++-------------- Tests/Fixtures/lf-ending-string.php | 4 ++++ Tests/Fixtures/multiline-string.php | 3 +-- Tests/VarExporterTest.php | 1 + 4 files changed, 25 insertions(+), 20 deletions(-) create mode 100644 Tests/Fixtures/lf-ending-string.php diff --git a/Internal/Exporter.php b/Internal/Exporter.php index c0b7fa1..06d747e 100644 --- a/Internal/Exporter.php +++ b/Internal/Exporter.php @@ -212,27 +212,28 @@ public static function export($value, $indent = '') $subIndent = $indent.' '; if (\is_string($value)) { - $code = var_export($value, true); - - if (false !== strpos($value, "\n") || false !== strpos($value, "\r")) { - $code = strtr($code, [ - "\r\n" => "'.\"\\r\\n\"\n".$subIndent.".'", - "\r" => "'.\"\\r\"\n".$subIndent.".'", - "\n" => "'.\"\\n\"\n".$subIndent.".'", - ]); - } + $code = sprintf("'%s'", addcslashes($value, "'\\")); - if (false !== strpos($value, "\0")) { - $code = str_replace('\' . "\0" . \'', '\'."\0".\'', $code); - $code = str_replace('".\'\'."', '', $code); - } + $code = preg_replace_callback('/([\0\r\n]++)(.)/', function ($m) use ($subIndent) { + $m[1] = sprintf('\'."%s".\'', str_replace( + ["\0", "\r", "\n", '\n\\'], + ['\0', '\r', '\n', '\n"'."\n".$subIndent.'."\\'], + $m[1] + )); - if (false !== strpos($code, "''.")) { - $code = str_replace("''.", '', $code); - } + if ("'" === $m[2]) { + return substr($m[1], 0, -2); + } + + if ('n".\'' === substr($m[1], -4)) { + return substr_replace($m[1], "\n".$subIndent.".'".$m[2], -2); + } + + return $m[1].$m[2]; + }, $code, -1, $count); - if (".''" === substr($code, -3)) { - $code = rtrim(substr($code, 0, -3)); + if ($count && 0 === strpos($code, "''.")) { + $code = substr($code, 3); } return $code; diff --git a/Tests/Fixtures/lf-ending-string.php b/Tests/Fixtures/lf-ending-string.php new file mode 100644 index 0000000..f6bcf84 --- /dev/null +++ b/Tests/Fixtures/lf-ending-string.php @@ -0,0 +1,4 @@ + 'B'."\r" - .'C'."\n" + .'A' => 'B'."\r".'C'."\n" ."\n", ]; diff --git a/Tests/VarExporterTest.php b/Tests/VarExporterTest.php index d80c285..1e328d8 100644 --- a/Tests/VarExporterTest.php +++ b/Tests/VarExporterTest.php @@ -112,6 +112,7 @@ public function testExport(string $testName, $value, bool $staticValueExpected = public function provideExport() { yield ['multiline-string', ["\0\0\r\nA" => "B\rC\n\n"], true]; + yield ['lf-ending-string', "'BOOM'\n.var_dump(123)//'", true]; yield ['bool', true, true]; yield ['simple-array', [123, ['abc']], true];