awjudd/guard-clauses

A simple package with guard clause helpers.

0.4.0 2024-10-29 00:08 UTC

This package is auto-updated.

Last update: 2024-10-29 00:09:41 UTC


README

A guard clause is a software pattern that simplifies complex functions by "failing fast", checking for invalid inputs up front and immediately failing if any are found.

Sample Usage

Avoiding Primative Obsession:

use JuddDev\GuardClauses\Guards\Numeric\IntegerGuard;

class PositiveInteger
{
    public function __construct(int $value)
    {
        IntegerGuard::isPositiveOrZero($value);
    }
}

By doing this, you are then able to quickly make sure your objects are valid upon creation.

You can also use it in methods:

use JuddDev\GuardClauses\Guards\Numeric\IntegerGuard;


class BankAccount
{
    public function __construct(private int $balance)
    {
    }

    public function withdraw(int $amount): bool
    {
        IntegerGuard::isPositiveOrZero($amount);

        // Logic to remove
    }
}

Why is this better? It reduces the overall nesting required in your code. While the below is a simple problem, you can see how it can propagate.

use JuddDev\GuardClauses\Guards\Numeric\IntegerGuard;

class BankAccount
{
    public function __construct(private int $balance)
    {
    }

    public function withdraw(int $amount): bool
    {
        if($amount <= 0) {
            return false;
        }

        // Logic to remove
    }
}