mirror of
https://github.com/danog/psalm.git
synced 2024-11-30 04:39:00 +01:00
Get rid of legacy 7.3 logic
This commit is contained in:
parent
2726ad4d6f
commit
07b45b8116
@ -72,7 +72,6 @@ use function file_exists;
|
|||||||
use function fwrite;
|
use function fwrite;
|
||||||
use function implode;
|
use function implode;
|
||||||
use function in_array;
|
use function in_array;
|
||||||
use function ini_get;
|
|
||||||
use function is_dir;
|
use function is_dir;
|
||||||
use function is_file;
|
use function is_file;
|
||||||
use function microtime;
|
use function microtime;
|
||||||
@ -86,11 +85,8 @@ use function strpos;
|
|||||||
use function strtolower;
|
use function strtolower;
|
||||||
use function substr;
|
use function substr;
|
||||||
use function usort;
|
use function usort;
|
||||||
use function version_compare;
|
|
||||||
|
|
||||||
use const PHP_EOL;
|
use const PHP_EOL;
|
||||||
use const PHP_OS;
|
|
||||||
use const PHP_VERSION;
|
|
||||||
use const PSALM_VERSION;
|
use const PSALM_VERSION;
|
||||||
use const STDERR;
|
use const STDERR;
|
||||||
|
|
||||||
@ -391,21 +387,13 @@ class ProjectAnalyzer
|
|||||||
$this->file_reference_provider->loadReferenceCache();
|
$this->file_reference_provider->loadReferenceCache();
|
||||||
$this->codebase->enterServerMode();
|
$this->codebase->enterServerMode();
|
||||||
|
|
||||||
if (ini_get('pcre.jit') === '1'
|
$cpu_count = self::getCpuCount();
|
||||||
&& PHP_OS === 'Darwin'
|
|
||||||
&& version_compare(PHP_VERSION, '7.3.0') >= 0
|
|
||||||
&& version_compare(PHP_VERSION, '7.4.0') < 0
|
|
||||||
) {
|
|
||||||
// do nothing
|
|
||||||
} else {
|
|
||||||
$cpu_count = self::getCpuCount();
|
|
||||||
|
|
||||||
// let's not go crazy
|
// let's not go crazy
|
||||||
$usable_cpus = $cpu_count - 2;
|
$usable_cpus = $cpu_count - 2;
|
||||||
|
|
||||||
if ($usable_cpus > 1) {
|
if ($usable_cpus > 1) {
|
||||||
$this->threads = $usable_cpus;
|
$this->threads = $usable_cpus;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$server->logInfo("Initializing: Initialize Plugins...");
|
$server->logInfo("Initializing: Initialize Plugins...");
|
||||||
@ -1356,15 +1344,6 @@ class ProjectAnalyzer
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// PHP 7.3 with JIT on OSX is screwed for multi-threads
|
|
||||||
if (ini_get('pcre.jit') === '1'
|
|
||||||
&& PHP_OS === 'Darwin'
|
|
||||||
&& version_compare(PHP_VERSION, '7.3.0') >= 0
|
|
||||||
&& version_compare(PHP_VERSION, '7.4.0') < 0
|
|
||||||
) {
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!extension_loaded('pcntl')) {
|
if (!extension_loaded('pcntl')) {
|
||||||
// Psalm requires pcntl for multi-threads support
|
// Psalm requires pcntl for multi-threads support
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -25,9 +25,6 @@ use function array_merge;
|
|||||||
use function in_array;
|
use function in_array;
|
||||||
use function is_string;
|
use function is_string;
|
||||||
use function strtolower;
|
use function strtolower;
|
||||||
use function version_compare;
|
|
||||||
|
|
||||||
use const PHP_VERSION;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @internal
|
* @internal
|
||||||
@ -267,8 +264,7 @@ class TryAnalyzer
|
|||||||
$fq_catch_class,
|
$fq_catch_class,
|
||||||
false,
|
false,
|
||||||
false,
|
false,
|
||||||
version_compare(PHP_VERSION, '7.0.0dev', '>=')
|
strtolower($fq_catch_class) !== 'throwable'
|
||||||
&& strtolower($fq_catch_class) !== 'throwable'
|
|
||||||
&& $codebase->interfaceExists($fq_catch_class)
|
&& $codebase->interfaceExists($fq_catch_class)
|
||||||
&& !$codebase->interfaceExtends($fq_catch_class, 'Throwable')
|
&& !$codebase->interfaceExtends($fq_catch_class, 'Throwable')
|
||||||
? ['Throwable' => new TNamedObject('Throwable')]
|
? ['Throwable' => new TNamedObject('Throwable')]
|
||||||
|
@ -13,7 +13,6 @@ use Psalm\Internal\CliUtils;
|
|||||||
use Psalm\Internal\Codebase\ReferenceMapGenerator;
|
use Psalm\Internal\Codebase\ReferenceMapGenerator;
|
||||||
use Psalm\Internal\Composer;
|
use Psalm\Internal\Composer;
|
||||||
use Psalm\Internal\ErrorHandler;
|
use Psalm\Internal\ErrorHandler;
|
||||||
use Psalm\Internal\Fork\Pool;
|
|
||||||
use Psalm\Internal\Fork\PsalmRestarter;
|
use Psalm\Internal\Fork\PsalmRestarter;
|
||||||
use Psalm\Internal\IncludeCollector;
|
use Psalm\Internal\IncludeCollector;
|
||||||
use Psalm\Internal\Provider\ClassLikeStorageCacheProvider;
|
use Psalm\Internal\Provider\ClassLikeStorageCacheProvider;
|
||||||
@ -73,15 +72,12 @@ use function str_replace;
|
|||||||
use function strlen;
|
use function strlen;
|
||||||
use function strpos;
|
use function strpos;
|
||||||
use function substr;
|
use function substr;
|
||||||
use function version_compare;
|
|
||||||
|
|
||||||
use const DIRECTORY_SEPARATOR;
|
use const DIRECTORY_SEPARATOR;
|
||||||
use const JSON_THROW_ON_ERROR;
|
use const JSON_THROW_ON_ERROR;
|
||||||
use const LC_CTYPE;
|
use const LC_CTYPE;
|
||||||
use const PHP_EOL;
|
use const PHP_EOL;
|
||||||
use const PHP_OS;
|
|
||||||
use const PHP_URL_SCHEME;
|
use const PHP_URL_SCHEME;
|
||||||
use const PHP_VERSION;
|
|
||||||
use const STDERR;
|
use const STDERR;
|
||||||
|
|
||||||
// phpcs:disable PSR1.Files.SideEffects
|
// phpcs:disable PSR1.Files.SideEffects
|
||||||
@ -269,8 +265,6 @@ final class Psalm
|
|||||||
|
|
||||||
$progress = self::initProgress($options, $config);
|
$progress = self::initProgress($options, $config);
|
||||||
|
|
||||||
self::emitMacPcreWarning($options, $threads);
|
|
||||||
|
|
||||||
self::restart($options, $threads, $progress);
|
self::restart($options, $threads, $progress);
|
||||||
|
|
||||||
if (isset($options['debug-emitted-issues'])) {
|
if (isset($options['debug-emitted-issues'])) {
|
||||||
@ -865,24 +859,6 @@ final class Psalm
|
|||||||
return $current_dir;
|
return $current_dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function emitMacPcreWarning(array $options, int $threads): void
|
|
||||||
{
|
|
||||||
if (!isset($options['threads'])
|
|
||||||
&& !isset($options['debug'])
|
|
||||||
&& $threads === 1
|
|
||||||
&& ini_get('pcre.jit') === '1'
|
|
||||||
&& PHP_OS === 'Darwin'
|
|
||||||
&& version_compare(PHP_VERSION, '7.3.0') >= 0
|
|
||||||
&& version_compare(PHP_VERSION, '7.4.0') < 0
|
|
||||||
) {
|
|
||||||
echo(
|
|
||||||
'If you want to run Psalm as a language server, or run Psalm with' . PHP_EOL
|
|
||||||
. 'multiple processes (--threads=4), beware:' . PHP_EOL
|
|
||||||
. Pool::MAC_PCRE_MESSAGE . PHP_EOL . PHP_EOL
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static function restart(array $options, int $threads, Progress $progress): void
|
private static function restart(array $options, int $threads, Progress $progress): void
|
||||||
{
|
{
|
||||||
$ini_handler = new PsalmRestarter('PSALM');
|
$ini_handler = new PsalmRestarter('PSALM');
|
||||||
|
@ -48,11 +48,8 @@ use function strpos;
|
|||||||
use function substr;
|
use function substr;
|
||||||
use function unserialize;
|
use function unserialize;
|
||||||
use function usleep;
|
use function usleep;
|
||||||
use function version_compare;
|
|
||||||
|
|
||||||
use const PHP_EOL;
|
use const PHP_EOL;
|
||||||
use const PHP_OS;
|
|
||||||
use const PHP_VERSION;
|
|
||||||
use const SIGALRM;
|
use const SIGALRM;
|
||||||
use const SIGTERM;
|
use const SIGTERM;
|
||||||
use const STREAM_IPPROTO_IP;
|
use const STREAM_IPPROTO_IP;
|
||||||
@ -88,12 +85,6 @@ class Pool
|
|||||||
/** @var ?Closure(mixed): void */
|
/** @var ?Closure(mixed): void */
|
||||||
private ?Closure $task_done_closure = null;
|
private ?Closure $task_done_closure = null;
|
||||||
|
|
||||||
public const MAC_PCRE_MESSAGE = 'Mac users: pcre.jit is set to 1 in your PHP config.' . PHP_EOL
|
|
||||||
. 'The pcre jit is known to cause segfaults in PHP 7.3 on Macs, and Psalm' . PHP_EOL
|
|
||||||
. 'will not execute in threaded mode to avoid indecipherable errors.' . PHP_EOL
|
|
||||||
. 'Consider adding pcre.jit=0 to your PHP config, or upgrade to PHP 7.4.' . PHP_EOL
|
|
||||||
. 'Relevant info: https://bugs.php.net/bug.php?id=77260';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array<int, array<int, mixed>> $process_task_data_iterator
|
* @param array<int, array<int, mixed>> $process_task_data_iterator
|
||||||
* An array of task data items to be divided up among the
|
* An array of task data items to be divided up among the
|
||||||
@ -141,16 +132,6 @@ class Pool
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ini_get('pcre.jit') === '1'
|
|
||||||
&& PHP_OS === 'Darwin'
|
|
||||||
&& version_compare(PHP_VERSION, '7.3.0') >= 0
|
|
||||||
&& version_compare(PHP_VERSION, '7.4.0') < 0
|
|
||||||
) {
|
|
||||||
die(
|
|
||||||
self::MAC_PCRE_MESSAGE . PHP_EOL
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// We'll keep track of if this is the parent process
|
// We'll keep track of if this is the parent process
|
||||||
// so that we can tell who will be doing the waiting
|
// so that we can tell who will be doing the waiting
|
||||||
$is_parent = false;
|
$is_parent = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user