Skip to content

Commit

Permalink
Rename "Consecutive" to "Circuit"
Browse files Browse the repository at this point in the history
The "Consecutive" rule is now renamed to "Circuit" to better reflect its
behavior of stopping at the first failure. I also favour this name
because it's much shorter.
  • Loading branch information
henriquemoody committed Dec 20, 2024
1 parent e465810 commit fb32edc
Show file tree
Hide file tree
Showing 26 changed files with 68 additions and 65 deletions.
2 changes: 1 addition & 1 deletion docs/02-feature-guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ Respect\Validation offers over 150 rules, many of which are designed to address
* Validating the **Length** of the input: [Length](rules/Length.md).
* Validating the **Maximum** value in the input: [Max](rules/Max.md).
* Validating the **Minimum** value in the input: [Min](rules/Min.md).
* Handling **Special cases**: [Lazy](rules/Lazy.md), [Consecutive](rules/Consecutive.md), [Call](rules/Call.md).
* Handling **Special cases**: [Lazy](rules/Lazy.md), [Circuit](rules/Circuit.md), [Call](rules/Call.md).

### Custom templates

Expand Down
1 change: 1 addition & 0 deletions docs/rules/AllOf.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ v::allOf(v::intVal(), v::positive())->isValid(15); // true
See also:

- [AnyOf](AnyOf.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [NoneOf](NoneOf.md)
- [OneOf](OneOf.md)
Expand Down
1 change: 1 addition & 0 deletions docs/rules/AnyOf.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ so `AnyOf()` returns true.
See also:

- [AllOf](AllOf.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [ContainsAny](ContainsAny.md)
- [NoneOf](NoneOf.md)
Expand Down
14 changes: 5 additions & 9 deletions docs/rules/Consecutive.md → docs/rules/Circuit.md
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
# Consecutive
# Circuit

- `Consecutive(Rule $rule1, Rule $rule2, Rule ...$rule)`
- `Circuit(Rule $rule1, Rule $rule2, Rule ...$rule)`

Validates the input against a series of rules until one fails.
Validates the input against a series of rules until the first fails.

This rule can be handy for getting the least error messages possible from a chain.

This rule can be helpful in combinations with [Lazy](Lazy.md). An excellent example is when you want to validate a
country code and a subdivision code.

```php
v::consecutive(
v::circuit(
v::key('countryCode', v::countryCode()),
v::lazy(static fn($input) => v::key('subdivisionCode', v::subdivisionCode($input['countryCode']))),
)->isValid($_POST);
Expand All @@ -22,11 +22,7 @@ would then have to write `v::key('countryCode', v::countryCode())` twice in your

## Templates

## Template placeholders

| Placeholder | Description |
|-------------|------------------------------------------------------------------|
| `name` | The validated input or the custom validator name (if specified). |
This rule does not have any templates, because it will always return the result of the first rule that fails. When all the validation rules pass, it will return the result of the last rule of the circuit.

## Categorization

Expand Down
1 change: 1 addition & 0 deletions docs/rules/Lazy.md
Original file line number Diff line number Diff line change
Expand Up @@ -47,4 +47,5 @@ See also:

- [Call](Call.md)
- [CallableType](CallableType.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
1 change: 1 addition & 0 deletions docs/rules/NoneOf.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ See also:

- [AllOf](AllOf.md)
- [AnyOf](AnyOf.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [Not](Not.md)
- [OneOf](OneOf.md)
Expand Down
1 change: 1 addition & 0 deletions docs/rules/OneOf.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ See also:

- [AllOf](AllOf.md)
- [AnyOf](AnyOf.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [NoneOf](NoneOf.md)
- [When](When.md)
1 change: 1 addition & 0 deletions docs/rules/SubdivisionCode.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ v::subdivisionCode('US')->isValid('CA'); // true
***
See also:

- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [CountryCode](CountryCode.md)
- [CurrencyCode](CurrencyCode.md)
Expand Down
1 change: 1 addition & 0 deletions docs/rules/When.md
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ See also:
- [AllOf](AllOf.md)
- [AlwaysInvalid](AlwaysInvalid.md)
- [AnyOf](AnyOf.md)
- [Circuit](Circuit.md)
- [Consecutive](Consecutive.md)
- [NoneOf](NoneOf.md)
- [OneOf](OneOf.md)
4 changes: 2 additions & 2 deletions library/Mixins/Builder.php
Original file line number Diff line number Diff line change
Expand Up @@ -65,12 +65,12 @@ public static function callback(callable $callback, mixed ...$arguments): Chain;

public static function charset(string $charset, string ...$charsets): Chain;

public static function circuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function cnh(): Chain;

public static function cnpj(): Chain;

public static function consecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function consonant(string ...$additionalChars): Chain;

public static function contains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/Chain.php
Original file line number Diff line number Diff line change
Expand Up @@ -70,12 +70,12 @@ public function callback(callable $callback, mixed ...$arguments): Chain;

public function charset(string $charset, string ...$charsets): Chain;

public function circuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function cnh(): Chain;

public function cnpj(): Chain;

public function consecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function consonant(string ...$additionalChars): Chain;

public function contains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/KeyBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,12 @@ public static function keyCallback(int|string $key, callable $callback, mixed ..

public static function keyCharset(int|string $key, string $charset, string ...$charsets): Chain;

public static function keyCircuit(int|string $key, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function keyCnh(int|string $key): Chain;

public static function keyCnpj(int|string $key): Chain;

public static function keyConsecutive(int|string $key, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function keyConsonant(int|string $key, string ...$additionalChars): Chain;

public static function keyContains(int|string $key, mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/KeyChain.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,12 @@ public function keyCallback(int|string $key, callable $callback, mixed ...$argum

public function keyCharset(int|string $key, string $charset, string ...$charsets): Chain;

public function keyCircuit(int|string $key, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function keyCnh(int|string $key): Chain;

public function keyCnpj(int|string $key): Chain;

public function keyConsecutive(int|string $key, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function keyConsonant(int|string $key, string ...$additionalChars): Chain;

public function keyContains(int|string $key, mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/NotBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,12 @@ public static function notCallback(callable $callback, mixed ...$arguments): Cha

public static function notCharset(string $charset, string ...$charsets): Chain;

public static function notCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function notCnh(): Chain;

public static function notCnpj(): Chain;

public static function notConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function notConsonant(string ...$additionalChars): Chain;

public static function notContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/NotChain.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,12 @@ public function notCallback(callable $callback, mixed ...$arguments): Chain;

public function notCharset(string $charset, string ...$charsets): Chain;

public function notCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function notCnh(): Chain;

public function notCnpj(): Chain;

public function notConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function notConsonant(string ...$additionalChars): Chain;

public function notContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/NullOrBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -57,12 +57,12 @@ public static function nullOrCallback(callable $callback, mixed ...$arguments):

public static function nullOrCharset(string $charset, string ...$charsets): Chain;

public static function nullOrCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function nullOrCnh(): Chain;

public static function nullOrCnpj(): Chain;

public static function nullOrConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function nullOrConsonant(string ...$additionalChars): Chain;

public static function nullOrContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/NullOrChain.php
Original file line number Diff line number Diff line change
Expand Up @@ -57,12 +57,12 @@ public function nullOrCallback(callable $callback, mixed ...$arguments): Chain;

public function nullOrCharset(string $charset, string ...$charsets): Chain;

public function nullOrCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function nullOrCnh(): Chain;

public function nullOrCnpj(): Chain;

public function nullOrConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function nullOrConsonant(string ...$additionalChars): Chain;

public function nullOrContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/PropertyBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,12 @@ public static function propertyCallback(string $propertyName, callable $callback

public static function propertyCharset(string $propertyName, string $charset, string ...$charsets): Chain;

public static function propertyCircuit(string $propertyName, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function propertyCnh(string $propertyName): Chain;

public static function propertyCnpj(string $propertyName): Chain;

public static function propertyConsecutive(string $propertyName, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function propertyConsonant(string $propertyName, string ...$additionalChars): Chain;

public static function propertyContains(
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/PropertyChain.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,12 @@ public function propertyCallback(string $propertyName, callable $callback, mixed

public function propertyCharset(string $propertyName, string $charset, string ...$charsets): Chain;

public function propertyCircuit(string $propertyName, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function propertyCnh(string $propertyName): Chain;

public function propertyCnpj(string $propertyName): Chain;

public function propertyConsecutive(string $propertyName, Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function propertyConsonant(string $propertyName, string ...$additionalChars): Chain;

public function propertyContains(string $propertyName, mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/UndefOrBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,12 @@ public static function undefOrCallback(callable $callback, mixed ...$arguments):

public static function undefOrCharset(string $charset, string ...$charsets): Chain;

public static function undefOrCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function undefOrCnh(): Chain;

public static function undefOrCnpj(): Chain;

public static function undefOrConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public static function undefOrConsonant(string ...$additionalChars): Chain;

public static function undefOrContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
4 changes: 2 additions & 2 deletions library/Mixins/UndefOrChain.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,12 +55,12 @@ public function undefOrCallback(callable $callback, mixed ...$arguments): Chain;

public function undefOrCharset(string $charset, string ...$charsets): Chain;

public function undefOrCircuit(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function undefOrCnh(): Chain;

public function undefOrCnpj(): Chain;

public function undefOrConsecutive(Rule $rule1, Rule $rule2, Rule ...$rules): Chain;

public function undefOrConsonant(string ...$additionalChars): Chain;

public function undefOrContains(mixed $containsValue, bool $identical = false): Chain;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
use Respect\Validation\Rules\Core\Composite;

#[Attribute(Attribute::TARGET_PROPERTY | Attribute::IS_REPEATABLE)]
final class Consecutive extends Composite
final class Circuit extends Composite
{
public function evaluate(mixed $input): Result
{
Expand Down
8 changes: 4 additions & 4 deletions library/Rules/Domain.php
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,9 @@ public function evaluate(mixed $input): Result
return new Result($this->partsRule->evaluate($parts)->isValid, $input, $this);
}

private function createGenericRule(): Consecutive
private function createGenericRule(): Circuit
{
return new Consecutive(
return new Circuit(
new StringType(),
new NoWhitespace(),
new Contains('.'),
Expand All @@ -74,13 +74,13 @@ private function createTldRule(bool $realTldCheck): Rule
return new Tld();
}

return new Consecutive(new Not(new StartsWith('-')), new Length(new GreaterThanOrEqual(2)));
return new Circuit(new Not(new StartsWith('-')), new Length(new GreaterThanOrEqual(2)));
}

private function createPartsRule(): Rule
{
return new Each(
new Consecutive(
new Circuit(
new Alnum('-'),
new Not(new StartsWith('-')),
new AnyOf(
Expand Down
2 changes: 1 addition & 1 deletion library/Transformers/DeprecatedKeyValue.php
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ public function transform(RuleSpec $ruleSpec): RuleSpec

[$comparedKey, $ruleName, $baseKey] = $ruleSpec->arguments;

return new RuleSpec('consecutive', [
return new RuleSpec('circuit', [
new KeyExists($comparedKey),
new KeyExists($baseKey),
new Lazy(
Expand Down
Loading

0 comments on commit fb32edc

Please sign in to comment.