<?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 float.
*/
interface FloatParameterInterface extends ParameterInterface
{
public const MIN = -PHP_FLOAT_MIN;
public const MAX = PHP_FLOAT_MAX;
/**
* Asserts the given `$value` is valid.
*/
public function __invoke(float $value): float;
/**
* 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(float $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(float $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(float $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(float ...$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(float ...$value): self;
/**
* Provides access to the default value (if any).
*/
public function default(): ?float;
/**
* Provides access to the minimum value.
*/
public function min(): ?float;
/**
* Provides access to the maximum value.
*/
public function max(): ?float;
/**
* Provides access to the accepted value(s).
*
* @return float[]
*/
public function accept(): array;
/**
* Provides access to the rejected value(s).
*
* @return float[]
*/
public function reject(): array;
public function assertCompatible(self $parameter): void;
}
|