mindplay / readable
Formats PHP values as human-readable strings
Installs: 409 153
Dependents: 8
Suggesters: 0
Security: 0
Stars: 8
Watchers: 3
Forks: 1
Open Issues: 0
Requires
- php: ^8.0
Requires (Dev)
- mindplay/testies: ^1.1.5
- phpunit/php-code-coverage: ^9 || ^10 || ^11
This package is auto-updated.
Last update: 2025-01-11 13:58:43 UTC
README
A few simple functions to format any kind of PHP value or type as human-readable.
Mainly, this is intended to help you produce better error-messages:
if (!is_int($value)) { throw new UnexpectedValueException("expected integer, got: " . readable::typeof($value)); } else if ($value > 100) { throw new RangeException("expected value up to 100, got: " . readable::value($value)); }
Note that this library is not "better var_dump" - it won't color-code things or dump deep object graphs. There are plenty of other libraries for that sort of thing.
Presently, this library consists of these simple functions:
readable::value($value)
formats any single PHP value as human-readable.readable::values($array)
formats an array of (mixed) values as human-readable.readable::typeof($value)
returns the type of value (or class name) for any given value.readable::callback($callable)
formats anycallable
as human-readable.readable::severity($int)
returns for exampleE_WARNING
as human-readable"Warning"
.readable::error($exception)
returns a human-readableException
/Error
summary.readable::trace($trace)
formats a stack-trace with file-names, line-numbers, function-names and (optionally) arguments.readable::path($path)
removes the project root path from the start of a path.
The latter function callback()
will fall back to regular value()
formatting if the given
value is not a callable - this function is preferable when a given value was expected to be
callable
, e.g. recognizes function-names as strings and objects implementing __invoke()
.
See the source code and test suite for all formatting features.