summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--config.lua2
-rw-r--r--nodes/node_controllers.lua17
-rw-r--r--settingtypes.txt4
3 files changed, 15 insertions, 8 deletions
diff --git a/config.lua b/config.lua
index 79cc42d..130db7e 100644
--- a/config.lua
+++ b/config.lua
@@ -61,3 +61,5 @@ setting("int", "power_ratio", 100, "The electrical charge to 1 coal heat unit co
setting("float", "marker_crate_good_duration", 3.0, "Duration that 'good' crate markers last")
setting("float", "marker_crate_bad_duration", 9.0, "Duration that 'bad' crate markers last")
+
+setting("bool", "emerge_unloaded_mapblocks", true, "When Digtron encounters unloaded map blocks, emerge them.") \ No newline at end of file
diff --git a/nodes/node_controllers.lua b/nodes/node_controllers.lua
index e00cb35..39b5318 100644
--- a/nodes/node_controllers.lua
+++ b/nodes/node_controllers.lua
@@ -127,6 +127,9 @@ local function auto_cycle(pos)
status = status .. "\n" .. S("Cycles remaining: @1", cycle) .. "\n" .. S("Halted!")
meta:set_string("infotext", status)
if return_code == 1 then --return code 1 happens when there's unloaded nodes adjacent, just keep trying.
+ if digtron.config.emerge_unloaded_mapblocks then
+ minetest.emerge_area(vector.add(pos, -128), vector.add(pos, 128))
+ end
minetest.after(meta:get_int("period"), auto_cycle, newpos)
else
meta:set_string("formspec", auto_formspec)
@@ -139,13 +142,16 @@ local function auto_cycle(pos)
end
return
end
-
+
local newpos, status, return_code = digtron.execute_dig_cycle(pos, player)
-
+
if vector.equals(pos, newpos) then
status = status .. "\n" .. S("Cycles remaining: @1", cycle) .. "\n" .. S("Halted!")
meta:set_string("infotext", status)
- if return_code == 1 then --return code 1 happens when there's unloaded nodes adjacent, just keep trying.
+ if return_code == 1 then --return code 1 happens when there's unloaded nodes adjacent, call emerge and keep trying.
+ if digtron.config.emerge_unloaded_mapblocks then
+ minetest.emerge_area(vector.add(pos, -128), vector.add(pos, 128))
+ end
minetest.after(meta:get_int("period"), auto_cycle, newpos)
else
meta:set_string("formspec", auto_formspec)
@@ -286,10 +292,6 @@ minetest.register_node("digtron:auto_controller", {
meta:set_string("waiting", "true")
meta:set_string("formspec", auto_formspec)
end,
-
- on_timer = function(pos, elapsed)
- minetest.get_meta(pos):set_string("waiting", nil)
- end,
})
---------------------------------------------------------------------------------------------------------------
@@ -341,5 +343,4 @@ minetest.register_node("digtron:pusher", {
on_timer = function(pos, elapsed)
minetest.get_meta(pos):set_string("waiting", nil)
end,
-
})
diff --git a/settingtypes.txt b/settingtypes.txt
index 6deee8b..0a77a7e 100644
--- a/settingtypes.txt
+++ b/settingtypes.txt
@@ -23,6 +23,10 @@ digtron_maximum_extrusion (Digtron maximum extrusion) int 25 1 100
digtron_marker_crate_good_duration (Duration that 'good' crate markers last) float 3.0 0.0 100.0
digtron_marker_crate_bad_duration (Duration that 'bad' crate markers last) float 9.0 0.0 100.0
+#When a Digtron encounters unloaded map blocks, cause them to load
+#so that the Digtron can continue moving.
+digtron_emerge_unloaded_mapblocks (Emerge unloaded map blocks) bool true
+
[Fuel costs]
#eg, stone.