diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-07-25 00:49:20 +1000 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2023-07-25 00:49:20 +1000 |
commit | ea084165bf2f414a49a559ddf5921b9073fc464c (patch) | |
tree | c8f1263d9e11600f3632df2d0202cb884673c97e /source/core/StarLua.cpp | |
parent | 8547c56ba4607e1c4efac483f97f01b8ba8c3a01 (diff) |
Optimize entityPortrait: Drawable > LuaTable instead of Drawable > Json > LuaTable
Diffstat (limited to 'source/core/StarLua.cpp')
-rw-r--r-- | source/core/StarLua.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/source/core/StarLua.cpp b/source/core/StarLua.cpp index 901e875..41355b1 100644 --- a/source/core/StarLua.cpp +++ b/source/core/StarLua.cpp @@ -461,7 +461,7 @@ ByteArray LuaEngine::compile(ByteArray const& contents, String const& name) { LuaString LuaEngine::createString(String const& str) { lua_checkstack(m_state, 1); - if (m_nullTerminated) + if (m_nullTerminated > 0) lua_pushstring(m_state, str.utf8Ptr()); else lua_pushlstring(m_state, str.utf8Ptr(), str.utf8Size()); @@ -556,6 +556,10 @@ LuaNullEnforcer LuaEngine::nullTerminate() { return LuaNullEnforcer(*this); } +void LuaEngine::setNullTerminated(bool nullTerminated) { + m_nullTerminated = nullTerminated ? 0 : INT_MIN; +} + LuaEngine* LuaEngine::luaEnginePtr(lua_State* state) { return (*reinterpret_cast<LuaEngine**>(lua_getextraspace(state))); } @@ -723,7 +727,7 @@ char const* LuaEngine::stringPtr(int handleIndex) { } size_t LuaEngine::stringLength(int handleIndex) { - if (m_nullTerminated) + if (m_nullTerminated > 0) return strlen(lua_tostring(m_handleThread, handleIndex)); else { size_t len = 0; @@ -733,7 +737,7 @@ size_t LuaEngine::stringLength(int handleIndex) { } String LuaEngine::string(int handleIndex) { - if (m_nullTerminated) + if (m_nullTerminated > 0) return String(lua_tostring(m_handleThread, handleIndex)); else { size_t len = 0; @@ -743,7 +747,7 @@ String LuaEngine::string(int handleIndex) { } StringView LuaEngine::stringView(int handleIndex) { - if (m_nullTerminated) + if (m_nullTerminated > 0) return StringView(lua_tostring(m_handleThread, handleIndex)); else { size_t len = 0; |