code clean
This commit is contained in:
@@ -25,6 +25,6 @@ type Void = [0]byte
|
|||||||
type Future[T any] func(func(T))
|
type Future[T any] func(func(T))
|
||||||
|
|
||||||
// Just for pure LLGo/Go, transpile to callback in Go+
|
// Just for pure LLGo/Go, transpile to callback in Go+
|
||||||
func Await[T1 any](call Future[T1]) (ret T1) {
|
func Await[T1 any](future Future[T1]) T1 {
|
||||||
return Run(call)
|
return Run(future)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,16 +19,7 @@
|
|||||||
|
|
||||||
package async
|
package async
|
||||||
|
|
||||||
var exec = &Executor{}
|
func Run[T any](future Future[T]) T {
|
||||||
|
|
||||||
type Executor struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func Exec() *Executor {
|
|
||||||
return exec
|
|
||||||
}
|
|
||||||
|
|
||||||
func Run[T any](future Future[T]) (ret T) {
|
|
||||||
ch := make(chan T)
|
ch := make(chan T)
|
||||||
go func() {
|
go func() {
|
||||||
future(func(v T) {
|
future(func(v T) {
|
||||||
|
|||||||
@@ -54,15 +54,16 @@ func (e *Executor) Run() {
|
|||||||
e.L.Run(libuv.RUN_DEFAULT)
|
e.L.Run(libuv.RUN_DEFAULT)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Run[T any](future Future[T]) (ret T) {
|
func Run[T any](future Future[T]) T {
|
||||||
loop := libuv.LoopNew()
|
loop := libuv.LoopNew()
|
||||||
exec := &Executor{loop}
|
exec := &Executor{loop}
|
||||||
oldExec := setExec(exec)
|
oldExec := setExec(exec)
|
||||||
|
var ret T
|
||||||
future(func(v T) {
|
future(func(v T) {
|
||||||
ret = v
|
ret = v
|
||||||
})
|
})
|
||||||
exec.Run()
|
exec.Run()
|
||||||
loop.Close()
|
loop.Close()
|
||||||
setExec(oldExec)
|
setExec(oldExec)
|
||||||
return
|
return ret
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -52,22 +52,22 @@ type bind3[Base any, A any, B any, C any] struct {
|
|||||||
fn func(*Base, A, B, C)
|
fn func(*Base, A, B, C)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Callback[Base any](base *Base) {
|
func callback[Base any](base *Base) {
|
||||||
bind := (*bind[Base])(unsafe.Pointer(base))
|
bind := (*bind[Base])(unsafe.Pointer(base))
|
||||||
bind.fn(base)
|
bind.fn(base)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Callback1[Base any, A any](base *Base, a A) {
|
func callback1[Base any, A any](base *Base, a A) {
|
||||||
bind := (*bind1[Base, A])(unsafe.Pointer(base))
|
bind := (*bind1[Base, A])(unsafe.Pointer(base))
|
||||||
bind.fn(base, a)
|
bind.fn(base, a)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Callback2[Base any, A any, B any](base *Base, a A, b B) {
|
func callback2[Base any, A any, B any](base *Base, a A, b B) {
|
||||||
bind := (*bind2[Base, A, B])(unsafe.Pointer(base))
|
bind := (*bind2[Base, A, B])(unsafe.Pointer(base))
|
||||||
bind.fn(base, a, b)
|
bind.fn(base, a, b)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Callback3[Base any, A any, B any, C any](base *Base, a A, b B, c C) {
|
func callback3[Base any, A any, B any, C any](base *Base, a A, b B, c C) {
|
||||||
bind := (*bind3[Base, A, B, C])(unsafe.Pointer(base))
|
bind := (*bind3[Base, A, B, C])(unsafe.Pointer(base))
|
||||||
bind.fn(base, a, b, c)
|
bind.fn(base, a, b, c)
|
||||||
}
|
}
|
||||||
@@ -89,55 +89,55 @@ func Callback3[Base any, A any, B any, C any](base *Base, a A, b B, c C) {
|
|||||||
func Bind[T any](call func(*T)) (p *T, cb Cb[T]) {
|
func Bind[T any](call func(*T)) (p *T, cb Cb[T]) {
|
||||||
bb := &bind[T]{fn: call}
|
bb := &bind[T]{fn: call}
|
||||||
p = (*T)(unsafe.Pointer(bb))
|
p = (*T)(unsafe.Pointer(bb))
|
||||||
cb = Callback[T]
|
cb = callback[T]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func BindF[T any, F ~func(*T)](call func(*T)) (*T, F) {
|
func BindF[T any, F ~func(*T)](call func(*T)) (*T, F) {
|
||||||
bb := &bind[T]{fn: call}
|
bb := &bind[T]{fn: call}
|
||||||
p := (*T)(unsafe.Pointer(bb))
|
p := (*T)(unsafe.Pointer(bb))
|
||||||
var fn F = Callback[T]
|
var fn F = callback[T]
|
||||||
return p, fn
|
return p, fn
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind1[T any, A any](call func(*T, A)) (p *T, cb Cb1[T, A]) {
|
func Bind1[T any, A any](call func(*T, A)) (p *T, cb Cb1[T, A]) {
|
||||||
bb := &bind1[T, A]{fn: call}
|
bb := &bind1[T, A]{fn: call}
|
||||||
p = (*T)(unsafe.Pointer(bb))
|
p = (*T)(unsafe.Pointer(bb))
|
||||||
cb = Callback1[T, A]
|
cb = callback1[T, A]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind1F[T any, F ~func(*T, A), A any](call func(*T, A)) (*T, F) {
|
func Bind1F[T any, F ~func(*T, A), A any](call func(*T, A)) (*T, F) {
|
||||||
bb := &bind1[T, A]{fn: call}
|
bb := &bind1[T, A]{fn: call}
|
||||||
p := (*T)(unsafe.Pointer(bb))
|
p := (*T)(unsafe.Pointer(bb))
|
||||||
var fn F = Callback1[T, A]
|
var fn F = callback1[T, A]
|
||||||
return p, fn
|
return p, fn
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind2[T any, A any, B any](call func(*T, A, B)) (p *T, cb Cb2[T, A, B]) {
|
func Bind2[T any, A any, B any](call func(*T, A, B)) (p *T, cb Cb2[T, A, B]) {
|
||||||
bb := &bind2[T, A, B]{fn: call}
|
bb := &bind2[T, A, B]{fn: call}
|
||||||
p = (*T)(unsafe.Pointer(bb))
|
p = (*T)(unsafe.Pointer(bb))
|
||||||
cb = Callback2[T, A, B]
|
cb = callback2[T, A, B]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind2F[T any, F ~func(*T, A, B), A any, B any](call func(*T, A, B)) (*T, F) {
|
func Bind2F[T any, F ~func(*T, A, B), A any, B any](call func(*T, A, B)) (*T, F) {
|
||||||
bb := &bind2[T, A, B]{fn: call}
|
bb := &bind2[T, A, B]{fn: call}
|
||||||
p := (*T)(unsafe.Pointer(bb))
|
p := (*T)(unsafe.Pointer(bb))
|
||||||
var fn F = Callback2[T, A, B]
|
var fn F = callback2[T, A, B]
|
||||||
return p, fn
|
return p, fn
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind3[T any, A any, B any, C any](call func(*T, A, B, C), a A, b B, c C) (p *T, cb Cb3[T, A, B, C]) {
|
func Bind3[T any, A any, B any, C any](call func(*T, A, B, C), a A, b B, c C) (p *T, cb Cb3[T, A, B, C]) {
|
||||||
bb := &bind3[T, A, B, C]{fn: call}
|
bb := &bind3[T, A, B, C]{fn: call}
|
||||||
p = (*T)(unsafe.Pointer(bb))
|
p = (*T)(unsafe.Pointer(bb))
|
||||||
cb = Callback3[T, A, B, C]
|
cb = callback3[T, A, B, C]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func Bind3F[T any, F ~func(*T, A, B, C), A any, B any, C any](call func(*T, A, B, C), a A, b B, c C) (*T, F) {
|
func Bind3F[T any, F ~func(*T, A, B, C), A any, B any, C any](call func(*T, A, B, C), a A, b B, c C) (*T, F) {
|
||||||
bb := &bind3[T, A, B, C]{fn: call}
|
bb := &bind3[T, A, B, C]{fn: call}
|
||||||
p := (*T)(unsafe.Pointer(bb))
|
p := (*T)(unsafe.Pointer(bb))
|
||||||
var fn F = Callback3[T, A, B, C]
|
var fn F = callback3[T, A, B, C]
|
||||||
return p, fn
|
return p, fn
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -241,7 +241,7 @@ func (t *Conn) Read() async.Future[tuple.Tuple2[[]byte, error]] {
|
|||||||
|
|
||||||
func (t *Conn) Write(data []byte) async.Future[error] {
|
func (t *Conn) Write(data []byte) async.Future[error] {
|
||||||
return async.Async(func(resolve func(error)) {
|
return async.Async(func(resolve func(error)) {
|
||||||
writer, _ := cbind.Bind1[libuv.Write](func(req *libuv.Write, status c.Int) {
|
writer, cb := cbind.Bind1F[libuv.Write, libuv.WriteCb](func(req *libuv.Write, status c.Int) {
|
||||||
var result error
|
var result error
|
||||||
if status != 0 {
|
if status != 0 {
|
||||||
result = libuvError(libuv.Errno(status))
|
result = libuvError(libuv.Errno(status))
|
||||||
@@ -251,7 +251,7 @@ func (t *Conn) Write(data []byte) async.Future[error] {
|
|||||||
tcp := (*libuv.Stream)(&t.tcp)
|
tcp := (*libuv.Stream)(&t.tcp)
|
||||||
buf, len := cbind.CBuffer(data)
|
buf, len := cbind.CBuffer(data)
|
||||||
bufs := &libuv.Buf{Base: buf, Len: uintptr(len)}
|
bufs := &libuv.Buf{Base: buf, Len: uintptr(len)}
|
||||||
writer.Write(tcp, bufs, 1, cbind.Callback1[libuv.Write, c.Int])
|
writer.Write(tcp, bufs, 1, cb)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user