feat: add hilbish.sink interface to create sinks

snail
sammyette 2024-12-29 19:21:54 -04:00
parent 56ba00e213
commit 679c7b2974
Signed by: sammyette
GPG Key ID: 904FC49417B44DCD
3 changed files with 44 additions and 14 deletions

4
api.go
View File

@ -23,6 +23,7 @@ import (
"syscall" "syscall"
"time" "time"
"hilbish/sink"
"hilbish/util" "hilbish/util"
rt "github.com/arnodel/golua/runtime" rt "github.com/arnodel/golua/runtime"
@ -133,6 +134,9 @@ func hilbishLoad(rtm *rt.Runtime) (rt.Value, func()) {
pluginModule := moduleLoader(rtm) pluginModule := moduleLoader(rtm)
mod.Set(rt.StringValue("module"), rt.TableValue(pluginModule)) mod.Set(rt.StringValue("module"), rt.TableValue(pluginModule))
sinkModule := sink.Loader(l)
mod.Set(rt.StringValue("sink"), rt.TableValue(sinkModule))
return rt.TableValue(mod), nil return rt.TableValue(mod), nil
} }

2
lua.go
View File

@ -4,7 +4,6 @@ import (
"fmt" "fmt"
"os" "os"
"hilbish/sink"
"hilbish/util" "hilbish/util"
"hilbish/golibs/bait" "hilbish/golibs/bait"
"hilbish/golibs/commander" "hilbish/golibs/commander"
@ -25,7 +24,6 @@ func luaInit() {
MessageHandler: debuglib.Traceback, MessageHandler: debuglib.Traceback,
}) })
lib.LoadAll(l) lib.LoadAll(l)
sink.SetupSinkType(l)
lib.LoadLibs(l, hilbishLoader) lib.LoadLibs(l, hilbishLoader)
// yes this is stupid, i know // yes this is stupid, i know

View File

@ -2,6 +2,7 @@ package sink
import ( import (
"bufio" "bufio"
"bytes"
"fmt" "fmt"
"io" "io"
"os" "os"
@ -18,14 +19,13 @@ var sinkMetaKey = rt.StringValue("hshsink")
// A sink is a structure that has input and/or output to/from // A sink is a structure that has input and/or output to/from
// a desination. // a desination.
type Sink struct{ type Sink struct{
writer *bufio.Writer rw *bufio.ReadWriter
reader *bufio.Reader
file *os.File file *os.File
UserData *rt.UserData UserData *rt.UserData
autoFlush bool autoFlush bool
} }
func SetupSinkType(rtm *rt.Runtime) { func Loader(rtm *rt.Runtime) *rt.Table {
sinkMeta := rt.NewTable() sinkMeta := rt.NewTable()
sinkMethods := rt.NewTable() sinkMethods := rt.NewTable()
@ -65,8 +65,23 @@ func SetupSinkType(rtm *rt.Runtime) {
sinkMeta.Set(rt.StringValue("__index"), rt.FunctionValue(rt.NewGoFunction(sinkIndex, "__index", 2, false))) sinkMeta.Set(rt.StringValue("__index"), rt.FunctionValue(rt.NewGoFunction(sinkIndex, "__index", 2, false)))
rtm.SetRegistry(sinkMetaKey, rt.TableValue(sinkMeta)) rtm.SetRegistry(sinkMetaKey, rt.TableValue(sinkMeta))
exports := map[string]util.LuaExport{
"new": {luaSinkNew, 0, false},
} }
mod := rt.NewTable()
util.SetExports(rtm, mod, exports)
return mod
}
func luaSinkNew(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
snk := NewSink(t.Runtime, new(bytes.Buffer))
return c.PushingNext1(t.Runtime, rt.UserDataValue(snk.UserData)), nil
}
// #member // #member
// readAll() -> string // readAll() -> string
@ -84,7 +99,7 @@ func luaSinkReadAll(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
lines := []string{} lines := []string{}
for { for {
line, err := s.reader.ReadString('\n') line, err := s.rw.ReadString('\n')
if err != nil { if err != nil {
if err == io.EOF { if err == io.EOF {
break break
@ -113,7 +128,7 @@ func luaSinkRead(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
return nil, err return nil, err
} }
str, _ := s.reader.ReadString('\n') str, _ := s.rw.ReadString('\n')
return c.PushingNext1(t.Runtime, rt.StringValue(str)), nil return c.PushingNext1(t.Runtime, rt.StringValue(str)), nil
} }
@ -135,9 +150,9 @@ func luaSinkWrite(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
return nil, err return nil, err
} }
s.writer.Write([]byte(data)) s.rw.Write([]byte(data))
if s.autoFlush { if s.autoFlush {
s.writer.Flush() s.rw.Flush()
} }
return c.Next(), nil return c.Next(), nil
@ -160,9 +175,9 @@ func luaSinkWriteln(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
return nil, err return nil, err
} }
s.writer.Write([]byte(data + "\n")) s.rw.Write([]byte(data + "\n"))
if s.autoFlush { if s.autoFlush {
s.writer.Flush() s.rw.Flush()
} }
return c.Next(), nil return c.Next(), nil
@ -181,7 +196,7 @@ func luaSinkFlush(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
return nil, err return nil, err
} }
s.writer.Flush() s.rw.Flush()
return c.Next(), nil return c.Next(), nil
} }
@ -212,9 +227,22 @@ func luaSinkAutoFlush(t *rt.Thread, c *rt.GoCont) (rt.Cont, error) {
return c.Next(), nil return c.Next(), nil
} }
func NewSink(rtm *rt.Runtime, rw io.ReadWriter) *Sink {
s := &Sink{
rw: bufio.NewReadWriter(bufio.NewReader(rw), bufio.NewWriter(rw)),
}
s.UserData = sinkUserData(rtm, s)
if f, ok := rw.(*os.File); ok {
s.file = f
}
return s
}
func NewSinkInput(rtm *rt.Runtime, r io.Reader) *Sink { func NewSinkInput(rtm *rt.Runtime, r io.Reader) *Sink {
s := &Sink{ s := &Sink{
reader: bufio.NewReader(r), rw: bufio.NewReadWriter(bufio.NewReader(r), nil),
} }
s.UserData = sinkUserData(rtm, s) s.UserData = sinkUserData(rtm, s)
@ -227,7 +255,7 @@ func NewSinkInput(rtm *rt.Runtime, r io.Reader) *Sink {
func NewSinkOutput(rtm *rt.Runtime, w io.Writer) *Sink { func NewSinkOutput(rtm *rt.Runtime, w io.Writer) *Sink {
s := &Sink{ s := &Sink{
writer: bufio.NewWriter(w), rw: bufio.NewReadWriter(nil, bufio.NewWriter(w)),
autoFlush: true, autoFlush: true,
} }
s.UserData = sinkUserData(rtm, s) s.UserData = sinkUserData(rtm, s)