| Conditions | 10 | 
| Paths | 4 | 
| Total Lines | 19 | 
| Lines | 0 | 
| Ratio | 0 % | 
| Changes | 0 | ||
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | <?php | ||
| 16 | public static function build(...$args): Step | ||
| 17 |     { | ||
| 18 |         if (sizeof($args) == 1 && $args[0] instanceof Step) { | ||
| 19 | return $args[0]; | ||
| 20 | } | ||
| 21 | if (sizeof($args) == 3 | ||
| 22 | && is_string($args[2]) | ||
| 23 | && $args[0] instanceof \Closure | ||
| 24 | && $args[1] instanceof \Closure | ||
| 25 |         ) { | ||
| 26 | return new LambdaStep($args[0], $args[1], $args[2]); | ||
| 27 | } | ||
| 28 | if (sizeof($args) == 2 | ||
| 29 | && $args[0] instanceof \Closure | ||
| 30 | && $args[1] instanceof \Closure | ||
| 31 |         ) { | ||
| 32 | return new LambdaStep($args[0], $args[1]); | ||
| 33 | } | ||
| 34 |         throw new FailureToBuildStep("Not sure how to build a step from provided data"); | ||
| 35 | } | ||
| 37 |