Add on_generated hook

This commit is contained in:
Perttu Ahola 2011-11-26 15:19:03 +02:00
parent 0dbb31afeb
commit 769cc9879f
5 changed files with 51 additions and 1 deletions

View File

@ -15,6 +15,7 @@
-- minetest.register_on_placenode(func(pos, newnode, placer)) -- minetest.register_on_placenode(func(pos, newnode, placer))
-- minetest.register_on_dignode(func(pos, oldnode, digger)) -- minetest.register_on_dignode(func(pos, oldnode, digger))
-- minetest.register_on_punchnode(func(pos, node, puncher)) -- minetest.register_on_punchnode(func(pos, node, puncher))
-- minetest.register_on_generated(func(minp, maxp))
-- minetest.register_on_newplayer(func(ObjectRef)) -- minetest.register_on_newplayer(func(ObjectRef))
-- minetest.register_on_respawnplayer(func(ObjectRef)) -- minetest.register_on_respawnplayer(func(ObjectRef))
-- ^ return true in func to disable regular player placement -- ^ return true in func to disable regular player placement
@ -1329,6 +1330,12 @@ minetest.register_on_respawnplayer(function(player)
-- return true -- return true
end) end)
minetest.register_on_generated(function(minp, maxp)
--print("on_generated: minp="..dump(minp).." maxp="..dump(maxp))
--cp = {x=(minp.x+maxp.x)/2, y=(minp.y+maxp.y)/2, z=(minp.z+maxp.z)/2}
--minetest.env:add_node(cp, {name="sand"})
end)
-- Example setting get -- Example setting get
print("setting max_users = " .. dump(minetest.setting_get("max_users"))) print("setting max_users = " .. dump(minetest.setting_get("max_users")))
print("setting asdf = " .. dump(minetest.setting_get("asdf"))) print("setting asdf = " .. dump(minetest.setting_get("asdf")))

View File

@ -60,7 +60,7 @@ namespace mapgen
u64 seed; u64 seed;
v3s16 blockpos; v3s16 blockpos;
UniqueQueue<v3s16> transforming_liquid; UniqueQueue<v3s16> transforming_liquid;
INodeDefManager *nodedef; // Destructor deletes INodeDefManager *nodedef;
BlockMakeData(); BlockMakeData();
~BlockMakeData(); ~BlockMakeData();

View File

@ -843,6 +843,13 @@ static int l_register_on_punchnode(lua_State *L)
return register_lua_callback(L, "registered_on_punchnodes"); return register_lua_callback(L, "registered_on_punchnodes");
} }
// register_on_generated(function)
static int l_register_on_generated(lua_State *L)
{
infostream<<"register_on_generated"<<std::endl;
return register_lua_callback(L, "registered_on_generateds");
}
// register_on_newplayer(function) // register_on_newplayer(function)
static int l_register_on_newplayer(lua_State *L) static int l_register_on_newplayer(lua_State *L)
{ {
@ -893,6 +900,7 @@ static const struct luaL_Reg minetest_f [] = {
{"register_on_placenode", l_register_on_placenode}, {"register_on_placenode", l_register_on_placenode},
{"register_on_dignode", l_register_on_dignode}, {"register_on_dignode", l_register_on_dignode},
{"register_on_punchnode", l_register_on_punchnode}, {"register_on_punchnode", l_register_on_punchnode},
{"register_on_generated", l_register_on_generated},
{"register_on_newplayer", l_register_on_newplayer}, {"register_on_newplayer", l_register_on_newplayer},
{"register_on_respawnplayer", l_register_on_respawnplayer}, {"register_on_respawnplayer", l_register_on_respawnplayer},
{"setting_get", l_setting_get}, {"setting_get", l_setting_get},
@ -1391,6 +1399,8 @@ void scriptapi_export(lua_State *L, Server *server)
lua_newtable(L); lua_newtable(L);
lua_setfield(L, -2, "registered_on_punchnodes"); lua_setfield(L, -2, "registered_on_punchnodes");
lua_newtable(L); lua_newtable(L);
lua_setfield(L, -2, "registered_on_generateds");
lua_newtable(L);
lua_setfield(L, -2, "registered_on_newplayers"); lua_setfield(L, -2, "registered_on_newplayers");
lua_newtable(L); lua_newtable(L);
lua_setfield(L, -2, "registered_on_respawnplayers"); lua_setfield(L, -2, "registered_on_respawnplayers");
@ -1694,6 +1704,32 @@ void scriptapi_environment_on_punchnode(lua_State *L, v3s16 p, MapNode node,
} }
} }
void scriptapi_environment_on_generated(lua_State *L, v3s16 minp, v3s16 maxp)
{
realitycheck(L);
assert(lua_checkstack(L, 20));
infostream<<"scriptapi_environment_on_generated"<<std::endl;
StackUnroller stack_unroller(L);
// Get minetest.registered_on_generateds
lua_getglobal(L, "minetest");
lua_getfield(L, -1, "registered_on_generateds");
luaL_checktype(L, -1, LUA_TTABLE);
int table = lua_gettop(L);
// Foreach
lua_pushnil(L);
while(lua_next(L, table) != 0){
// key at index -2 and value at index -1
luaL_checktype(L, -1, LUA_TFUNCTION);
// Call function
pushpos(L, minp);
pushpos(L, maxp);
if(lua_pcall(L, 2, 0, 0))
script_error(L, "error: %s\n", lua_tostring(L, -1));
// value removed, keep key for next iteration
}
}
/* /*
luaentity luaentity
*/ */

View File

@ -49,6 +49,8 @@ void scriptapi_environment_on_dignode(lua_State *L, v3s16 p, MapNode oldnode,
// When punching node // When punching node
void scriptapi_environment_on_punchnode(lua_State *L, v3s16 p, MapNode node, void scriptapi_environment_on_punchnode(lua_State *L, v3s16 p, MapNode node,
ServerActiveObject *puncher); ServerActiveObject *puncher);
// After generating a piece of map
void scriptapi_environment_on_generated(lua_State *L, v3s16 minp, v3s16 maxp);
/* misc */ /* misc */
void scriptapi_on_newplayer(lua_State *L, ServerActiveObject *player); void scriptapi_on_newplayer(lua_State *L, ServerActiveObject *player);

View File

@ -234,6 +234,11 @@ void * EmergeThread::Thread()
if(enable_mapgen_debug_info) if(enable_mapgen_debug_info)
infostream<<"EmergeThread: generating"<<std::endl; infostream<<"EmergeThread: generating"<<std::endl;
block = map.generateBlock(p, modified_blocks); block = map.generateBlock(p, modified_blocks);
v3s16 minp = block->getPos()*MAP_BLOCKSIZE;
v3s16 maxp = minp + v3s16(1,1,1)*(MAP_BLOCKSIZE-1);
scriptapi_environment_on_generated(m_server->m_lua,
minp, maxp);
} }
} }