mirror of
https://github.com/joe7575/techpack.git
synced 2024-11-26 09:03:46 +01:00
v2.01 SaferLua Terminal to be connected to the SaferLua Controller
This commit is contained in:
parent
3560082270
commit
f62ee1db4a
@ -1,4 +1,4 @@
|
|||||||
# TechPack V2.00
|
# TechPack V2.01
|
||||||
|
|
||||||
TechPack, a Mining, Crafting, & Farming Modpack for Minetest.
|
TechPack, a Mining, Crafting, & Farming Modpack for Minetest.
|
||||||
|
|
||||||
@ -55,6 +55,7 @@ TechPack provides:
|
|||||||
- sending mails or chat messages
|
- sending mails or chat messages
|
||||||
- output on a display
|
- output on a display
|
||||||
- a Controller to be programmed in Lua
|
- a Controller to be programmed in Lua
|
||||||
|
- a Terminal to be connected to the Lua Controller
|
||||||
- a Signal Tower node showing machine states
|
- a Signal Tower node showing machine states
|
||||||
- a Display node for text outputs of the Controller
|
- a Display node for text outputs of the Controller
|
||||||
- Metal ladders, stairways, and bridges
|
- Metal ladders, stairways, and bridges
|
||||||
@ -143,6 +144,8 @@ tubelib_addons1 optional: unified_inventory
|
|||||||
- 2018-12-23 V2.xx * on the way to v2
|
- 2018-12-23 V2.xx * on the way to v2
|
||||||
- 2018-12-29 V2.00 * beta
|
- 2018-12-29 V2.00 * beta
|
||||||
- 2019-01-12 V2.00 * release
|
- 2019-01-12 V2.00 * release
|
||||||
|
- 2019-01-27 V2.01 * SaferLua Controller Terminal added
|
||||||
|
|
||||||
|
|
||||||
## New in v2 (from players point of view)
|
## New in v2 (from players point of view)
|
||||||
- Almost all machines break after a certain amount of time (switch into the state 'defect') and have to be repaired.
|
- Almost all machines break after a certain amount of time (switch into the state 'defect') and have to be repaired.
|
||||||
|
@ -2,6 +2,20 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## V2.01 (2019-01-27)
|
||||||
|
|
||||||
|
### Additions
|
||||||
|
- SaferLua Terminal to be connected to the SaferLua Controller
|
||||||
|
|
||||||
|
### Removals
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
- Server: formspec added to enter valid usernames for server access
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## V2.00.07 (2019-01-27)
|
## V2.00.07 (2019-01-27)
|
||||||
|
|
||||||
### Additions
|
### Additions
|
||||||
|
@ -25,6 +25,17 @@ sl_controller.register_function("get_input", {
|
|||||||
" The device has to be connected with the controller."
|
" The device has to be connected with the controller."
|
||||||
})
|
})
|
||||||
|
|
||||||
|
sl_controller.register_function("get_string", {
|
||||||
|
cmnd = function(self, num)
|
||||||
|
num = tostring(num or "")
|
||||||
|
return sl_controller.get_command(self.meta.number)
|
||||||
|
end,
|
||||||
|
help = ' $get_string() --> text sting or nil\n'..
|
||||||
|
' Read an entered string (command) from the Terminal.\n'..
|
||||||
|
' example: s = $get_string()\n'..
|
||||||
|
" The Terminal has to be connected with the controller."
|
||||||
|
})
|
||||||
|
|
||||||
sl_controller.register_function("get_status", {
|
sl_controller.register_function("get_status", {
|
||||||
cmnd = function(self, num)
|
cmnd = function(self, num)
|
||||||
num = tostring(num or "")
|
num = tostring(num or "")
|
||||||
@ -170,6 +181,16 @@ sl_controller.register_action("display", {
|
|||||||
' example: $display("0123", 1, "Hello ", name, " !")'
|
' example: $display("0123", 1, "Hello ", name, " !")'
|
||||||
})
|
})
|
||||||
|
|
||||||
|
sl_controller.register_action("terminal", {
|
||||||
|
cmnd = function(self, num, text)
|
||||||
|
text = tostring(text or "")
|
||||||
|
tubelib.send_message(num, self.meta.owner, nil, "term", text)
|
||||||
|
end,
|
||||||
|
help = " $terminal(num, text)\n"..
|
||||||
|
' Send a text line to the terminal with number "num".\n'..
|
||||||
|
' example: $terminal("0123", "Hello "..name)'
|
||||||
|
})
|
||||||
|
|
||||||
sl_controller.register_action("clear_screen", {
|
sl_controller.register_action("clear_screen", {
|
||||||
cmnd = function(self, num)
|
cmnd = function(self, num)
|
||||||
num = tostring(num or "")
|
num = tostring(num or "")
|
||||||
|
@ -283,6 +283,7 @@ local function compile(pos, meta, number)
|
|||||||
|
|
||||||
if code then
|
if code then
|
||||||
Cache[number] = {code=code, inputs={}}
|
Cache[number] = {code=code, inputs={}}
|
||||||
|
Cache[number].inputs.term = "" -- terminal inputs
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
@ -543,6 +544,16 @@ function sl_controller.get_input(number, input)
|
|||||||
return "off"
|
return "off"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- used for Terminal commands
|
||||||
|
function sl_controller.get_command(number)
|
||||||
|
if Cache[number] and Cache[number].inputs then
|
||||||
|
local cmnd = Cache[number].inputs["term"] or ""
|
||||||
|
Cache[number].inputs["term"] = ""
|
||||||
|
return cmnd
|
||||||
|
end
|
||||||
|
return ""
|
||||||
|
end
|
||||||
|
|
||||||
tubelib.register_node("sl_controller:controller", {}, {
|
tubelib.register_node("sl_controller:controller", {}, {
|
||||||
on_recv_message = function(pos, topic, payload)
|
on_recv_message = function(pos, topic, payload)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
@ -552,6 +563,8 @@ tubelib.register_node("sl_controller:controller", {}, {
|
|||||||
set_input(pos, number, payload, topic)
|
set_input(pos, number, payload, topic)
|
||||||
elseif topic == "off" then
|
elseif topic == "off" then
|
||||||
set_input(pos, number, payload, topic)
|
set_input(pos, number, payload, topic)
|
||||||
|
elseif topic == "term" then
|
||||||
|
set_input(pos, number, "term", payload)
|
||||||
elseif topic == "state" then
|
elseif topic == "state" then
|
||||||
local running = meta:get_int("running") or tubelib.STATE_STOPPED
|
local running = meta:get_int("running") or tubelib.STATE_STOPPED
|
||||||
return tubelib.statestring(running)
|
return tubelib.statestring(running)
|
||||||
|
@ -16,4 +16,5 @@ dofile(minetest.get_modpath("sl_controller") .. "/config.lua")
|
|||||||
dofile(minetest.get_modpath("sl_controller") .. "/controller.lua")
|
dofile(minetest.get_modpath("sl_controller") .. "/controller.lua")
|
||||||
dofile(minetest.get_modpath("sl_controller") .. "/commands.lua")
|
dofile(minetest.get_modpath("sl_controller") .. "/commands.lua")
|
||||||
dofile(minetest.get_modpath("sl_controller") .. "/battery.lua")
|
dofile(minetest.get_modpath("sl_controller") .. "/battery.lua")
|
||||||
dofile(minetest.get_modpath("sl_controller") .. "/server.lua")
|
dofile(minetest.get_modpath("sl_controller") .. "/server.lua")
|
||||||
|
dofile(minetest.get_modpath("sl_controller") .. "/terminal.lua")
|
@ -21,6 +21,16 @@ local DEFAULT_MEM = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local function formspec(meta)
|
||||||
|
local names = meta:get_string("names") or ""
|
||||||
|
return "size[9,4]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
"field[0.2,1;9,1;names;Allowed user names (spaces separated):;"..names.."]" ..
|
||||||
|
"button_exit[3.5,2.5;2,1;exit;Save]"
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
local function on_time(pos, elasped)
|
local function on_time(pos, elasped)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
@ -65,10 +75,20 @@ minetest.register_node("sl_controller:server", {
|
|||||||
meta:set_string("owner", placer:get_player_name())
|
meta:set_string("owner", placer:get_player_name())
|
||||||
meta:set_string("number", number)
|
meta:set_string("number", number)
|
||||||
tubelib.set_data(number, "memory", table.copy(DEFAULT_MEM))
|
tubelib.set_data(number, "memory", table.copy(DEFAULT_MEM))
|
||||||
|
meta:set_string("formspec", formspec(meta))
|
||||||
on_time(pos, 0)
|
on_time(pos, 0)
|
||||||
minetest.get_node_timer(pos):start(20)
|
minetest.get_node_timer(pos):start(20)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
on_receive_fields = function(pos, formname, fields, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
if fields.names and fields.names ~= "" then
|
||||||
|
local names = string.gsub(fields.names, " +", " ")
|
||||||
|
meta:set_string("names", names)
|
||||||
|
meta:set_string("formspec", formspec(meta))
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
on_dig = function(pos, node, puncher, pointed_thing)
|
on_dig = function(pos, node, puncher, pointed_thing)
|
||||||
if minetest.is_protected(pos, puncher:get_player_name()) then
|
if minetest.is_protected(pos, puncher:get_player_name()) then
|
||||||
return
|
return
|
||||||
@ -113,6 +133,23 @@ local function calc_size(v)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function get_memory(num, name)
|
||||||
|
local info = tubelib.get_node_info(num)
|
||||||
|
if info and info.name == "sl_controller:server" then
|
||||||
|
local meta = minetest.get_meta(info.pos)
|
||||||
|
local owner = meta:get_string("owner")
|
||||||
|
if name == owner then
|
||||||
|
return tubelib.get_data(num, "memory") or table.copy(DEFAULT_MEM)
|
||||||
|
end
|
||||||
|
local names = meta:get_string("names")
|
||||||
|
for _,n in ipairs(string.split(names, " ")) do
|
||||||
|
if name == n then
|
||||||
|
return tubelib.get_data(num, "memory") or table.copy(DEFAULT_MEM)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local function write_value(mem, key, item)
|
local function write_value(mem, key, item)
|
||||||
if mem and mem.size < SERVER_CAPA then
|
if mem and mem.size < SERVER_CAPA then
|
||||||
if mem.data[key] then
|
if mem.data[key] then
|
||||||
@ -136,19 +173,7 @@ end
|
|||||||
|
|
||||||
tubelib.register_node("sl_controller:server", {}, {
|
tubelib.register_node("sl_controller:server", {}, {
|
||||||
on_recv_message = function(pos, topic, payload)
|
on_recv_message = function(pos, topic, payload)
|
||||||
local meta = minetest.get_meta(pos)
|
return "unsupported"
|
||||||
if meta then
|
|
||||||
local number = meta:get_string("number")
|
|
||||||
local mem = tubelib.get_data(number, "memory") or table.copy(DEFAULT_MEM)
|
|
||||||
if topic == "read" then
|
|
||||||
return read_value(mem, payload)
|
|
||||||
elseif topic == "write" then
|
|
||||||
write_value(mem, payload.key, payload.value)
|
|
||||||
tubelib.set_data(number, "memory", mem)
|
|
||||||
else
|
|
||||||
return "unsupported"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end,
|
end,
|
||||||
on_node_load = function(pos)
|
on_node_load = function(pos)
|
||||||
minetest.get_node_timer(pos):start(20)
|
minetest.get_node_timer(pos):start(20)
|
||||||
@ -159,7 +184,10 @@ tubelib.register_node("sl_controller:server", {}, {
|
|||||||
sl_controller.register_function("server_read", {
|
sl_controller.register_function("server_read", {
|
||||||
cmnd = function(self, num, key)
|
cmnd = function(self, num, key)
|
||||||
if type(key) == "string" then
|
if type(key) == "string" then
|
||||||
return tubelib.send_request(num, "read", key)
|
local mem = get_memory(num, self.meta.owner)
|
||||||
|
if mem then
|
||||||
|
return read_value(mem, key)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
self.error("Invalid server_read parameter")
|
self.error("Invalid server_read parameter")
|
||||||
end
|
end
|
||||||
@ -173,7 +201,10 @@ sl_controller.register_function("server_read", {
|
|||||||
sl_controller.register_action("server_write", {
|
sl_controller.register_action("server_write", {
|
||||||
cmnd = function(self, num, key, value)
|
cmnd = function(self, num, key, value)
|
||||||
if type(key) == "string" then
|
if type(key) == "string" then
|
||||||
tubelib.send_message(num, self.meta.owner, nil, "write", {key=key, value=value})
|
local mem = get_memory(num, self.meta.owner)
|
||||||
|
if mem then
|
||||||
|
write_value(mem, key, value)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
self.error("Invalid server_write parameter")
|
self.error("Invalid server_write parameter")
|
||||||
end
|
end
|
||||||
|
163
sl_controller/terminal.lua
Normal file
163
sl_controller/terminal.lua
Normal file
@ -0,0 +1,163 @@
|
|||||||
|
--[[
|
||||||
|
|
||||||
|
sl_controller
|
||||||
|
=============
|
||||||
|
|
||||||
|
Copyright (C) 2018-2019 Joachim Stolberg
|
||||||
|
|
||||||
|
LGPLv2.1+
|
||||||
|
See LICENSE.txt for more information
|
||||||
|
|
||||||
|
terminal.lua:
|
||||||
|
|
||||||
|
]]--
|
||||||
|
|
||||||
|
local HELP = [[#### SmartLine Controller Terminal ####
|
||||||
|
|
||||||
|
Send commands to your Controller
|
||||||
|
and output text messages from your
|
||||||
|
Controller to the Terminal.
|
||||||
|
|
||||||
|
Commands can have up to 80 characters.
|
||||||
|
Local commands:
|
||||||
|
- cls = clear screen
|
||||||
|
- help = this message
|
||||||
|
- pub = switch to public use
|
||||||
|
- priv = switch to private use
|
||||||
|
]]
|
||||||
|
|
||||||
|
local function formspec1()
|
||||||
|
return "size[6,4]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
"field[0.5,1;5,1;number;SaferLua Controller number:;]" ..
|
||||||
|
"button_exit[1.5,2.5;2,1;exit;Save]"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function formspec2(meta)
|
||||||
|
local output = meta:get_string("output")
|
||||||
|
output = minetest.formspec_escape(output)
|
||||||
|
output = output:gsub("\n", ",")
|
||||||
|
return "size[9,8]"..
|
||||||
|
default.gui_bg..
|
||||||
|
default.gui_bg_img..
|
||||||
|
default.gui_slots..
|
||||||
|
"table[0.1,0.1;8.6,6.6;output;"..output..";200]"..
|
||||||
|
"field[0.5,7.6;6,1;cmnd;Enter command;]" ..
|
||||||
|
"field_close_on_enter[cmnd;false]"..
|
||||||
|
"button[6.7,7.3;2,1;ok;Enter]"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function output(pos, text)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
text = meta:get_string("output") .. "\n" .. (text or "")
|
||||||
|
text = text:sub(-500,-1)
|
||||||
|
meta:set_string("output", text)
|
||||||
|
meta:set_string("formspec", formspec2(meta))
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
local function command(pos, cmnd, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local owner = meta:get_string("owner") or ""
|
||||||
|
if cmnd then
|
||||||
|
cmnd = cmnd:sub(1,80)
|
||||||
|
|
||||||
|
if cmnd == "cls" then
|
||||||
|
meta:set_string("output", "")
|
||||||
|
meta:set_string("formspec", formspec2(meta))
|
||||||
|
elseif cmnd == "help" then
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_string("output", HELP)
|
||||||
|
meta:set_string("formspec", formspec2(meta))
|
||||||
|
elseif cmnd == "pub" and owner == player then
|
||||||
|
meta:set_int("public", 1)
|
||||||
|
output(pos, player..":$ "..cmnd)
|
||||||
|
output(pos, "Switched to public use!")
|
||||||
|
elseif cmnd == "priv" and owner == player then
|
||||||
|
meta:set_int("public", 0)
|
||||||
|
output(pos, player..":$ "..cmnd)
|
||||||
|
output(pos, "Switched to private use!")
|
||||||
|
elseif meta:get_int("public") == 1 or owner == player then
|
||||||
|
local number = meta:get_string("number") or "0000"
|
||||||
|
output(pos, player..":$ "..cmnd)
|
||||||
|
tubelib.send_message(number, owner, nil, "term", cmnd)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("sl_controller:terminal", {
|
||||||
|
description = "SaferLua Controller Terminal",
|
||||||
|
tiles = {
|
||||||
|
-- up, down, right, left, back, front
|
||||||
|
'sl_controller_terminal_top.png',
|
||||||
|
'sl_controller_terminal_bottom.png',
|
||||||
|
'sl_controller_terminal_side.png',
|
||||||
|
'sl_controller_terminal_side.png',
|
||||||
|
'sl_controller_terminal_bottom.png',
|
||||||
|
"sl_controller_terminal_front.png",
|
||||||
|
},
|
||||||
|
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-12/32, -16/32, -8/32, 12/32, -14/32, 12/32},
|
||||||
|
{-12/32, -14/32, 12/32, 12/32, 6/32, 14/32},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
after_place_node = function(pos, placer)
|
||||||
|
local number = tubelib.add_node(pos, "sl_controller:terminal")
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
meta:set_string("own_number", number)
|
||||||
|
meta:set_string("formspec", formspec1())
|
||||||
|
meta:set_string("owner", placer:get_player_name())
|
||||||
|
meta:set_string("infotext", "SaferLua Controller Terminal "..number..": not connected")
|
||||||
|
end,
|
||||||
|
|
||||||
|
on_receive_fields = function(pos, formname, fields, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
if fields.number and fields.number ~= "" then
|
||||||
|
if tubelib.check_numbers(fields.number) then
|
||||||
|
meta:set_string("number", fields.number)
|
||||||
|
local own_number = meta:get_string("own_number")
|
||||||
|
meta:set_string("infotext", "SaferLua Controller Terminal "..own_number..": connected with "..fields.number)
|
||||||
|
meta:set_string("formspec", formspec2(meta))
|
||||||
|
end
|
||||||
|
elseif (fields.key_enter == "true" or fields.ok == "Enter") and fields.cmnd ~= "" then
|
||||||
|
command(pos, fields.cmnd, player:get_player_name())
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
after_dig_node = function(pos)
|
||||||
|
tubelib.remove_node(pos)
|
||||||
|
end,
|
||||||
|
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {choppy=2, cracky=2, crumbly=2},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = default.node_sound_metal_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "sl_controller:terminal",
|
||||||
|
recipe = {
|
||||||
|
{"", "smartline:display", ""},
|
||||||
|
{"", "", ""},
|
||||||
|
{"dye:black", "tubelib:wlanchip", "default:copper_ingot"},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
tubelib.register_node("sl_controller:terminal", {}, {
|
||||||
|
on_recv_message = function(pos, topic, payload)
|
||||||
|
if topic == "term" then
|
||||||
|
output(pos, payload)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
Binary file not shown.
Before Width: | Height: | Size: 546 B After Width: | Height: | Size: 346 B |
BIN
sl_controller/textures/sl_controller_terminal_bottom.png
Normal file
BIN
sl_controller/textures/sl_controller_terminal_bottom.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 261 B |
BIN
sl_controller/textures/sl_controller_terminal_front.png
Normal file
BIN
sl_controller/textures/sl_controller_terminal_front.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 248 B |
BIN
sl_controller/textures/sl_controller_terminal_side.png
Normal file
BIN
sl_controller/textures/sl_controller_terminal_side.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 209 B |
BIN
sl_controller/textures/sl_controller_terminal_top.png
Normal file
BIN
sl_controller/textures/sl_controller_terminal_top.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 317 B |
Loading…
Reference in New Issue
Block a user