1
0
mirror of https://github.com/moparisthebest/minetest synced 2025-01-09 20:58:00 -05:00

Ensure that Map::findNodesWithMetadata() reports nodes strictly within the node-granular area

This commit is contained in:
kwolekr 2015-05-08 13:31:03 -04:00
parent f1ccfd3c3d
commit ff740a4179

View File

@ -1898,6 +1898,8 @@ std::vector<v3s16> Map::findNodesWithMetadata(v3s16 p1, v3s16 p2)
v3s16 bpmin = getNodeBlockPos(p1); v3s16 bpmin = getNodeBlockPos(p1);
v3s16 bpmax = getNodeBlockPos(p2); v3s16 bpmax = getNodeBlockPos(p2);
VoxelArea area(p1, p2);
for (s16 z = bpmin.Z; z <= bpmax.Z; z++) for (s16 z = bpmin.Z; z <= bpmax.Z; z++)
for (s16 y = bpmin.Y; y <= bpmax.Y; y++) for (s16 y = bpmin.Y; y <= bpmax.Y; y++)
for (s16 x = bpmin.X; x <= bpmax.X; x++) { for (s16 x = bpmin.X; x <= bpmax.X; x++) {
@ -1917,8 +1919,13 @@ std::vector<v3s16> Map::findNodesWithMetadata(v3s16 p1, v3s16 p2)
v3s16 p_base = blockpos * MAP_BLOCKSIZE; v3s16 p_base = blockpos * MAP_BLOCKSIZE;
std::vector<v3s16> keys = block->m_node_metadata.getAllKeys(); std::vector<v3s16> keys = block->m_node_metadata.getAllKeys();
for (size_t i = 0; i != keys.size(); i++) for (size_t i = 0; i != keys.size(); i++) {
positions_with_meta.push_back(keys[i] + p_base); v3s16 p(keys[i] + p_base);
if (!area.contains(p))
continue;
positions_with_meta.push_back(p);
}
} }
return positions_with_meta; return positions_with_meta;