summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--technic/machines/LV/extractor.lua1
-rw-r--r--technic/machines/MV/tool_workshop.lua2
-rw-r--r--technic/machines/switching_station.lua2
-rw-r--r--technic/tools/flashlight.lua50
4 files changed, 28 insertions, 27 deletions
diff --git a/technic/machines/LV/extractor.lua b/technic/machines/LV/extractor.lua
index c4d8ad3..c814d9e 100644
--- a/technic/machines/LV/extractor.lua
+++ b/technic/machines/LV/extractor.lua
@@ -121,6 +121,7 @@ minetest.register_abm({
-- Power off automatically if no longer connected to a switching station
technic.switching_station_timeout_count(pos, "LV")
+ local src_item = nil
if srcstack then
src_item = srcstack:to_table()
end
diff --git a/technic/machines/MV/tool_workshop.lua b/technic/machines/MV/tool_workshop.lua
index 7191c0c..9955d5f 100644
--- a/technic/machines/MV/tool_workshop.lua
+++ b/technic/machines/MV/tool_workshop.lua
@@ -60,7 +60,7 @@ minetest.register_abm({
-- Power off automatically if no longer connected to a switching station
technic.switching_station_timeout_count(pos, "MV")
- srcstack = inv:get_stack("src", 1)
+ local srcstack = inv:get_stack("src", 1)
if inv:is_empty("src") or
srcstack:get_wear() == 0 or
srcstack:get_name() == "technic:water_can" or
diff --git a/technic/machines/switching_station.lua b/technic/machines/switching_station.lua
index 206284f..f7a0f44 100644
--- a/technic/machines/switching_station.lua
+++ b/technic/machines/switching_station.lua
@@ -67,7 +67,7 @@ minetest.register_node("technic:switching_station",{
-- A node must be touched by the station continuously in order to function
function technic.switching_station_timeout_count(pos, tier)
local meta = minetest.get_meta(pos)
- timeout = meta:get_int(tier.."_EU_timeout")
+ local timeout = meta:get_int(tier.."_EU_timeout")
if timeout == 0 then
meta:set_int(tier.."_EU_input", 0)
else
diff --git a/technic/tools/flashlight.lua b/technic/tools/flashlight.lua
index 61eceae..4e86893 100644
--- a/technic/tools/flashlight.lua
+++ b/technic/tools/flashlight.lua
@@ -27,10 +27,34 @@ local players = {}
local player_positions = {}
local last_wielded = {}
-function round(num)
+local function round(num)
return math.floor(num + 0.5)
end
+local function check_for_flashlight(player)
+ if player == nil then
+ return false
+ end
+ local inv = player:get_inventory()
+ local hotbar = inv:get_list("main")
+ for i = 1, 8 do
+ if hotbar[i]:get_name() == "technic:flashlight" then
+ local meta = minetest.deserialize(hotbar[i]:get_metadata())
+ if not meta or not meta.charge then
+ return false
+ end
+ if meta.charge - 2 > 0 then
+ meta.charge = meta.charge - 2;
+ technic.set_RE_wear(hotbar[i], meta.charge, flashlight_max_charge)
+ hotbar[i]:set_metadata(minetest.serialize(meta))
+ inv:set_stack("main", i, hotbar[i])
+ return true
+ end
+ end
+ end
+ return false
+end
+
minetest.register_on_joinplayer(function(player)
local player_name = player:get_player_name()
table.insert(players, player_name)
@@ -143,27 +167,3 @@ minetest.register_node("technic:light_off", {
},
})
-function check_for_flashlight(player)
- if player == nil then
- return false
- end
- local inv = player:get_inventory()
- local hotbar = inv:get_list("main")
- for i = 1, 8 do
- if hotbar[i]:get_name() == "technic:flashlight" then
- local meta = minetest.deserialize(hotbar[i]:get_metadata())
- if not meta or not meta.charge then
- return false
- end
- if meta.charge - 2 > 0 then
- meta.charge = meta.charge - 2;
- technic.set_RE_wear(hotbar[i], meta.charge, flashlight_max_charge)
- hotbar[i]:set_metadata(minetest.serialize(meta))
- inv:set_stack("main", i, hotbar[i])
- return true
- end
- end
- end
- return false
-end
-