summaryrefslogtreecommitdiff
path: root/src/server/activeobjectmgr.cpp
diff options
context:
space:
mode:
authorLoïc Blot <nerzhul@users.noreply.github.com>2020-04-16 08:25:48 +0200
committerGitHub <noreply@github.com>2020-04-16 08:25:48 +0200
commite8ac5a31cf12afcfddf8e3ed31e8038930edb06f (patch)
tree5bdc776c5bbe190e32e42899b455e6d16179e3b5 /src/server/activeobjectmgr.cpp
parent62ae7adab2bebde04864c12543caefbffab24963 (diff)
downloadminetest-e8ac5a31cf12afcfddf8e3ed31e8038930edb06f.tar.gz
minetest-e8ac5a31cf12afcfddf8e3ed31e8038930edb06f.tar.bz2
minetest-e8ac5a31cf12afcfddf8e3ed31e8038930edb06f.zip
Optimize get_objects_inside_radius calls (#9671)
* Optimize getObjectsInsideRadius calls our previous implementation calls the ActiveObjectMgr to return ids and then lookup those ids in the same map and test each object Instead now we call the global map to return the pointers directly and we ask filtering when building the list using lamba. This drop double looping over ranges of active objects (and then filtered one) and drop x lookups on the map regarding the first call results
Diffstat (limited to 'src/server/activeobjectmgr.cpp')
-rw-r--r--src/server/activeobjectmgr.cpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/server/activeobjectmgr.cpp b/src/server/activeobjectmgr.cpp
index 984ae7794..1b8e31409 100644
--- a/src/server/activeobjectmgr.cpp
+++ b/src/server/activeobjectmgr.cpp
@@ -111,17 +111,19 @@ void ActiveObjectMgr::removeObject(u16 id)
}
// clang-format on
-void ActiveObjectMgr::getObjectsInsideRadius(
- const v3f &pos, float radius, std::vector<u16> &result)
+void ActiveObjectMgr::getObjectsInsideRadius(const v3f &pos, float radius,
+ std::vector<ServerActiveObject *> &result,
+ std::function<bool(ServerActiveObject *obj)> include_obj_cb)
{
float r2 = radius * radius;
for (auto &activeObject : m_active_objects) {
ServerActiveObject *obj = activeObject.second;
- u16 id = activeObject.first;
const v3f &objectpos = obj->getBasePosition();
if (objectpos.getDistanceFromSQ(pos) > r2)
continue;
- result.push_back(id);
+
+ if (!include_obj_cb || include_obj_cb(obj))
+ result.push_back(obj);
}
}