Template6

A Template Engine for Raku

NAME

Template6 - A Template Engine for Raku

SYNOPSIS

use Template6;

DESCRIPTION

Inspired by Template Toolkit from Perl, Template6 is a simple template engine designed to be a content-neutral template language.

I also intend to borrow features and ideas from my own Flower and Garden projects.

This project does not intend to create an exact clone of Template Toolkit. Some features from TT are not planned for inclusion, and likewise, some feature will be included that are not in TT. Not all features will work the same either.

Currently implemented features

GET and SET statements, including implicit versions.

  • [% get varname %]

  • [% varname %]

  • [% set varname = value %]

  • [% varname = value %]

FOR statement.

This replaces the FOREACH statement in TT2. It can be used in one of four ways:

  • [% for listname as itemname %]

  • [% for listname -> itemname %]

  • [% for itemname in listname %]

  • [% for itemname = listname %]

If used with Hashes, you'll need to query the .key or .value accessors.

IF/ELSIF/ELSE/UNLESS statements.

These are very simplistic at the moment, but work for basic tests.

  • Querying nested data structures using a simple dot operator syntax.

  • CALL and DEFAULT statements.

  • INSERT, INCLUDE and PROCESS statements.

Differences with Template Toolkit

  • You should use explicit quotes, including in INSERT/INCLUDE/PROCESS directives.

  • All statement directives are case insensitive.

  • There are no plans for the INTERPOLATE option/style.

  • Anything not yet implemented (see TODO below.)

Caveats

  • Whitespace control is not implemented, so some things are fairly odd. See TODO.

  • A lot of little nit-picky stuff, likely related to the whitespace issue.

TODO

Short Term Goals

  • WRAPPER statement

  • block statements

  • given/when statements

  • Add 'absolute' and 'relative' options to Template6::Provider::File

  • Whitespace control

  • Precompiled/cached templates

  • Tag styles (limited to definable start_tag and end_tag)

Long Term Goals

  • Filters

  • Variable interpolation (in strings, variable names, etc.)

  • Capture of directive output

  • Directive comments

  • Side-effect notation

  • Multiple directives in a single statement tag set

  • Macros, plugins, etc.

Possible future directions

I would also like to investigate the potential for an alternative to Template6::Parser that generates Raku closures without the use of EVAL. This would be far trickier, and would not be compatible with the precompiled templates, but would be an interesting exercise nonetheless.

AUTHOR

Timothy Totten

COPYRIGHT AND LICENSE

Copyright 2012 - 2017 Timothy Totten

Copyright 2018 - 2022 Raku Community

This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.

Template6 v0.10.1

A Template Engine for Raku

Authors

  • Timothy Totten

License

Artistic-2.0

Dependencies

Test Dependencies

Provides

  • Template6
  • Template6::Context
  • Template6::Parser
  • Template6::Provider
  • Template6::Provider::File
  • Template6::Provider::String
  • Template6::Service
  • Template6::Stash

The Camelia image is copyright 2009 by Larry Wall. "Raku" is trademark of the Yet Another Society. All rights reserved.