igorw/compose
Composer 安装命令:
composer require igorw/compose
包简介
Function composition.
README 文档
README
Function composition.
Allows you to stitch functions together to form a pipeline. This can be useful if you have to transform data in many steps and you want to describe those steps on a high level.
compose
Generally, function composition means taking two functions f and g, and
producing a new function z, which applies f to the result of g.
z = compose(f, g)
; z(x) => f(g(x))
This library provides a compose function that does just this.
$z = igorw\compose($f, $g);
var_dump($z($x));
It supports an arbitrary number of functions to be composed via varargs.
$z = igorw\compose($f, $g, $h, $i);
The innermost function (the last one in the list) can take an arbitrary number of arguments, whereas the others may only take a single argument.
$z = igorw\compose($f, $g);
$z('a', 'b', 'c');
// => $f($g('a', 'b', 'c'))
pipeline
pipeline is the same as compose, but the arguments are reversed. This is
more easy to read in some cases, because you can list the functions in the
order they will be called.
It is quite similar to a unix pipe in that regard.
Examples
function transform_data($data) {
return [
'name' => $data['firstname'].' '.$data['lastname'],
];
}
$transformJson = igorw\pipeline(
function ($json) { return json_decode($json, true); },
'transform_data',
'json_encode'
);
$json = <<<EOF
{"firstname": "Igor", "lastname": "Wiedler"}
{"firstname": "Beau", "lastname": "Simensen"}
EOF;
$list = explode("\n", $json);
$newList = array_map($transformJson, $list);
$newJson = implode("\n", $newList);
// =>
// {"name": "Igor Wiedler"}
// {"name": "Beau Simensen"}
统计信息
- 总下载量: 24.81k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 84
- 点击次数: 3
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2013-04-17