Added implementation of E_PLUGIN_CHUNK_GENERATING lua hook
It crashes the server when a plugin actually overrides default behavior though... git-svn-id: http://mc-server.googlecode.com/svn/trunk@594 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
429ccb59b5
commit
373dac3204
@ -1644,6 +1644,14 @@
|
|||||||
RelativePath="..\source\Bindings.h"
|
RelativePath="..\source\Bindings.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\source\cLuaChunk.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\source\cLuaChunk.h"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\source\cLuaCommandBinder.cpp"
|
RelativePath="..\source\cLuaCommandBinder.cpp"
|
||||||
>
|
>
|
||||||
|
@ -45,3 +45,4 @@ $cfile "cGroup.h"
|
|||||||
$cfile "packets/cPacket_Login.h"
|
$cfile "packets/cPacket_Login.h"
|
||||||
$cfile "packets/cPacket_BlockDig.h"
|
$cfile "packets/cPacket_BlockDig.h"
|
||||||
$cfile "packets/cPacket_BlockPlace.h"
|
$cfile "packets/cPacket_BlockPlace.h"
|
||||||
|
$cfile "cLuaChunk.h"
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
** Lua binding: AllToLua
|
** Lua binding: AllToLua
|
||||||
** Generated automatically by tolua++-1.0.92 on 06/09/12 17:10:20.
|
** Generated automatically by tolua++-1.0.92 on 06/10/12 15:55:56.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __cplusplus
|
#ifndef __cplusplus
|
||||||
@ -55,6 +55,7 @@ TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S);
|
|||||||
#include "packets/cPacket_Login.h"
|
#include "packets/cPacket_Login.h"
|
||||||
#include "packets/cPacket_BlockDig.h"
|
#include "packets/cPacket_BlockDig.h"
|
||||||
#include "packets/cPacket_BlockPlace.h"
|
#include "packets/cPacket_BlockPlace.h"
|
||||||
|
#include "cLuaChunk.h"
|
||||||
|
|
||||||
/* function to release collected object via destructor */
|
/* function to release collected object via destructor */
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@ -164,6 +165,7 @@ static void tolua_reg_types (lua_State* tolua_S)
|
|||||||
{
|
{
|
||||||
tolua_usertype(tolua_S,"TakeDamageInfo");
|
tolua_usertype(tolua_S,"TakeDamageInfo");
|
||||||
tolua_usertype(tolua_S,"cPlugin");
|
tolua_usertype(tolua_S,"cPlugin");
|
||||||
|
tolua_usertype(tolua_S,"cLuaChunk");
|
||||||
tolua_usertype(tolua_S,"cStringMap");
|
tolua_usertype(tolua_S,"cStringMap");
|
||||||
tolua_usertype(tolua_S,"Lua__cEntity");
|
tolua_usertype(tolua_S,"Lua__cEntity");
|
||||||
tolua_usertype(tolua_S,"Lua__cPacket_BlockDig");
|
tolua_usertype(tolua_S,"Lua__cPacket_BlockDig");
|
||||||
@ -7664,6 +7666,44 @@ static int tolua_AllToLua_cPlugin_OnChunkGenerated00(lua_State* tolua_S)
|
|||||||
}
|
}
|
||||||
#endif //#ifndef TOLUA_DISABLE
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
|
/* method: OnChunkGenerating of class cPlugin */
|
||||||
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_cPlugin_OnChunkGenerating00
|
||||||
|
static int tolua_AllToLua_cPlugin_OnChunkGenerating00(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
if (
|
||||||
|
!tolua_isusertype(tolua_S,1,"cPlugin",0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,2,0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,3,0,&tolua_err) ||
|
||||||
|
!tolua_isusertype(tolua_S,4,"cLuaChunk",0,&tolua_err) ||
|
||||||
|
!tolua_isnoobj(tolua_S,5,&tolua_err)
|
||||||
|
)
|
||||||
|
goto tolua_lerror;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
cPlugin* self = (cPlugin*) tolua_tousertype(tolua_S,1,0);
|
||||||
|
int a_ChunkX = ((int) tolua_tonumber(tolua_S,2,0));
|
||||||
|
int a_ChunkZ = ((int) tolua_tonumber(tolua_S,3,0));
|
||||||
|
cLuaChunk* a_pLuaChunk = ((cLuaChunk*) tolua_tousertype(tolua_S,4,0));
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
if (!self) tolua_error(tolua_S,"invalid 'self' in function 'OnChunkGenerating'", NULL);
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
bool tolua_ret = (bool) self->OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
|
tolua_pushboolean(tolua_S,(bool)tolua_ret);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'OnChunkGenerating'.",&tolua_err);
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
/* method: GetName of class cPlugin */
|
/* method: GetName of class cPlugin */
|
||||||
#ifndef TOLUA_DISABLE_tolua_AllToLua_cPlugin_GetName00
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_cPlugin_GetName00
|
||||||
static int tolua_AllToLua_cPlugin_GetName00(lua_State* tolua_S)
|
static int tolua_AllToLua_cPlugin_GetName00(lua_State* tolua_S)
|
||||||
@ -8087,6 +8127,19 @@ public:
|
|||||||
return ( void ) cPlugin:: OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
return ( void ) cPlugin:: OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
bool OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk* a_pLuaChunk) {
|
||||||
|
if (push_method("OnChunkGenerating", tolua_AllToLua_cPlugin_OnChunkGenerating00)) {
|
||||||
|
tolua_pushnumber(lua_state, (lua_Number)a_ChunkX);
|
||||||
|
tolua_pushnumber(lua_state, (lua_Number)a_ChunkZ);
|
||||||
|
tolua_pushusertype(lua_state, (void*)a_pLuaChunk, "cLuaChunk");
|
||||||
|
ToluaBase::dbcall(lua_state, 4, 1);
|
||||||
|
bool tolua_ret = ( bool )tolua_toboolean(lua_state, -1, 0);
|
||||||
|
lua_pop(lua_state, 1);
|
||||||
|
return tolua_ret;
|
||||||
|
} else {
|
||||||
|
return ( bool ) cPlugin:: OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
void cPlugin__OnDisable( void ) {
|
void cPlugin__OnDisable( void ) {
|
||||||
return ( void )cPlugin::OnDisable();
|
return ( void )cPlugin::OnDisable();
|
||||||
@ -8129,6 +8182,9 @@ public:
|
|||||||
};
|
};
|
||||||
void cPlugin__OnChunkGenerated( cWorld* a_World, int a_ChunkX, int a_ChunkZ) {
|
void cPlugin__OnChunkGenerated( cWorld* a_World, int a_ChunkX, int a_ChunkZ) {
|
||||||
return ( void )cPlugin::OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
return ( void )cPlugin::OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
||||||
|
};
|
||||||
|
bool cPlugin__OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk* a_pLuaChunk) {
|
||||||
|
return ( bool )cPlugin::OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
};
|
};
|
||||||
Lua__cPlugin( void ): cPlugin(){};
|
Lua__cPlugin( void ): cPlugin(){};
|
||||||
};
|
};
|
||||||
@ -8654,6 +8710,44 @@ static int tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerated00(lua_State* to
|
|||||||
}
|
}
|
||||||
#endif //#ifndef TOLUA_DISABLE
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
|
/* method: cPlugin__OnChunkGenerating of class Lua__cPlugin */
|
||||||
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerating00
|
||||||
|
static int tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerating00(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
if (
|
||||||
|
!tolua_isusertype(tolua_S,1,"Lua__cPlugin",0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,2,0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,3,0,&tolua_err) ||
|
||||||
|
!tolua_isusertype(tolua_S,4,"cLuaChunk",0,&tolua_err) ||
|
||||||
|
!tolua_isnoobj(tolua_S,5,&tolua_err)
|
||||||
|
)
|
||||||
|
goto tolua_lerror;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
Lua__cPlugin* self = (Lua__cPlugin*) tolua_tousertype(tolua_S,1,0);
|
||||||
|
int a_ChunkX = ((int) tolua_tonumber(tolua_S,2,0));
|
||||||
|
int a_ChunkZ = ((int) tolua_tonumber(tolua_S,3,0));
|
||||||
|
cLuaChunk* a_pLuaChunk = ((cLuaChunk*) tolua_tousertype(tolua_S,4,0));
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
if (!self) tolua_error(tolua_S,"invalid 'self' in function 'cPlugin__OnChunkGenerating'", NULL);
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
bool tolua_ret = (bool) self->cPlugin__OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
|
tolua_pushboolean(tolua_S,(bool)tolua_ret);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'cPlugin__OnChunkGenerating'.",&tolua_err);
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
/* method: new of class Lua__cPlugin */
|
/* method: new of class Lua__cPlugin */
|
||||||
#ifndef TOLUA_DISABLE_tolua_AllToLua_Lua__cPlugin_new00
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_Lua__cPlugin_new00
|
||||||
static int tolua_AllToLua_Lua__cPlugin_new00(lua_State* tolua_S)
|
static int tolua_AllToLua_Lua__cPlugin_new00(lua_State* tolua_S)
|
||||||
@ -9038,6 +9132,19 @@ public:
|
|||||||
return ( void ) cPlugin_NewLua:: OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
return ( void ) cPlugin_NewLua:: OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
bool OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk* a_pLuaChunk) {
|
||||||
|
if (push_method("OnChunkGenerating", tolua_AllToLua_cPlugin_OnChunkGenerating00)) {
|
||||||
|
tolua_pushnumber(lua_state, (lua_Number)a_ChunkX);
|
||||||
|
tolua_pushnumber(lua_state, (lua_Number)a_ChunkZ);
|
||||||
|
tolua_pushusertype(lua_state, (void*)a_pLuaChunk, "cLuaChunk");
|
||||||
|
ToluaBase::dbcall(lua_state, 4, 1);
|
||||||
|
bool tolua_ret = ( bool )tolua_toboolean(lua_state, -1, 0);
|
||||||
|
lua_pop(lua_state, 1);
|
||||||
|
return tolua_ret;
|
||||||
|
} else {
|
||||||
|
return ( bool ) cPlugin_NewLua:: OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
void cPlugin_NewLua__OnDisable( void ) {
|
void cPlugin_NewLua__OnDisable( void ) {
|
||||||
return ( void )cPlugin_NewLua::OnDisable();
|
return ( void )cPlugin_NewLua::OnDisable();
|
||||||
@ -9084,6 +9191,9 @@ public:
|
|||||||
void cPlugin_NewLua__OnChunkGenerated( cWorld* a_World, int a_ChunkX, int a_ChunkZ) {
|
void cPlugin_NewLua__OnChunkGenerated( cWorld* a_World, int a_ChunkX, int a_ChunkZ) {
|
||||||
return ( void )cPlugin_NewLua::OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
return ( void )cPlugin_NewLua::OnChunkGenerated(a_World,a_ChunkX,a_ChunkZ);
|
||||||
};
|
};
|
||||||
|
bool cPlugin_NewLua__OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk* a_pLuaChunk) {
|
||||||
|
return ( bool )cPlugin_NewLua::OnChunkGenerating(a_ChunkX,a_ChunkZ,a_pLuaChunk);
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
/* method: tolua__set_instance of class Lua__cPlugin_NewLua */
|
/* method: tolua__set_instance of class Lua__cPlugin_NewLua */
|
||||||
@ -17416,6 +17526,78 @@ static int tolua_set_cPacket_BlockPlace_m_Uses(lua_State* tolua_S)
|
|||||||
}
|
}
|
||||||
#endif //#ifndef TOLUA_DISABLE
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
|
/* method: SetBlock of class cLuaChunk */
|
||||||
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_cLuaChunk_SetBlock00
|
||||||
|
static int tolua_AllToLua_cLuaChunk_SetBlock00(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
if (
|
||||||
|
!tolua_isusertype(tolua_S,1,"cLuaChunk",0,&tolua_err) ||
|
||||||
|
(tolua_isvaluenil(tolua_S,2,&tolua_err) || !tolua_isusertype(tolua_S,2,"const Vector3i",0,&tolua_err)) ||
|
||||||
|
!tolua_isnumber(tolua_S,3,0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,4,0,&tolua_err) ||
|
||||||
|
!tolua_isnoobj(tolua_S,5,&tolua_err)
|
||||||
|
)
|
||||||
|
goto tolua_lerror;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
cLuaChunk* self = (cLuaChunk*) tolua_tousertype(tolua_S,1,0);
|
||||||
|
const Vector3i* a_Pos = ((const Vector3i*) tolua_tousertype(tolua_S,2,0));
|
||||||
|
char a_BlockID = ((char) tolua_tonumber(tolua_S,3,0));
|
||||||
|
unsigned char a_BlockMeta = ((unsigned char) tolua_tonumber(tolua_S,4,0));
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
if (!self) tolua_error(tolua_S,"invalid 'self' in function 'SetBlock'", NULL);
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
self->SetBlock(*a_Pos,a_BlockID,a_BlockMeta);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'SetBlock'.",&tolua_err);
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
|
/* method: FillBlocks of class cLuaChunk */
|
||||||
|
#ifndef TOLUA_DISABLE_tolua_AllToLua_cLuaChunk_FillBlocks00
|
||||||
|
static int tolua_AllToLua_cLuaChunk_FillBlocks00(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
if (
|
||||||
|
!tolua_isusertype(tolua_S,1,"cLuaChunk",0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,2,0,&tolua_err) ||
|
||||||
|
!tolua_isnumber(tolua_S,3,0,&tolua_err) ||
|
||||||
|
!tolua_isnoobj(tolua_S,4,&tolua_err)
|
||||||
|
)
|
||||||
|
goto tolua_lerror;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
cLuaChunk* self = (cLuaChunk*) tolua_tousertype(tolua_S,1,0);
|
||||||
|
char a_BlockID = ((char) tolua_tonumber(tolua_S,2,0));
|
||||||
|
unsigned char a_BlockMeta = ((unsigned char) tolua_tonumber(tolua_S,3,0));
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
if (!self) tolua_error(tolua_S,"invalid 'self' in function 'FillBlocks'", NULL);
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
self->FillBlocks(a_BlockID,a_BlockMeta);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
#ifndef TOLUA_RELEASE
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'FillBlocks'.",&tolua_err);
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#ifndef TOLUA_DISABLE
|
||||||
|
|
||||||
/* Open function */
|
/* Open function */
|
||||||
TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S)
|
TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
@ -18329,6 +18511,7 @@ TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S)
|
|||||||
tolua_function(tolua_S,"OnTakeDamage",tolua_AllToLua_cPlugin_OnTakeDamage00);
|
tolua_function(tolua_S,"OnTakeDamage",tolua_AllToLua_cPlugin_OnTakeDamage00);
|
||||||
tolua_function(tolua_S,"OnKilled",tolua_AllToLua_cPlugin_OnKilled00);
|
tolua_function(tolua_S,"OnKilled",tolua_AllToLua_cPlugin_OnKilled00);
|
||||||
tolua_function(tolua_S,"OnChunkGenerated",tolua_AllToLua_cPlugin_OnChunkGenerated00);
|
tolua_function(tolua_S,"OnChunkGenerated",tolua_AllToLua_cPlugin_OnChunkGenerated00);
|
||||||
|
tolua_function(tolua_S,"OnChunkGenerating",tolua_AllToLua_cPlugin_OnChunkGenerating00);
|
||||||
tolua_function(tolua_S,"GetName",tolua_AllToLua_cPlugin_GetName00);
|
tolua_function(tolua_S,"GetName",tolua_AllToLua_cPlugin_GetName00);
|
||||||
tolua_function(tolua_S,"SetName",tolua_AllToLua_cPlugin_SetName00);
|
tolua_function(tolua_S,"SetName",tolua_AllToLua_cPlugin_SetName00);
|
||||||
tolua_function(tolua_S,"GetVersion",tolua_AllToLua_cPlugin_GetVersion00);
|
tolua_function(tolua_S,"GetVersion",tolua_AllToLua_cPlugin_GetVersion00);
|
||||||
@ -18362,6 +18545,7 @@ TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S)
|
|||||||
tolua_function(tolua_S,"cPlugin__OnTakeDamage",tolua_AllToLua_Lua__cPlugin_cPlugin__OnTakeDamage00);
|
tolua_function(tolua_S,"cPlugin__OnTakeDamage",tolua_AllToLua_Lua__cPlugin_cPlugin__OnTakeDamage00);
|
||||||
tolua_function(tolua_S,"cPlugin__OnKilled",tolua_AllToLua_Lua__cPlugin_cPlugin__OnKilled00);
|
tolua_function(tolua_S,"cPlugin__OnKilled",tolua_AllToLua_Lua__cPlugin_cPlugin__OnKilled00);
|
||||||
tolua_function(tolua_S,"cPlugin__OnChunkGenerated",tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerated00);
|
tolua_function(tolua_S,"cPlugin__OnChunkGenerated",tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerated00);
|
||||||
|
tolua_function(tolua_S,"cPlugin__OnChunkGenerating",tolua_AllToLua_Lua__cPlugin_cPlugin__OnChunkGenerating00);
|
||||||
tolua_function(tolua_S,"new",tolua_AllToLua_Lua__cPlugin_new00);
|
tolua_function(tolua_S,"new",tolua_AllToLua_Lua__cPlugin_new00);
|
||||||
tolua_function(tolua_S,"new_local",tolua_AllToLua_Lua__cPlugin_new00_local);
|
tolua_function(tolua_S,"new_local",tolua_AllToLua_Lua__cPlugin_new00_local);
|
||||||
tolua_function(tolua_S,".call",tolua_AllToLua_Lua__cPlugin_new00_local);
|
tolua_function(tolua_S,".call",tolua_AllToLua_Lua__cPlugin_new00_local);
|
||||||
@ -18793,6 +18977,11 @@ TOLUA_API int tolua_AllToLua_open (lua_State* tolua_S)
|
|||||||
tolua_variable(tolua_S,"m_Count",tolua_get_cPacket_BlockPlace_m_Count,tolua_set_cPacket_BlockPlace_m_Count);
|
tolua_variable(tolua_S,"m_Count",tolua_get_cPacket_BlockPlace_m_Count,tolua_set_cPacket_BlockPlace_m_Count);
|
||||||
tolua_variable(tolua_S,"m_Uses",tolua_get_cPacket_BlockPlace_m_Uses,tolua_set_cPacket_BlockPlace_m_Uses);
|
tolua_variable(tolua_S,"m_Uses",tolua_get_cPacket_BlockPlace_m_Uses,tolua_set_cPacket_BlockPlace_m_Uses);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
|
tolua_cclass(tolua_S,"cLuaChunk","cLuaChunk","",NULL);
|
||||||
|
tolua_beginmodule(tolua_S,"cLuaChunk");
|
||||||
|
tolua_function(tolua_S,"SetBlock",tolua_AllToLua_cLuaChunk_SetBlock00);
|
||||||
|
tolua_function(tolua_S,"FillBlocks",tolua_AllToLua_cLuaChunk_FillBlocks00);
|
||||||
|
tolua_endmodule(tolua_S);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
** Lua binding: AllToLua
|
** Lua binding: AllToLua
|
||||||
** Generated automatically by tolua++-1.0.92 on 06/09/12 17:10:20.
|
** Generated automatically by tolua++-1.0.92 on 06/10/12 15:55:56.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Exported function */
|
/* Exported function */
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include "FinishGen.h"
|
#include "FinishGen.h"
|
||||||
#include "cRoot.h"
|
#include "cRoot.h"
|
||||||
#include "cPluginManager.h"
|
#include "cPluginManager.h"
|
||||||
|
#include "cLuaChunk.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -483,18 +484,28 @@ void cChunkGenerator::DoGenerate(int a_ChunkX, int a_ChunkY, int a_ChunkZ)
|
|||||||
cEntityList Entities;
|
cEntityList Entities;
|
||||||
cBlockEntityList BlockEntities;
|
cBlockEntityList BlockEntities;
|
||||||
|
|
||||||
// Use the composed generator:
|
|
||||||
m_BiomeGen->GenBiomes(a_ChunkX, a_ChunkZ, BiomeMap);
|
cLuaChunk LuaChunk( BlockTypes, BlockMeta, HeightMap, BiomeMap );
|
||||||
m_HeightGen->GenHeightMap(a_ChunkX, a_ChunkZ, HeightMap);
|
if( cRoot::Get()->GetPluginManager()->CallHook( cPluginManager::E_PLUGIN_CHUNK_GENERATING, 3, a_ChunkX, a_ChunkZ, &LuaChunk ) )
|
||||||
m_CompositionGen->ComposeTerrain(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, BiomeMap, Entities, BlockEntities);
|
|
||||||
for (cStructureGenList::iterator itr = m_StructureGens.begin(); itr != m_StructureGens.end(); ++itr)
|
|
||||||
{
|
{
|
||||||
(*itr)->GenStructures(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, Entities, BlockEntities);
|
// A plugin interrupted generation, handle something plugin specific?
|
||||||
} // for itr - m_StructureGens[]
|
//LOG("returned true");
|
||||||
for (cFinishGenList::iterator itr = m_FinishGens.begin(); itr != m_FinishGens.end(); ++itr)
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
(*itr)->GenFinish(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, BiomeMap, Entities, BlockEntities);
|
// Use the composed generator:
|
||||||
} // for itr - m_FinishGens[]
|
m_BiomeGen->GenBiomes(a_ChunkX, a_ChunkZ, BiomeMap);
|
||||||
|
m_HeightGen->GenHeightMap(a_ChunkX, a_ChunkZ, HeightMap);
|
||||||
|
m_CompositionGen->ComposeTerrain(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, BiomeMap, Entities, BlockEntities);
|
||||||
|
for (cStructureGenList::iterator itr = m_StructureGens.begin(); itr != m_StructureGens.end(); ++itr)
|
||||||
|
{
|
||||||
|
(*itr)->GenStructures(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, Entities, BlockEntities);
|
||||||
|
} // for itr - m_StructureGens[]
|
||||||
|
for (cFinishGenList::iterator itr = m_FinishGens.begin(); itr != m_FinishGens.end(); ++itr)
|
||||||
|
{
|
||||||
|
(*itr)->GenFinish(a_ChunkX, a_ChunkZ, BlockTypes, BlockMeta, HeightMap, BiomeMap, Entities, BlockEntities);
|
||||||
|
} // for itr - m_FinishGens[]
|
||||||
|
}
|
||||||
|
|
||||||
m_World->SetChunkData(
|
m_World->SetChunkData(
|
||||||
a_ChunkX, a_ChunkY, a_ChunkZ,
|
a_ChunkX, a_ChunkY, a_ChunkZ,
|
||||||
|
4
source/cLuaChunk.cpp
Normal file
4
source/cLuaChunk.cpp
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
#include "Globals.h"
|
||||||
|
|
||||||
|
#include "cLuaChunk.h"
|
||||||
|
|
39
source/cLuaChunk.h
Normal file
39
source/cLuaChunk.h
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "ChunkDef.h"
|
||||||
|
|
||||||
|
class cLuaChunk //tolua_export
|
||||||
|
{ //tolua_export
|
||||||
|
public:
|
||||||
|
cLuaChunk( cChunkDef::BlockTypes & a_BlockTypes
|
||||||
|
, cChunkDef::BlockNibbles & a_BlockNibbles
|
||||||
|
, cChunkDef::HeightMap & a_HeightMap
|
||||||
|
, cChunkDef::BiomeMap & a_BiomeMap
|
||||||
|
)
|
||||||
|
: m_BiomeMap( a_BiomeMap )
|
||||||
|
, m_BlockTypes( a_BlockTypes )
|
||||||
|
, m_BlockMeta( a_BlockNibbles )
|
||||||
|
, m_HeightMap( a_HeightMap )
|
||||||
|
{}
|
||||||
|
~cLuaChunk()
|
||||||
|
{}
|
||||||
|
|
||||||
|
void SetBlock( const Vector3i & a_Pos, char a_BlockID, unsigned char a_BlockMeta ) //tolua_export
|
||||||
|
{ //tolua_export
|
||||||
|
} //tolua_export
|
||||||
|
|
||||||
|
void FillBlocks( char a_BlockID, unsigned char a_BlockMeta ) //tolua_export
|
||||||
|
{ //tolua_export
|
||||||
|
const NIBBLETYPE CompressedMeta = a_BlockMeta | a_BlockMeta << 4;
|
||||||
|
memset( m_BlockTypes, a_BlockID, sizeof( cChunkDef::BlockTypes ) );
|
||||||
|
memset( m_BlockMeta, CompressedMeta, sizeof( cChunkDef::BlockNibbles ) );
|
||||||
|
|
||||||
|
memset( m_BiomeMap, 0, sizeof( cChunkDef::BiomeMap ) );
|
||||||
|
memset( m_HeightMap, 0, sizeof( cChunkDef::HeightMap ) );
|
||||||
|
} //tolua_export
|
||||||
|
private:
|
||||||
|
EMCSBiome * m_BiomeMap;
|
||||||
|
BLOCKTYPE * m_BlockTypes;
|
||||||
|
NIBBLETYPE * m_BlockMeta;
|
||||||
|
HEIGHTTYPE * m_HeightMap;
|
||||||
|
}; //tolua_export
|
@ -14,6 +14,7 @@ class cItem;
|
|||||||
class cEntity;
|
class cEntity;
|
||||||
class cPawn;
|
class cPawn;
|
||||||
class cWorld;
|
class cWorld;
|
||||||
|
class cLuaChunk;
|
||||||
struct TakeDamageInfo;
|
struct TakeDamageInfo;
|
||||||
|
|
||||||
|
|
||||||
@ -49,6 +50,7 @@ public:
|
|||||||
virtual void OnTakeDamage( cPawn* a_Pawn, TakeDamageInfo* a_TakeDamageInfo ) { (void)a_Pawn; (void)a_TakeDamageInfo; }
|
virtual void OnTakeDamage( cPawn* a_Pawn, TakeDamageInfo* a_TakeDamageInfo ) { (void)a_Pawn; (void)a_TakeDamageInfo; }
|
||||||
virtual bool OnKilled( cPawn* a_Killed, cEntity* a_Killer ) { (void)a_Killed; (void)a_Killer; return false; }
|
virtual bool OnKilled( cPawn* a_Killed, cEntity* a_Killer ) { (void)a_Killed; (void)a_Killer; return false; }
|
||||||
virtual void OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ) {}
|
virtual void OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ) {}
|
||||||
|
virtual bool OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk * a_pLuaChunk ) { return false; }
|
||||||
|
|
||||||
// Accessors
|
// Accessors
|
||||||
const char* GetName() const { return m_Name.c_str(); }
|
const char* GetName() const { return m_Name.c_str(); }
|
||||||
|
@ -381,6 +381,26 @@ bool cPluginManager::CallHook( PluginHook a_Hook, unsigned int a_NumArgs, ... )
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case E_PLUGIN_CHUNK_GENERATING:
|
||||||
|
{
|
||||||
|
if (a_NumArgs != 3)
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
va_list argptr;
|
||||||
|
va_start( argptr, a_NumArgs);
|
||||||
|
int ChunkX = va_arg(argptr, int);
|
||||||
|
int ChunkZ = va_arg(argptr, int);
|
||||||
|
cLuaChunk * LuaChunk = va_arg(argptr, cLuaChunk *);
|
||||||
|
va_end (argptr);
|
||||||
|
for( PluginList::iterator itr = Plugins->second.begin(); itr != Plugins->second.end(); ++itr )
|
||||||
|
{
|
||||||
|
if( (*itr)->OnChunkGenerating(ChunkX, ChunkZ, LuaChunk) )
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
@ -450,19 +470,22 @@ void cPluginManager::UnloadPluginsNow()
|
|||||||
|
|
||||||
void cPluginManager::RemoveHooks( cPlugin* a_Plugin )
|
void cPluginManager::RemoveHooks( cPlugin* a_Plugin )
|
||||||
{
|
{
|
||||||
m_Hooks[ E_PLUGIN_TICK].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_TICK].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_CHAT].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_CHAT].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_COLLECT_ITEM].remove( a_Plugin );
|
m_Hooks[ E_PLUGIN_COLLECT_ITEM].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_BLOCK_DIG].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_BLOCK_DIG].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_BLOCK_PLACE].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_BLOCK_PLACE].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_DISCONNECT].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_DISCONNECT].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_HANDSHAKE].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_HANDSHAKE].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_LOGIN].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_LOGIN].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_PLAYER_SPAWN].remove( a_Plugin );
|
m_Hooks[ E_PLUGIN_PLAYER_SPAWN].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_PLAYER_JOIN].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_PLAYER_JOIN].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_PLAYER_MOVE].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_PLAYER_MOVE].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_TAKE_DAMAGE].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_TAKE_DAMAGE].remove ( a_Plugin );
|
||||||
m_Hooks[ E_PLUGIN_KILLED].remove ( a_Plugin );
|
m_Hooks[ E_PLUGIN_KILLED].remove ( a_Plugin );
|
||||||
|
m_Hooks[ E_PLUGIN_CHUNK_GENERATED ].remove ( a_Plugin );
|
||||||
|
m_Hooks[ E_PLUGIN_CHUNK_GENERATING ].remove( a_Plugin );
|
||||||
|
m_Hooks[ E_PLUGIN_BLOCK_TO_DROPS ].remove ( a_Plugin );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -363,6 +363,27 @@ void cPlugin_NewLua::OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_Chun
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool cPlugin_NewLua::OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk * a_pLuaChunk )
|
||||||
|
{
|
||||||
|
cCSLock Lock(m_CriticalSection);
|
||||||
|
if (!PushFunction("OnChunkGenerating"))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
tolua_pushnumber (m_LuaState, a_ChunkX);
|
||||||
|
tolua_pushnumber (m_LuaState, a_ChunkZ);
|
||||||
|
tolua_pushusertype(m_LuaState, a_pLuaChunk, "cLuaChunk");
|
||||||
|
|
||||||
|
if( !CallFunction(3, 1, "OnChunkGenerating") )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool bRetVal = (tolua_toboolean( m_LuaState, -1, 0) > 0);
|
||||||
|
return bRetVal;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
cWebPlugin_Lua* cPlugin_NewLua::CreateWebPlugin(lua_State* a_LuaState)
|
cWebPlugin_Lua* cPlugin_NewLua::CreateWebPlugin(lua_State* a_LuaState)
|
||||||
{
|
{
|
||||||
cCSLock Lock( m_CriticalSection );
|
cCSLock Lock( m_CriticalSection );
|
||||||
|
@ -38,6 +38,7 @@ public: //tolua_export
|
|||||||
virtual bool OnKilled( cPawn* a_Killed, cEntity* a_Killer ) override;
|
virtual bool OnKilled( cPawn* a_Killed, cEntity* a_Killer ) override;
|
||||||
|
|
||||||
virtual void OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ) override;
|
virtual void OnChunkGenerated(cWorld * a_World, int a_ChunkX, int a_ChunkZ) override;
|
||||||
|
virtual bool OnChunkGenerating( int a_ChunkX, int a_ChunkZ, cLuaChunk * a_pLuaChunk ) override;
|
||||||
|
|
||||||
lua_State* GetLuaState() { return m_LuaState; }
|
lua_State* GetLuaState() { return m_LuaState; }
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user