aboutsummaryrefslogtreecommitdiff
path: root/php/src
diff options
context:
space:
mode:
Diffstat (limited to 'php/src')
-rw-r--r--php/src/Template.php110
1 files changed, 110 insertions, 0 deletions
diff --git a/php/src/Template.php b/php/src/Template.php
index 34dfe09..47bcf5d 100644
--- a/php/src/Template.php
+++ b/php/src/Template.php
@@ -629,6 +629,116 @@ Filters::init();
*
* # prints "hello Paul"
*
+ * You can also filter values in templates, using the pipe symbol:
+ *
+ * # create template that converts name to upper-case
+ * $tmpl = new Template('hello %{name | uc}');
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'name' => 'Paul',
+ * ]) . "\n";
+ *
+ * # prints "hello PAUL"
+ *
+ * Filters can be chained:
+ *
+ * # create template that converts name to upper-case and then
+ * # strips leading and trailing whitespace
+ * $tmpl = new Template('hello %{name | uc | trim}');
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'name' => ' Paul ',
+ * ]) . "\n";
+ *
+ * # prints "hello PAUL"
+ *
+ * Filters can take arguments:
+ *
+ * # create template that converts name to lowercase and then
+ * # calculates the SHA-1 digest of the result
+ * $tmpl = new Template('hello %{name | lc | hash sha1}');
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'name' => 'Paul',
+ * ]) . "\n";
+ *
+ * # prints "hello a027184a55211cd23e3f3094f1fdc728df5e0500"
+ *
+ * You can define custom global filters:
+ *
+ * # load template and filter classes
+ * use \Pablotron\Luigi\Template;
+ * use \Pablotron\Luigi\Filters;
+ *
+ * # create custom global filter named 'foobarify'
+ * Filters::$FILTERS['foobarify'] = function($s) {
+ * return "foo-{$s}-bar";
+ * };
+ *
+ * # create template that converts name to lowercase and then
+ * # calculates the SHA-1 digest of the result
+ * $tmpl = new Template('hello %{name | foobarify}');
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'name' => 'Paul',
+ * ]) . "\n";
+ *
+ * # prints "hello foo-Paul-bar"
+ *
+ * Or define custom filters for a template:
+ *
+ * # load template and filter classes
+ * use \Pablotron\Luigi\Template;
+ *
+ * # create template that converts name to lowercase and then
+ * # calculates the SHA-1 digest of the result
+ * $tmpl = new Template('hello %{name | reverse}', [);
+ * 'reverse' => function($s) {
+ * return strrev($s);
+ * },
+ * ]);
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'name' => 'Paul',
+ * ]) . "\n";
+ *
+ * # prints "hello luaP"
+ *
+ * Your custom filters can accept arguments, too:
+ *
+ * # load template and filter classes
+ * use \Pablotron\Luigi\Template;
+ * use \Pablotron\Luigi\Filters;
+ *
+ * # create custom global filter named 'foobarify'
+ * Filters::$FILTERS['wrap'] = function($s, $args) {
+ * if (count($args) == 2) {
+ * return sprintf('(%s, %s, %s)', $args[0], $s, $args[1]);
+ * } else if (count($args) == 1) {
+ * return sprintf('(%s in %s)', %s, $args[0]);
+ * } else if (count($args) == 0) {
+ * return $s;
+ * } else {
+ * throw new Exception("invalid argument count");
+ * }
+ * };
+ *
+ * # create template that converts name to lowercase and then
+ * # calculates the SHA-1 digest of the result
+ * $tmpl = new Template('sandwich: %{meat | wrap slice heel}, taco: %{meat | wrap shell}');
+ *
+ * # run template and print result
+ * echo $tmpl->run([
+ * 'meat' => 'chicken',
+ * ]) . "\n";
+ *
+ * # prints "sandwich: (slice, chicken, heel), taco: (chicken in shell)"
+ *
* @api
*
*/