fenekku / moustachu

Mustache templating for Nim
65 stars 8 forks source link
mustache nim template-engine

Moustachu

Build Status

Moustachu is a(N im)plementation of Mustache (get it?). Mustache is "logic-less templating".

Usage

In code


import moustachu

var tmplate = """Hello {{name}}
You have just won {{value}} dollars!
{{#in_ca}}
Well, {{taxed_value}} dollars, after taxes.
{{/in_ca}}"""

var c : Context = newContext()
c["name"] = "Chris"
c["value"] = 10000
c["taxed_value"] = 10000 - (10000 * 0.4)
c["in_ca"] = true

echo render(tmplate, c)

For other mustache examples look at the specs directory. For other moustachu-specific examples see the tests folder.

For the formal description of the mustache format, please visit mustache(5). Ignore the sections on "lambdas" and "set delimeters".

Not mentioned in the formal description (but mentioned in the spec code), the spec also supports using a dot . as an "implicit iterator" for arrays containing unnamed items. For example, a sequence of strings or integers would use an implicit iterator:

import moustachu

var c : Context = newContext()
c["zoo_name"] = "Anytown"
c["animals"] = @["lions", "tigers", "bears"]

var tmplate = """Animals at the {{zoo_name}} Zoo:

{{#animals}}
* {{.}}
{{/animals}}"""

echo render(tmplate, c)

On the command line

$ moustachu <context>.json <template>.moustache
$ moustachu <context>.json <template>.moustache --file=<output>

The first version will print to stdout and the second will generate a file.

Compliance

Moustachu supports the specs found in its specs directory:

Installation

The recommended way to install moustachu is through nimble:

Install nimble. Then do:

$ nimble install moustachu

This will install the latest tagged version of moustachu.

The moustachu package includes the moustachu binary to use on the command line and the moustachu library to use in your code.

Design

Develop and Test

Get the source code:

$ git clone https://github.com/fenekku/moustachu.git
$ cd moustachu
# make your changes ...
# test
$ nimble tests
# run benchmarks
$ nimble benchmarks

This will test against the selected specs copied from mustache/spec

TODO