From 1c15f53318d49ccd148ec42b0a4345c4a8cd06bf Mon Sep 17 00:00:00 2001 From: Perttu Ahola Date: Wed, 28 Dec 2011 18:18:08 +0200 Subject: Add EnvRef:get_objects_inside_radius(pos, radius) --- src/environment.cpp | 17 +++++++++++++++++ src/environment.h | 12 +++++++++--- src/scriptapi.cpp | 31 +++++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+), 3 deletions(-) (limited to 'src') diff --git a/src/environment.cpp b/src/environment.cpp index aa2b45f8f..88f1527fc 100644 --- a/src/environment.cpp +++ b/src/environment.cpp @@ -752,6 +752,23 @@ void ServerEnvironment::addActiveBlockModifier(ActiveBlockModifier *abm) m_abms.push_back(ABMWithState(abm)); } +std::set ServerEnvironment::getObjectsInsideRadius(v3f pos, float radius) +{ + std::set objects; + for(core::map::Iterator + i = m_active_objects.getIterator(); + i.atEnd()==false; i++) + { + ServerActiveObject* obj = i.getNode()->getValue(); + u16 id = i.getNode()->getKey(); + v3f objectpos = obj->getBasePosition(); + if(objectpos.getDistanceFrom(pos) > radius) + continue; + objects.insert(id); + } + return objects; +} + void ServerEnvironment::clearAllObjects() { infostream<<"ServerEnvironment::clearAllObjects(): " diff --git a/src/environment.h b/src/environment.h index e14a9c485..3ebbee910 100644 --- a/src/environment.h +++ b/src/environment.h @@ -261,18 +261,24 @@ public: void activateBlock(MapBlock *block, u32 additional_dtime=0); /* - ActiveBlockModifiers (TODO) + ActiveBlockModifiers ------------------------------------------- - NOTE: Not used currently (TODO: Use or remove) */ void addActiveBlockModifier(ActiveBlockModifier *abm); - /* Other stuff */ + /* + Other stuff + ------------------------------------------- + */ + + // Find all active objects inside a radius around a point + std::set getObjectsInsideRadius(v3f pos, float radius); // Clear all objects, loading and going through every MapBlock void clearAllObjects(); + // This makes stuff happen void step(f32 dtime); private: diff --git a/src/scriptapi.cpp b/src/scriptapi.cpp index 23336e32d..1a50e1e34 100644 --- a/src/scriptapi.cpp +++ b/src/scriptapi.cpp @@ -2592,6 +2592,36 @@ private: return 1; } + // EnvRef:get_objects_inside_radius(pos, radius) + static int l_get_objects_inside_radius(lua_State *L) + { + // Get the table insert function + lua_getglobal(L, "table"); + lua_getfield(L, -1, "insert"); + int table_insert = lua_gettop(L); + // Get environemnt + EnvRef *o = checkobject(L, 1); + ServerEnvironment *env = o->m_env; + if(env == NULL) return 0; + // Do it + v3f pos = readFloatPos(L, 2); + float radius = luaL_checknumber(L, 3) * BS; + std::set ids = env->getObjectsInsideRadius(pos, radius); + lua_newtable(L); + int table = lua_gettop(L); + for(std::set::const_iterator + i = ids.begin(); i != ids.end(); i++){ + ServerActiveObject *obj = env->getActiveObject(*i); + // Insert object reference into table + lua_pushvalue(L, table_insert); + lua_pushvalue(L, table); + objectref_get_or_create(L, obj); + if(lua_pcall(L, 2, 0, 0)) + script_error(L, "error: %s", lua_tostring(L, -1)); + } + return 1; + } + static int gc_object(lua_State *L) { EnvRef *o = *(EnvRef **)(lua_touserdata(L, 1)); delete o; @@ -2668,6 +2698,7 @@ const luaL_reg EnvRef::methods[] = { method(EnvRef, add_firefly), method(EnvRef, get_meta), method(EnvRef, get_player_by_name), + method(EnvRef, get_objects_inside_radius), {0,0} }; -- cgit v1.2.3