mstch/README.md

68 lines
1.2 KiB
Markdown
Raw Permalink Normal View History

2015-04-24 01:35:29 +02:00
# mstch - {{mustache}} templates in C++11
mstch is a complete implementation of [{{mustache}}](http://mustache.github.io/) templates using modern C++.
2015-04-24 01:48:42 +02:00
2015-04-24 01:35:29 +02:00
[![Build Status](https://travis-ci.org/no1msd/mstch.svg?branch=master)](https://travis-ci.org/no1msd/mstch)
## Basic usage
```c++
#include <iostream>
#include <mstch/mstch.hpp>
int main() {
std::string view{"{{#names}}Hi {{name}}!\n{{/names}}"};
mstch::map context{
{"names", mstch::array{
2015-04-24 01:37:09 +02:00
mstch::map{{"name", std::string{"Chris"}}},
mstch::map{{"name", std::string{"Mark"}}},
mstch::map{{"name", std::string{"Scott"}}},
}}
2015-04-24 01:35:29 +02:00
};
std::cout << mstch::render(view, context) << std::endl;
return 0;
}
```
The output of this example will be:
```
2015-04-24 01:48:42 +02:00
Hi Chris!
Hi Mark!
Hi Scott!
2015-04-24 01:35:29 +02:00
```
## Requirements
- A C++ compiler with decent C++11 support. Currently only tested with GCC 4.9.
- Boost 1.54
- CMake for building
2015-04-24 01:48:42 +02:00
## Installing
2015-04-24 01:35:29 +02:00
From the root of the source tree:
```bash
$ mkdir build
$ cd build
$ cmake ..
$ make
2015-04-24 01:48:42 +02:00
$ make install
2015-04-24 01:35:29 +02:00
```
2015-04-24 01:48:42 +02:00
### Running the unit tests
2015-04-24 01:35:29 +02:00
```bash
$ mkdir build
$ cd build
$ cmake -DWITH_UNIT_TESTS=ON ..
$ make
$ make test
```
2015-04-24 01:48:42 +02:00
## Advanced usage
2015-04-24 01:35:29 +02:00
TODO