fix: just pass C pointers in NewState & PushCClosureK

This commit is contained in:
Erica Marigold 2024-07-18 22:04:27 +05:30
parent 594added91
commit 1e26c9cac0
No known key found for this signature in database
GPG key ID: 2768CC0C23D245D1
4 changed files with 34 additions and 21 deletions

View file

@ -2,14 +2,15 @@
#include <lua.h> #include <lua.h>
#include <_cgo_export.h> #include <_cgo_export.h>
void* clua_alloc(void* ud, void *ptr, size_t osize, size_t nsize) // void* clua_alloc(void* ud, void *ptr, size_t osize, size_t nsize)
{ // {
return (void*) go_allocf((GoUintptr) ud,(GoUintptr) ptr, osize, nsize); // return (void*) go_allocf((GoUintptr) ud,(GoUintptr) ptr, osize, nsize);
} // }
lua_State* clua_newstate(void* goallocf)
lua_State* clua_newstate(void* f, void* ud)
{ {
return lua_newstate(&clua_alloc, goallocf); return lua_newstate((lua_Alloc)f, ud);
} }
l_noret cluaL_errorL(lua_State* L, char* msg) l_noret cluaL_errorL(lua_State* L, char* msg)
@ -18,5 +19,5 @@ l_noret cluaL_errorL(lua_State* L, char* msg)
} }
void clua_pushcclosurek(lua_State* L, void* f, char* debugname, int nup, void* cont) { void clua_pushcclosurek(lua_State* L, void* f, char* debugname, int nup, void* cont) {
return lua_pushcclosurek(L, f, debugname, nup, cont); return lua_pushcclosurek(L, (lua_CFunction)f, debugname, nup, (lua_Continuation)cont);
} }

View file

@ -1,7 +1,6 @@
#include <stdlib.h> #include <stdlib.h>
#include <lua.h> #include <lua.h>
void* clua_alloc(void* ud, void *ptr, size_t osize, size_t nsize); lua_State* clua_newstate(void* f, void* ud);
lua_State* clua_newstate(void* goallocf);
l_noret cluaL_errorL(lua_State* L, char* msg); l_noret cluaL_errorL(lua_State* L, char* msg);
void clua_pushcclosurek(lua_State* L, void* f, char* debugname, int nup, void* cont); void clua_pushcclosurek(lua_State* L, void* f, char* debugname, int nup, void* cont);

View file

@ -22,14 +22,13 @@ type LuaContinuation func(L *LuaState, status int32) int32
type LuaUDestructor = func(*C.void) type LuaUDestructor = func(*C.void)
type LuaDestructor = func(L *LuaState, _ unsafe.Pointer) type LuaDestructor = func(L *LuaState, _ unsafe.Pointer)
// type LuaAlloc = func(ud, ptr *C.void, osize, nsize C.size_t) *C.void type LuaAlloc = func(ud, ptr unsafe.Pointer, osize, nsize C.size_t) *C.void
type LuaAlloc = func(ptr unsafe.Pointer, osize, nsize uint64) unsafe.Pointer
//export go_allocf // TODO: Figure out when to C.malloc, and when to pass Go ptr
func go_allocf(fp uintptr, ptr uintptr, osize uint64, nsize uint64) uintptr { // Answer: If C frees some memory, then it's to be C.malloc'd, else pass go ptr
p := ((*((*LuaAlloc)(unsafe.Pointer(fp))))(unsafe.Pointer(ptr), osize, nsize)) // Basically, some lua functions will manage memory themselves, and in that case
return uintptr(p) // we give them a C pointer - else we manage it ourselves. Technically you can give
} // everything a C pointer, but you don't need to!
// //
// ================== // ==================
@ -37,8 +36,14 @@ func go_allocf(fp uintptr, ptr uintptr, osize uint64, nsize uint64) uintptr {
// ================== // ==================
// //
func NewState(ud unsafe.Pointer) *LuaState { func NewState(f LuaAlloc, ud unsafe.Pointer) *LuaState {
return C.clua_newstate(unsafe.Pointer(ud)) cf := C.malloc(C.size_t(unsafe.Sizeof(f)))
*(*LuaAlloc)(cf) = f
cud := C.malloc(C.size_t(unsafe.Sizeof(ud)))
cud = ud
return C.clua_newstate(cf, cud)
} }
func LuaClose(L *LuaState) { func LuaClose(L *LuaState) {
@ -299,10 +304,14 @@ func PushCClosureK(L *LuaState, f LuaCFunction, debugname string, nup int32, con
if cont == nil { if cont == nil {
ccont = C.NULL ccont = C.NULL
} else { } else {
ccont = C.malloc(C.size_t(unsafe.Sizeof(cont)))
ccont = unsafe.Pointer(&cont) ccont = unsafe.Pointer(&cont)
} }
C.clua_pushcclosurek(L, unsafe.Pointer(&f), cdebugname, C.int(nup), ccont) cf := C.malloc(C.size_t(unsafe.Sizeof(f)))
*(*LuaCFunction)(cf) = f
C.clua_pushcclosurek(L, cf, cdebugname, C.int(nup), ccont)
} }
// TODO: Rest of it // TODO: Rest of it

View file

@ -4,10 +4,14 @@ import lualib "github.com/CompeyDev/lei/internal"
func main() { func main() {
lua := lualib.LNewState() lua := lualib.LNewState()
println("Lua VM Address: ", lua)
lualib.PushCClosureK(lua, func(L *lualib.LuaState) int32 { lualib.PushCClosureK(lua, func(L *lualib.LuaState) int32 {
println("hi from closure?") println("hi from closure?")
return 0 return 0
}, "test", 0, nil) }, "test", 0, nil)
println(lua) if !lualib.IsCFunction(lua, 1) {
panic("CFunction was not correctly pushed onto stack")
}
} }