File: /home/mmickelson/w2p.spidev.xyz/vendor/phpunit/phpunit/src/Framework/Constraint/IsType.php
<?php
/*
 * This file is part of PHPUnit.
 *
 * (c) Sebastian Bergmann <sebastian@phpunit.de>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace PHPUnit\Framework\Constraint;
/**
 * Constraint that asserts that the value it is evaluated for is of a
 * specified type.
 *
 * The expected value is passed in the constructor.
 */
class IsType extends Constraint
{
    public const TYPE_ARRAY    = 'array';
    public const TYPE_BOOL     = 'bool';
    public const TYPE_FLOAT    = 'float';
    public const TYPE_INT      = 'int';
    public const TYPE_NULL     = 'null';
    public const TYPE_NUMERIC  = 'numeric';
    public const TYPE_OBJECT   = 'object';
    public const TYPE_RESOURCE = 'resource';
    public const TYPE_STRING   = 'string';
    public const TYPE_SCALAR   = 'scalar';
    public const TYPE_CALLABLE = 'callable';
    public const TYPE_ITERABLE = 'iterable';
    /**
     * @var array
     */
    private $types = [
        'array'    => true,
        'boolean'  => true,
        'bool'     => true,
        'double'   => true,
        'float'    => true,
        'integer'  => true,
        'int'      => true,
        'null'     => true,
        'numeric'  => true,
        'object'   => true,
        'real'     => true,
        'resource' => true,
        'string'   => true,
        'scalar'   => true,
        'callable' => true,
        'iterable' => true
    ];
    /**
     * @var string
     */
    private $type;
    /**
     * @throws \PHPUnit\Framework\Exception
     */
    public function __construct(string $type)
    {
        parent::__construct();
        if (!isset($this->types[$type])) {
            throw new \PHPUnit\Framework\Exception(
                \sprintf(
                    'Type specified for PHPUnit\Framework\Constraint\IsType <%s> ' .
                    'is not a valid type.',
                    $type
                )
            );
        }
        $this->type = $type;
    }
    /**
     * Returns a string representation of the constraint.
     */
    public function toString(): string
    {
        return \sprintf(
            'is of type "%s"',
            $this->type
        );
    }
    /**
     * Evaluates the constraint for parameter $other. Returns true if the
     * constraint is met, false otherwise.
     *
     * @param mixed $other value or object to evaluate
     */
    protected function matches($other): bool
    {
        switch ($this->type) {
            case 'numeric':
                return \is_numeric($other);
            case 'integer':
            case 'int':
                return \is_int($other);
            case 'double':
            case 'float':
            case 'real':
                return \is_float($other);
            case 'string':
                return \is_string($other);
            case 'boolean':
            case 'bool':
                return \is_bool($other);
            case 'null':
                return null === $other;
            case 'array':
                return \is_array($other);
            case 'object':
                return \is_object($other);
            case 'resource':
                return \is_resource($other) || \is_string(@\get_resource_type($other));
            case 'scalar':
                return \is_scalar($other);
            case 'callable':
                return \is_callable($other);
            case 'iterable':
                return \is_iterable($other);
        }
    }
}