20250217
[Д] [BoolExtensions]: Добавлен новый статический класс, расширяющий возможности типа bool.
This commit is contained in:
parent
3aefbd7f27
commit
64c1f386eb
73
sources/extensions/BoolExtensions.php
Normal file
73
sources/extensions/BoolExtensions.php
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace goodboyalex\php_components_pack\extensions;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Расширение типа "правда/ложь".
|
||||||
|
*
|
||||||
|
* @author Александр Бабаев
|
||||||
|
* @package php_components_pack
|
||||||
|
* @version 1.0
|
||||||
|
* @since 1.0.7
|
||||||
|
*/
|
||||||
|
final class BoolExtensions
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Вывод в строку <code>ifTrue</code>, если выражение <code>b</code> правдиво и <code>ifFalse</code> в противном
|
||||||
|
* случае.
|
||||||
|
*
|
||||||
|
* @param bool $b Выражение типа правда/ложь.
|
||||||
|
* @param string $ifTrue Строка для правдивого выражения. По умолчанию "true".
|
||||||
|
* @param string $ifFalse Строка для лживого выражения. По умолчанию "false".
|
||||||
|
*
|
||||||
|
* @return string Вывод строки.
|
||||||
|
*/
|
||||||
|
public static function ExportToString (bool $b, string $ifTrue = "true", string $ifFalse = "false"): string
|
||||||
|
{
|
||||||
|
return $b ? $ifTrue : $ifFalse;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Вычисляет, есть ли хотя бы одно из переменных формата правда/ложь <code>expressions</code> в значении
|
||||||
|
* <code>true</code>.
|
||||||
|
*
|
||||||
|
* @param array $expressions Переменные формата правда/ложь.
|
||||||
|
*
|
||||||
|
* @return bool Есть ли хотя бы одно в значении true.
|
||||||
|
*
|
||||||
|
* @throws Exception Выбрасывается, если хотя бы один аргумент <code>expressions</code> не являются типом
|
||||||
|
* правда/ложь.
|
||||||
|
*/
|
||||||
|
public static function AnyTrue (array $expressions): bool
|
||||||
|
{
|
||||||
|
return self::TrueCount($expressions) > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Вычисляет количество переменных формата правда/ложь <code>expressions</code> в значении <code>true</code>.
|
||||||
|
*
|
||||||
|
* @param array $expressions Переменные формата правда/ложь.
|
||||||
|
*
|
||||||
|
* @return int Количество переменных в значении true.
|
||||||
|
*
|
||||||
|
* @throws Exception Выбрасывается, если хотя бы один аргумент <code>expressions</code> не являются типом
|
||||||
|
* правда/ложь.
|
||||||
|
*/
|
||||||
|
public static function TrueCount (array $expressions): int
|
||||||
|
{
|
||||||
|
// Проверяем все аргументы
|
||||||
|
foreach ($expressions as $expression)
|
||||||
|
// - если аргумент не является типом правда/ложь
|
||||||
|
if (!is_bool($expression))
|
||||||
|
// -- то выбрасываем исключение
|
||||||
|
throw new Exception('All arguments must be bool. / Все аргументы должны быть типа «правда/ложь».');
|
||||||
|
|
||||||
|
// Используем array_filter для фильтрации всех истинных значений
|
||||||
|
$filtered = array_filter($expressions);
|
||||||
|
|
||||||
|
// Возвращаем количество элементов в отфильтрованном массиве
|
||||||
|
return count($filtered);
|
||||||
|
}
|
||||||
|
}
|
68
tests/extensions/BoolExtensionsTest.php
Normal file
68
tests/extensions/BoolExtensionsTest.php
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace goodboyalex\php_components_pack\tests\extensions;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
use goodboyalex\php_components_pack\extensions\BoolExtensions;
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
class BoolExtensionsTest extends TestCase
|
||||||
|
{
|
||||||
|
public function testAnyTrue ()
|
||||||
|
{
|
||||||
|
$this->PrepareForTest();
|
||||||
|
|
||||||
|
$hasTrue = [
|
||||||
|
true, false, true, false, true, false, true, false, true, false, true, false, true, false, true, false,
|
||||||
|
true, false, true, false, true, false, true, false, true, false, true, false
|
||||||
|
];
|
||||||
|
|
||||||
|
$noTrue = [
|
||||||
|
false, false, false, false, false, false, false, false, false, false, false, false, false, false, false,
|
||||||
|
false, false, false, false, false, false, false, false, false, false, false
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->assertTrue(BoolExtensions::AnyTrue($hasTrue));
|
||||||
|
|
||||||
|
$this->assertFalse(BoolExtensions::AnyTrue($noTrue));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function PrepareForTest (): void
|
||||||
|
{
|
||||||
|
require_once __DIR__ . '/../../sources/extensions/BoolExtensions.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testTrueCount ()
|
||||||
|
{
|
||||||
|
$this->PrepareForTest();
|
||||||
|
|
||||||
|
$array = [
|
||||||
|
true, false, true, false, true, false, true, false, true, false, true, false,
|
||||||
|
true, false, true, false, true, false, true, false, true, false, true, false, true, false, true,
|
||||||
|
false
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->assertEquals(14,
|
||||||
|
BoolExtensions::TrueCount($array));
|
||||||
|
|
||||||
|
$this->expectException(Exception::class);
|
||||||
|
|
||||||
|
$array[] = "ПРЕДАТЕЛЬ!";
|
||||||
|
|
||||||
|
BoolExtensions::TrueCount($array);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testExportToString ()
|
||||||
|
{
|
||||||
|
$this->PrepareForTest();
|
||||||
|
|
||||||
|
$b = true;
|
||||||
|
|
||||||
|
$this->assertEquals('О, да!', BoolExtensions::ExportToString($b, 'О, да!', 'О, нет!'));
|
||||||
|
|
||||||
|
$b = false;
|
||||||
|
|
||||||
|
$this->assertEquals('О, нет!', BoolExtensions::ExportToString($b, 'О, да!', 'О, нет!'));
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user