<?php
/*
* This file is part of Chevere.
*
* (c) Rodolfo Berrios <[email protected]>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Chevere\Parameter\Interfaces;
/**
* Describes the component in charge of defining a parameter of type int.
*/
interface IntParameterInterface extends ParameterInterface
{
public const MIN = PHP_INT_MIN;
public const MAX = PHP_INT_MAX;
/**
* Asserts the given `$value` is valid.
*/
public function __invoke(int $value): int;
/**
* Return an instance with the specified default value.
*
* This method MUST retain the state of the current instance, and return
* an instance that contains the specified default value.
*/
public function withDefault(int $value): self;
/**
* Return an instance with the specified minimum value.
*
* This method MUST retain the state of the current instance, and return
* an instance that contains the specified minimum value.
*/
public function withMin(int $value): self;
/**
* Return an instance with the specified maximum value.
*
* This method MUST retain the state of the current instance, and return
* an instance that contains the specified maximum value.
*/
public function withMax(int $value): self;
/**
* Return an instance with the specified accepted value(s).
*
* This method MUST retain the state of the current instance, and return
* an instance that contains the specified accepted value(s).
*
* When using this method it will nullify the minimum and maximum values.
*/
public function withAccept(int ...$value): self;
/**
* Return an instance with the specified rejected value(s).
*
* This method MUST retain the state of the current instance, and return
* an instance that contains the specified rejected value(s).
*
* When using this method it will nullify the minimum and maximum values.
*/
public function withReject(int ...$value): self;
/**
* Provides access to the default value (if any).
*/
public function default(): ?int;
/**
* Provides access to the minimum value.
*/
public function min(): ?int;
/**
* Provides access to the maximum value.
*/
public function max(): ?int;
/**
* Provides access to the accepted value(s).
*
* @return int[]
*/
public function accept(): array;
/**
* Provides access to the rejected value(s).
*
* @return int[]
*/
public function reject(): array;
public function assertCompatible(self $parameter): void;
}
|