mirror of
https://github.com/minetest-mods/technic.git
synced 2025-07-01 15:50:39 +02:00
Add digiline interface to quarry
This adds a digiline interface that can be used to start, stop and restart, set the radius and get the current status.
This commit is contained in:
committed by
Buckaroo Banzai
parent
35e989ba2e
commit
6a9cf6da27
@ -108,3 +108,25 @@ The commands:
|
|||||||
- `"start"`: Tries to start the reactor, `"Start successful"` is sent back on success, `"Error"` if something is wrong.
|
- `"start"`: Tries to start the reactor, `"Start successful"` is sent back on success, `"Error"` if something is wrong.
|
||||||
|
|
||||||
If the automatic start is enabled, it will always send `"fuel used"` when it uses fuel.
|
If the automatic start is enabled, it will always send `"fuel used"` when it uses fuel.
|
||||||
|
|
||||||
|
|
||||||
|
## Quarry
|
||||||
|
You should send a table to it containing the `command` and for some commands the `value` field.
|
||||||
|
Some strings will automatically be converted to tables:
|
||||||
|
- `"get"` :arrow_right: `{command = "get"}`
|
||||||
|
- `"on"` :arrow_right: `{command = "on"}`
|
||||||
|
- `"off"` :arrow_right: `{command = "off"}`
|
||||||
|
- `"restart` :arrow_right: `{command = "restart"}`
|
||||||
|
- `"radius "..value` :arrow_right: `{command = "radius", value = value}`
|
||||||
|
|
||||||
|
The commands:
|
||||||
|
- `"get"`: The forcefield emitter sends back a table containing:
|
||||||
|
- `"enabled"`: `0` is off, `1` is on.
|
||||||
|
- `"radius"`
|
||||||
|
- `"finished"`
|
||||||
|
- `"dug_nodes"`
|
||||||
|
- `"dig_level"`: A negative value means above the quarry, a positive value means below.
|
||||||
|
- `"on"`: Activate the quarry.
|
||||||
|
- `"off"`: Deactivate the quarry.
|
||||||
|
- `"restart"`: Restart the quarry.
|
||||||
|
- `"radius"`: Set the radius to `value` and restart the quarry if the radius changed.
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
|
|
||||||
local S = technic.getter
|
local S = technic.getter
|
||||||
|
|
||||||
|
local has_digilines = minetest.get_modpath("digilines")
|
||||||
|
|
||||||
local quarry_dig_above_nodes = tonumber(minetest.settings:get("technic.quarry.dig_above_nodes") or "3")
|
local quarry_dig_above_nodes = tonumber(minetest.settings:get("technic.quarry.dig_above_nodes") or "3")
|
||||||
local quarry_max_depth = tonumber(minetest.settings:get("technic.quarry.maxdepth") or "100")
|
local quarry_max_depth = tonumber(minetest.settings:get("technic.quarry.maxdepth") or "100")
|
||||||
local quarry_time_limit = tonumber(minetest.settings:get("technic.quarry.time_limit") or "5000")
|
local quarry_time_limit = tonumber(minetest.settings:get("technic.quarry.time_limit") or "5000")
|
||||||
@ -11,12 +13,17 @@ local machine_name = S("%s Quarry"):format("HV")
|
|||||||
local quarry_formspec =
|
local quarry_formspec =
|
||||||
"size[8,9]"..
|
"size[8,9]"..
|
||||||
"item_image[7,0;1,1;technic:quarry]"..
|
"item_image[7,0;1,1;technic:quarry]"..
|
||||||
"list[context;cache;1,1;4,3;]"..
|
"list[context;cache;0,1;4,3;]"..
|
||||||
"listring[context;cache]"..
|
"listring[context;cache]"..
|
||||||
"list[current_player;main;0,5;8,4;]"..
|
"list[current_player;main;0,5;8,4;]"..
|
||||||
"listring[current_player;main]"..
|
"listring[current_player;main]"..
|
||||||
"label[0,0;"..machine_name.."]"..
|
"label[0,0;"..machine_name.."]"..
|
||||||
"button[5,1.9;2,1;restart;"..S("Restart").."]"
|
"button[6,0.9;2,1;restart;"..S("Restart").."]"
|
||||||
|
|
||||||
|
if has_digilines then
|
||||||
|
quarry_formspec = quarry_formspec
|
||||||
|
.. "field[4.3,3.4;4,1;channel;Channel;${channel}]"
|
||||||
|
end
|
||||||
|
|
||||||
-- hard-coded spiral dig pattern for up to 17x17 dig area
|
-- hard-coded spiral dig pattern for up to 17x17 dig area
|
||||||
local quarry_dig_pattern = {
|
local quarry_dig_pattern = {
|
||||||
@ -60,10 +67,10 @@ end
|
|||||||
|
|
||||||
local function set_quarry_status(pos)
|
local function set_quarry_status(pos)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local formspec = quarry_formspec.."field[5.3,3.4;2,1;size;"..S("Radius:")..";"..meta:get_int("size").."]"
|
local formspec = quarry_formspec.."field[4.3,2.4;2,1;size;"..S("Radius:")..";"..meta:get_int("size").."]"
|
||||||
local status = S("Digging not started")
|
local status = S("Digging not started")
|
||||||
if meta:get_int("enabled") == 1 then
|
if meta:get_int("enabled") == 1 then
|
||||||
formspec = formspec.."button[5,0.9;2,1;disable;"..S("Enabled").."]"
|
formspec = formspec.."button[4,0.9;2,1;disable;"..S("Enabled").."]"
|
||||||
if meta:get_int("purge_on") == 1 then
|
if meta:get_int("purge_on") == 1 then
|
||||||
status = S("Purging cache")
|
status = S("Purging cache")
|
||||||
meta:set_string("infotext", S("%s purging cache"):format(machine_name))
|
meta:set_string("infotext", S("%s purging cache"):format(machine_name))
|
||||||
@ -79,7 +86,7 @@ local function set_quarry_status(pos)
|
|||||||
meta:set_int("HV_EU_demand", quarry_demand)
|
meta:set_int("HV_EU_demand", quarry_demand)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
formspec = formspec.."button[5,0.9;2,1;enable;"..S("Disabled").."]"
|
formspec = formspec.."button[4,0.9;2,1;enable;"..S("Disabled").."]"
|
||||||
meta:set_string("infotext", S("%s Disabled"):format(machine_name))
|
meta:set_string("infotext", S("%s Disabled"):format(machine_name))
|
||||||
meta:set_int("HV_EU_demand", 0)
|
meta:set_int("HV_EU_demand", 0)
|
||||||
end
|
end
|
||||||
@ -101,6 +108,9 @@ local function quarry_receive_fields(pos, formname, fields, sender)
|
|||||||
reset_quarry(pos)
|
reset_quarry(pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
if fields.channel then
|
||||||
|
meta:set_string("channel", fields.channel)
|
||||||
|
end
|
||||||
if fields.enable then meta:set_int("enabled", 1) end
|
if fields.enable then meta:set_int("enabled", 1) end
|
||||||
if fields.disable then meta:set_int("enabled", 0) end
|
if fields.disable then meta:set_int("enabled", 0) end
|
||||||
if fields.restart then reset_quarry(pos) end
|
if fields.restart then reset_quarry(pos) end
|
||||||
@ -248,6 +258,62 @@ local function quarry_run(pos, node)
|
|||||||
set_quarry_status(pos)
|
set_quarry_status(pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local digiline_def = function(pos, _, channel, msg)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
if channel ~= meta:get_string("channel") then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
-- Convert string messages to tables:
|
||||||
|
if type(msg) == "string" then
|
||||||
|
local smsg = msg:lower()
|
||||||
|
msg = {}
|
||||||
|
if smsg == "get" then
|
||||||
|
msg.command = "get"
|
||||||
|
elseif smsg:sub(1,7) == "radius " then
|
||||||
|
msg.command = "radius"
|
||||||
|
msg.value = smsg:sub(8,-1)
|
||||||
|
elseif smsg == "on" then
|
||||||
|
msg.command = "on"
|
||||||
|
elseif smsg == "off" then
|
||||||
|
msg.command = "off"
|
||||||
|
elseif smsg == "restart" then
|
||||||
|
msg.command = "restart"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if type(msg) ~= "table" then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
if msg.command == "get" then
|
||||||
|
digilines.receptor_send(pos, technic.digilines.rules, channel, {
|
||||||
|
enabled = meta:get_int("enabled"),
|
||||||
|
radius = meta:get_int("size"),
|
||||||
|
finished = meta:get_int("finished"),
|
||||||
|
dug_nodes = meta:get_int("dug"),
|
||||||
|
dig_level = meta:get_int("dig_level") - pos.y
|
||||||
|
})
|
||||||
|
elseif msg.command == "radius" then
|
||||||
|
local size = tonumber(msg.value)
|
||||||
|
if not size or size < 1 or size > 8 or size == meta:get_int("size") then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
meta:set_int("size", size)
|
||||||
|
reset_quarry(pos)
|
||||||
|
set_quarry_status(pos)
|
||||||
|
elseif msg.command == "on" then
|
||||||
|
meta:set_int("enabled", 1)
|
||||||
|
set_quarry_status(pos)
|
||||||
|
elseif msg.command == "off" then
|
||||||
|
meta:set_int("enabled", 0)
|
||||||
|
set_quarry_status(pos)
|
||||||
|
elseif msg.command == "restart" then
|
||||||
|
reset_quarry(pos)
|
||||||
|
set_quarry_status(pos)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_node("technic:quarry", {
|
minetest.register_node("technic:quarry", {
|
||||||
description = S("%s Quarry"):format("HV"),
|
description = S("%s Quarry"):format("HV"),
|
||||||
tiles = {
|
tiles = {
|
||||||
@ -327,7 +393,17 @@ minetest.register_node("technic:quarry", {
|
|||||||
set_quarry_status(pos)
|
set_quarry_status(pos)
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
digiline = {
|
||||||
|
receptor = {
|
||||||
|
rules = technic.digilines.rules,
|
||||||
|
action = function() end,
|
||||||
|
},
|
||||||
|
effector = {
|
||||||
|
rules = technic.digilines.rules,
|
||||||
|
action = digiline_def,
|
||||||
|
},
|
||||||
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
|
Reference in New Issue
Block a user