summaryrefslogtreecommitdiff
path: root/src/mg_ore.cpp
diff options
context:
space:
mode:
authorkwolekr <kwolekr@minetest.net>2014-12-12 14:07:49 -0500
committerkwolekr <kwolekr@minetest.net>2014-12-12 14:08:04 -0500
commitcf8213ea827f38ae5d4b8ef16c396545e3e59657 (patch)
treee739591704b1776002baa1bde7a4ff86de5f06ad /src/mg_ore.cpp
parentcec141adc1fd0845e27df9b0c88d979dd765e76f (diff)
downloadminetest-cf8213ea827f38ae5d4b8ef16c396545e3e59657.tar.gz
minetest-cf8213ea827f38ae5d4b8ef16c396545e3e59657.tar.bz2
minetest-cf8213ea827f38ae5d4b8ef16c396545e3e59657.zip
Add minetest.clear_registered_decorations() and clear_registered_ores()
Diffstat (limited to 'src/mg_ore.cpp')
-rw-r--r--src/mg_ore.cpp21
1 files changed, 20 insertions, 1 deletions
diff --git a/src/mg_ore.cpp b/src/mg_ore.cpp
index d94b861c2..de3f6b0e5 100644
--- a/src/mg_ore.cpp
+++ b/src/mg_ore.cpp
@@ -37,6 +37,12 @@ FlagDesc flagdesc_ore[] = {
///////////////////////////////////////////////////////////////////////////////
+OreManager::OreManager(IGameDef *gamedef) :
+ GenElementManager(gamedef)
+{
+}
+
+
size_t OreManager::placeAllOres(Mapgen *mg, u32 seed, v3s16 nmin, v3s16 nmax)
{
size_t nplaced = 0;
@@ -54,6 +60,20 @@ size_t OreManager::placeAllOres(Mapgen *mg, u32 seed, v3s16 nmin, v3s16 nmax)
}
+void OreManager::clear()
+{
+ for (size_t i = 0; i < m_elements.size(); i++) {
+ Ore *ore = (Ore *)m_elements[i];
+ if (!ore)
+ continue;
+
+ m_resolver->cancelNodeList(&ore->c_wherein);
+ m_resolver->cancelNode(&ore->c_ore);
+ }
+ m_elements.clear();
+}
+
+
///////////////////////////////////////////////////////////////////////////////
@@ -169,4 +189,3 @@ void OreSheet::generate(ManualMapVoxelManipulator *vm, int seed,
}
}
}
-