Skip to content

sschober/mustache.go

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Overview

mustache.go is an implementation of the mustache template language in Go. It is better suited for website templates than Go's native pkg/template. mustache.go is fast -- it parses templates efficiently and stores them in a tree-like structure which allows for fast execution.

Documentation

For more information about mustache, check out the [mustache project page] ( http://github.com/defunkt/mustache ).

Also check out some example mustache files

Usage

There are only four methods in this package:

func Render(data string, context interface{}) (string, os.Error)

func RenderFile(filename string, context interface{}) (string, os.Error)

func ParseString(data string) (*template, os.Error)

func ParseFile(filename string) (*template, os.Error) 

The Render method takes a string and a data source, which is generally a map or struct. There's an analagous method, RenderFile, which takes a filename as an argument and uses that for the template contents.

data,_ := mustache.Render("hello {{c}}", map[string]string{"c":"world"})
println(data)

If you're planning to render the same template multiple times, you do it efficiently by compiling the template first:

tmpl,_ := mustache.Parse("hello {{c}}")
var buf bytes.Buffer;
for i := 0; i < 10; i++ {
    tmpl.Render (map[string]string { "c":"world"}, &buf)  
}

For more example usage, please see mustache_test.go

Supported features

  • Variables
  • Comments
  • Change delimiter
  • Sections (boolean and enumerable)
  • Partials
  • Methods (incomplete)

About

The mustache template language in Go

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%