Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
kataras committed Feb 15, 2020
1 parent b841bf6 commit fc59ff0
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 9 deletions.
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ require (
github.com/iris-contrib/go.uuid v2.0.0+incompatible
github.com/iris-contrib/pongo2 v0.0.1
github.com/iris-contrib/schema v0.0.1
github.com/iris-contrib/jade v1.1.1
github.com/iris-contrib/jade v1.1.2
github.com/json-iterator/go v1.1.9
github.com/kataras/golog v0.0.10
github.com/kataras/neffos v0.0.14
Expand Down
23 changes: 15 additions & 8 deletions view/pug.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"bytes"
"io/ioutil"
"path"
"strings"

"github.com/iris-contrib/jade"
)
Expand All @@ -22,28 +23,34 @@ import (
// https://github.com/kataras/iris/tree/master/_examples/view/template_pug_3
func Pug(directory, extension string) *HTMLEngine {
s := HTML(directory, extension)

s.middleware = func(name string, text []byte) (contents string, err error) {
name = path.Join(path.Clean(directory), name)
tmpl := jade.New(name)
// Fixes: https://github.com/kataras/iris/issues/1450
// by adding a custom ReadFunc inside the jade parser.
// And Also able to use relative paths on "extends" and "include" directives:
// e.g. instead of extends "templates/layout.pug" we use "layout.pug"
// so contents of templates are independent of their root location.
tmpl.ReadFunc = func(name string) ([]byte, error) {
name = path.Join(directory, name)
if !strings.HasPrefix(path.Clean(name), path.Clean(directory)) {
name = path.Join(directory, name)
}

if s.assetFn != nil {
return s.assetFn(name)
}
return ioutil.ReadFile(name)
}

tmpl, err = tmpl.Parse(text)
// Fixes: https://github.com/kataras/iris/issues/1450
// by adding a custom ReadFunc inside the jade parser.
// And Also able to use relative paths on "extends" and "include" directives:
// e.g. instead of extends "templates/layout.pug" we use "layout.pug"
// so contents of templates are independent of their root location.

exec, err := tmpl.Parse(text)
if err != nil {
return
}

b := new(bytes.Buffer)
tmpl.WriteIn(b)
exec.WriteIn(b)
return b.String(), nil
}
return s
Expand Down

0 comments on commit fc59ff0

Please sign in to comment.