Немного корректируем Lua

This commit is contained in:
DBotThePony 2022-02-08 16:02:10 +07:00
parent 0d95044ca3
commit a8af98f715
Signed by: DBot
GPG Key ID: DCC23B5715498507
2 changed files with 48 additions and 58 deletions

View File

@ -2,11 +2,36 @@ package ru.dbotthepony.kstarbound.lua;
import com.sun.jna.Native; import com.sun.jna.Native;
import com.sun.jna.Pointer; import com.sun.jna.Pointer;
import com.sun.jna.ptr.LongByReference;
import java.io.File; import java.io.File;
public final class LuaJNA { public final class LuaJNA {
public static native int lua_pcallk(long p, int numArgs, int numResults, int msgh, Pointer ctx, ILua.lua_KFunction callback); public static native int lua_pcallk(long p, int numArgs, int numResults, int msgh, Pointer ctx, LuaJNADynamic.lua_KFunction callback);
public static native int lua_callk(long p, int numArgs, int numResults, Pointer ctx, LuaJNADynamic.lua_KFunction callback);
public static native Pointer luaL_newstate();
public static native void lua_close(long pointer);
// Стандартные библиотеки
public static native void luaopen_base(long pointer);
public static native void luaopen_package(long pointer);
public static native void luaopen_coroutine(long pointer);
public static native void luaopen_table(long pointer);
public static native void luaopen_io(long pointer);
public static native void luaopen_os(long pointer);
public static native void luaopen_string(long pointer);
public static native void luaopen_math(long pointer);
public static native void luaopen_utf8(long pointer);
public static native void luaopen_debug(long pointer);
public static native int lua_checkstack(long pointer, int value);
public static native int lua_absindex(long pointer, int value);
public static native int lua_gettop(long pointer);
public static native Pointer lua_tolstring(long pointer, int index, LongByReference size);
public static native void lua_setglobal(long pointer, String name);
static { static {
Native.register(new File("./lua54.dll").getAbsolutePath()); Native.register(new File("./lua54.dll").getAbsolutePath());

View File

@ -19,13 +19,10 @@ private typealias psize_t = LongByReference
private typealias lua_KContext = Pointer private typealias lua_KContext = Pointer
interface ILua : Library { interface LuaJNADynamic : Library {
fun luaL_newstate(): Pointer
fun lua_checkstack(luaState: Pointer, amount: Int): Int
fun lua_absindex(luaState: Pointer, value: Int): Int
fun lua_close(luaState: Pointer)
fun lua_atpanic(luaState: Pointer, fn: lua_CFunction): Pointer fun lua_atpanic(luaState: Pointer, fn: lua_CFunction): Pointer
fun lua_load(luaState: Pointer, reader: lua_Reader, data: Pointer?, chunkName: String, mode: String): Int
fun lua_pushlstring(luaState: Pointer, str: Pointer, len: size_t): Pointer?
interface lua_CFunction : Callback { interface lua_CFunction : Callback {
fun invoke(luaState: Pointer): Int fun invoke(luaState: Pointer): Int
@ -35,47 +32,15 @@ interface ILua : Library {
fun invoke(luaState: Pointer, data: Pointer?, size: psize_t): Pointer? /* String */ fun invoke(luaState: Pointer, data: Pointer?, size: psize_t): Pointer? /* String */
} }
fun lua_load(luaState: Pointer, reader: lua_Reader, data: Pointer?, chunkName: String, mode: String): Int
// Оно является макросом
/* fun lua_pcall(luaState: Pointer, numArgs: Int, numResults: Int, msgh: Int): Int {
return lua_pcallk(luaState, numArgs, numResults, msgh, Pointer.NULL, null)
} */
interface lua_KFunction : Callback { interface lua_KFunction : Callback {
/* /*
** Type for continuation functions ** Type for continuation functions
*/ */
fun invoke(luaState: Pointer, status: Int, ctx: lua_KContext?): Int fun invoke(luaState: Pointer, status: Int, ctx: lua_KContext?): Int
} }
fun lua_pcallk(luaState: Pointer, numArgs: Int, numResults: Int, msgh: Int, ctx: lua_KContext?, k: lua_KFunction?): Int
fun lua_callk(luaState: Pointer, numArgs: Int, numResults: Int, ctx: lua_KContext?, k: lua_KFunction?): Int
fun lua_tolstring(luaState: Pointer, index: Int, len: psize_t): Pointer?
fun lua_pushcclosure(luaState: Pointer, fn: lua_CFunction, n: Int)
fun lua_setglobal(luaState: Pointer, name: String)
// Стандартные библиотеки
fun luaopen_base(luaState: Pointer)
fun luaopen_package(luaState: Pointer)
fun luaopen_coroutine(luaState: Pointer)
fun luaopen_table(luaState: Pointer)
fun luaopen_io(luaState: Pointer)
fun luaopen_os(luaState: Pointer)
fun luaopen_string(luaState: Pointer)
fun luaopen_math(luaState: Pointer)
fun luaopen_utf8(luaState: Pointer)
fun luaopen_debug(luaState: Pointer)
fun lua_pushlstring(luaState: Pointer, str: Pointer, len: size_t): Pointer?
fun lua_error(luaState: Pointer): Int
fun lua_gettop(luaState: Pointer): Int
} }
val LUA_JNA: ILua = Native.load("lua54", ILua::class.java) val LUA_JNA: LuaJNADynamic = Native.load("lua54", LuaJNADynamic::class.java)
private fun stringToBuffer(str: String): ByteBuffer { private fun stringToBuffer(str: String): ByteBuffer {
val bytes = str.toByteArray(charset = Charsets.UTF_8) val bytes = str.toByteArray(charset = Charsets.UTF_8)
@ -104,11 +69,11 @@ private fun lua_pushlstring(luaState: Pointer, str: String) {
} }
class LuaState : Closeable { class LuaState : Closeable {
private val pointer = LUA_JNA.luaL_newstate() private val pointer = LuaJNA.luaL_newstate()
private val nativePointer get() = Pointer.nativeValue(pointer) private val nativePointer = Pointer.nativeValue(pointer)
private var destroyed = false private var destroyed = false
private val panicHandler = object : ILua.lua_CFunction { private val panicHandler = object : LuaJNADynamic.lua_CFunction {
override fun invoke(luaState: Pointer): Int { override fun invoke(luaState: Pointer): Int {
throw RuntimeException("$this panicked!") throw RuntimeException("$this panicked!")
} }
@ -120,14 +85,14 @@ class LuaState : Closeable {
LUA_JNA.lua_atpanic(pointer, panicHandler) LUA_JNA.lua_atpanic(pointer, panicHandler)
LUA_JNA.luaopen_base(pointer) LuaJNA.luaopen_base(nativePointer)
LUA_JNA.luaopen_package(pointer) LuaJNA.luaopen_package(nativePointer)
LUA_JNA.luaopen_table(pointer) LuaJNA.luaopen_table(nativePointer)
LUA_JNA.luaopen_coroutine(pointer) LuaJNA.luaopen_coroutine(nativePointer)
LUA_JNA.luaopen_string(pointer) LuaJNA.luaopen_string(nativePointer)
LUA_JNA.luaopen_math(pointer) LuaJNA.luaopen_math(nativePointer)
LUA_JNA.luaopen_utf8(pointer) LuaJNA.luaopen_utf8(nativePointer)
LUA_JNA.luaopen_debug(pointer) LuaJNA.luaopen_debug(nativePointer)
pushClosure { pushClosure {
val build = mutableListOf<String?>() val build = mutableListOf<String?>()
@ -139,7 +104,7 @@ class LuaState : Closeable {
LOGGER.info("Lua/print(): {}", build.joinToString("\t")) LOGGER.info("Lua/print(): {}", build.joinToString("\t"))
} }
LUA_JNA.lua_setglobal(pointer, "print") LuaJNA.lua_setglobal(nativePointer, "print")
} }
fun pushClosure(lambda: (state: LuaState) -> Unit) { fun pushClosure(lambda: (state: LuaState) -> Unit) {
@ -159,17 +124,17 @@ class LuaState : Closeable {
} }
fun checkStack(minAmount: Int): Boolean { fun checkStack(minAmount: Int): Boolean {
return LUA_JNA.lua_checkstack(pointer, minAmount) > 0 return LuaJNA.lua_checkstack(nativePointer, minAmount) > 0
} }
fun absoluteIndex(index: Int): Int { fun absoluteIndex(index: Int): Int {
return LUA_JNA.lua_absindex(pointer, index) return LuaJNA.lua_absindex(nativePointer, index)
} }
fun load(code: String, chunkName: String = "main chunk") { fun load(code: String, chunkName: String = "main chunk") {
val buf = stringToBuffer(code) val buf = stringToBuffer(code)
throwLoadError(LUA_JNA.lua_load(pointer, object : ILua.lua_Reader { throwLoadError(LUA_JNA.lua_load(pointer, object : LuaJNADynamic.lua_Reader {
override fun invoke(luaState: Pointer, data: Pointer?, size: psize_t): Pointer? { override fun invoke(luaState: Pointer, data: Pointer?, size: psize_t): Pointer? {
if (buf.remaining() == 0) { if (buf.remaining() == 0) {
size.value = 0 size.value = 0
@ -196,7 +161,7 @@ class LuaState : Closeable {
fun getString(index: Int = -1, limit: Long = 4096): String? { fun getString(index: Int = -1, limit: Long = 4096): String? {
val len = psize_t() val len = psize_t()
val p = LUA_JNA.lua_tolstring(pointer, absoluteIndex(index), len) ?: return null val p = LuaJNA.lua_tolstring(nativePointer, absoluteIndex(index), len) ?: return null
if (len.value == 0L) { if (len.value == 0L) {
return "" return ""
@ -211,14 +176,14 @@ class LuaState : Closeable {
return readBytes.toString(charset = Charsets.UTF_8) return readBytes.toString(charset = Charsets.UTF_8)
} }
val stackTop get() = LUA_JNA.lua_gettop(pointer) val stackTop get() = LuaJNA.lua_gettop(nativePointer)
override fun close() { override fun close() {
if (destroyed) { if (destroyed) {
throw IllegalStateException("Already destroyed") throw IllegalStateException("Already destroyed")
} }
LUA_JNA.lua_close(pointer) LuaJNA.lua_close(nativePointer)
destroyed = true destroyed = true
} }