1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00
This commit is contained in:
Daniil Gentili 2024-01-17 13:29:08 +01:00
parent 0504394e8b
commit 4e5e30633b
69 changed files with 136 additions and 0 deletions

View File

@ -14,6 +14,7 @@ use Psalm\Issue\DuplicateParam;
use Psalm\Issue\PossiblyUndefinedVariable;
use Psalm\Issue\UndefinedVariable;
use Psalm\IssueBuffer;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type;
use Psalm\Type\Atomic\TNamedObject;
use Psalm\Type\Union;
@ -30,6 +31,7 @@ use function strtolower;
*/
final class ClosureAnalyzer extends FunctionLikeAnalyzer
{
use UnserializeMemoryUsageSuppressionTrait;
/**
* @param PhpParser\Node\Expr\Closure|PhpParser\Node\Expr\ArrowFunction $function
*/

View File

@ -7,6 +7,7 @@ namespace Psalm\Internal\Analyzer;
use PhpParser;
use Psalm\Config;
use Psalm\Context;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use UnexpectedValueException;
use function is_string;
@ -18,6 +19,7 @@ use function strtolower;
*/
final class FunctionAnalyzer extends FunctionLikeAnalyzer
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(PhpParser\Node\Stmt\Function_ $function, SourceAnalyzer $source)
{
$codebase = $source->getCodebase();

View File

@ -20,6 +20,7 @@ use Psalm\IssueBuffer;
use Psalm\StatementsSource;
use Psalm\Storage\ClassLikeStorage;
use Psalm\Storage\MethodStorage;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use UnexpectedValueException;
use function in_array;
@ -31,6 +32,7 @@ use function strtolower;
*/
final class MethodAnalyzer extends FunctionLikeAnalyzer
{
use UnserializeMemoryUsageSuppressionTrait;
// https://github.com/php/php-src/blob/a83923044c48982c80804ae1b45e761c271966d3/Zend/zend_enum.c#L77-L95
private const FORBIDDEN_ENUM_METHODS = [
'__construct',

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class Any extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return $this;

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class ArrayKeyDoesNotExist extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new ArrayKeyExists();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class ArrayKeyExists extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new ArrayKeyDoesNotExist();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class DoesNotHaveAtLeastCount extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param positive-int $count */
public function __construct(public readonly int $count)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class DoesNotHaveExactCount extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param positive-int $count */
public function __construct(public readonly int $count)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class DoesNotHaveMethod extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly string $method)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class Empty_ extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new NonEmpty();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class Falsy extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new Truthy();

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use UnexpectedValueException;
/**
@ -12,6 +13,7 @@ use UnexpectedValueException;
*/
final class HasArrayKey extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly string $key)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class HasAtLeastCount extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param positive-int $count */
public function __construct(public readonly int $count)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class HasExactCount extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param positive-int $count */
public function __construct(public readonly int $count)
{

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use UnexpectedValueException;
/**
@ -12,6 +13,7 @@ use UnexpectedValueException;
*/
final class HasIntOrStringArrayAccess extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
throw new UnexpectedValueException('This should never be called');

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class HasMethod extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly string $method)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use UnexpectedValueException;
/**
@ -12,6 +13,7 @@ use UnexpectedValueException;
*/
final class HasStringArrayAccess extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
throw new UnexpectedValueException('This should never be called');

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Union;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Union;
*/
final class InArray extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Union $type)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsAClass extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param Atomic\TTemplateParamClass|Atomic\TNamedObject $type */
public function __construct(public readonly Atomic $type, public readonly bool $allow_string)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsClassEqual extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly string $type)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsClassNotEqual extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly string $type)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsCountable extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new IsNotCountable(true);

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsEqualIsset extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new Any();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsGreaterThan extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly int $value)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsGreaterThanOrEqualTo extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly int $value)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsIdentical extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsIsset extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new IsNotIsset();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsLessThan extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly int $value)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsLessThanOrEqualTo extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly int $value)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsLooselyEqual extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsNotAClass extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param Atomic\TTemplateParamClass|Atomic\TNamedObject $type */
public function __construct(public readonly Atomic $type, public readonly bool $allow_string)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsNotCountable extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly bool $is_negatable)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsNotIdentical extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class IsNotIsset extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new IsIsset();

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsNotLooselyEqual extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsNotType extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Atomic;
*/
final class IsType extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly Atomic $type)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use function json_encode;
@ -15,6 +16,7 @@ use const JSON_THROW_ON_ERROR;
*/
final class NestedAssertions extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param array<string, list<list<Assertion>>> $assertions */
public function __construct(public readonly array $assertions)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class NonEmpty extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new Empty_();

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class NonEmptyCountable extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public readonly bool $is_negatable)
{
}

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Union;
/**
@ -12,6 +13,7 @@ use Psalm\Type\Union;
*/
final class NotInArray extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public readonly Union $type,
) {

View File

@ -5,6 +5,7 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use function json_encode;
@ -15,6 +16,7 @@ use const JSON_THROW_ON_ERROR;
*/
final class NotNestedAssertions extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
/** @param array<string, list<list<Assertion>>> $assertions */
public function __construct(public readonly array $assertions)
{

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class NotNonEmptyCountable extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new NonEmptyCountable(true);

View File

@ -5,12 +5,14 @@ declare(strict_types=1);
namespace Psalm\Storage\Assertion;
use Psalm\Storage\Assertion;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
/**
* @psalm-immutable
*/
final class Truthy extends Assertion
{
use UnserializeMemoryUsageSuppressionTrait;
public function getNegation(): Assertion
{
return new Falsy();

View File

@ -6,6 +6,7 @@ namespace Psalm\Storage;
final class FunctionStorage extends FunctionLikeStorage
{
use UnserializeMemoryUsageSuppressionTrait;
/** @var array<string, bool> */
public array $byref_uses = [];
}

View File

@ -8,6 +8,7 @@ use Psalm\Type\Union;
final class MethodStorage extends FunctionLikeStorage
{
use UnserializeMemoryUsageSuppressionTrait;
public bool $is_static = false;
public int $visibility = 0;

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -11,6 +12,7 @@ use Psalm\Type\Atomic;
*/
abstract class Scalar extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function canBeFullyExpressedInPhp(int $analysis_php_version_id): bool
{
return true;

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Analyzer\StatementsAnalyzer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -19,6 +20,7 @@ use function count;
*/
class TArray extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
/**
* @use GenericTrait<array{Union, Union}>
*/

View File

@ -8,6 +8,7 @@ use Psalm\Codebase;
use Psalm\Internal\Analyzer\StatementsAnalyzer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\FunctionLikeParameter;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -18,6 +19,7 @@ use Psalm\Type\Union;
*/
final class TCallable extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
use CallableTrait;
public string $value;

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type;
use Psalm\Type\Atomic;
@ -14,6 +15,7 @@ use Psalm\Type\Atomic;
*/
final class TClassConstant extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $fq_classlike_name,
public string $const_name,

View File

@ -9,6 +9,7 @@ use Psalm\Internal\Analyzer\StatementsAnalyzer;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Internal\Type\TemplateStandinTypeReplacer;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -21,6 +22,7 @@ use Psalm\Type\Union;
*/
final class TClassStringMap extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
/**
* Constructs a new instance of a list
*/

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
final class TClosedResource extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'closed-resource';

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -17,6 +18,7 @@ use Psalm\Type\Union;
*/
final class TConditional extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $param_name,
public string $defining_class,

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Analyzer\StatementsAnalyzer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -22,6 +23,7 @@ use function substr;
*/
final class TIterable extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
use HasIntersectionTrait;
/**
* @use GenericTrait<array{Union, Union}>

View File

@ -10,6 +10,7 @@ use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Internal\Type\TemplateStandinTypeReplacer;
use Psalm\Internal\Type\TypeCombiner;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -32,6 +33,7 @@ use function str_replace;
*/
class TKeyedArray extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
/**
* If the shape has fallback params then they are here
*

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
class TMixed extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public bool $from_loop_isset = false, bool $from_docblock = false)
{
parent::__construct($from_docblock);

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -14,6 +15,7 @@ use Psalm\Type\Atomic;
*/
final class TNever extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'never';

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
final class TNull extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'null';

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
class TObject extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'object';

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -15,6 +16,7 @@ use Psalm\Type\Atomic;
*/
final class TPropertiesOf extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
// These should match the values of
// `Psalm\Internal\Analyzer\ClassLikeAnalyzer::VISIBILITY_*`, as they are
// used to compared against properties visibililty.

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
final class TResource extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'resource';

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -11,6 +12,7 @@ use Psalm\Type\Atomic;
*/
final class TTemplateIndexedAccess extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $array_param_name,
public string $offset_param_name,

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -17,6 +18,7 @@ use Psalm\Type\Union;
*/
final class TTemplateKeyOf extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $param_name,
public string $defining_class,

View File

@ -6,6 +6,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -19,6 +20,7 @@ use function implode;
*/
final class TTemplateParam extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
use HasIntersectionTrait;
/**

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -17,6 +18,7 @@ use Psalm\Type\Union;
*/
final class TTemplatePropertiesOf extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
/**
* @param TPropertiesOf::VISIBILITY_*|null $visibility_filter
*/

View File

@ -7,6 +7,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Internal\Type\TemplateResult;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -17,6 +18,7 @@ use Psalm\Type\Union;
*/
final class TTemplateValueOf extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $param_name,
public string $defining_class,

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -11,6 +12,7 @@ use Psalm\Type\Atomic;
*/
final class TTypeAlias extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(
public string $declaring_fq_classlike_name,
public string $alias_name,

View File

@ -6,6 +6,7 @@ namespace Psalm\Type\Atomic;
use Psalm\Codebase;
use Psalm\Storage\EnumCaseStorage;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
use Psalm\Type\Union;
@ -20,6 +21,7 @@ use function assert;
*/
final class TValueOf extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function __construct(public Union $type, bool $from_docblock = false)
{
parent::__construct($from_docblock);

View File

@ -4,6 +4,7 @@ declare(strict_types=1);
namespace Psalm\Type\Atomic;
use Psalm\Storage\UnserializeMemoryUsageSuppressionTrait;
use Psalm\Type\Atomic;
/**
@ -13,6 +14,7 @@ use Psalm\Type\Atomic;
*/
final class TVoid extends Atomic
{
use UnserializeMemoryUsageSuppressionTrait;
public function getKey(bool $include_extra = true): string
{
return 'void';