Download the PHP package squirrelphp/scalar-types without Composer
On this page you can find all versions of the php package squirrelphp/scalar-types. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download squirrelphp/scalar-types
More information about squirrelphp/scalar-types
Files in squirrelphp/scalar-types
Package scalar-types
Short Description Make the coercive mode and strict mode behavior of PHP accessible explicitly via functions.
License MIT
Homepage https://github.com/squirrelphp/scalar-types
Informations about the package scalar-types
Squirrel Scalar Types
Make the coercive mode and strict mode behavior of PHP accessible explicitly via functions: Includes coercions and is_coerceable checks that work like the implicit scalar type coercions in PHP, and an easy way to enforce a specific scalar type mimicking the behavior of strict mode in PHP.
Installation
composer require squirrelphp/scalar-types
Table of contents
- Test if value can be coerced
- Coerce value
- Enforce a type for a value
Test if value can be coerced
All these functions have one mixed argument $value
and return true or false:
is_coerceable_to_int
Returns true if $value
is one of the following:
- An integer
- A float without fractional part
- A numeric string without fractional part
- A boolean
For any other values it returns false.
is_coerceable_to_float
Returns true if $value
is one of the following:
- An integer
- A float
- A numeric string
- A boolean
For any other values it returns false.
is_coerceable_to_bool
Returns true if $value
is one of the following:
- An integer with value 0 or 1
- A float with value 0 or 1
- An empty string
- A string with value '0' or '1'
- A boolean
For any other values it returns false.
is_coerceable_to_string
Returns true if $value
is one of the following:
- An integer
- A float
- A string
- A boolean
- An object with the magic method __toString
For any other values it returns false.
Coerce value
All these functions have one mixed argument $value
and return the type they are coercing to, following the same logic as implicit type coercions in PHP.
coerce_to_int
Coerce a value like PHP 8.2 would do it, which can lead to a TypeError for non-scalar and non-numeric values and a deprecation notice for a float or numeric string with a fractional part.
coerce_to_float
Coerce a value like PHP 8.2 would do it, which can lead to a TypeError for non-scalar and non-numeric values.
coerce_to_bool
Coerce a value like PHP 8.2 would do it, which can lead to a TypeError for non-scalar values and a deprecation notice for values other than "", "0", "1", 0, 1, 0.0 and 1.0.
coerce_to_string
Coerce a value like PHP 8.2 would do it, which can lead to a TypeError for non-scalar values except if it is an object that implements the magic __toString method.
Enforce a type for a value
All these functions have one mixed argument $value
and return the type they are enforcing, according to the same logic as strict mode in PHP.
enforce_int
Returns $value
as an integer if it is an integer. Throws a TypeError otherwise.
enforce_float
Returns $value
as a float if it is an integer or a float. Throws a TypeError otherwise.
enforce_bool
Returns $value
as a boolean if it is a boolean. Throws a TypeError otherwise.
enforce_string
Returns $value
as a string if it is a string. Throws a TypeError otherwise.