mirror of
https://github.com/minetest-mods/technic.git
synced 2025-01-13 11:30:43 +01:00
Genericise can logic
Factor out the logic common to water and lava cans. Provide it in the form of a technic.register_can() function, which can be called by other mods to register cans for other liquids.
This commit is contained in:
parent
cca72f43f1
commit
6771ad9d33
@ -1,26 +1,5 @@
|
|||||||
local water_can_max_load = 16
|
|
||||||
local lava_can_max_load = 8
|
|
||||||
|
|
||||||
local S = technic.getter
|
local S = technic.getter
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'technic:water_can 1',
|
|
||||||
recipe = {
|
|
||||||
{'technic:zinc_ingot', 'technic:rubber','technic:zinc_ingot'},
|
|
||||||
{'technic:carbon_steel_ingot', '', 'technic:carbon_steel_ingot'},
|
|
||||||
{'technic:zinc_ingot', 'technic:carbon_steel_ingot', 'technic:zinc_ingot'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = 'technic:lava_can 1',
|
|
||||||
recipe = {
|
|
||||||
{'technic:zinc_ingot', 'technic:stainless_steel_ingot','technic:zinc_ingot'},
|
|
||||||
{'technic:stainless_steel_ingot', '', 'technic:stainless_steel_ingot'},
|
|
||||||
{'technic:zinc_ingot', 'technic:stainless_steel_ingot', 'technic:zinc_ingot'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
local function set_can_wear(itemstack, level, max_level)
|
local function set_can_wear(itemstack, level, max_level)
|
||||||
local temp
|
local temp
|
||||||
if level == 0 then
|
if level == 0 then
|
||||||
@ -33,9 +12,12 @@ local function set_can_wear(itemstack, level, max_level)
|
|||||||
itemstack:set_wear(temp)
|
itemstack:set_wear(temp)
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_tool("technic:water_can", {
|
function technic.register_can(d)
|
||||||
description = S("Water Can"),
|
local data = {}
|
||||||
inventory_image = "technic_water_can.png",
|
for k, v in pairs(d) do data[k] = v end
|
||||||
|
minetest.register_tool(data.can_name, {
|
||||||
|
description = data.can_description,
|
||||||
|
inventory_image = data.can_inventory_image,
|
||||||
stack_max = 1,
|
stack_max = 1,
|
||||||
wear_represents = "content_level",
|
wear_represents = "content_level",
|
||||||
liquids_pointable = true,
|
liquids_pointable = true,
|
||||||
@ -51,12 +33,12 @@ minetest.register_tool("technic:water_can", {
|
|||||||
else
|
else
|
||||||
charge = tonumber(itemstack:get_metadata())
|
charge = tonumber(itemstack:get_metadata())
|
||||||
end
|
end
|
||||||
if node.name == "default:water_source" then
|
if node.name == data.liquid_source_name then
|
||||||
if charge < water_can_max_load then
|
if charge < data.can_capacity then
|
||||||
minetest.remove_node(pointed_thing.under)
|
minetest.remove_node(pointed_thing.under)
|
||||||
charge = charge + 1
|
charge = charge + 1
|
||||||
itemstack:set_metadata(tostring(charge))
|
itemstack:set_metadata(tostring(charge))
|
||||||
set_can_wear(itemstack, charge, water_can_max_load)
|
set_can_wear(itemstack, charge, data.can_capacity)
|
||||||
end
|
end
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
@ -64,82 +46,63 @@ minetest.register_tool("technic:water_can", {
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if node.name == "default:water_flowing" then
|
if node.name == data.liquid_flowing_name then
|
||||||
minetest.set_node(pointed_thing.under, {name="default:water_source"})
|
minetest.set_node(pointed_thing.under, {name=data.liquid_source_name})
|
||||||
charge = charge - 1
|
charge = charge - 1
|
||||||
itemstack:set_metadata(tostring(charge))
|
itemstack:set_metadata(tostring(charge))
|
||||||
set_can_wear(itemstack, charge, water_can_max_load)
|
set_can_wear(itemstack, charge, data.can_capacity)
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
|
|
||||||
node = minetest.get_node(pointed_thing.above)
|
node = minetest.get_node(pointed_thing.above)
|
||||||
if node.name == "air" then
|
if node.name == "air" then
|
||||||
minetest.set_node(pointed_thing.above, {name="default:water_source"})
|
minetest.set_node(pointed_thing.above, {name=data.liquid_source_name})
|
||||||
charge = charge - 1;
|
charge = charge - 1
|
||||||
itemstack:set_metadata(tostring(charge))
|
itemstack:set_metadata(tostring(charge))
|
||||||
set_can_wear(itemstack, charge, water_can_max_load)
|
set_can_wear(itemstack, charge, data.can_capacity)
|
||||||
return itemstack
|
return itemstack
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
on_refill = function(stack)
|
on_refill = function(stack)
|
||||||
stack:set_metadata(tostring(water_can_max_load))
|
stack:set_metadata(tostring(data.can_capacity))
|
||||||
set_can_wear(stack, water_can_max_load, water_can_max_load)
|
set_can_wear(stack, data.can_capacity, data.can_capacity)
|
||||||
return stack
|
return stack
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_tool("technic:lava_can", {
|
|
||||||
description = S("Lava Can"),
|
|
||||||
inventory_image = "technic_lava_can.png",
|
|
||||||
stack_max = 1,
|
|
||||||
wear_represents = "content_level",
|
|
||||||
liquids_pointable = true,
|
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
|
||||||
if pointed_thing.type ~= "node" then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
node = minetest.get_node(pointed_thing.under)
|
|
||||||
local charge = 0
|
|
||||||
if itemstack:get_metadata() == "" then
|
|
||||||
charge = 0
|
|
||||||
else
|
|
||||||
charge = tonumber(itemstack:get_metadata())
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if node.name == "default:lava_source" then
|
technic.register_can({
|
||||||
if charge < lava_can_max_load then
|
can_name = "technic:water_can",
|
||||||
minetest.remove_node(pointed_thing.under)
|
can_description = S("Water Can"),
|
||||||
charge = charge + 1
|
can_inventory_image = "technic_water_can.png",
|
||||||
itemstack:set_metadata(tostring(charge))
|
can_capacity = 16,
|
||||||
set_can_wear(itemstack, charge, lava_can_max_load)
|
liquid_source_name = "default:water_source",
|
||||||
end
|
liquid_flowing_name = "default:water_flowing",
|
||||||
return itemstack
|
|
||||||
end
|
|
||||||
if charge == 0 then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
if node.name == "default:lava_flowing" then
|
|
||||||
minetest.set_node(pointed_thing.under, {name="default:lava_source"})
|
|
||||||
charge = charge - 1
|
|
||||||
itemstack:set_metadata(tostring(charge))
|
|
||||||
set_can_wear(itemstack, charge, lava_can_max_load)
|
|
||||||
return itemstack
|
|
||||||
end
|
|
||||||
|
|
||||||
node = minetest.get_node(pointed_thing.above)
|
|
||||||
if node.name == "air" then
|
|
||||||
minetest.set_node(pointed_thing.above, {name="default:lava_source"})
|
|
||||||
charge = charge - 1
|
|
||||||
itemstack:set_metadata(tostring(charge))
|
|
||||||
set_can_wear(itemstack, charge, lava_can_max_load)
|
|
||||||
return itemstack
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
on_refill = function(stack)
|
|
||||||
stack:set_metadata(tostring(lava_can_max_load))
|
|
||||||
set_can_wear(stack, lava_can_max_load, lava_can_max_load)
|
|
||||||
return stack
|
|
||||||
end,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'technic:water_can 1',
|
||||||
|
recipe = {
|
||||||
|
{'technic:zinc_ingot', 'technic:rubber','technic:zinc_ingot'},
|
||||||
|
{'technic:carbon_steel_ingot', '', 'technic:carbon_steel_ingot'},
|
||||||
|
{'technic:zinc_ingot', 'technic:carbon_steel_ingot', 'technic:zinc_ingot'},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
technic.register_can({
|
||||||
|
can_name = "technic:lava_can",
|
||||||
|
can_description = S("Lava Can"),
|
||||||
|
can_inventory_image = "technic_lava_can.png",
|
||||||
|
can_capacity = 8,
|
||||||
|
liquid_source_name = "default:lava_source",
|
||||||
|
liquid_flowing_name = "default:lava_flowing",
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'technic:lava_can 1',
|
||||||
|
recipe = {
|
||||||
|
{'technic:zinc_ingot', 'technic:stainless_steel_ingot','technic:zinc_ingot'},
|
||||||
|
{'technic:stainless_steel_ingot', '', 'technic:stainless_steel_ingot'},
|
||||||
|
{'technic:zinc_ingot', 'technic:stainless_steel_ingot', 'technic:zinc_ingot'},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user