Files
piratepoet/mailpoet/tasks/fix-php82-robo.php
alex-mailpoet a9788b04d4 Remove Code Sniffer ignore
[MAILPOET-4900]
2023-01-30 14:13:33 +01:00

45 lines
1.4 KiB
PHP

<?php declare(strict_types = 1);
// throw exception if anything fails
set_error_handler(function ($severity, $message, $file, $line) {
throw new ErrorException($message, 0, $severity, $file, $line);
});
// Skip for production build
if (!file_exists(__DIR__ . '/../vendor/consolidation/robo/src/Common/CommandArguments.php')) {
exit;
}
// Fixes for PHP8.2 Compatibility
// Development packages
$replacements = [
// Robo patches can be removed after a new version with this fix is released:
// https://github.com/consolidation/robo/issues/1135
[
'file' => __DIR__ . '/../vendor/consolidation/robo/src/Common/CommandArguments.php',
'find' => [
'$this->arguments .= \' \' . implode(\' \', array_map(\'static::escape\', $args));',
],
'replace' => [
'$this->arguments .= \' \' . implode(\' \', array_map([static::class, \'escape\'], $args));',
],
],
[
'file' => __DIR__ . '/../vendor/consolidation/robo/src/Task/Base/Exec.php',
'find' => [
'$stopRunningJobs = Closure::fromCallable([\'self\', \'stopRunningJobs\']);',
],
'replace' => [
'$stopRunningJobs = Closure::fromCallable(self::class.\'::stopRunningJobs\');',
],
],
];
// Apply replacements
foreach ($replacements as $singleFile) {
$data = file_get_contents($singleFile['file']);
$data = str_replace($singleFile['find'], $singleFile['replace'], $data);
file_put_contents($singleFile['file'], $data);
}