eater / shoarma
partial's, closures and all kind of magic
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.7
- phpunit/phpunit: ^6.4
This package is auto-updated.
Last update: 2019-03-01 01:46:49 UTC
README
Bringing back fun in functions
fun(class $object, string $method)
returns \Closure
Shorthand replacement for [$object, $method], will also throw when called from wrong context
this(string $method)
returns \Closure
Shorthand replacement for fun($this, $method), via magic (debug_backtrace) will collect the correct this object
partial(callable $call, $arguments)
returns \Shoarma\Partial
Creates a partial for $call, \Shoarma\arg and \Shoarma\args can be used to displace arguments e.g.
<?php
use function \Shoarma\partial;
use function \Shoarma\arg;
$func = function ($one, $two, $three) {
echo "1. {$one}\n2. {$two}\n3. {$three}\n";
};
$partial = partial($func, [arg(1), "2", arg(0)]);
// This will now print "1. 1\n 2. 2\n3. 3"
$partial(3, 1);
arg(int $offset)
returns \Shoarma\Partial\Argument
Selects 1 argument for the partial
args(int $offset, $length = null)
returns \Shoarma\Partial\Argument
Selects a range of arguments for the partial, if $length is null, it will take everything starting at $offset
wrap(callable $call, callable $wrapper)
returns Shoarma\Wrap
Will return $wrapper wrapped around $call
$wrapper will be called with a \Shoarma\Wrap\Inside object around $call and the other arguments
e.g.
<?php
use \Shoarma\Wrap\Inside;
use function \Shoarma\wrap;
$func = function ($hello, $world) {
return "{$hello} {$world}\n";
};
$wrapper = wrap($func, function (Inside $next) {
// is the same as $next->callOriginal();
// Will use the arguments given to the wrapper
return $next();
// is the same as $next->callWith('Hello', 'World');
// so if you really need to call $next with no arguments you can use
// $next->callWith();
return $next('Hello', 'World');
});
// Will print "Goodbye mars"
echo $wrapper("Goodbye", "Mars");