From 350a5a7a279c8da794795042a3821601864e04ed Mon Sep 17 00:00:00 2001 From: Andrew Siegman Date: Fri, 20 Jul 2018 11:13:01 -0500 Subject: [PATCH] careful treatment of string PHPExcel in migrator --- src/PhpSpreadsheet/Helper/Migrator.php | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/PhpSpreadsheet/Helper/Migrator.php b/src/PhpSpreadsheet/Helper/Migrator.php index 93686626b9..4eb6063379 100644 --- a/src/PhpSpreadsheet/Helper/Migrator.php +++ b/src/PhpSpreadsheet/Helper/Migrator.php @@ -204,7 +204,6 @@ public function getMapping() 'PHPExcel_Settings' => \PhpOffice\PhpSpreadsheet\Settings::class, 'PHPExcel_Style' => \PhpOffice\PhpSpreadsheet\Style\Style::class, 'PHPExcel_Worksheet' => \PhpOffice\PhpSpreadsheet\Worksheet\Worksheet::class, - 'PHPExcel' => \PhpOffice\PhpSpreadsheet\Spreadsheet::class, ]; $methods = [ @@ -272,6 +271,11 @@ private function recursiveReplace($path) $original = file_get_contents($file); $converted = str_replace($from, $to, $original); + // The string "PHPExcel" gets special treatment because of how common it might be. + // This regex requires a word boundary around the string, and it can't be + // preceded by $ or -> (goal is to filter out cases where a variable is named $PHPExcel or similar) + $converted = preg_replace('/(?)\bPHPExcel\b/', \PhpOffice\PhpSpreadsheet\Spreadsheet::class, $original); + if ($original !== $converted) { echo $file . " converted\n"; file_put_contents($file, $converted);