Fixed some bugs within the squirrel plugin system.
Implemented feature request www.mc-server.org/support/index.php?do=details&task_id=53 git-svn-id: http://mc-server.googlecode.com/svn/trunk@655 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
7276cc0f9b
commit
273ddcbfff
@ -278,8 +278,8 @@ MCServer : \
|
|||||||
build/sqstate.o\
|
build/sqstate.o\
|
||||||
build/sqtable.o\
|
build/sqtable.o\
|
||||||
build/sqvm.o\
|
build/sqvm.o\
|
||||||
build/squirrelbindings/SquirrelBindings.o\
|
build/SquirrelBindings.o\
|
||||||
build/squirrelbindings/SquirrelFunctions.o\
|
build/SquirrelFunctions.o\
|
||||||
build/cSquirrelCommandBinder.o\
|
build/cSquirrelCommandBinder.o\
|
||||||
build/cPlugin_Squirrel.o\
|
build/cPlugin_Squirrel.o\
|
||||||
build/CraftingRecipes.o
|
build/CraftingRecipes.o
|
||||||
@ -527,8 +527,8 @@ MCServer : \
|
|||||||
build/sqstate.o\
|
build/sqstate.o\
|
||||||
build/sqtable.o\
|
build/sqtable.o\
|
||||||
build/sqvm.o\
|
build/sqvm.o\
|
||||||
build/squirrelbindings/SquirrelBindings.o\
|
build/SquirrelBindings.o\
|
||||||
build/squirrelbindings/SquirrelFunctions.o\
|
build/SquirrelFunctions.o\
|
||||||
build/cSquirrelCommandBinder.o\
|
build/cSquirrelCommandBinder.o\
|
||||||
build/cPlugin_Squirrel.o\
|
build/cPlugin_Squirrel.o\
|
||||||
-o MCServer
|
-o MCServer
|
||||||
@ -771,8 +771,8 @@ clean :
|
|||||||
build/sqstate.o\
|
build/sqstate.o\
|
||||||
build/sqtable.o\
|
build/sqtable.o\
|
||||||
build/sqvm.o\
|
build/sqvm.o\
|
||||||
build/squirrelbindings/SquirrelBindings.o\
|
build/SquirrelBindings.o\
|
||||||
build/squirrelbindings/SquirrelFunctions.o\
|
build/SquirrelFunctions.o\
|
||||||
build/cSquirrelCommandBinder.o\
|
build/cSquirrelCommandBinder.o\
|
||||||
build/cPlugin_Squirrel.o\
|
build/cPlugin_Squirrel.o\
|
||||||
MCServer
|
MCServer
|
||||||
@ -1686,14 +1686,14 @@ build/CraftingRecipes.o : source/CraftingRecipes.cpp
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
build/squirrelbindings/SquirrelBindings.o : source/squirrelbindings/SquirrelBindings.cpp
|
build/SquirrelBindings.o : source/squirrelbindings/SquirrelBindings.cpp
|
||||||
$(CC) $(CC_OPTIONS) source/squirrelbindings/SquirrelBindings.cpp -c $(INCLUDE) -o build/squirrelbindings/SquirrelBindings.o
|
$(CC) $(CC_OPTIONS) source/squirrelbindings/SquirrelBindings.cpp -c $(INCLUDE) -o build/SquirrelBindings.o
|
||||||
|
|
||||||
build/cSquirrelCommandBinder.o : source/cSquirrelCommandBinder.cpp
|
build/cSquirrelCommandBinder.o : source/cSquirrelCommandBinder.cpp
|
||||||
$(CC) $(CC_OPTIONS) source/cSquirrelCommandBinder.cpp -c $(INCLUDE) -o build/cSquirrelCommandBinder.o
|
$(CC) $(CC_OPTIONS) source/cSquirrelCommandBinder.cpp -c $(INCLUDE) -o build/cSquirrelCommandBinder.o
|
||||||
|
|
||||||
build/squirrelbindings/SquirrelFunctions.o : source/squirrelbindings/SquirrelFunctions.cpp
|
build/SquirrelFunctions.o : source/squirrelbindings/SquirrelFunctions.cpp
|
||||||
$(CC) $(CC_OPTIONS) source/squirrelbindings/SquirrelFunctions.cpp -c $(INCLUDE) -o build/squirrelbindings/SquirrelFunctions.o
|
$(CC) $(CC_OPTIONS) source/squirrelbindings/SquirrelFunctions.cpp -c $(INCLUDE) -o build/SquirrelFunctions.o
|
||||||
|
|
||||||
build/cPlugin_Squirrel.o : source/cPlugin_Squirrel.cpp
|
build/cPlugin_Squirrel.o : source/cPlugin_Squirrel.cpp
|
||||||
$(CC) $(CC_OPTIONS) source/cPlugin_Squirrel.cpp -c $(INCLUDE) -o build/cPlugin_Squirrel.o
|
$(CC) $(CC_OPTIONS) source/cPlugin_Squirrel.cpp -c $(INCLUDE) -o build/cPlugin_Squirrel.o
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
#include "cSquirrelCommandBinder.h"
|
#include "cSquirrelCommandBinder.h"
|
||||||
#include "../iniFile/iniFile.h"
|
#include "../iniFile/iniFile.h"
|
||||||
#include "tolua++.h"
|
#include "tolua++.h"
|
||||||
|
#include "cPlayer.h"
|
||||||
|
|
||||||
#include "squirrelbindings/SquirrelBindings.h"
|
#include "squirrelbindings/SquirrelBindings.h"
|
||||||
#include "squirrelbindings/SquirrelFunctions.h"
|
#include "squirrelbindings/SquirrelFunctions.h"
|
||||||
@ -206,6 +207,14 @@ bool cPluginManager::CallHook(PluginHook a_Hook, unsigned int a_NumArgs, ...)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Check if it was a standard command (starts with a slash)
|
||||||
|
if(Message[0] == '/')
|
||||||
|
{
|
||||||
|
Player->SendMessage("Unknown Command");
|
||||||
|
LOGINFO("Player \"%s\" issued command: %s", Player->GetName().c_str(), Message);
|
||||||
|
return true; //Cancel sending
|
||||||
|
}
|
||||||
|
|
||||||
if (Plugins == m_Hooks.end())
|
if (Plugins == m_Hooks.end())
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
|
@ -77,6 +77,8 @@ void cPlugin_Squirrel::OnDisable()
|
|||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnDisable")) return;
|
||||||
|
|
||||||
m_Plugin->GetFunction("OnDisable").Execute();
|
m_Plugin->GetFunction("OnDisable").Execute();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -88,6 +90,8 @@ void cPlugin_Squirrel::Tick(float a_Dt)
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnTick")) return;
|
||||||
|
|
||||||
m_Plugin->GetFunction("OnTick").Execute(a_Dt);
|
m_Plugin->GetFunction("OnTick").Execute(a_Dt);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,6 +103,8 @@ bool cPlugin_Squirrel::OnCollectItem( cPickup* a_Pickup, cPlayer* a_Player )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnCollectItem")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnCollectItem").Evaluate<bool>(a_Pickup, a_Player);
|
return m_Plugin->GetFunction("OnCollectItem").Evaluate<bool>(a_Pickup, a_Player);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,6 +116,7 @@ bool cPlugin_Squirrel::OnDisconnect(const AString & a_Reason, cPlayer* a_Player
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnDisconnect")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnDisconnect").Evaluate<bool>(a_Reason, a_Player);
|
return m_Plugin->GetFunction("OnDisconnect").Evaluate<bool>(a_Reason, a_Player);
|
||||||
}
|
}
|
||||||
@ -122,6 +129,8 @@ bool cPlugin_Squirrel::OnBlockPlace( cPacket_BlockPlace* a_PacketData, cPlayer*
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnBlockPlace")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnBlockPlace").Evaluate<bool>(a_PacketData, a_Player);
|
return m_Plugin->GetFunction("OnBlockPlace").Evaluate<bool>(a_PacketData, a_Player);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,6 +142,8 @@ bool cPlugin_Squirrel::OnBlockDig( cPacket_BlockDig* a_PacketData, cPlayer* a_Pl
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnBlockDig")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnBlockDig").Evaluate<bool>(a_PacketData, a_Player, a_PickupItem);
|
return m_Plugin->GetFunction("OnBlockDig").Evaluate<bool>(a_PacketData, a_Player, a_PickupItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,6 +155,8 @@ bool cPlugin_Squirrel::OnChat( const char* a_Chat, cPlayer* a_Player )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnChat")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnChat").Evaluate<bool>(a_Chat, a_Player);
|
return m_Plugin->GetFunction("OnChat").Evaluate<bool>(a_Chat, a_Player);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -156,6 +169,8 @@ bool cPlugin_Squirrel::OnLogin( cPacket_Login* a_PacketData )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnLogin")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnLogin").Evaluate<bool>(a_PacketData);
|
return m_Plugin->GetFunction("OnLogin").Evaluate<bool>(a_PacketData);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,6 +182,8 @@ void cPlugin_Squirrel::OnPlayerSpawn( cPlayer* a_Player )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnPlayerSpawn")) return;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnPlayerSpawn").Execute(a_Player);
|
return m_Plugin->GetFunction("OnPlayerSpawn").Execute(a_Player);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -179,6 +196,8 @@ bool cPlugin_Squirrel::OnPlayerJoin( cPlayer* a_Player )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnPlayerJoin")) return false;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnPlayerJoin").Evaluate<bool>(a_Player);
|
return m_Plugin->GetFunction("OnPlayerJoin").Evaluate<bool>(a_Player);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,6 +209,8 @@ void cPlugin_Squirrel::OnPlayerMove( cPlayer* a_Player )
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnPlayerMove")) return;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnPlayerMove").Execute(a_Player);
|
return m_Plugin->GetFunction("OnPlayerMove").Execute(a_Player);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -202,6 +223,8 @@ void cPlugin_Squirrel::OnTakeDamage( cPawn* a_Pawn, TakeDamageInfo* a_TakeDamage
|
|||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnTakeDamage")) return;
|
||||||
|
|
||||||
return m_Plugin->GetFunction("OnTakeDamage")(a_Pawn, a_TakeDamageInfo);
|
return m_Plugin->GetFunction("OnTakeDamage")(a_Pawn, a_TakeDamageInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -212,7 +235,7 @@ void cPlugin_Squirrel::OnTakeDamage( cPawn* a_Pawn, TakeDamageInfo* a_TakeDamage
|
|||||||
bool cPlugin_Squirrel::OnKilled( cPawn* a_Killed, cEntity* a_Killer )
|
bool cPlugin_Squirrel::OnKilled( cPawn* a_Killed, cEntity* a_Killer )
|
||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
if(!m_Plugin->HasFunction("OnKilled")) return false;
|
||||||
return m_Plugin->GetFunction("OnKilled").Evaluate<bool>(a_Killed, a_Killer);
|
return m_Plugin->GetFunction("OnKilled").Evaluate<bool>(a_Killed, a_Killer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -223,7 +246,7 @@ bool cPlugin_Squirrel::OnKilled( cPawn* a_Killed, cEntity* a_Killer )
|
|||||||
void cPlugin_Squirrel::OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ)
|
void cPlugin_Squirrel::OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
if(!m_Plugin->HasFunction("OnChunkGenerated")) return;
|
||||||
return m_Plugin->GetFunction("OnChunkGenerated")(a_World, a_ChunkX, a_ChunkZ);
|
return m_Plugin->GetFunction("OnChunkGenerated")(a_World, a_ChunkX, a_ChunkZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -234,7 +257,7 @@ void cPlugin_Squirrel::OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_Ch
|
|||||||
bool cPlugin_Squirrel::OnChunkGenerating(cWorld * a_World, int a_ChunkX, int a_ChunkZ, cLuaChunk * a_pLuaChunk)
|
bool cPlugin_Squirrel::OnChunkGenerating(cWorld * a_World, int a_ChunkX, int a_ChunkZ, cLuaChunk * a_pLuaChunk)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
if(!m_Plugin->HasFunction("OnChunkGenerating")) return false;
|
||||||
return m_Plugin->GetFunction("OnChunkGenerating").Evaluate<bool>(a_World, a_ChunkX, a_ChunkZ, a_pLuaChunk);
|
return m_Plugin->GetFunction("OnChunkGenerating").Evaluate<bool>(a_World, a_ChunkX, a_ChunkZ, a_pLuaChunk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -245,7 +268,7 @@ bool cPlugin_Squirrel::OnChunkGenerating(cWorld * a_World, int a_ChunkX, int a_C
|
|||||||
bool cPlugin_Squirrel::OnPreCrafting(const cPlayer * a_Player, const cCraftingGrid * a_Grid, cCraftingRecipe * a_Recipe)
|
bool cPlugin_Squirrel::OnPreCrafting(const cPlayer * a_Player, const cCraftingGrid * a_Grid, cCraftingRecipe * a_Recipe)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
if(!m_Plugin->HasFunction("OnPreCrafting")) return false;
|
||||||
return m_Plugin->GetFunction("OnPreCrafting").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
return m_Plugin->GetFunction("OnPreCrafting").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -257,7 +280,7 @@ bool cPlugin_Squirrel::OnPreCrafting(const cPlayer * a_Player, const cCraftingGr
|
|||||||
bool cPlugin_Squirrel::OnCraftingNoRecipe(const cPlayer * a_Player, const cCraftingGrid * a_Grid, cCraftingRecipe * a_Recipe)
|
bool cPlugin_Squirrel::OnCraftingNoRecipe(const cPlayer * a_Player, const cCraftingGrid * a_Grid, cCraftingRecipe * a_Recipe)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
if(!m_Plugin->HasFunction("OnCraftingNoRecipe")) return false;
|
||||||
return m_Plugin->GetFunction("OnCraftingNoRecipe").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
return m_Plugin->GetFunction("OnCraftingNoRecipe").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -269,7 +292,7 @@ bool cPlugin_Squirrel::OnPostCrafting(const cPlayer * a_Player, const cCraftingG
|
|||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnPostCrafting")) return false;
|
||||||
return m_Plugin->GetFunction("OnPostCrafting").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
return m_Plugin->GetFunction("OnPostCrafting").Evaluate<bool>((cPlayer *) a_Player, (cCraftingGrid *) a_Grid, a_Recipe);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,7 +307,7 @@ bool cPlugin_Squirrel::OnBlockToPickup(
|
|||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnBlockToPickup")) return false;
|
||||||
return m_Plugin->GetFunction("OnBlockToPickup").Evaluate<bool>(a_BlockType, a_BlockMeta, (cPlayer *) a_Player, a_EquippedItem, a_Pickups);
|
return m_Plugin->GetFunction("OnBlockToPickup").Evaluate<bool>(a_BlockType, a_BlockMeta, (cPlayer *) a_Player, a_EquippedItem, a_Pickups);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -297,7 +320,7 @@ bool cPlugin_Squirrel::OnWeatherChanged(cWorld * a_World)
|
|||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnWeatherChanged")) return false;
|
||||||
return m_Plugin->GetFunction("OnWeatherChanged").Evaluate<bool>(a_World);
|
return m_Plugin->GetFunction("OnWeatherChanged").Evaluate<bool>(a_World);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -313,7 +336,7 @@ bool cPlugin_Squirrel::OnUpdatingSign(
|
|||||||
{
|
{
|
||||||
cCSLock Lock(m_CriticalSection);
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnUpdatingSign")) return false;
|
||||||
return m_Plugin->GetFunction("OnUpdatingSign")
|
return m_Plugin->GetFunction("OnUpdatingSign")
|
||||||
.Evaluate<bool>(
|
.Evaluate<bool>(
|
||||||
a_World,
|
a_World,
|
||||||
@ -337,6 +360,9 @@ bool cPlugin_Squirrel::OnUpdatedSign(
|
|||||||
const AString & a_Line1, const AString & a_Line2, const AString & a_Line3, const AString & a_Line4
|
const AString & a_Line1, const AString & a_Line2, const AString & a_Line3, const AString & a_Line4
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
|
||||||
|
if(!m_Plugin->HasFunction("OnUpdatedSign")) return false;
|
||||||
return m_Plugin->GetFunction("OnUpdatedSign")
|
return m_Plugin->GetFunction("OnUpdatedSign")
|
||||||
.Evaluate<bool>(
|
.Evaluate<bool>(
|
||||||
a_World,
|
a_World,
|
||||||
|
@ -9,15 +9,20 @@ public:
|
|||||||
m_SquirrelObject = a_Obj;
|
m_SquirrelObject = a_Obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
Sqrat::Function GetFunction(const char *methodName)
|
Sqrat::Function GetFunction(const char *a_MethodName)
|
||||||
{
|
{
|
||||||
if(m_SquirrelObject.IsNull())
|
if(m_SquirrelObject.IsNull())
|
||||||
return Sqrat::Function();
|
return Sqrat::Function();
|
||||||
|
|
||||||
Sqrat::Function method(m_SquirrelObject, methodName);
|
Sqrat::Function method(m_SquirrelObject, a_MethodName);
|
||||||
return method;
|
return method;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool HasFunction(const char *a_MethodName)
|
||||||
|
{
|
||||||
|
return !this->GetFunction(a_MethodName).IsNull();
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Sqrat::Object m_SquirrelObject;
|
Sqrat::Object m_SquirrelObject;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user