scrumworks/property-reader
最新稳定版本:v0.9
Composer 安装命令:
composer require scrumworks/property-reader
包简介
Property reader which can work with typed properties and phpdoc
关键字:
README 文档
README
Installation
composer require scrumworks/property-reader
Documentation
Class property can be translated to these variants:
null
null is returned for properties without any information.
It's generally mixed type, but it's acting differently f.e. in array types.
public $var;
MixedVariableType
It's returned for variables with mixed directly information.
/** * @var mixed */ public $var;
ScalarVariableType
Supports this basic scalar types:
int,integerfloatbool,booleanstring
/** * @var integer */ public int $var;
ArrayVariableType
Arrays are considered to be seqential array or hashmap.
Arrays are translated in this way: (we use definition array<key, type>)
- generic
arrayhas typearray<null, null> - seqential
int[]has typearray<null, int> - hashmap
array<string, string>has typearray<string, string>
In general - null in key is proposing seqential array, other types (only integer and string are supported) are
propose hashmap. Only difference is key == value == null, then it's
generic array.
Warning - mixed[] has different type than array
We also support nested arrays like int[][] or array<string, string>[]
/** * @var int[] */ public array $var;
ClassVariableType
/** * @var SomeClass */ public SomeClass $var;
UnionVariableType
/** * @var int|string */ public $var;
Nullablity of types
Every type can by set to be nullable in this ways:
?intint|null
Types null and MixedVariableType are nullable by default.
Warning - ?int|string isn't (?int)|string but int|string|null
Example usage
<?php use ScrumWorks\PropertyReader\PropertyTypeReader; use ScrumWorks\PropertyReader\VariableTypeWriter; use ScrumWorks\PropertyReader\VariableTypeUnifyService; class Example { public $untyped; public int $integer; /** * @var ?string */ public $nullableString; /** * @var array<string, string[]> */ public array $hashmap; public VariableTypeWriter $class; /** * @var int|int[]|null */ public $union; } $reflection = new ReflectionClass(Example::class); $variableTypeUnifyService = new VariableTypeUnifyService(); $propertyTypeReader = new PropertyTypeReader($variableTypeUnifyService); $variableTypeWriter = new VariableTypeWriter(); foreach ($reflection->getProperties() as $propertyReflection) { $variableType = $propertyTypeReader->readUnifiedVariableType($propertyReflection); printf( "%s: %s\n", $propertyReflection->getName(), $variableTypeWriter->variableTypeToString($variableType) ); }
will result to
untyped: mixed integer: int nullableString: ?string hashmap: array<string, string[]> class: ScrumWorks\PropertyReader\VariableTypeWriter union: ?int|int[]
VariableType API
use ScrumWorks\PropertyReader\VariableType\ArrayVariableType; use ScrumWorks\PropertyReader\VariableType\ScalarVariableType; // load object... /** @var ArrayVariableType $hashmapType */ $hashmapType = $propertyTypeReader->readUnifiedVariableType($reflection->getProperty('hashmap')); assert($hashmapType->isNullable() === false); assert($hashmapType->getKeyType() instanceof ScalarVariableType); assert($hashmapType->getKeyType()->getType() === ScalarVariableType::TYPE_STRING);
Testing
You can run the tests with:
composer run-script test
Contribution Guide
Feel free to open an Issue or add a Pull request.
Credits
People:
统计信息
- 总下载量: 354.94k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-11-09