From 1c2bdee5c978aa6555a9a500cc58147c0d80f757 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nguy=E1=BB=85n=20Th=E1=BA=BF=20Nguy=C3=AAn?= Date: Fri, 10 Apr 2015 00:07:35 +0700 Subject: [PATCH] use pongo2 context render html --- examples/pluggable_renderer/example_pongo2.go | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/examples/pluggable_renderer/example_pongo2.go b/examples/pluggable_renderer/example_pongo2.go index 9b79deb5..a4d46403 100644 --- a/examples/pluggable_renderer/example_pongo2.go +++ b/examples/pluggable_renderer/example_pongo2.go @@ -5,7 +5,6 @@ import ( "github.com/flosch/pongo2" "github.com/gin-gonic/gin" - "github.com/gin-gonic/gin/render" ) func main() { @@ -13,10 +12,11 @@ func main() { router.HTMLRender = newPongoRender() router.GET("/index", func(c *gin.Context) { - c.HTML(200, "index.html", gin.H{ + ctx := pongo2.Context{ "title": "Gin meets pongo2 !", - "name": c.Input.Get("name"), - }) + "name": "gin and pongo2", + } + c.HTML(200, "index.html", ctx) }) router.Run(":8080") } @@ -28,7 +28,12 @@ type pongoRender struct { func newPongoRender() *pongoRender { return &pongoRender{map[string]*pongo2.Template{}} } - +func writeHeader(w http.ResponseWriter, code int, contentType string) { + if code >= 0 { + w.Header().Set("Content-Type", contentType) + w.WriteHeader(code) + } +} func (p *pongoRender) Render(w http.ResponseWriter, code int, data ...interface{}) error { file := data[0].(string) ctx := data[1].(pongo2.Context) @@ -44,6 +49,6 @@ func (p *pongoRender) Render(w http.ResponseWriter, code int, data ...interface{ p.cache[file] = tmpl t = tmpl } - render.WriteHeader(w, code, "text/html") + writeHeader(w, code, "text/html") return t.ExecuteWriter(ctx, w) }