Moustachu
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.
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:
- comments
- interpolation
- inverted
- partials
- sections
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
- Make the interfaces with the data structures as dynamic-like as possible
- No lambdas, nor set delimiters. At least for now. Let's keep it simple please.
Test
Get the source code:
$ git clone https://github.com/fenekku/moustachu.git
$ cd moustachu
$ nim c -r runTests.nim
This will test against the selected specs copied from mustache/spec
TODO
- Use to see what else to do/fix