Helpers for different operations with PHP data types, variables and containers.
composer require smoren/type-tools
Method | Description | Code Snippet |
---|---|---|
getString |
Returns unique string of the given variable | UniqueExtractor::getString($var, $strict) |
getHash |
Returns unique md5 hash string of the given variable | UniqueExtractor::getHash($var, $strict) |
Method | Description | Code Snippet |
---|---|---|
cast |
Cast object to another relative type | ObjectTypeCaster::cast($sourceObject, $destinationClass) |
Method | Description | Code Snippet |
---|---|---|
getPropertyValue |
Returns value of the object property | ObjectAccess::getPropertyValue($object, $propertyName) |
setPropertyValue |
Sets value of the object property | ObjectAccess::setPropertyValue($object, $propertyName, $value) |
hasReadableProperty |
Returns true if object has readable property by name or by getter | ObjectAccess::hasReadableProperty($object, $propertyName) |
hasWritableProperty |
Returns true if object has writable property by name or by getter | ObjectAccess::hasWritableProperty($object, $propertyName) |
hasPublicProperty |
Returns true if object has public property | ObjectAccess::hasPublicProperty($object, $propertyName) |
hasPublicMethod |
Returns true if object has public method | ObjectAccess::hasPublicMethod($object, $methodName) |
hasProperty |
Returns true if object has property | ObjectAccess::hasProperty($object, $propertyName) |
hasMethod |
Returns true if object has method | ObjectAccess::hasMethod($object, $methodName) |
Method | Description | Code Snippet |
---|---|---|
get |
Returns value from the container by key | MapAccess::get($container, $key, $defaultValue) |
set |
Sets value to the container by key | MapAccess::set($container, $key, $value) |
exists |
Returns true if accessible key exists in the container | MapAccess::exists($container, $key) |
Tool for extracting unique IDs and hashes of any PHP variables and data structures.
Works in two modes: strict and non-strict.
In strict mode:
In non-strict mode:
Returns unique string of the given variable.
UniqueExtractor::getString(mixed $var, bool $strict): string
use SmorenTypeToolsUniqueExtractor;
$intValue = 5;
$floatValue = 5.0;
$intValueStrictUniqueId = UniqueExtractor::getString($intValue, true);
$floatValueStrictUniqueId = UniqueExtractor::getString($floatValue, true);
var_dump($intValueStrictUniqueId === $floatValueStrictUniqueId);
// false
$intValueNonStrictUniqueId = UniqueExtractor::getString($intValue, false);
$floatValueNonStrictUniqueId = UniqueExtractor::getString($floatValue, false);
var_dump($intValueNonStrictUniqueId === $floatValueNonStrictUniqueId);
// true
Returns unique md5 hash string of the given variable.
UniqueExtractor::getHash(mixed $var, bool $strict): string
use SmorenTypeToolsUniqueExtractor;
$intValue = 5;
$floatValue = 5.0;
$intValueStrictHash = UniqueExtractor::getHash($intValue, true);
$floatValueStrictHash = UniqueExtractor::getHash($floatValue, true);
var_dump($intValueStrictHash === $floatValueStrictHash);
// false
$intValueNonStrictHash = UniqueExtractor::getHash($intValue, false);
$floatValueNonStrictHash = UniqueExtractor::getHash($floatValue, false);
var_dump($intValueNonStrictHash === $floatValueNonStrictHash);
// true
Tool for casting types of objects.
Cast object to another relative type (upcast or downcast).
ObjectTypeCaster::cast(object $sourceObject, string $destinationClass): mixed
use SmorenTypeToolsObjectTypeCaster;
class ParentClass
{
public int $a;
protected int $b;
public function __construct(int $a, int $b)
{
$this->a = $a;
$this->b = $b;
}
public function toArray(): array
{
return [$this->a, $this->b];
}
}
class ChildClass extends ParentClass
{
private $c = null;
public function __construct(int $a, int $b, int $c)
{
parent::__construct($a, $b);
$this->c = $c;
}
public function toArray(): array
{
return [$this->a, $this->b, $this->c];
}
}
/* Downcast */
$parentClassObject = new ParentClass(1, 2);
print_r($parentClassObject->toArray());
// [1, 2]
$castedToChildClass = ObjectTypeCaster::cast($parentClassObject, ChildClass::class);
print_r($castedToChildClass->toArray());
// [1, 2, null]
var_dump(get_class($castedToChildClass));
// ChildClass
/* Upcast */
$childClassObject = new ChildClass(1, 2, 3);
print_r($childClassObject->toArray());
// [1, 2, 3]
$castedToParentClass = ObjectTypeCaster::cast($childClassObject, ParentClass::class);
print_r($castedToParentClass->toArray());
// [1, 2]
var_dump(get_class($castedToParentClass));
// ParentClass
Tool for reflecting and accessing object properties and methods.
Returns value of the object property.
ObjectAccess::getPropertyValue(object $object, string $propertyName): mixed
Can access property by its name or by getter.
Throws SmorenTypeToolsExceptionsKeyError
if property is not accessible to read.
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
public function getPrivateProperty(): int
{
return $this->privateProperty;
}
}
$myObject = new MyClass();
// Getting by name:
var_dump(ObjectAccess::getPropertyValue($myObject, 'publicProperty'));
// 1
// Getting by getter (getPrivateProperty()):
var_dump(ObjectAccess::getPropertyValue($myObject, 'privateProperty'));
// 2
Sets value of the object property.
ObjectAccess::setPropertyValue(object $object, string $propertyName, mixed $value): void
Can access property by its name or by setter.
Throws SmorenTypeToolsExceptionsKeyError
if property is not accessible to write.
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
public function setPrivateProperty(int $value): void
{
$this->privateProperty = $value;
}
public function toArray(): array
{
return [$this->publicProperty, $this->privateProperty];
}
}
$myObject = new MyClass();
// Setting by name:
ObjectAccess::setPropertyValue($myObject, 'publicProperty', 11);
// Setting by setter (setPrivateProperty()):
ObjectAccess::getPropertyValue($myObject, 'privateProperty', 22);
print_r($myObject->toArray());
// [11, 22]
Returns true if object has property that is readable by name or by getter.
ObjectAccess::hasReadableProperty(object $object, string $propertyName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
private int $notAccessibleProperty = 3;
public function getPrivateProperty(): int
{
return $this->privateProperty;
}
}
$myObject = new MyClass();
// Accessible by name:
var_dump(ObjectAccess::hasReadableProperty($myObject, 'publicProperty'));
// true
// Accessible by getter:
var_dump(ObjectAccess::hasReadableProperty($myObject, 'privateProperty'));
// true
// Not accessible:
var_dump(ObjectAccess::hasReadableProperty($myObject, 'notAccessibleProperty'));
// false
Returns true if object has property that is writable by name or by setter.
ObjectAccess::hasWritableProperty(object $object, string $propertyName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
private int $notAccessibleProperty = 3;
public function setPrivateProperty(int $value): void
{
$this->privateProperty = $value;
}
}
$myObject = new MyClass();
// Accessible by name:
var_dump(ObjectAccess::hasWritableProperty($myObject, 'publicProperty'));
// true
// Accessible by setter:
var_dump(ObjectAccess::hasWritableProperty($myObject, 'privateProperty'));
// true
// Not accessible:
var_dump(ObjectAccess::hasWritableProperty($myObject, 'notAccessibleProperty'));
// false
Returns true if object has public property.
ObjectAccess::hasPublicProperty(object $object, string $propertyName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
}
$myObject = new MyClass();
var_dump(ObjectAccess::hasPublicProperty($myObject, 'publicProperty'));
// true
var_dump(ObjectAccess::hasPublicProperty($myObject, 'privateProperty'));
// false
Returns true if object has public method.
ObjectAccess::hasPublicMethod(object $object, string $methodName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public function publicMethod(): int
{
return 1;
}
private function privateMethod(): int
{
return 2;
}
}
$myObject = new MyClass();
var_dump(ObjectAccess::hasPublicMethod($myObject, 'publicMethod'));
// true
var_dump(ObjectAccess::hasPublicMethod($myObject, 'privateMethod'));
// false
Returns true if object has property.
ObjectAccess::hasProperty(object $object, string $propertyName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
}
$myObject = new MyClass();
var_dump(ObjectAccess::hasProperty($myObject, 'publicProperty'));
// true
var_dump(ObjectAccess::hasProperty($myObject, 'privateProperty'));
// true
var_dump(ObjectAccess::hasProperty($myObject, 'anotherProperty'));
// false
Returns true if object has method.
ObjectAccess::hasMethod(object $object, string $methodName): bool
use SmorenTypeToolsObjectAccess;
class MyClass {
public function publicMethod(): int
{
return 1;
}
private function privateMethod(): int
{
return 2;
}
}
$myObject = new MyClass();
var_dump(ObjectAccess::hasMethod($myObject, 'publicMethod'));
// true
var_dump(ObjectAccess::hasMethod($myObject, 'privateMethod'));
// true
Tool for map-like accessing of different containers by string keys.
Can access:
Returns value from the container by key or default value if key does not exist or not accessible.
Throws SmorenTypeToolsExceptionsKeyError
if key is not accessible to read.
MapAccess::get(mixed $container, string $key, mixed $defaultValue = null): mixed
use SmorenTypeToolsMapAccess;
$array = [
'a' => 1,
];
var_dump(MapAccess::get($array, 'a', 0));
// 1
var_dump(MapAccess::get($array, 'b', 0));
// 0
var_dump(MapAccess::get($array, 'b'));
// null
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
private int $notAccessibleProperty = 3;
public function getPrivateProperty(): int
{
return $this->privateProperty;
}
}
$myObject = new MyClass();
// Accessible by name:
var_dump(MapAccess::get($myObject, 'publicProperty', 0));
// 1
// Accessible by getter:
var_dump(MapAccess::get($myObject, 'privateProperty'));
// 2
// Not accessible:
var_dump(MapAccess::get($myObject, 'notAccessibleProperty', -1));
// -1
var_dump(MapAccess::get($myObject, 'notAccessibleProperty'));
// null
// Nonexistent:
var_dump(MapAccess::get($myObject, 'nonexistentProperty', -1));
// -1
var_dump(MapAccess::get($myObject, 'nonexistentProperty'));
// null
Sets value to the container by key.
MapAccess::set(mixed $container, string $key, mixed $value): void
Throws SmorenTypeToolsExceptionsKeyError
if key is not accessible to write.
use SmorenTypeToolsMapAccess;
$array = [
'a' => 1,
];
MapAccess::set($array, 'a', 11);
MapAccess::set($array, 'b', 22);
print_r($array);
// ['a' => 11, 'b' => 22]
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
public function setPrivateProperty(int $value): void
{
$this->privateProperty = $value;
}
public function toArray(): array
{
return [$this->publicProperty, $this->privateProperty];
}
}
$myObject = new MyClass();
// Accessible by name:
MapAccess::get($myObject, 'publicProperty', 11);
// Accessible by getter:
MapAccess::get($myObject, 'privateProperty', 22);
print_r($myObject->toArray());
// [11, 22]
Returns true if accessible key exists in the container.
MapAccess::exists(mixed $container, string $key): bool
use SmorenTypeToolsMapAccess;
$array = [
'a' => 1,
];
var_dump(MapAccess::exists($array, 'a'));
// true
var_dump(MapAccess::exists($array, 'b'));
// false
class MyClass {
public int $publicProperty = 1;
private int $privateProperty = 2;
private int $notAccessibleProperty = 3;
public function getPrivateProperty(): int
{
return $this->privateProperty;
}
}
$myObject = new MyClass();
// Accessible by name:
var_dump(MapAccess::exists($myObject, 'publicProperty'));
// true
// Accessible by getter:
var_dump(MapAccess::exists($myObject, 'privateProperty'));
// true
// Not accessible:
var_dump(MapAccess::get($myObject, 'notAccessibleProperty'));
// false
// Nonexistent:
var_dump(MapAccess::get($myObject, 'nonexistentProperty', -1));
// false
composer install
composer test-init
composer test
PHP Type Tools is licensed under the MIT License.