Integrate templates into bindata optionally (#314)
Integrated optional bindata for the templatestokarchuk/v1.17
parent
1b5b297c39
commit
83ed234472
@ -0,0 +1,103 @@ |
||||
// +build !bindata
|
||||
|
||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||
// Use of this source code is governed by a MIT-style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package templates |
||||
|
||||
import ( |
||||
"html/template" |
||||
"io/ioutil" |
||||
"path" |
||||
"strings" |
||||
|
||||
"code.gitea.io/gitea/modules/log" |
||||
"code.gitea.io/gitea/modules/setting" |
||||
"github.com/Unknwon/com" |
||||
"gopkg.in/macaron.v1" |
||||
) |
||||
|
||||
var ( |
||||
templates = template.New("") |
||||
) |
||||
|
||||
// Renderer implements the macaron handler for serving the templates.
|
||||
func Renderer() macaron.Handler { |
||||
return macaron.Renderer(macaron.RenderOptions{ |
||||
Funcs: NewFuncMap(), |
||||
Directory: path.Join(setting.StaticRootPath, "templates"), |
||||
AppendDirectories: []string{ |
||||
path.Join(setting.CustomPath, "templates"), |
||||
}, |
||||
}) |
||||
} |
||||
|
||||
// Mailer provides the templates required for sending notification mails.
|
||||
func Mailer() *template.Template { |
||||
for _, funcs := range NewFuncMap() { |
||||
templates.Funcs(funcs) |
||||
} |
||||
|
||||
staticDir := path.Join(setting.StaticRootPath, "templates", "mail") |
||||
|
||||
if com.IsDir(staticDir) { |
||||
files, err := com.StatDir(staticDir) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read %s templates dir. %v", staticDir, err) |
||||
} else { |
||||
for _, filePath := range files { |
||||
if !strings.HasSuffix(filePath, ".tmpl") { |
||||
continue |
||||
} |
||||
|
||||
content, err := ioutil.ReadFile(path.Join(staticDir, filePath)) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read static %s template. %v", filePath, err) |
||||
continue |
||||
} |
||||
|
||||
templates.New( |
||||
strings.TrimSuffix( |
||||
filePath, |
||||
".tmpl", |
||||
), |
||||
).Parse(string(content)) |
||||
} |
||||
} |
||||
} |
||||
|
||||
customDir := path.Join(setting.CustomPath, "templates", "mail") |
||||
|
||||
if com.IsDir(customDir) { |
||||
files, err := com.StatDir(customDir) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read %s templates dir. %v", customDir, err) |
||||
} else { |
||||
for _, filePath := range files { |
||||
if !strings.HasSuffix(filePath, ".tmpl") { |
||||
continue |
||||
} |
||||
|
||||
content, err := ioutil.ReadFile(path.Join(customDir, filePath)) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read custom %s template. %v", filePath, err) |
||||
continue |
||||
} |
||||
|
||||
templates.New( |
||||
strings.TrimSuffix( |
||||
filePath, |
||||
".tmpl", |
||||
), |
||||
).Parse(string(content)) |
||||
} |
||||
} |
||||
} |
||||
|
||||
return templates |
||||
} |
@ -0,0 +1,109 @@ |
||||
// +build bindata
|
||||
|
||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||
// Use of this source code is governed by a MIT-style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package templates |
||||
|
||||
import ( |
||||
"html/template" |
||||
"io/ioutil" |
||||
"path" |
||||
"strings" |
||||
|
||||
"code.gitea.io/gitea/modules/log" |
||||
"code.gitea.io/gitea/modules/setting" |
||||
"github.com/Unknwon/com" |
||||
"github.com/go-macaron/bindata" |
||||
"gopkg.in/macaron.v1" |
||||
) |
||||
|
||||
var ( |
||||
templates = template.New("") |
||||
) |
||||
|
||||
// Renderer implements the macaron handler for serving the templates.
|
||||
func Renderer() macaron.Handler { |
||||
return macaron.Renderer(macaron.RenderOptions{ |
||||
Funcs: NewFuncMap(), |
||||
AppendDirectories: []string{ |
||||
path.Join(setting.CustomPath, "templates"), |
||||
}, |
||||
TemplateFileSystem: bindata.Templates( |
||||
bindata.Options{ |
||||
Asset: Asset, |
||||
AssetDir: AssetDir, |
||||
AssetInfo: AssetInfo, |
||||
AssetNames: AssetNames, |
||||
Prefix: "", |
||||
}, |
||||
), |
||||
}) |
||||
} |
||||
|
||||
// Mailer provides the templates required for sending notification mails.
|
||||
func Mailer() *template.Template { |
||||
for _, funcs := range NewFuncMap() { |
||||
templates.Funcs(funcs) |
||||
} |
||||
|
||||
for _, assetPath := range AssetNames() { |
||||
if !strings.HasPrefix(assetPath, "mail/") { |
||||
continue |
||||
} |
||||
|
||||
if !strings.HasSuffix(assetPath, ".tmpl") { |
||||
continue |
||||
} |
||||
|
||||
content, err := Asset(assetPath) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read embedded %s template. %v", assetPath, err) |
||||
continue |
||||
} |
||||
|
||||
templates.New( |
||||
strings.TrimPrefix( |
||||
strings.TrimSuffix( |
||||
assetPath, |
||||
".tmpl", |
||||
), |
||||
"mail/", |
||||
), |
||||
).Parse(string(content)) |
||||
} |
||||
|
||||
customDir := path.Join(setting.CustomPath, "templates", "mail") |
||||
|
||||
if com.IsDir(customDir) { |
||||
files, err := com.StatDir(customDir) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read %s templates dir. %v", customDir, err) |
||||
} else { |
||||
for _, filePath := range files { |
||||
if !strings.HasSuffix(filePath, ".tmpl") { |
||||
continue |
||||
} |
||||
|
||||
content, err := ioutil.ReadFile(path.Join(customDir, filePath)) |
||||
|
||||
if err != nil { |
||||
log.Warn("Failed to read custom %s template. %v", filePath, err) |
||||
continue |
||||
} |
||||
|
||||
templates.New( |
||||
strings.TrimSuffix( |
||||
filePath, |
||||
".tmpl", |
||||
), |
||||
).Parse(string(content)) |
||||
} |
||||
} |
||||
} |
||||
|
||||
return templates |
||||
} |
@ -0,0 +1,10 @@ |
||||
// Copyright 2016 The Gitea Authors. All rights reserved.
|
||||
// Use of this source code is governed by a MIT-style
|
||||
// license that can be found in the LICENSE file.
|
||||
|
||||
package templates |
||||
|
||||
//go:generate go-bindata -tags "bindata" -ignore "\\.go" -pkg "templates" -o "bindata.go" ../../templates/...
|
||||
//go:generate go fmt bindata.go
|
||||
//go:generate sed -i.bak s/..\/..\/templates\/// bindata.go
|
||||
//go:generate rm -f bindata.go.bak
|
@ -1 +0,0 @@ |
||||
0.9.99.0915 |
Loading…
Reference in new issue