respect-validation/library/Rules/PrimeNumber.php
Ismael Elias 6e26ba8837
Apply contribution guidelines to "PrimeNumber" rule
Co-Authored-By: Henrique Moody <henriquemoody@gmail.com>
2018-06-09 08:54:30 +02:00

53 lines
1.2 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use function ceil;
use function is_numeric;
use function sqrt;
/**
* Validates whether the input is a prime number.
*
* @author Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
* @author Camilo Teixeira de Melo <kmilotxm@users.noreply.github.com>
* @author Henrique Moody <henriquemoody@gmail.com>
* @author Ismael Elias <ismael.esq@hotmail.com>
* @author Kleber Hamada Sato <kleberhs007@yahoo.com>
*/
final class PrimeNumber extends AbstractRule
{
/**
* {@inheritdoc}
*/
public function validate($input): bool
{
if (!is_numeric($input) || $input <= 1) {
return false;
}
if (2 != $input && 0 == ($input % 2)) {
return false;
}
for ($i = 3; $i <= ceil(sqrt((float) $input)); $i += 2) {
if (0 == ($input % $i)) {
return false;
}
}
return true;
}
}