1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00

improve Atomic Types documentation (#4735)

* improve Atomic Types documentation

* add doc

* add doc
This commit is contained in:
orklah 2020-11-30 03:41:36 +01:00 committed by GitHub
parent 5222cadfb3
commit b60c42adca
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
62 changed files with 234 additions and 15 deletions

View File

@ -17,7 +17,7 @@ new Union([new TString(), new TInt()]); // equivalent to string|int in docblock
Primitive types like floats, integers and strings, plus arrays, and classes. You can find all of these in [`src/Psalm/Types/Atomic`](https://github.com/vimeo/psalm/tree/master/src/Psalm/Type/Atomic).
Note that all non-abstract classes in this folder are valid types. Most (with the exception of `Fn`, `TKeyedArray`, `GetClassT` and `GetTypeT`) are prefixed 'T'.
Note that all non-abstract classes in this folder are valid types. They are all prefixed by 'T'.
The classes are as follows:
@ -41,16 +41,40 @@ The classes are as follows:
`TResource` - denotes the `resource` type (e.g. a file handle).
`TClosedResource` - denotes the `resource` type that has been closed (e.g. a file handle through `fclose()`).
`TAssertionFalsy` - Represents any value reduced to false when computed in boolean context. This is used for assertions
`TConditional` - Internal representation of a conditional return type in phpdoc. For example ($param1 is int ? int : string)
`TIntMask` - Represents the type that is the result of a bitmask combination of its parameters. `int-mask<1, 2, 4>` corresponds to `1|2|3|4|5|6|7`
`TIntMaskOf` - as above, but used with with a reference to constants in code`int-mask<MyClass::CLASS_CONSTANT_*>` will corresponds to `1|2|3|4|5|6|7` if there are three constant 1, 2 and 4
`TKeyOfClassConstant` - Represents an offset of a class constant array.
`TValueOfClassConstant` - Represents a value of a class constant array.
`TTemplateIndexedAccess` - To be documented
`TTemplateKeyOf` - Represents the type used when using TKeyOfClassConstant when the type of the class constant array is a template
`TTypeAlias` - To be documented
### Scalar supertype
`TScalar` - denotes the `scalar` super type (which can also result from an `is_scalar` check). This type encompasses `float`, `int`, `bool` and `string`.
`TEmptyScalar` - denotes a `scalar` type that is also empty.
`TNonEmptyScalar` - denotes a `scalar` type that is also non-empty.
### Numeric supertype
`TNumeric` - denotes the `numeric` type (which can also result from an `is_numeric` check).
`TEmptyNumeric` - denotes the `numeric` type that's also empty (which can also result from an `is_numeric` and `empty` check).
### Scalar types
All scalar types have literal versions e.g. `int` vs `int(5)`.
@ -59,13 +83,15 @@ All scalar types have literal versions e.g. `int` vs `int(5)`.
`TInt` - denotes the `int` type, where the exact value is unknown.
`TLiteralInt` is used to represent an integer value where the exact numeric value is known.
`TLiteralInt` - is used to represent an integer value where the exact numeric value is known.
`TPositiveInt` - denotes an int that is also positive (strictly > 0)
#### Floats
`TFloat` - denotes the `float` type, where the exact value is unknown.
`TLiteralFloat` is used to represent a floating point value where the exact numeric value is known.
`TLiteralFloat` - is used to represent a floating point value where the exact numeric value is known.
#### Bools
@ -95,18 +121,34 @@ if (true === $first) {
`TString` - denotes the `string` type, where the exact value is unknown.
`TNonEmptyString` - denotes a string, that is also non-empty
`TNumericString` - denotes a string that's also a numeric value e.g. `"5"`. It can result from `is_string($s) && is_numeric($s)`.
`TLiteralString` is used to represent a string whose value is known.
`TLiteralString` - is used to represent a string whose value is known.
`TClassString` - denotes the `class-string` type, used to describe a string representing a valid PHP class. The parent type from which the classes descend may or may not be specified in the constructor.
`TLiteralClassString` - denotes a specific class string, generated by expressions like `A::class`.
`TTraitString` - denotes the `trait-string` type, used to describe a string representing a valid PHP trait.
`TDependentGetClass` - Represents a string whose value is a fully-qualified class found by get_class($var)
`TDependentGetDebugType` - Represents a string whose value is that of a type found by get_debug_type($var)
`TDependentGetType` - Represents a string whose value is that of a type found by gettype($var)
`TCallableString` - denotes the `callable-string` type, used to represent an unknown string that is also `callable`.
`THtmlEscapedString`, `TSqlSelectString` - these are special types, specifically for consumption by plugins.
`TLowercaseString` - denotes a string where every character is lowercased. (which can also result from a `strtolower` call).
`TNonEmptyLowercaseString` - denotes a non-empty-string where every character is lowercased. (which can also result from a `strtolower` call).
`TSingleLetter` - denotes a string that has a length of 1
#### Scalar class constants
`TScalarClassConstant` - denotes a class constant whose value might not yet be known.
@ -119,6 +161,8 @@ if (true === $first) {
`TArray` - denotes a simple array of the form `array<TKey, TValue>`. It expects an array with two elements, both union types.
`TList` - Represents an array that has some particularities: its keys are integers, they start at 0, they are consecutive and go upwards (no negative int)
`TNonEmptyArray` - as above, but denotes an array known to be non-empty.
`TKeyedArray` represents an 'object-like array' - an array with known keys.
@ -137,14 +181,18 @@ foreach (range(1,1) as $_) $a[(string)rand(0,1)] = rand(0,1); // array<string,in
`TCallableArray` - denotes an array that is _also_ `callable`.
`TCallableList` - denotes a list that is _also_ `callable`.
`TCallableKeyedArray` - denotes an object-like array that is _also_ `callable`.
`TClassStringMap` - Represents an array where the type of each value is a function of its string key value
### Callables & closures
`TCallable` - denotes the `callable` type. Can result from an `is_callable` check.
`Fn` - denotes a `Closure` type.
`TClosure` - denotes a `Closure` type.
`TCallable` and `Fn` can optionally be defined with parameters and return types, too
`TCallable` and `TClosure` can optionally be defined with parameters and return types, too
### Object supertypes
@ -160,6 +208,8 @@ foreach (range(1,1) as $_) $a[(string)rand(0,1)] = rand(0,1); // array<string,in
`TCallableObject` - denotes an object that is also `callable` (i.e. it has `__invoke` defined).
`TAnonymousClassInstance` - Denotes an anonymous class (i.e. `new class{}`) with potential methods
### Template
`TTemplateParam` - denotes a template parameter that has been previously specified in a `@template` tag.

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes an anonymous class (i.e. `new class{}`) with potential methods
*/
class TAnonymousClassInstance extends TNamedObject
{
public function toPhpString(

View File

@ -6,7 +6,7 @@ use function get_class;
use Psalm\Type\Atomic;
/**
* Represents an array with generic type parameters.
* Denotes a simple array of the form `array<TKey, TValue>`. It expects an array with two elements, both union types.
*/
class TArray extends \Psalm\Type\Atomic
{

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `array-key` type, used for something that could be the offset of an `array`.
*/
class TArrayKey extends Scalar
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Represents any value reduced to false when computed in boolean context. This is used for assertions
*/
class TAssertionFalsy extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `bool` type where the exact value is unknown.
*/
class TBool extends Scalar
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `callable` type. Can result from an `is_callable` check.
*/
class TCallable extends \Psalm\Type\Atomic
{
use CallableTrait;

View File

@ -2,7 +2,7 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Denotes an array that is _also_ `callable`.
*/
class TCallableArray extends TNonEmptyArray
{

View File

@ -2,7 +2,7 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Denotes an object-like array that is _also_ `callable`.
*/
class TCallableKeyedArray extends TKeyedArray
{

View File

@ -2,7 +2,7 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Denotes a list that is _also_ `callable`.
*/
class TCallableList extends TNonEmptyList
{

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes an object that is also `callable` (i.e. it has `__invoke` defined).
*/
class TCallableObject extends TObject
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `callable-string` type, used to represent an unknown string that is also `callable`.
*/
class TCallableString extends TString
{

View File

@ -12,6 +12,10 @@ use function stripos;
use function strpos;
use function strtolower;
/**
* Denotes the `class-string` type, used to describe a string representing a valid PHP class.
* The parent type from which the classes descend may or may not be specified in the constructor.
*/
class TClassString extends TString
{
/**

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `resource` type that has been closed (e.g. a file handle through `fclose()`).
*/
class TClosedResource extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -6,6 +6,9 @@ use Psalm\Internal\Type\TemplateResult;
use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use Psalm\Type\Union;
/**
* Internal representation of a conditional return type in phpdoc. For example ($param1 is int ? int : string)
*/
class TConditional extends \Psalm\Type\Atomic
{
/**

View File

@ -1,6 +1,10 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `empty` type, used to describe a type corresponding to no value whatsoever.
* Empty arrays `[]` have the type `array<empty, empty>`.
*/
class TEmpty extends Scalar
{
public function __toString(): string

View File

@ -1,6 +1,10 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `mixed` type, but empty.
* Generated for `$x` inside the `if` statement `if (!$x) {...}` when `$x` is `mixed` outside.
*/
class TEmptyMixed extends TMixed
{
public function getId(bool $nested = false): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `numeric` type that's also empty (which can also result from an `is_numeric` and `empty` check).
*/
class TEmptyNumeric extends TNumeric
{
public function getId(bool $nested = false): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a `scalar` type that is also empty.
*/
class TEmptyScalar extends TScalar
{
public function getId(bool $nested = false): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `false` value type
*/
class TFalse extends TBool
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `float` type, where the exact value is unknown.
*/
class TFloat extends Scalar
{
public function __toString(): string

View File

@ -7,6 +7,9 @@ use Psalm\Type\Atomic;
use function substr;
use function array_merge;
/**
* Denotes an object type that has generic parameters e.g. `ArrayObject<string, Foo\Bar>`
*/
class TGenericObject extends TNamedObject
{
use GenericTrait;

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Special type, specifically for consumption by plugins.
*/
class THtmlEscapedString extends TString
{
public function getKey(bool $include_extra = true): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `int` type, where the exact value is unknown.
*/
class TInt extends Scalar
{
public function __toString(): string

View File

@ -3,6 +3,10 @@ namespace Psalm\Type\Atomic;
use function substr;
/**
* Represents the type that is the result of a bitmask combination of its parameters.
* `int-mask<1, 2, 4>` corresponds to `1|2|3|4|5|6|7`
*/
class TIntMask extends TInt
{
/** @var non-empty-array<TLiteralInt|TScalarClassConstant> */

View File

@ -1,6 +1,11 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Represents the type that is the result of a bitmask combination of its parameters.
* This is the same concept as TIntMask but TIntMaskOf is used with with a reference to constants in code
* `int-mask<MyClass::CLASS_CONSTANT_*>` will corresponds to `1|2|3|4|5|6|7` if there are three constant 1, 2 and 4
*/
class TIntMaskOf extends TInt
{
/** @var TScalarClassConstant|TKeyOfClassConstant|TValueOfClassConstant */

View File

@ -7,6 +7,9 @@ use Psalm\Type\Atomic;
use function substr;
use function array_merge;
/**
* denotes the `iterable` type(which can also result from an `is_iterable` check).
*/
class TIterable extends Atomic
{
use HasIntersectionTrait;

View File

@ -7,6 +7,9 @@ use function stripos;
use function strpos;
use function strtolower;
/**
* Represents an offset of a class constant array.
*/
class TKeyOfClassConstant extends Scalar
{
/** @var string */

View File

@ -19,7 +19,7 @@ use Psalm\Type\Atomic;
use Psalm\Type\Union;
/**
* Represents an array where we know its key values
* Represents an 'object-like array' - an array with known keys.
*/
class TKeyedArray extends \Psalm\Type\Atomic
{

View File

@ -12,7 +12,10 @@ use Psalm\Type\Atomic;
use Psalm\Type\Union;
/**
* Represents an array where we know its key values
* Represents an array that has some particularities:
* - its keys are integers
* - they start at 0
* - they are consecutive and go upwards (no negative int)
*/
class TList extends \Psalm\Type\Atomic
{

View File

@ -7,6 +7,9 @@ use function stripos;
use function strpos;
use function strtolower;
/**
* Denotes a specific class string, generated by expressions like `A::class`.
*/
class TLiteralClassString extends TLiteralString
{
/**

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a floating point value where the exact numeric value is known.
*/
class TLiteralFloat extends TFloat
{
/** @var float */

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes an integer value where the exact numeric value is known.
*/
class TLiteralInt extends TInt
{
/** @var int */

View File

@ -5,6 +5,9 @@ use function preg_replace;
use function strlen;
use function substr;
/**
* Denotes a string whose value is known.
*/
class TLiteralString extends TString
{
/** @var string */

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `mixed` type, used when you dont know the type of an expression.
*/
class TMixed extends \Psalm\Type\Atomic
{
/** @var bool */

View File

@ -9,6 +9,9 @@ use Psalm\Type\Atomic;
use function substr;
use function array_map;
/**
* Denotes an object type where the type of the object is known e.g. `Exception`, `Throwable`, `Foo\Bar`
*/
class TNamedObject extends Atomic
{
use HasIntersectionTrait;

View File

@ -1,6 +1,10 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `no-return`/`never-return` type for functions that never return, either throwing an exception or
* terminating (like the builtin `exit()`).
*/
class TNever extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -2,7 +2,8 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Denotes array known to be non-empty of the form `non-empty-array<TKey, TValue>`.
* It expects an array with two elements, both union types.
*/
class TNonEmptyArray extends TArray
{

View File

@ -2,7 +2,7 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Represents a non-empty list
*/
class TNonEmptyList extends TList
{

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a non-empty-string where every character is lowercased. (which can also result from a `strtolower` call).
*/
class TNonEmptyLowercaseString extends TNonEmptyString
{
public function getKey(bool $include_extra = true): string

View File

@ -1,6 +1,10 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `mixed` type, but not empty.
* Generated for `$x` inside the `if` statement `if ($x) {...}` when `$x` is `mixed` outside.
*/
class TNonEmptyMixed extends TMixed
{
public function getId(bool $nested = false): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a `scalar` type that is also non-empty.
*/
class TNonEmptyScalar extends TScalar
{
public function getId(bool $nested = false): string

View File

@ -2,7 +2,7 @@
namespace Psalm\Type\Atomic;
/**
* Represents a non-empty array
* Denotes a string, that is also non-empty
*/
class TNonEmptyString extends TString
{

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `null` type
*/
class TNull extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `numeric` type (which can also result from an `is_numeric` check).
*/
class TNumeric extends Scalar
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a string that's also a numeric value e.g. `"5"`. It can result from `is_string($s) && is_numeric($s)`.
*/
class TNumericString extends TString
{
public function getKey(bool $include_extra = true): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `object` type
*/
class TObject extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -15,6 +15,9 @@ use Psalm\Internal\Type\TemplateInferredTypeReplacer;
use function array_merge;
use function array_values;
/**
* Denotes an object with specified member variables e.g. `object{foo:int, bar:string}`.
*/
class TObjectWithProperties extends TObject
{
use HasIntersectionTrait;

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes an int that is also positive (strictly > 0)
*/
class TPositiveInt extends TInt
{
public function getId(bool $nested = false): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `resource` type (e.g. a file handle).
*/
class TResource extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -1,6 +1,10 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `scalar` super type (which can also result from an `is_scalar` check).
* This type encompasses `float`, `int`, `bool` and `string`.
*/
class TScalar extends Scalar
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a class constant whose value might not yet be known.
*/
class TScalarClassConstant extends Scalar
{
/** @var string */

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a string that has a length of 1
*/
class TSingleLetter extends TString
{
}

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `string` type, where the exact value is unknown.
*/
class TString extends Scalar
{
/**

View File

@ -3,6 +3,9 @@ namespace Psalm\Type\Atomic;
use Psalm\Type\Union;
/**
* Represents the type used when using TKeyOfClassConstant when the type of the class constant array is a template
*/
class TTemplateKeyOf extends TArrayKey
{
/**

View File

@ -7,6 +7,9 @@ use Psalm\Internal\Type\TemplateResult;
use Psalm\Type\Union;
use function array_map;
/**
* denotes a template parameter that has been previously specified in a `@template` tag.
*/
class TTemplateParam extends \Psalm\Type\Atomic
{
use HasIntersectionTrait;

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes a `class-string` corresponding to a template parameter previously specified in a `@template` tag.
*/
class TTemplateParamClass extends TClassString
{
/**

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `trait-string` type, used to describe a string representing a valid PHP trait.
*/
class TTraitString extends TString
{
public function getKey(bool $include_extra = true): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `true` value type
*/
class TTrue extends TBool
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Represents a value of a class constant array.
*/
class TValueOfClassConstant extends \Psalm\Type\Atomic
{
/** @var string */

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Type\Atomic;
/**
* Denotes the `void` type, normally just used to annotate a function/method that returns nothing
*/
class TVoid extends \Psalm\Type\Atomic
{
public function __toString(): string

View File

@ -1,6 +1,9 @@
<?php
namespace Psalm\Test\Config\Plugin\Hook\StringProvider;
/**
* Special type, specifically for consumption by plugins.
*/
class TSqlSelectString extends \Psalm\Type\Atomic\TLiteralString
{
public function getKey(bool $include_extra = true) : string