You are here

abstract class GuardUtils in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 vendor/zendframework/zend-stdlib/src/Guard/GuardUtils.php \Zend\Stdlib\Guard\GuardUtils

Static guard helper class

Bridges the gap for allowing refactoring until traits can be used by default.

Hierarchy

Expanded class hierarchy of GuardUtils

File

vendor/zendframework/zend-stdlib/src/Guard/GuardUtils.php, line 21

Namespace

Zend\Stdlib\Guard
View source
abstract class GuardUtils {
  const DEFAULT_EXCEPTION_CLASS = 'Zend\\Stdlib\\Exception\\InvalidArgumentException';

  /**
   * Verifies that the data is an array or Traversable
   *
   * @param  mixed  $data           the data to verify
   * @param  string $dataName       the data name
   * @param  string $exceptionClass FQCN for the exception
   * @throws \Exception
   */
  public static function guardForArrayOrTraversable($data, $dataName = 'Argument', $exceptionClass = self::DEFAULT_EXCEPTION_CLASS) {
    if (!is_array($data) && !$data instanceof Traversable) {
      $message = sprintf('%s must be an array or Traversable, [%s] given', $dataName, is_object($data) ? get_class($data) : gettype($data));
      throw new $exceptionClass($message);
    }
  }

  /**
   * Verify that the data is not empty
   *
   * @param  mixed  $data           the data to verify
   * @param  string $dataName       the data name
   * @param  string $exceptionClass FQCN for the exception
   * @throws \Exception
   */
  public static function guardAgainstEmpty($data, $dataName = 'Argument', $exceptionClass = self::DEFAULT_EXCEPTION_CLASS) {
    if (empty($data)) {
      $message = sprintf('%s cannot be empty', $dataName);
      throw new $exceptionClass($message);
    }
  }

  /**
   * Verify that the data is not null
   *
   * @param  mixed  $data           the data to verify
   * @param  string $dataName       the data name
   * @param  string $exceptionClass FQCN for the exception
   * @throws \Exception
   */
  public static function guardAgainstNull($data, $dataName = 'Argument', $exceptionClass = self::DEFAULT_EXCEPTION_CLASS) {
    if (null === $data) {
      $message = sprintf('%s cannot be null', $dataName);
      throw new $exceptionClass($message);
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
GuardUtils::DEFAULT_EXCEPTION_CLASS constant
GuardUtils::guardAgainstEmpty public static function Verify that the data is not empty
GuardUtils::guardAgainstNull public static function Verify that the data is not null
GuardUtils::guardForArrayOrTraversable public static function Verifies that the data is an array or Traversable