Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php namespace Psalm\Internal\Provider; use Closure; use Psalm\Plugin\EventHandler\Even..
Decoded Output download
<?php
namespace Psalm\Internal\Provider;
use Closure;
use Psalm\Plugin\EventHandler\Event\FunctionExistenceProviderEvent;
use Psalm\Plugin\EventHandler\FunctionExistenceProviderInterface;
use Psalm\StatementsSource;
use function is_subclass_of;
use function strtolower;
/**
* @internal
*/
final class FunctionExistenceProvider
{
/**
* @var array<
* lowercase-string,
* array<Closure(FunctionExistenceProviderEvent): ?bool>
* >
*/
private static array $handlers = [];
public function __construct()
{
self::$handlers = [];
}
/**
* @param class-string $class
*/
public function registerClass(string $class): void
{
if (is_subclass_of($class, FunctionExistenceProviderInterface::class, true)) {
$callable = Closure::fromCallable([$class, 'doesFunctionExist']);
foreach ($class::getFunctionIds() as $function_id) {
$this->registerClosure($function_id, $callable);
}
}
}
/**
* @param lowercase-string $function_id
* @param Closure(FunctionExistenceProviderEvent): ?bool $c
*/
public function registerClosure(string $function_id, Closure $c): void
{
self::$handlers[$function_id][] = $c;
}
public function has(string $function_id): bool
{
return isset(self::$handlers[strtolower($function_id)]);
}
public function doesFunctionExist(
StatementsSource $statements_source,
string $function_id
): ?bool {
foreach (self::$handlers[strtolower($function_id)] ?? [] as $function_handler) {
$event = new FunctionExistenceProviderEvent(
$statements_source,
$function_id,
);
$function_exists = $function_handler($event);
if ($function_exists !== null) {
return $function_exists;
}
}
return null;
}
}
?>
Did this file decode correctly?
Original Code
<?php
namespace Psalm\Internal\Provider;
use Closure;
use Psalm\Plugin\EventHandler\Event\FunctionExistenceProviderEvent;
use Psalm\Plugin\EventHandler\FunctionExistenceProviderInterface;
use Psalm\StatementsSource;
use function is_subclass_of;
use function strtolower;
/**
* @internal
*/
final class FunctionExistenceProvider
{
/**
* @var array<
* lowercase-string,
* array<Closure(FunctionExistenceProviderEvent): ?bool>
* >
*/
private static array $handlers = [];
public function __construct()
{
self::$handlers = [];
}
/**
* @param class-string $class
*/
public function registerClass(string $class): void
{
if (is_subclass_of($class, FunctionExistenceProviderInterface::class, true)) {
$callable = Closure::fromCallable([$class, 'doesFunctionExist']);
foreach ($class::getFunctionIds() as $function_id) {
$this->registerClosure($function_id, $callable);
}
}
}
/**
* @param lowercase-string $function_id
* @param Closure(FunctionExistenceProviderEvent): ?bool $c
*/
public function registerClosure(string $function_id, Closure $c): void
{
self::$handlers[$function_id][] = $c;
}
public function has(string $function_id): bool
{
return isset(self::$handlers[strtolower($function_id)]);
}
public function doesFunctionExist(
StatementsSource $statements_source,
string $function_id
): ?bool {
foreach (self::$handlers[strtolower($function_id)] ?? [] as $function_handler) {
$event = new FunctionExistenceProviderEvent(
$statements_source,
$function_id,
);
$function_exists = $function_handler($event);
if ($function_exists !== null) {
return $function_exists;
}
}
return null;
}
}
Function Calls
None |
Stats
MD5 | 4fbda07bce1eca3c68fe66789473d4f5 |
Eval Count | 0 |
Decode Time | 138 ms |