Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Global variable and default value for resource names #3363

Merged
merged 21 commits into from
Jun 30, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions Client/mods/deathmatch/logic/lua/CLuaMain.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -170,6 +170,9 @@ void CLuaMain::InitVM()
lua_pushelement(m_luaVM, m_pResource->GetResourceEntity());
lua_setglobal(m_luaVM, "resourceRoot");

lua_pushstring(m_luaVM, m_pResource->GetName());
lua_setglobal(m_luaVM, "resourceName");

lua_pushelement(m_luaVM, m_pResource->GetResourceGUIEntity());
lua_setglobal(m_luaVM, "guiRoot");

Expand Down
42 changes: 17 additions & 25 deletions Client/mods/deathmatch/logic/luadefs/CLuaResourceDefs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@
*****************************************************************************/

#include "StdInc.h"
#include <lua/CLuaFunctionParser.h>

using std::list;

void CLuaResourceDefs::LoadFunctions()
Expand All @@ -18,7 +20,7 @@ void CLuaResourceDefs::LoadFunctions()
{"call", Call},
{"getThisResource", GetThisResource},
{"getResourceConfig", GetResourceConfig},
{"getResourceName", GetResourceName},
{"getResourceName", ArgumentParserWarn<false, GetResourceName>},
{"getResourceFromName", GetResourceFromName},
{"getResourceRootElement", GetResourceRootElement},
{"getResourceGUIElement", GetResourceGUIElement},
Expand Down Expand Up @@ -220,34 +222,24 @@ int CLuaResourceDefs::GetResourceConfig(lua_State* luaVM)
return 1;
}

int CLuaResourceDefs::GetResourceName(lua_State* luaVM)
std::string CLuaResourceDefs::GetResourceName(lua_State* luaVM, std::optional<CResource*> resourceElement)
{
// Verify arguments
CResource* pResource = NULL;
CScriptArgReader argStream(luaVM);
argStream.ReadUserData(pResource);

if (!argStream.HasErrors())
if (resourceElement && resourceElement.has_value())
{
if (pResource)
{
// Grab its name and return it
const char* szName = pResource->GetName();
if (szName)
{
lua_pushstring(luaVM, szName);
return 1;
}
}
else
m_pScriptDebugging->LogBadPointer(luaVM, "resource", 1);
return (*resourceElement)->GetName();
}
else
m_pScriptDebugging->LogCustom(luaVM, argStream.GetFullErrorMessage());

// Failed
lua_pushboolean(luaVM, false);
return 1;
CLuaMain* localVM = m_pLuaManager->GetVirtualMachine(luaVM);

if (!localVM)
throw std::invalid_argument("Couldn't find the virtual machine");

CResource* localResource = localVM->GetResource();

if (!localResource)
throw std::invalid_argument("Couldn't find the resource");

return localResource->GetName();
}

int CLuaResourceDefs::GetResourceFromName(lua_State* luaVM)
Expand Down
3 changes: 2 additions & 1 deletion Client/mods/deathmatch/logic/luadefs/CLuaResourceDefs.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@ class CLuaResourceDefs : public CLuaDefs
LUA_DECLARE(Call);
LUA_DECLARE(GetThisResource);
LUA_DECLARE(GetResourceConfig);
LUA_DECLARE(GetResourceName);
LUA_DECLARE(GetResourceFromName);
LUA_DECLARE(GetResourceRootElement);
LUA_DECLARE(GetResourceGUIElement);
Expand All @@ -30,4 +29,6 @@ class CLuaResourceDefs : public CLuaDefs
LUA_DECLARE(GetResourceState);
LUA_DECLARE(LoadString);
LUA_DECLARE(Load);

static std::string GetResourceName(lua_State* luaVM, std::optional<CResource*> resourceElement);
};
3 changes: 3 additions & 0 deletions Server/mods/deathmatch/logic/lua/CLuaMain.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,9 @@ void CLuaMain::Initialize()

lua_pushelement(m_luaVM, m_pResource->GetResourceRootElement());
lua_setglobal(m_luaVM, "resourceRoot");

lua_pushstring(m_luaVM, m_pResource->GetName());
lua_setglobal(m_luaVM, "resourceName");
}

void CLuaMain::LoadEmbeddedScripts()
Expand Down
35 changes: 21 additions & 14 deletions Server/mods/deathmatch/logic/luadefs/CLuaResourceDefs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ void CLuaResourceDefs::LoadFunctions()
{"getResourceLoadFailureReason", getResourceLoadFailureReason},
{"getResourceLastStartTime", getResourceLastStartTime},
{"getResourceLoadTime", getResourceLoadTime},
{"getResourceName", getResourceName},
{"getResourceName", ArgumentParserWarn<false, GetResourceName>},
{"getResourceRootElement", getResourceRootElement},
{"getResourceDynamicElementRoot", getResourceDynamicElementRoot},
{"getResourceMapRootElement", getResourceMapRootElement},
Expand Down Expand Up @@ -898,23 +898,30 @@ int CLuaResourceDefs::getResourceLoadTime(lua_State* luaVM)
return 1;
}

int CLuaResourceDefs::getResourceName(lua_State* luaVM)
std::string CLuaResourceDefs::GetResourceName(lua_State* luaVM, std::optional<CResource*> resourceElement)
{
CResource* pResource;

CScriptArgReader argStream(luaVM);
argStream.ReadUserData(pResource);

if (!argStream.HasErrors())
if (resourceElement && resourceElement.has_value())
{
lua_pushstring(luaVM, pResource->GetName().c_str());
return 1;
if (!(*resourceElement)->IsActive())
throw std::invalid_argument("The resource isn't active");

return (*resourceElement)->GetName();
}
else
m_pScriptDebugging->LogCustom(luaVM, argStream.GetFullErrorMessage());

lua_pushboolean(luaVM, false);
return 1;
CLuaMain* localVM = m_pLuaManager->GetVirtualMachine(luaVM);

if (!localVM)
throw std::invalid_argument("Couldn't find the virtual machine");

CResource* localResource = localVM->GetResource();

if (!localResource)
throw std::invalid_argument("Couldn't find the resource");

if (!localResource->IsActive())
throw std::invalid_argument("The resource isn't active");

return localResource->GetName();
}

int CLuaResourceDefs::getResourceRootElement(lua_State* luaVM)
Expand Down
3 changes: 2 additions & 1 deletion Server/mods/deathmatch/logic/luadefs/CLuaResourceDefs.h
Original file line number Diff line number Diff line change
Expand Up @@ -47,14 +47,15 @@ class CLuaResourceDefs : public CLuaDefs
LUA_DECLARE(getResourceLoadFailureReason);
LUA_DECLARE(getResourceLastStartTime);
LUA_DECLARE(getResourceLoadTime);
LUA_DECLARE(getResourceName);
LUA_DECLARE(getResourceRootElement);
LUA_DECLARE(getResourceDynamicElementRoot);
LUA_DECLARE(getResourceMapRootElement);
LUA_DECLARE(getResourceExportedFunctions);
LUA_DECLARE(getResourceOrganizationalPath);
LUA_DECLARE(isResourceArchived);

static bool isResourceProtected(CResource* const resource);
static std::string GetResourceName(lua_State* luaVM, std::optional<CResource*> resourceElement);
Nico8340 marked this conversation as resolved.
Show resolved Hide resolved

// Set stuff
LUA_DECLARE(setResourceInfo);
Expand Down
Loading