1
0
mirror of https://github.com/mt-mods/led_marquee.git synced 2025-01-10 00:10:20 +01:00

Maintenance + translation support (#2)

* maintenance + translation support

* fix too long line warning

* improvements through code review
This commit is contained in:
Niklp 2023-07-05 13:55:41 +02:00 committed by GitHub
parent 4732886317
commit 0cc8f9e7a4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 52 additions and 24 deletions

10
.github/workflows/luacheck.yml vendored Normal file
View File

@ -0,0 +1,10 @@
name: luacheck
on: [push, pull_request]
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
- uses: Roang-zero1/factorio-mod-luacheck@master
with:
luacheckrc_url: ""

11
.luacheckrc Normal file
View File

@ -0,0 +1,11 @@
unused_args = false
read_globals = {
table = {fields = {"copy"}},
"minetest",
"digilines"
}
globals = {
"led_marquee"
}

View File

@ -4,13 +4,15 @@
led_marquee = {} led_marquee = {}
led_marquee.scheduled_messages = {} led_marquee.scheduled_messages = {}
-- settings
led_marquee.message_minimum_time = tonumber(minetest.settings:get("led_marquee_message_minimum_time")) or 0.5 led_marquee.message_minimum_time = tonumber(minetest.settings:get("led_marquee_message_minimum_time")) or 0.5
led_marquee.message_schedule_dtime = tonumber(minetest.settings:get("led_marquee_message_schedule_dtime")) or 0.2 led_marquee.message_schedule_dtime = tonumber(minetest.settings:get("led_marquee_message_schedule_dtime")) or 0.2
led_marquee.message_schedule_size = tonumber(minetest.settings:get("led_marquee_message_schedule_size")) or 10 led_marquee.message_schedule_size = tonumber(minetest.settings:get("led_marquee_message_schedule_size")) or 10
led_marquee.relay_timer = 0 led_marquee.relay_timer = 0
local S = minetest.get_translator(minetest.get_current_modname()) local S = minetest.get_translator(minetest.get_current_modname())
local FS = function(...) return minetest.formspec_escape(S(...)) end
local color_to_char = { local color_to_char = {
"0", "0",
@ -101,26 +103,12 @@ local reset_meta = function(pos)
minetest.get_meta(pos):set_string("formspec", minetest.get_meta(pos):set_string("formspec",
"formspec_version[4]".. "formspec_version[4]"..
"size[8,4]".. "size[8,4]"..
"button_exit[3,2.5;2,0.5;proceed;Proceed]".. "button_exit[3,2.5;2,0.5;proceed;"..FS("Proceed").."]"..
"field[1.75,1.5;4.5,0.5;channel;Channel;${channel}]" "field[1.75,1.5;4.5,0.5;channel;"..FS("Channel")..";${channel}]"
) )
end end
local on_digiline_receive_std = function(pos, node, channel, msg)
local meta = minetest.get_meta(pos)
local setchan = meta:get_string("channel")
if setchan ~= channel then return end
local num = tonumber(msg)
if msg == "colon" or msg == "period" or msg == "off" or (num and (num >= 0 and num <= 9)) then
minetest.swap_node(pos, { name = "led_marquee:marquee_"..msg, param2 = node.param2})
end
end
-- convert Lua's idea of a UTF-8 char to ISO-8859-1 -- convert Lua's idea of a UTF-8 char to ISO-8859-1
-- first char is non-break space, 0xA0
local iso_chars=" ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖ×ØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ"
local get_iso = function(c) local get_iso = function(c)
local hb = string.byte(c,1) or 0 local hb = string.byte(c,1) or 0
local lb = string.byte(c,2) or 0 local lb = string.byte(c,2) or 0
@ -366,11 +354,12 @@ local on_digiline_receive_string = function(pos, node, channel, msg)
local skip = tonumber(string.sub(msg, 12)) local skip = tonumber(string.sub(msg, 12))
led_marquee.scroll_text(pos, nil, skip) led_marquee.scroll_text(pos, nil, skip)
elseif msg == "get" then -- get the master panel's displayed char as ASCII numerical value elseif msg == "get" then -- get the master panel's displayed char as ASCII numerical value
digilines.receptor_send(pos, digiline.rules.default, channel, tonumber(string.match(minetest.get_node(pos).name,"led_marquee:char_(.+)"))) -- wonderfully horrible string manipulaiton digilines.receptor_send(pos, digilines.rules.default, channel,
tonumber(string.match(minetest.get_node(pos).name,"led_marquee:char_(.+)")))
elseif msg == "getstr" then -- get the last stored message elseif msg == "getstr" then -- get the last stored message
digilines.receptor_send(pos, digiline.rules.default, channel, meta:get_string("last_msg")) digilines.receptor_send(pos, digilines.rules.default, channel, meta:get_string("last_msg"))
elseif msg == "getindex" then -- get the scroll index elseif msg == "getindex" then -- get the scroll index
digilines.receptor_send(pos, digiline.rules.default, channel, meta:get_int("index")) digilines.receptor_send(pos, digilines.rules.default, channel, meta:get_int("index"))
else else
msg = string.gsub(msg, "//", string.char(30)) msg = string.gsub(msg, "//", string.char(30))
led_marquee.set_timer(pos, 0) led_marquee.set_timer(pos, 0)
@ -400,8 +389,8 @@ end
for i = 31, 255 do for i = 31, 255 do
local groups = { cracky = 2, not_in_creative_inventory = 1} local groups = { cracky = 2, not_in_creative_inventory = 1}
local light = LIGHT_MAX-2 local light = minetest.LIGHT_MAX-2
local description = S("LED marquee panel ("..i..")") local description = S("LED marquee panel (@1)", i)
local leds = "led_marquee_char_"..i..".png^[mask:led_marquee_leds_on.png" local leds = "led_marquee_char_"..i..".png^[mask:led_marquee_leds_on.png"
if i == 31 then if i == 31 then

5
locale/led_marquee.de.tr Normal file
View File

@ -0,0 +1,5 @@
# textdomain: led_marquee
LED marquee panel (@1)=LED-Anzeigetafel (@1)
LED marquee panel=LED-Anzeigetafel
Proceed=Fortsetzen
Channel=Kanal

5
locale/template.txt Normal file
View File

@ -0,0 +1,5 @@
# textdomain: led_marquee
LED marquee panel (@1)=
LED marquee panel=
Proceed=
Channel=

8
settingtypes.txt Normal file
View File

@ -0,0 +1,8 @@
# Minimal marquee interval
led_marquee_message_minimum_time float 0.5
# Marquee globalstep update interval
led_marquee_message_schedule_dtime float 0.2
# Global message queue size
led_marquee_message_schedule_size int 10