c691f370b4
This aims to reduce spammed log files and corrects nonsense translations to the terminal
72 lines
1.9 KiB
Lua
72 lines
1.9 KiB
Lua
-- define global
|
|
hopper = {}
|
|
|
|
-- internationalization boilerplate
|
|
local MP = minetest.get_modpath(minetest.get_current_modname())
|
|
local S = minetest.get_translator("hopper")
|
|
|
|
hopper.translator_escaped = function(...)
|
|
return minetest.formspec_escape(S(...))
|
|
end
|
|
|
|
if minetest.get_modpath("default") then
|
|
hopper.formspec_bg = default.gui_bg .. default.gui_bg_img .. default.gui_slots
|
|
else
|
|
hopper.formspec_bg = "bgcolor[#080808BB;true]" .. "listcolors[#00000069;#5A5A5A;#141318;#30434C;#FFF]"
|
|
end
|
|
|
|
dofile(MP.."/config.lua")
|
|
dofile(MP.."/api.lua")
|
|
dofile(MP.."/utility.lua")
|
|
dofile(MP.."/doc.lua")
|
|
dofile(MP.."/nodes/hoppers.lua")
|
|
dofile(MP.."/nodes/chute.lua")
|
|
dofile(MP.."/nodes/sorter.lua")
|
|
dofile(MP.."/crafts.lua")
|
|
dofile(MP.."/abms.lua")
|
|
|
|
|
|
-------------------------------------------------------------------------------------------
|
|
-- Formspec handling
|
|
|
|
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|
if "hopper_formspec:" == string.sub(formname, 1, 16) then
|
|
local pos = minetest.string_to_pos(string.sub(formname, 17, -1))
|
|
local meta = minetest.get_meta(pos)
|
|
local eject_setting = meta:get_string("eject") == "true"
|
|
local filter_all_setting = meta:get_string("filter_all") == "true"
|
|
if fields.eject then
|
|
if eject_setting then
|
|
meta:set_string("eject", nil)
|
|
else
|
|
meta:set_string("eject", "true")
|
|
end
|
|
end
|
|
if fields.filter_all then
|
|
if filter_all_setting then
|
|
meta:set_string("filter_all", nil)
|
|
else
|
|
meta:set_string("filter_all", "true")
|
|
end
|
|
end
|
|
end
|
|
end)
|
|
|
|
|
|
|
|
-- add lucky blocks
|
|
if minetest.get_modpath("lucky_block") then
|
|
lucky_block:add_blocks({
|
|
{"dro", {"hopper:hopper"}, 3},
|
|
{"nod", "default:lava_source", 1},
|
|
})
|
|
end
|
|
|
|
-- Utility function for inventory movement logs
|
|
function hopper.log_inventory(...)
|
|
minetest.log(hopper.config.inv_log_level, ...)
|
|
end
|
|
|
|
|
|
minetest.log("action", "[hopper] Hopper mod loaded")
|