| 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 |