small code clean-up
This commit is contained in:
parent
2812d1a25f
commit
9bea61445b
11
API.lua
11
API.lua
@ -89,7 +89,6 @@ end
|
|||||||
-- start spawning ores
|
-- start spawning ores
|
||||||
function spawners.start_spawning_ores(pos, ore_name, sound_custom, spawners_pos)
|
function spawners.start_spawning_ores(pos, ore_name, sound_custom, spawners_pos)
|
||||||
if not pos or not ore_name then return end
|
if not pos or not ore_name then return end
|
||||||
|
|
||||||
local sound_name
|
local sound_name
|
||||||
local player_near = false
|
local player_near = false
|
||||||
|
|
||||||
@ -101,7 +100,7 @@ function spawners.start_spawning_ores(pos, ore_name, sound_custom, spawners_pos)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local how_many = math.random(0,2)
|
local how_many = math.random(0,2)
|
||||||
how_many = how_many+1
|
-- how_many = how_many+1
|
||||||
print("how_many: "..how_many)
|
print("how_many: "..how_many)
|
||||||
|
|
||||||
for i=1, how_many do
|
for i=1, how_many do
|
||||||
@ -116,9 +115,9 @@ function spawners.start_spawning_ores(pos, ore_name, sound_custom, spawners_pos)
|
|||||||
gain = 10,
|
gain = 10,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
print("#2 spawing "..ore_name.." at "..minetest.pos_to_string(pos))
|
||||||
minetest.set_node(pos, {name=ore_name})
|
minetest.set_node(pos, {name=ore_name})
|
||||||
spawners.add_effects(pos, 1)
|
spawners.add_effects(pos, 1)
|
||||||
print("#2 spawing "..ore_name.." at "..minetest.pos_to_string(pos))
|
|
||||||
else
|
else
|
||||||
minetest.sound_play(sound_name, {
|
minetest.sound_play(sound_name, {
|
||||||
pos = pos,
|
pos = pos,
|
||||||
@ -126,9 +125,9 @@ function spawners.start_spawning_ores(pos, ore_name, sound_custom, spawners_pos)
|
|||||||
gain = 10,
|
gain = 10,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
print("#1 spawing "..ore_name.." at "..minetest.pos_to_string(pos))
|
||||||
minetest.set_node(pos, {name=ore_name})
|
minetest.set_node(pos, {name=ore_name})
|
||||||
spawners.add_effects(pos, 1)
|
spawners.add_effects(pos, 1)
|
||||||
print("#1 spawing "..ore_name.." at "..minetest.pos_to_string(pos))
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -161,6 +160,8 @@ function spawners.check_around_radius_ores(pos, check_node)
|
|||||||
if node_ore_pos then
|
if node_ore_pos then
|
||||||
found_node = node_ore_pos
|
found_node = node_ore_pos
|
||||||
print("found stone: "..minetest.pos_to_string(found_node));
|
print("found stone: "..minetest.pos_to_string(found_node));
|
||||||
|
else
|
||||||
|
found_node = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -262,7 +263,7 @@ function spawners.check_node_status_ores(pos, ore_name, check_node)
|
|||||||
local player_near, found_node = spawners.check_around_radius_ores(pos, check_node)
|
local player_near, found_node = spawners.check_around_radius_ores(pos, check_node)
|
||||||
|
|
||||||
if player_near then
|
if player_near then
|
||||||
return false, found_node
|
return true, found_node
|
||||||
else
|
else
|
||||||
return true, false
|
return true, false
|
||||||
end
|
end
|
||||||
|
@ -1,9 +1,5 @@
|
|||||||
--
|
|
||||||
-- Formspecs
|
-- Formspecs
|
||||||
--
|
local ore_formspec =
|
||||||
|
|
||||||
local function active_formspec(fuel_percent, item_percent)
|
|
||||||
local formspec =
|
|
||||||
"size[8,8.5]"..
|
"size[8,8.5]"..
|
||||||
default.gui_bg..
|
default.gui_bg..
|
||||||
default.gui_bg_img..
|
default.gui_bg_img..
|
||||||
@ -15,25 +11,6 @@ local function active_formspec(fuel_percent, item_percent)
|
|||||||
"listring[current_name;fuel]"..
|
"listring[current_name;fuel]"..
|
||||||
"listring[current_player;main]"..
|
"listring[current_player;main]"..
|
||||||
default.get_hotbar_bg(0, 4.25)
|
default.get_hotbar_bg(0, 4.25)
|
||||||
return formspec
|
|
||||||
end
|
|
||||||
|
|
||||||
local inactive_formspec =
|
|
||||||
"size[8,8.5]"..
|
|
||||||
default.gui_bg..
|
|
||||||
default.gui_bg_img..
|
|
||||||
default.gui_slots..
|
|
||||||
"list[current_name;fuel;3.5,1.5;1,1;]"..
|
|
||||||
"list[current_player;main;0,4.25;8,1;]"..
|
|
||||||
"list[current_player;main;0,5.5;8,3;8]"..
|
|
||||||
"button_exit[5,1.5;2,1;exit;Save]"..
|
|
||||||
"listring[current_name;fuel]"..
|
|
||||||
"listring[current_player;main]"..
|
|
||||||
default.get_hotbar_bg(0, 4.25)
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Node callback functions that are the same for active and inactive furnace
|
|
||||||
--
|
|
||||||
|
|
||||||
function spawners.get_formspec(pos)
|
function spawners.get_formspec(pos)
|
||||||
|
|
||||||
@ -52,104 +29,10 @@ function spawners.get_formspec(pos)
|
|||||||
|
|
||||||
local fuellist = inv:get_list("fuel")
|
local fuellist = inv:get_list("fuel")
|
||||||
|
|
||||||
--
|
|
||||||
-- Cooking
|
|
||||||
--
|
|
||||||
|
|
||||||
-- Check if we have cookable content
|
|
||||||
-- local cooked, aftercooked = minetest.get_craft_result({method = "cooking", width = 1, items = srclist})
|
|
||||||
-- local cookable = true
|
|
||||||
|
|
||||||
-- if cooked.time == 0 then
|
|
||||||
-- cookable = false
|
|
||||||
-- end
|
|
||||||
|
|
||||||
-- Check if we have enough fuel to burn
|
|
||||||
-- if fuel_time < fuel_totaltime then
|
|
||||||
-- -- The furnace is currently active and has enough fuel
|
|
||||||
-- fuel_time = fuel_time + 1
|
|
||||||
|
|
||||||
-- -- If there is a cookable item then check if it is ready yet
|
|
||||||
-- if cookable then
|
|
||||||
-- src_time = src_time + 1
|
|
||||||
-- if src_time >= cooked.time then
|
|
||||||
-- -- Place result in dst list if possible
|
|
||||||
-- if inv:room_for_item("dst", cooked.item) then
|
|
||||||
-- inv:add_item("dst", cooked.item)
|
|
||||||
-- inv:set_stack("src", 1, aftercooked.items[1])
|
|
||||||
-- src_time = 0
|
|
||||||
-- end
|
|
||||||
-- end
|
|
||||||
-- end
|
|
||||||
-- else
|
|
||||||
-- -- Furnace ran out of fuel
|
|
||||||
-- if cookable then
|
|
||||||
-- -- We need to get new fuel
|
|
||||||
-- local fuel, afterfuel = minetest.get_craft_result({method = "fuel", width = 1, items = fuellist})
|
|
||||||
|
|
||||||
-- if fuel.time == 0 then
|
|
||||||
-- -- No valid fuel in fuel list
|
|
||||||
-- fuel_totaltime = 0
|
|
||||||
-- fuel_time = 0
|
|
||||||
-- src_time = 0
|
|
||||||
-- else
|
|
||||||
-- -- Take fuel from fuel list
|
|
||||||
-- inv:set_stack("fuel", 1, afterfuel.items[1])
|
|
||||||
|
|
||||||
-- fuel_totaltime = fuel.time
|
|
||||||
-- fuel_time = 0
|
|
||||||
|
|
||||||
-- end
|
|
||||||
-- else
|
|
||||||
-- -- We don't need to get new fuel since there is no cookable item
|
|
||||||
-- fuel_totaltime = 0
|
|
||||||
-- fuel_time = 0
|
|
||||||
-- src_time = 0
|
|
||||||
-- end
|
|
||||||
-- end
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Update formspec, infotext and node
|
-- Update formspec, infotext and node
|
||||||
--
|
local formspec = ore_formspec
|
||||||
local formspec = inactive_formspec
|
|
||||||
-- local item_state = ""
|
|
||||||
-- local item_percent = 0
|
|
||||||
-- if cookable then
|
|
||||||
-- item_percent = math.floor(src_time / cooked.time * 100)
|
|
||||||
-- item_state = item_percent .. "%"
|
|
||||||
-- else
|
|
||||||
-- if srclist[1]:is_empty() then
|
|
||||||
-- item_state = "Empty"
|
|
||||||
-- else
|
|
||||||
-- item_state = "Not cookable"
|
|
||||||
-- end
|
|
||||||
-- end
|
|
||||||
|
|
||||||
-- local fuel_state = "Empty"
|
|
||||||
-- local active = "inactive "
|
|
||||||
-- if fuel_time <= fuel_totaltime and fuel_totaltime ~= 0 then
|
|
||||||
-- active = "active "
|
|
||||||
-- local fuel_percent = math.floor(fuel_time / fuel_totaltime * 100)
|
|
||||||
-- fuel_state = fuel_percent .. "%"
|
|
||||||
-- formspec = active_formspec(fuel_percent, item_percent)
|
|
||||||
-- -- swap_node(pos, "default:furnace_active")
|
|
||||||
-- else
|
|
||||||
-- if not fuellist[1]:is_empty() then
|
|
||||||
-- fuel_state = "0%"
|
|
||||||
-- end
|
|
||||||
-- -- swap_node(pos, "default:furnace")
|
|
||||||
-- end
|
|
||||||
|
|
||||||
-- local infotext = "Furnace " .. active .. "(Item: " .. item_state .. "; Fuel: " .. fuel_state .. ")"
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Set meta values
|
|
||||||
--
|
|
||||||
-- meta:set_float("fuel_totaltime", fuel_totaltime)
|
|
||||||
-- meta:set_float("fuel_time", fuel_time)
|
|
||||||
-- meta:set_float("src_time", src_time)
|
|
||||||
meta:set_string("formspec", formspec)
|
meta:set_string("formspec", formspec)
|
||||||
-- meta:set_string("infotext", infotext)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function can_dig(pos, player)
|
local function can_dig(pos, player)
|
||||||
@ -200,14 +83,13 @@ local function on_receive_fields(pos, formname, fields, sender)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- get the ore name
|
||||||
local ingot = ore_node.name
|
local ingot = ore_node.name
|
||||||
ingot = string.split(ingot, ":")
|
ingot = string.split(ingot, ":")
|
||||||
ingot = string.split(ingot[2], "_")
|
ingot = string.split(ingot[2], "_")
|
||||||
|
|
||||||
|
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
-- inv:set_size("fuel", 1)
|
|
||||||
local fuellist = inv:get_list("fuel")
|
local fuellist = inv:get_list("fuel")
|
||||||
|
|
||||||
if inv:is_empty("fuel") then
|
if inv:is_empty("fuel") then
|
||||||
@ -216,13 +98,12 @@ local function on_receive_fields(pos, formname, fields, sender)
|
|||||||
end
|
end
|
||||||
meta:set_string("infotext", ingot[3].." ore spawner is empty")
|
meta:set_string("infotext", ingot[3].." ore spawner is empty")
|
||||||
else
|
else
|
||||||
meta:set_string("infotext", ingot[3].." ore spawner has "..inv:get_stack("fuel", 1):get_count().." ingots")
|
meta:set_string("infotext", ingot[3].." ore spawner fuel: "..inv:get_stack("fuel", 1):get_count())
|
||||||
end
|
end
|
||||||
|
|
||||||
-- fix iron vs. steel issue
|
-- fix iron vs. steel issue
|
||||||
if ingot[3] == "iron" then
|
if ingot[3] == "iron" then
|
||||||
ingot[3] = "steel"
|
ingot[3] = "steel"
|
||||||
print("changing ingot name to: "..ingot[3])
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if not fuellist[1]:is_empty() and inv:get_stack("fuel", 1):get_name() == "default:"..ingot[3].."_ingot" then
|
if not fuellist[1]:is_empty() and inv:get_stack("fuel", 1):get_name() == "default:"..ingot[3].."_ingot" then
|
||||||
@ -230,7 +111,6 @@ local function on_receive_fields(pos, formname, fields, sender)
|
|||||||
-- fix iron vs. steel issue
|
-- fix iron vs. steel issue
|
||||||
if ingot[3] == "steel" then
|
if ingot[3] == "steel" then
|
||||||
ingot[3] = "iron"
|
ingot[3] = "iron"
|
||||||
print("changing ingot name to: "..ingot[3])
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local waiting, found_node = spawners.check_node_status_ores(pos, "stone_with_"..ingot[3], "default:stone")
|
local waiting, found_node = spawners.check_node_status_ores(pos, "stone_with_"..ingot[3], "default:stone")
|
||||||
@ -245,22 +125,9 @@ local function on_receive_fields(pos, formname, fields, sender)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
print("get_stack: "..inv:get_stack("fuel", 1):get_count())
|
|
||||||
print("get_stack: "..inv:get_stack("fuel", 1):take_item():to_string())
|
|
||||||
print("take_item: "..inv:get_stack("fuel", 1):take_item():get_count())
|
|
||||||
-- inv:set_stack("fuel", 1, aftercooked.items[1])
|
|
||||||
-- print("get_stack: "..inv:get_stack("fuel", 1))
|
|
||||||
-- inv:set_stack("fuel", 1, inv:get_stack("fuel", 1):take_item())
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
--
|
|
||||||
-- Ores creation
|
-- Ores creation
|
||||||
--
|
|
||||||
|
|
||||||
function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_custom)
|
function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_custom)
|
||||||
-- dummy inside the spawner
|
-- dummy inside the spawner
|
||||||
local dummy_ore_definition = {
|
local dummy_ore_definition = {
|
||||||
@ -319,13 +186,7 @@ function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_
|
|||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {cracky=1,level=2,igniter=1,not_in_creative_inventory=1},
|
groups = {cracky=1,level=2,igniter=1,not_in_creative_inventory=1},
|
||||||
drop = "spawners:"..ore_name.."_spawner",
|
drop = "spawners:"..ore_name.."_spawner",
|
||||||
-- on_construct = function(pos)
|
|
||||||
-- pos.y = pos.y + offset
|
|
||||||
-- minetest.add_entity(pos,"spawners:dummy_ore_"..ore_name)
|
|
||||||
-- end,
|
|
||||||
|
|
||||||
can_dig = can_dig,
|
can_dig = can_dig,
|
||||||
|
|
||||||
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
||||||
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
@ -354,13 +215,7 @@ function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_
|
|||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {cracky=1,level=2,not_in_creative_inventory=1},
|
groups = {cracky=1,level=2,not_in_creative_inventory=1},
|
||||||
drop = "spawners:"..ore_name.."_spawner",
|
drop = "spawners:"..ore_name.."_spawner",
|
||||||
-- on_construct = function(pos)
|
|
||||||
-- spawners.get_formspec(pos)
|
|
||||||
-- pos.y = pos.y + offset
|
|
||||||
-- minetest.add_entity(pos,"spawners:dummy_ore_"..ore_name)
|
|
||||||
-- end,
|
|
||||||
can_dig = can_dig,
|
can_dig = can_dig,
|
||||||
|
|
||||||
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
||||||
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
@ -378,17 +233,7 @@ function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_
|
|||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {cracky=1,level=2},
|
groups = {cracky=1,level=2},
|
||||||
on_construct = function(pos)
|
on_construct = function(pos)
|
||||||
-- local waiting, found_node = spawners.check_node_status_ores(pos, ore_name, "default:stone")
|
|
||||||
|
|
||||||
spawners.get_formspec(pos)
|
spawners.get_formspec(pos)
|
||||||
|
|
||||||
-- if found_node then
|
|
||||||
-- minetest.swap_node(pos, {name="spawners:"..ore_name.."_spawner_active"})
|
|
||||||
-- elseif waiting then
|
|
||||||
-- minetest.swap_node(pos, {name="spawners:"..ore_name.."_spawner_waiting"})
|
|
||||||
-- else
|
|
||||||
-- end
|
|
||||||
|
|
||||||
pos.y = pos.y + offset
|
pos.y = pos.y + offset
|
||||||
minetest.add_entity(pos,"spawners:dummy_ore_"..ore_name)
|
minetest.add_entity(pos,"spawners:dummy_ore_"..ore_name)
|
||||||
end,
|
end,
|
||||||
@ -400,9 +245,7 @@ function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_
|
|||||||
on_receive_fields = on_receive_fields,
|
on_receive_fields = on_receive_fields,
|
||||||
})
|
})
|
||||||
|
|
||||||
--
|
|
||||||
-- ABM
|
-- ABM
|
||||||
--
|
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {"spawners:"..ore_name.."_spawner_active", "spawners:"..ore_name.."_spawner_waiting"},
|
nodenames = {"spawners:"..ore_name.."_spawner_active", "spawners:"..ore_name.."_spawner_waiting"},
|
||||||
interval = 5.0,
|
interval = 5.0,
|
||||||
@ -437,15 +280,6 @@ function spawners.create_ore(ore_name, mod_prefix, size, offset, texture, sound_
|
|||||||
meta:set_string("infotext", ore_name.." ore spawner has "..inv:get_stack("fuel", 1):get_count().." ingots")
|
meta:set_string("infotext", ore_name.." ore spawner has "..inv:get_stack("fuel", 1):get_count().." ingots")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
-- print("get_stack: "..inv:get_stack("fuel", 1):get_count())
|
|
||||||
-- print("get_stack: "..inv:get_stack("fuel", 1):take_item():to_string())
|
|
||||||
-- print("take_item: "..inv:get_stack("fuel", 1):take_item():get_count())
|
|
||||||
-- print(inv:get_stack("fuel", 1):get_count()-inv:get_stack("fuel", 1):take_item():get_count())
|
|
||||||
-- inv:set_stack("fuel", 1, aftercooked.items[1])
|
|
||||||
-- print("get_stack: "..inv:get_stack("fuel", 1))
|
|
||||||
-- inv:set_stack("fuel", 1, inv:get_stack("fuel", 1):take_item())
|
|
||||||
|
|
||||||
-- enough place to spawn more ores
|
-- enough place to spawn more ores
|
||||||
spawners.start_spawning_ores(found_node, "default:"..ore_name, sound_custom)
|
spawners.start_spawning_ores(found_node, "default:"..ore_name, sound_custom)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user