* @link https://getkirby.com * @copyright Bastian Allgeier * @license https://getkirby.com/license */ class Helpers { /** * Triggers a deprecation warning if debug mode is active * * @param string $message * @return bool Whether the warning was triggered */ public static function deprecated(string $message): bool { if (App::instance()->option('debug') === true) { return trigger_error($message, E_USER_DEPRECATED) === true; } return false; } /** * Simple object and variable dumper * to help with debugging. * * @param mixed $variable * @param bool $echo * @return string */ public static function dump($variable, bool $echo = true): string { $kirby = App::instance(); if ($kirby->environment()->cli() === true) { $output = print_r($variable, true) . PHP_EOL; } else { $output = '
' . print_r($variable, true) . ''; } if ($echo === true) { echo $output; } return $output; } /** * Performs an action with custom handling * for all PHP errors and warnings * @since 3.7.4 * * @param \Closure $action Any action that may cause an error or warning * @param \Closure $condition Closure that returns bool to determine if to * suppress an error, receives arguments for * `set_error_handler()` * @param mixed $fallback Value to return when error is suppressed * @return mixed Return value of the `$action` closure, * possibly overridden by `$fallback` */ public static function handleErrors(Closure $action, Closure $condition, $fallback = null) { $override = null; $handler = set_error_handler(function () use (&$override, &$handler, $condition, $fallback) { // check if suppress condition is met $suppress = $condition(...func_get_args()); if ($suppress !== true) { // handle other warnings with Whoops if loaded if (is_callable($handler) === true) { return $handler(...func_get_args()); } // otherwise use the standard error handler return false; // @codeCoverageIgnore } // use fallback to override return for suppressed errors $override = $fallback; if (is_callable($override) === true) { $override = $override(); } // no additional error handling return true; }); $result = $action(); restore_error_handler(); return $override ?? $result; } /** * Checks if a helper was overridden by the user * by setting the `KIRBY_HELPER_*` constant * @internal * * @param string $name Name of the helper * @return bool */ public static function hasOverride(string $name): bool { $name = 'KIRBY_HELPER_' . strtoupper($name); return defined($name) === true && constant($name) === false; } /** * Determines the size/length of numbers, * strings, arrays and countable objects * * @param mixed $value * @return int * @throws \Kirby\Exception\InvalidArgumentException */ public static function size($value): int { if (is_numeric($value)) { return (int)$value; } if (is_string($value)) { return Str::length(trim($value)); } if (is_countable($value)) { return count($value); } throw new InvalidArgumentException('Could not determine the size of the given value'); } }