aboutsummaryrefslogtreecommitdiff
path: root/plugin.go
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2019-12-09 17:54:24 +0100
committerSimon Ser <contact@emersion.fr>2019-12-09 17:54:24 +0100
commit76599232dc8f652e04dfc62258c8707c00f8b7fc (patch)
tree5534451af628a128c1916c7a82df2d3f00b57308 /plugin.go
parentf42cb45457cc0b581a731745593caeed7b770849 (diff)
downloadalps-76599232dc8f652e04dfc62258c8707c00f8b7fc.tar.gz
alps-76599232dc8f652e04dfc62258c8707c00f8b7fc.zip
Add a Lua API to set template filters
Diffstat (limited to 'plugin.go')
-rw-r--r--plugin.go40
1 files changed, 37 insertions, 3 deletions
diff --git a/plugin.go b/plugin.go
index d2737d0..26473b1 100644
--- a/plugin.go
+++ b/plugin.go
@@ -2,6 +2,7 @@ package koushin
import (
"fmt"
+ "html/template"
"path/filepath"
"github.com/labstack/echo/v4"
@@ -11,6 +12,7 @@ import (
type Plugin interface {
Name() string
+ Filters() template.FuncMap
Render(name string, data interface{}) error
Close() error
}
@@ -19,6 +21,7 @@ type luaPlugin struct {
filename string
state *lua.LState
renderCallbacks map[string]*lua.LFunction
+ filters template.FuncMap
}
func (p *luaPlugin) Name() string {
@@ -32,23 +35,53 @@ func (p *luaPlugin) onRender(l *lua.LState) int {
return 0
}
+func (p *luaPlugin) setFilter(l *lua.LState) int {
+ name := l.CheckString(1)
+ f := l.CheckFunction(2)
+ p.filters[name] = func(args... interface{}) string {
+ luaArgs := make([]lua.LValue, len(args))
+ for i, v := range args {
+ luaArgs[i] = luar.New(l, v)
+ }
+
+ err := l.CallByParam(lua.P{
+ Fn: f,
+ NRet: 1,
+ Protect: true,
+ }, luaArgs...)
+ if err != nil {
+ panic(err) // TODO: better error handling?
+ }
+
+ ret := l.CheckString(-1)
+ l.Pop(1)
+ return ret
+ }
+ return 0
+}
+
func (p *luaPlugin) Render(name string, data interface{}) error {
f, ok := p.renderCallbacks[name]
if !ok {
return nil
}
- if err := p.state.CallByParam(lua.P{
+ err := p.state.CallByParam(lua.P{
Fn: f,
NRet: 0,
Protect: true,
- }, luar.New(p.state, data)); err != nil {
+ }, luar.New(p.state, data))
+ if err != nil {
return err
}
return nil
}
+func (p *luaPlugin) Filters() template.FuncMap {
+ return p.filters
+}
+
func (p *luaPlugin) Close() error {
p.state.Close()
return nil
@@ -60,12 +93,13 @@ func loadLuaPlugin(filename string) (*luaPlugin, error) {
filename: filename,
state: l,
renderCallbacks: make(map[string]*lua.LFunction),
+ filters: make(template.FuncMap),
}
mt := l.NewTypeMetatable("koushin")
l.SetGlobal("koushin", mt)
l.SetField(mt, "on_render", l.NewFunction(p.onRender))
- // TODO: set_filter
+ l.SetField(mt, "set_filter", l.NewFunction(p.setFilter))
if err := l.DoFile(filename); err != nil {
l.Close()