Member since
Much clearer than nesting multiple calls.
For example:
$result = "Hello World"
|> 'htmlentities'
|> 'str_split'
|> fn($x) => array_map('strtoupper', $x)
|> fn($x) => array_filter($x, fn($v) => $v != 'O');
Is 'nicer' since it has better readability and clearer syntax than:
$result = array_filter(
str_split(
strtoupper(
htmlentities("Hello World")
)
),
fn($v) => $v != '0'
);
Keep interfaces to be interfaces!
It looks pretty much the exact function as abstract class. I still think interfaces/contracts should not include any concrete implementation