mirror of
https://github.com/radio95-rnt/rds95.git
synced 2026-02-26 20:33:53 +01:00
massive lua api refactor
This commit is contained in:
@@ -17,7 +17,7 @@ local _RDS_ODA_pointer = 1
|
||||
---@param aid integer
|
||||
---@param data integer
|
||||
---@return integer oda_id
|
||||
function register_oda(group, group_version, aid, data)
|
||||
function ext.register_oda(group, group_version, aid, data)
|
||||
if group == 14 or group == 15 or group == 2 or group == 0 then error("Group is incorrect", 2) end
|
||||
if (group == 10 or group == 4 or group == 1) and group_version then error("Group is incorrect", 2) end
|
||||
local oda = _ODA.new(group, group_version, aid, data, false)
|
||||
@@ -33,7 +33,7 @@ end
|
||||
|
||||
---Unregisters an ODA, this stops the handler or AID being called/sent
|
||||
---@param oda_id integer
|
||||
function unregister_oda(oda_id)
|
||||
function ext.unregister_oda(oda_id)
|
||||
if oda_id < 1 or oda_id > #_RDS_ODAs or _RDS_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
|
||||
_RDS_ODAs[oda_id] = false
|
||||
@@ -45,7 +45,7 @@ end
|
||||
---Sets the id_data for a existing ODA group
|
||||
---@param oda_id integer
|
||||
---@param data integer
|
||||
function set_oda_id_data(oda_id, data)
|
||||
function ext.set_oda_id_data(oda_id, data)
|
||||
if oda_id < 1 or oda_id > #_RDS_ODAs or _RDS_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
_RDS_ODAs[oda_id].data = data
|
||||
end
|
||||
@@ -57,7 +57,7 @@ end
|
||||
---You are asked to set groups B last 5 bits, leave rest 0
|
||||
---@param oda_id integer The ID returned by register_oda
|
||||
---@param fun ODAHandler
|
||||
function set_oda_handler(oda_id, fun)
|
||||
function ext.set_oda_handler(oda_id, fun)
|
||||
if oda_id < 1 or oda_id > #_RDS_ODAs or _RDS_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
if _RDS_ODAs[oda_id].group == 3 then error("3A ODAs cannot have handlers.", 2) end
|
||||
_RDS_ODAs[oda_id].handler = fun
|
||||
@@ -113,18 +113,13 @@ function group(group_type)
|
||||
if #_RDS_ODAs == 0 then return false, 0, 0, 0 end
|
||||
if _RDS_ODA_pointer > #_RDS_ODAs or _RDS_ODA_pointer < 1 then _RDS_ODA_pointer = 1 end
|
||||
|
||||
if group_type == "O" then
|
||||
return get_aid()
|
||||
elseif group_type == "K" then
|
||||
return get_data()
|
||||
end
|
||||
if group_type == "O" then return get_aid()
|
||||
elseif group_type == "K" then return get_data() end
|
||||
end
|
||||
return false, 0, 0, 0
|
||||
end
|
||||
|
||||
local _old_on_state_oda = on_state
|
||||
function on_state()
|
||||
table.insert(on_states, function ()
|
||||
_RDS_ODAs = {}
|
||||
_RDS_ODA_pointer = 1
|
||||
if type(_old_on_state_oda) == "function" then _old_on_state_oda() end
|
||||
end
|
||||
end)
|
||||
@@ -14,7 +14,7 @@ _RDS2_ODA_pointer = 1
|
||||
---@param data integer
|
||||
---@param file_related boolean
|
||||
---@return integer oda_id
|
||||
function register_oda_rds2(aid, data, file_related)
|
||||
function ext.register_oda_rds2(aid, data, file_related)
|
||||
local oda = _RDS2_ODA.new(aid, data, false, file_related)
|
||||
for i = 1, #_RDS2_ODAs do
|
||||
if _RDS2_ODAs[i] == false then
|
||||
@@ -28,7 +28,7 @@ end
|
||||
|
||||
---Unregisters an RDS 2 ODA, this stops the handler or AID being called/sent
|
||||
---@param oda_id integer
|
||||
function unregister_oda_rds2(oda_id)
|
||||
function ext.unregister_oda_rds2(oda_id)
|
||||
if oda_id < 1 or oda_id > #_RDS2_ODAs or _RDS2_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
|
||||
_RDS2_ODAs[oda_id] = false
|
||||
@@ -39,14 +39,14 @@ end
|
||||
|
||||
---@param oda_id integer
|
||||
---@param data integer
|
||||
function set_oda_id_data_rds2(oda_id, data)
|
||||
function ext.set_oda_id_data_rds2(oda_id, data)
|
||||
if oda_id < 1 or oda_id > #_RDS2_ODAs or _RDS2_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
_RDS2_ODAs[oda_id].data = data
|
||||
end
|
||||
|
||||
---@param oda_id integer
|
||||
---@param func RDS2_ODAHandler
|
||||
function set_oda_handler_rds2(oda_id, func)
|
||||
function ext.set_oda_handler_rds2(oda_id, func)
|
||||
if oda_id < 1 or oda_id > #_RDS2_ODAs or _RDS2_ODAs[oda_id] == false then error("Invalid ODA ID: " .. tostring(oda_id), 2) end
|
||||
_RDS2_ODAs[oda_id].handler = func
|
||||
end
|
||||
@@ -125,10 +125,8 @@ function rds2_group(stream)
|
||||
end
|
||||
end
|
||||
|
||||
local _old_on_state_oda_rds2 = on_state
|
||||
function on_state()
|
||||
table.insert(on_states, function ()
|
||||
_RDS2_ODAs = {}
|
||||
_RDS2_ODA_aid = 0
|
||||
_RDS2_ODA_pointer = 1
|
||||
if type(_old_on_state_oda_rds2) == "function" then _old_on_state_oda_rds2() end
|
||||
end
|
||||
end)
|
||||
@@ -55,8 +55,8 @@ end
|
||||
|
||||
local function init_af_oda()
|
||||
if _Af_Oda_id == nil then
|
||||
_Af_Oda_id = register_oda(7, false, 0x6365, 0)
|
||||
set_oda_handler(_Af_Oda_id, function()
|
||||
_Af_Oda_id = ext.register_oda(7, false, 0x6365, 0)
|
||||
ext.set_oda_handler(_Af_Oda_id, function()
|
||||
local b, c, d = get_next_af_oda_group()
|
||||
return true, b, c, d
|
||||
end)
|
||||
@@ -69,7 +69,7 @@ local function save_af_to_userdata(afs)
|
||||
|
||||
local payload = string.pack("B", count)
|
||||
for i = 1, count do payload = payload .. string.pack("f", afs[i]) end
|
||||
set_userdata_offset(USERDATA_ODA_OFFSET, #payload, payload)
|
||||
userdata.set_offset(USERDATA_ODA_OFFSET, #payload, payload)
|
||||
end
|
||||
|
||||
local function _process_af_list(afs)
|
||||
@@ -86,13 +86,13 @@ local function _process_af_list(afs)
|
||||
end
|
||||
|
||||
local function load_af_from_userdata()
|
||||
local header = get_userdata_offset(USERDATA_ODA_OFFSET, 1)
|
||||
local header = userdata.get_offset(USERDATA_ODA_OFFSET, 1)
|
||||
if header == "" or header == nil then return end
|
||||
|
||||
local count = string.unpack("B", header)
|
||||
if count == 0 or count > 25 then return end
|
||||
|
||||
local data = get_userdata_offset(USERDATA_ODA_OFFSET + 1, count * 4)
|
||||
local data = userdata.get_offset(USERDATA_ODA_OFFSET + 1, count * 4)
|
||||
if #data < (count * 4) then return end
|
||||
|
||||
local afs = {}
|
||||
@@ -106,14 +106,12 @@ end
|
||||
|
||||
---Sets the AFs included in the ODA and saves them
|
||||
---@param afs table List of numbers (e.g., {98.1, 102.5})
|
||||
function set_rds_af_oda(afs)
|
||||
function rds.ext.set_af_oda(afs)
|
||||
_process_af_list(afs)
|
||||
save_af_to_userdata(afs)
|
||||
end
|
||||
|
||||
local _old_on_state_af = on_state
|
||||
function on_state()
|
||||
table.insert(on_states, function ()
|
||||
load_af_from_userdata()
|
||||
if _Af_Oda_len ~= 0 then init_af_oda() end
|
||||
if type(_old_on_state_af) == "function" then _old_on_state_af() end
|
||||
end
|
||||
end)
|
||||
@@ -6,25 +6,25 @@ local USERDATA_ERT_OFFSET = 0
|
||||
|
||||
local function init_ert()
|
||||
if _Ert_oda_id == nil then
|
||||
_Ert_oda_id = register_oda(13, false, 0x6552, 1)
|
||||
set_oda_handler(_Ert_oda_id, function ()
|
||||
if string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+258, 1)) == 1 then
|
||||
local new_data = get_userdata_offset(USERDATA_ERT_OFFSET, 128)
|
||||
local new_segments = string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+128, 1))
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+129, 128, new_data)
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+257, 1, string.char(new_segments))
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+258, 1, string.char(0))
|
||||
_Ert_oda_id = ext.register_oda(13, false, 0x6552, 1)
|
||||
ext.set_oda_handler(_Ert_oda_id, function ()
|
||||
if string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+258, 1)) == 1 then
|
||||
local new_data = userdata.get_offset(USERDATA_ERT_OFFSET, 128)
|
||||
local new_segments = string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+128, 1))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+129, 128, new_data)
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+257, 1, string.char(new_segments))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+258, 1, string.char(0))
|
||||
_Ert_state = 0
|
||||
end
|
||||
|
||||
local segments = string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+257, 1))
|
||||
local segments = string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+257, 1))
|
||||
|
||||
if segments == 0 then return false, 0, 0, 0 end
|
||||
|
||||
if _Ert_state >= segments then _Ert_state = 0 end
|
||||
|
||||
local b = _Ert_state & 31
|
||||
local chunk = get_userdata_offset(USERDATA_ERT_OFFSET + 129 + _Ert_state * 4, 4)
|
||||
local chunk = userdata.get_offset(USERDATA_ERT_OFFSET + 129 + _Ert_state * 4, 4)
|
||||
local c = (string.byte(chunk, 1) << 8) | string.byte(chunk, 2)
|
||||
local d = (string.byte(chunk, 3) << 8) | string.byte(chunk, 4)
|
||||
|
||||
@@ -36,16 +36,16 @@ end
|
||||
|
||||
function unregister_ert()
|
||||
if _Ert_oda_id ~= nil then
|
||||
unregister_oda(_Ert_oda_id)
|
||||
ext.unregister_oda(_Ert_oda_id)
|
||||
_Ert_oda_id = nil
|
||||
end
|
||||
end
|
||||
|
||||
function set_rds_ert(ert)
|
||||
function rds.ext.set_ert(ert)
|
||||
if #ert == 0 then
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET, 128, "")
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+128, 1, string.char(0))
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+258, 1, string.char(1))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET, 128, "")
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+128, 1, string.char(0))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+258, 1, string.char(1))
|
||||
return
|
||||
end
|
||||
|
||||
@@ -55,33 +55,31 @@ function set_rds_ert(ert)
|
||||
local padding = (4 - (#data % 4)) % 4
|
||||
data = data .. string.rep("\0", padding)
|
||||
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET, 128, data)
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET, 128, data)
|
||||
|
||||
local segments = #data // 4
|
||||
if segments > 32 then segments = 32 end
|
||||
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+128, 1, string.char(segments))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+128, 1, string.char(segments))
|
||||
|
||||
if string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+257, 1)) == 0 then
|
||||
if string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+257, 1)) == 0 then
|
||||
init_ert()
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+129, 128, data)
|
||||
set_userdata_offset(USERDATA_ERT_OFFSET+257, 1, string.char(segments))
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+129, 128, data)
|
||||
userdata.set_offset(USERDATA_ERT_OFFSET+257, 1, string.char(segments))
|
||||
_Ert_state = 0
|
||||
else set_userdata_offset(USERDATA_ERT_OFFSET+258, 1, string.char(1)) end
|
||||
else userdata.set_offset(USERDATA_ERT_OFFSET+258, 1, string.char(1)) end
|
||||
|
||||
if _Ert_oda_id == nil then init_ert() end
|
||||
end
|
||||
|
||||
function get_rds_ert()
|
||||
local segments = string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+128, 1))
|
||||
function rds.ext.get_ert()
|
||||
local segments = string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+128, 1))
|
||||
if segments == 0 then return "" end
|
||||
|
||||
local data = get_userdata_offset(USERDATA_ERT_OFFSET, 128)
|
||||
local data = userdata.get_offset(USERDATA_ERT_OFFSET, 128)
|
||||
return data:match("^(.-)[\r%z]*") or ""
|
||||
end
|
||||
|
||||
local _old_on_state_ert = on_state
|
||||
function on_state()
|
||||
if string.byte(get_userdata_offset(USERDATA_ERT_OFFSET+257, 1)) ~= 0 then init_ert() end
|
||||
if type(_old_on_state_ert) == "function" then _old_on_state_ert() end
|
||||
end
|
||||
table.insert(on_states, function ()
|
||||
if string.byte(userdata.get_offset(USERDATA_ERT_OFFSET+257, 1)) ~= 0 then init_ert() end
|
||||
end)
|
||||
@@ -43,7 +43,7 @@ end
|
||||
|
||||
function RftInstance:stop()
|
||||
if self.oda_id ~= nil and self.aid ~= 0 then
|
||||
unregister_oda_rds2(self.oda_id)
|
||||
ext.unregister_oda_rds2(self.oda_id)
|
||||
self.oda_id = nil
|
||||
end
|
||||
|
||||
@@ -59,9 +59,9 @@ end
|
||||
---@private
|
||||
function RftInstance:start()
|
||||
if self.oda_id == nil and self.aid ~= 0 then
|
||||
self.oda_id = register_oda_rds2(self.aid, 0, true)
|
||||
self.oda_id = ext.register_oda_rds2(self.aid, 0, true)
|
||||
|
||||
set_oda_handler_rds2(self.oda_id, function(stream)
|
||||
ext.set_oda_handler_rds2(self.oda_id, function(stream)
|
||||
if #self.file_data == 0 or self.paused then
|
||||
return false, 0, 0, 0, 0
|
||||
end
|
||||
@@ -138,7 +138,7 @@ function RftInstance:sendFile(aid, path, id, crc, once)
|
||||
local f_size = #self.file_data
|
||||
if crc == 0 then
|
||||
self.crc_mode = 0
|
||||
self.crc_full_file = crc16(self.file_data)
|
||||
self.crc_full_file = dp.crc16(self.file_data)
|
||||
elseif crc == true or crc == 7 then
|
||||
if f_size <= 40960 then self.crc_mode = 1
|
||||
elseif f_size > 40960 and f_size <= 81920 then self.crc_mode = 2
|
||||
@@ -153,7 +153,7 @@ function RftInstance:sendFile(aid, path, id, crc, once)
|
||||
local chunk_size = 5 * multiplier
|
||||
for i = 1, f_size, chunk_size do
|
||||
local chunk = string.sub(self.file_data, i, i + chunk_size - 1)
|
||||
local v = crc16(chunk)
|
||||
local v = dp.crc16(chunk)
|
||||
self.crc_data = self.crc_data .. string.char(v >> 8, v & 0xff)
|
||||
end
|
||||
end
|
||||
@@ -161,7 +161,7 @@ function RftInstance:sendFile(aid, path, id, crc, once)
|
||||
if f_size > (0x3ffff * 5) then error("File too large") end
|
||||
if self.oda_id == nil then self:start() end
|
||||
|
||||
set_oda_id_data_rds2(self.oda_id, f_size | (id & 63) << 18 | (self.version & 7) << 24 | (self.crc_enabled and 1 or 0) << 27)
|
||||
ext.set_oda_id_data_rds2(self.oda_id, f_size | (id & 63) << 18 | (self.version & 7) << 24 | (self.crc_enabled and 1 or 0) << 27)
|
||||
self.last_id = id
|
||||
self.paused = false
|
||||
return interrupted
|
||||
|
||||
@@ -8,11 +8,11 @@ local USERDATA_RTP_OFFSET = 259
|
||||
|
||||
local function init_rtp()
|
||||
if _Rtp_oda_id == nil then
|
||||
_Rtp_oda_id = register_oda(11, false, 0x4BD7, 0)
|
||||
set_oda_handler(_Rtp_oda_id, function ()
|
||||
local b = (_Rtp_toggle and 1 or 0) << 4 | string.byte(get_userdata_offset(USERDATA_RTP_OFFSET, 1)) << 3
|
||||
local data_0 = get_userdata_offset(USERDATA_RTP_OFFSET+1, 3)
|
||||
local data_1 = get_userdata_offset(USERDATA_RTP_OFFSET+4, 3)
|
||||
_Rtp_oda_id = ext.register_oda(11, false, 0x4BD7, 0)
|
||||
ext.set_oda_handler(_Rtp_oda_id, function ()
|
||||
local b = (_Rtp_toggle and 1 or 0) << 4 | string.byte(userdata.get_offset(USERDATA_RTP_OFFSET, 1)) << 3
|
||||
local data_0 = userdata.get_offset(USERDATA_RTP_OFFSET+1, 3)
|
||||
local data_1 = userdata.get_offset(USERDATA_RTP_OFFSET+4, 3)
|
||||
b = b | (string.byte(data_0, 1) & 0xf8) >> 3
|
||||
|
||||
local c = (string.byte(data_0, 1) & 0x7) << 13
|
||||
@@ -31,11 +31,11 @@ end
|
||||
|
||||
local function init_ertp()
|
||||
if _Ertp_oda_id == nil then
|
||||
_Ertp_oda_id = register_oda(12, false, 0x4BD8, 0)
|
||||
set_oda_handler(_Ertp_oda_id, function ()
|
||||
local b = (_Ertp_toggle and 1 or 0) << 4 | string.byte(get_userdata_offset(USERDATA_RTP_OFFSET+7, 1)) << 3
|
||||
local data_0 = get_userdata_offset(USERDATA_RTP_OFFSET+8, 3)
|
||||
local data_1 = get_userdata_offset(USERDATA_RTP_OFFSET+11, 3)
|
||||
_Ertp_oda_id = ext.register_oda(12, false, 0x4BD8, 0)
|
||||
ext.set_oda_handler(_Ertp_oda_id, function ()
|
||||
local b = (_Ertp_toggle and 1 or 0) << 4 | string.byte(userdata.get_offset(USERDATA_RTP_OFFSET+7, 1)) << 3
|
||||
local data_0 = userdata.get_offset(USERDATA_RTP_OFFSET+8, 3)
|
||||
local data_1 = userdata.get_offset(USERDATA_RTP_OFFSET+11, 3)
|
||||
b = b | (string.byte(data_0, 1) & 0xf8) >> 3
|
||||
|
||||
local c = (string.byte(data_0, 1) & 0x7) << 13
|
||||
@@ -52,46 +52,44 @@ local function init_ertp()
|
||||
end
|
||||
end
|
||||
|
||||
function set_rds_rtp_meta(ertp, running)
|
||||
function rds.ext.set_rtp_meta(ertp, running)
|
||||
if ertp then
|
||||
if running and _Ertp_oda_id == nil then init_ertp() end
|
||||
set_userdata_offset(USERDATA_RTP_OFFSET+7, 1, string.char(running and 1 or 0))
|
||||
userdata.set_offset(USERDATA_RTP_OFFSET+7, 1, string.char(running and 1 or 0))
|
||||
else
|
||||
if running and _Rtp_oda_id == nil then init_rtp() end
|
||||
set_userdata_offset(USERDATA_RTP_OFFSET, 1, string.char(running and 1 or 0))
|
||||
userdata.set_offset(USERDATA_RTP_OFFSET, 1, string.char(running and 1 or 0))
|
||||
end
|
||||
end
|
||||
function get_rds_rtp_meta(ertp)
|
||||
function rds.ext.get_rtp_meta(ertp)
|
||||
local offset = ertp and (USERDATA_RTP_OFFSET+7) or USERDATA_RTP_OFFSET
|
||||
return string.byte(get_userdata_offset(offset, 1)) ~= 0
|
||||
return string.byte(userdata.get_offset(offset, 1)) ~= 0
|
||||
end
|
||||
function toggle_rds_rtp(ertp)
|
||||
function rds.ext.toggle_rtp(ertp)
|
||||
if ertp then _Ertp_toggle = not _Ertp_toggle
|
||||
else _Rtp_toggle = not _Rtp_toggle end
|
||||
end
|
||||
|
||||
function set_rds_rtplus_tags(ertp, t1, s1, l1, t2, s2, l2)
|
||||
set_rds_rtp_meta(ertp, true)
|
||||
toggle_rds_rtp(ertp)
|
||||
set_userdata_offset(ertp and (USERDATA_RTP_OFFSET+8) or (USERDATA_RTP_OFFSET+1), 6, string.char(t1, s1, l1, t2, s2, l2))
|
||||
function rds.ext.set_rtplus_tags(ertp, t1, s1, l1, t2, s2, l2)
|
||||
rds.ext.set_rds_rtp_meta(ertp, true)
|
||||
rds.ext.toggle_rds_rtp(ertp)
|
||||
userdata.set_offset(ertp and (USERDATA_RTP_OFFSET+8) or (USERDATA_RTP_OFFSET+1), 6, string.char(t1, s1, l1, t2, s2, l2))
|
||||
end
|
||||
function get_rds_rtplus_tags(ertp)
|
||||
return string.byte(get_userdata_offset(ertp and (USERDATA_RTP_OFFSET+8) or (USERDATA_RTP_OFFSET+1), 6), 1, 6)
|
||||
function rds.ext.get_rtplus_tags(ertp)
|
||||
return string.byte(userdata.get_offset(ertp and (USERDATA_RTP_OFFSET+8) or (USERDATA_RTP_OFFSET+1), 6), 1, 6)
|
||||
end
|
||||
|
||||
function unregister_rtp(ertp)
|
||||
if ertp and _Ertp_oda_id ~= nil then
|
||||
unregister_oda(_Ertp_oda_id)
|
||||
ext.unregister_oda(_Ertp_oda_id)
|
||||
_Ertp_oda_id = nil
|
||||
elseif _Rtp_oda_id ~= nil then
|
||||
unregister_oda(_Rtp_oda_id)
|
||||
ext.unregister_oda(_Rtp_oda_id)
|
||||
_Rtp_oda_id = nil
|
||||
end
|
||||
end
|
||||
|
||||
local _old_on_state_rtp = on_state
|
||||
function on_state()
|
||||
if get_rds_rtp_meta(false) then init_rtp() end
|
||||
if get_rds_rtp_meta(true) then init_ertp() end
|
||||
if type(_old_on_state_rtp) == "function" then _old_on_state_rtp() end
|
||||
end
|
||||
table.insert(on_states, function ()
|
||||
if rds.ext.get_rtp_meta(false) then init_rtp() end
|
||||
if rds.ext.get_rtp_meta(true) then init_ertp() end
|
||||
end)
|
||||
@@ -40,52 +40,52 @@ function data_handle(data)
|
||||
data = data:lower()
|
||||
if data == "ver" then return string.format("rds95 core v. %s - (C) 2025 radio95 - lua parser\r\n", core_version)
|
||||
elseif data == "init" then
|
||||
set_rds_program_defaults()
|
||||
dp.set_rds_program_defaults()
|
||||
return "+\r\n"
|
||||
elseif data == "reset" then
|
||||
reset_rds()
|
||||
dp.reset_rds()
|
||||
return "+\r\n"
|
||||
elseif data == "pi" then return string.format("PI=%s\r\n", string.format("%x", get_rds_pi()))
|
||||
elseif data == "pty" then return string.format("PTY=%s\r\n", string.format("%d", get_rds_pty()))
|
||||
elseif data == "ecc" then return string.format("ECC=%s\r\n", string.format("%x", get_rds_ecc()))
|
||||
elseif data == "slcd" then return string.format("SLCD=%s\r\n", string.format("%x", get_rds_slc_data()))
|
||||
elseif data == "ct" then return string.format("CT=%s\r\n", string.format("%d", (get_rds_ct() and 1 or 0)))
|
||||
elseif data == "dpty" then return string.format("DPTY=%s\r\n", string.format("%d", (get_rds_dpty() and 1 or 0)))
|
||||
elseif data == "tp" then return string.format("TP=%s\r\n", string.format("%d", (get_rds_tp() and 1 or 0)))
|
||||
elseif data == "ta" then return string.format("TA=%s\r\n", string.format("%d", (get_rds_ta() and 1 or 0)))
|
||||
elseif data == "rt1en" then return string.format("RT1EN=%s\r\n", string.format("%d", (get_rds_rt1_enabled() and 1 or 0)))
|
||||
elseif data == "rt2en" then return string.format("RT2EN=%s\r\n", string.format("%d", (get_rds_rt2_enabled() and 1 or 0)))
|
||||
elseif data == "ptynen" then return string.format("PTYNEN=%s\r\n", string.format("%d", (get_rds_ptyn_enabled() and 1 or 0)))
|
||||
elseif data == "rttype" then return string.format("RTTYPE=%s\r\n", string.format("%d", get_rds_rt_type()))
|
||||
elseif data == "rds2mod" then return string.format("RDS2MOD=%s\r\n", string.format("%d", get_rds2_mode()))
|
||||
elseif data == "pi" then return string.format("PI=%s\r\n", string.format("%x", rds.get_pi()))
|
||||
elseif data == "pty" then return string.format("PTY=%s\r\n", string.format("%d", rds.get_pty()))
|
||||
elseif data == "ecc" then return string.format("ECC=%s\r\n", string.format("%x", rds.get_ecc()))
|
||||
elseif data == "slcd" then return string.format("SLCD=%s\r\n", string.format("%x", rds.get_slc_data()))
|
||||
elseif data == "ct" then return string.format("CT=%s\r\n", string.format("%d", (rds.get_ct() and 1 or 0)))
|
||||
elseif data == "dpty" then return string.format("DPTY=%s\r\n", string.format("%d", (rds.get_dpty() and 1 or 0)))
|
||||
elseif data == "tp" then return string.format("TP=%s\r\n", string.format("%d", (rds.get_tp() and 1 or 0)))
|
||||
elseif data == "ta" then return string.format("TA=%s\r\n", string.format("%d", (rds.get_ta() and 1 or 0)))
|
||||
elseif data == "rt1en" then return string.format("RT1EN=%s\r\n", string.format("%d", (rds.get_rt1_enabled() and 1 or 0)))
|
||||
elseif data == "rt2en" then return string.format("RT2EN=%s\r\n", string.format("%d", (rds.get_rt2_enabled() and 1 or 0)))
|
||||
elseif data == "ptynen" then return string.format("PTYNEN=%s\r\n", string.format("%d", (rds.get_ptyn_enabled() and 1 or 0)))
|
||||
elseif data == "rttype" then return string.format("RTTYPE=%s\r\n", string.format("%d", rds.get_rt_type()))
|
||||
elseif data == "rds2mod" then return string.format("RDS2MOD=%s\r\n", string.format("%d", rds.get_rds2_mode()))
|
||||
elseif data == "rdsgen" then return string.format("RDSGEN=%s\r\n", string.format("%d", get_rds_streams()))
|
||||
elseif data == "level" then return string.format("LEVEL=%s\r\n", string.format("%d", get_rds_level() * 255))
|
||||
elseif data == "link" then return string.format("LINK=%s\r\n", string.format("%d", (get_rds_link() and 1 or 0)))
|
||||
elseif data == "link" then return string.format("LINK=%s\r\n", string.format("%d", (rds.get_link() and 1 or 0)))
|
||||
elseif data == "rtp" then
|
||||
local t1, s1, l1, t2, s2, l2 = get_rds_rtplus_tags(false)
|
||||
local t1, s1, l1, t2, s2, l2 = rds.ext.get_rtplus_tags(false)
|
||||
return string.format("RTP=%d,%d,%d,%d,%d,%d\r\n", t1, s1, l1, t2, s2, l2)
|
||||
elseif data == "ertp" then
|
||||
local t1, s1, l1, t2, s2, l2 = get_rds_rtplus_tags(true)
|
||||
local t1, s1, l1, t2, s2, l2 = rds.ext.get_rtplus_tags(true)
|
||||
return string.format("ERTP=%d,%d,%d,%d,%d,%d\r\n", t1, s1, l1, t2, s2, l2)
|
||||
elseif data == "rtprun" then
|
||||
local running = get_rds_rtp_meta(false)
|
||||
local running = rds.ext.get_rtp_meta(false)
|
||||
local f1 = 2 or (running and 1 or 0)
|
||||
return string.format("RTPRUN=%d\r\n", f1)
|
||||
elseif data == "ertprun" then
|
||||
local running = get_rds_rtp_meta(true)
|
||||
local running = rds.ext.get_rtp_meta(true)
|
||||
local f1 = 2 or (running and 1 or 0)
|
||||
return string.format("ERTPRUN=%d\r\n", f1)
|
||||
elseif data == "lps" then return string.format("LPS=%s\r\n", get_rds_lps())
|
||||
elseif data == "ert" then return string.format("ERT=%s\r\n", get_rds_ert())
|
||||
elseif data == "grpseq" then return string.format("GRPSEQ=%s\r\n", get_rds_grpseq())
|
||||
elseif data == "grpseq2" then return string.format("GRPSEQ2=%s\r\n", get_rds_grpseq2())
|
||||
elseif data == "lps" then return string.format("LPS=%s\r\n", rds.get_lps())
|
||||
elseif data == "ert" then return string.format("ERT=%s\r\n", rds.ext.get_ert())
|
||||
elseif data == "grpseq" then return string.format("GRPSEQ=%s\r\n", rds.get_grpseq())
|
||||
elseif data == "grpseq2" then return string.format("GRPSEQ2=%s\r\n", rds.get_grpseq2())
|
||||
else
|
||||
local eon_cmd, eon_num = data:match("^eon(%d+)([a-z]+)$")
|
||||
if eon_cmd then
|
||||
local eon_idx = tonumber(eon_cmd)
|
||||
if not eon_idx or eon_idx < 1 or eon_idx > eon_count then return "?\r\n" end
|
||||
if not eon_idx or eon_idx < 1 or eon_idx > rds.eon_count then return "?\r\n" end
|
||||
eon_idx = eon_idx - 1
|
||||
local enabled, pi, tp, ta, pty, ps, afs, data_val = get_rds_eon(eon_idx)
|
||||
local enabled, pi, tp, ta, pty, ps, afs, data_val = rds.get_eon(eon_idx)
|
||||
|
||||
if eon_num == "en" then return string.format("EON%dEN=%d\r\n", eon_idx + 1, enabled and 1 or 0)
|
||||
elseif eon_num == "pi" then return string.format("EON%dPI=%x\r\n", eon_idx + 1, pi)
|
||||
@@ -106,48 +106,48 @@ function data_handle(data)
|
||||
local eon_num, eon_type = cmd:match("^eon(%d+)([a-z]+)$")
|
||||
if eon_num then
|
||||
local eon_idx = tonumber(eon_num)
|
||||
if not eon_idx or eon_idx < 1 or eon_idx > eon_count then return "?\r\n" end
|
||||
if not eon_idx or eon_idx < 1 or eon_idx > rds.eon_count then return "?\r\n" end
|
||||
eon_idx = eon_idx - 1
|
||||
|
||||
local enabled, pi, tp, ta, pty, ps, afs, data_val = get_rds_eon(eon_idx)
|
||||
local enabled, pi, tp, ta, pty, ps, afs, data_val = rds.get_eon(eon_idx)
|
||||
if eon_type == "en" then
|
||||
local en_val = tonumber(value)
|
||||
if not en_val then return "-\r\n" end
|
||||
enabled = (en_val ~= 0)
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "pi" then
|
||||
local pi_val = tonumber(value, 16)
|
||||
if not pi_val then return "-\r\n" end
|
||||
set_rds_eon(eon_idx, enabled, pi_val, tp, ta, pty, ps, afs, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi_val, tp, ta, pty, ps, afs, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "ps" then
|
||||
local ps_val = value:sub(1, 24)
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps_val, afs, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps_val, afs, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "pty" then
|
||||
local pty_val = tonumber(value)
|
||||
if not pty_val then return "-\r\n" end
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty_val, ps, afs, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty_val, ps, afs, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "ta" then
|
||||
if not enabled or not tp then return "-\r\n" end
|
||||
local ta_val = tonumber(value)
|
||||
if not ta_val then return "-\r\n" end
|
||||
ta = (ta_val ~= 0)
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
if ta then set_rds_ta(true) end
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
if ta then rds.set_ta(true) end
|
||||
return "+\r\n"
|
||||
elseif eon_type == "tp" then
|
||||
local tp_val = tonumber(value)
|
||||
if not tp_val then return "-\r\n" end
|
||||
tp = (tp_val ~= 0)
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "af" then
|
||||
local af_table = {}
|
||||
if value == "" or value == "0" then
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, {}, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, {}, data_val)
|
||||
return "+\r\n"
|
||||
end
|
||||
for freq_str in value:gmatch("([^,]+)") do
|
||||
@@ -156,12 +156,12 @@ function data_handle(data)
|
||||
else return "-\r\n" end
|
||||
end
|
||||
if #af_table > 25 then return "-\r\n" end
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, af_table, data_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, af_table, data_val)
|
||||
return "+\r\n"
|
||||
elseif eon_type == "dt" then
|
||||
local dt_val = tonumber(value, 16)
|
||||
if not dt_val then return "-\r\n" end
|
||||
set_rds_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, dt_val)
|
||||
rds.set_eon(eon_idx, enabled, pi, tp, ta, pty, ps, afs, dt_val)
|
||||
return "+\r\n"
|
||||
else return "?\r\n" end
|
||||
end
|
||||
@@ -179,7 +179,7 @@ function data_handle(data)
|
||||
end
|
||||
|
||||
if #groups > 8 or #groups == 0 then return "-\r\n" end
|
||||
set_rds_udg(xy, groups)
|
||||
rds.set_udg(xy, groups)
|
||||
return "+\r\n"
|
||||
end
|
||||
if udg2_num then
|
||||
@@ -193,7 +193,7 @@ function data_handle(data)
|
||||
end
|
||||
|
||||
if #groups > 8 or #groups == 0 then return "-" end
|
||||
set_rds_udg2(xy, groups)
|
||||
rds.set_udg2(xy, groups)
|
||||
return "+\r\n"
|
||||
end
|
||||
|
||||
@@ -201,67 +201,67 @@ function data_handle(data)
|
||||
local pi = tonumber(value, 16)
|
||||
if not pi then return "-\r\n" end
|
||||
if (pi & 0xF000) == 0 then return "-\r\n" end
|
||||
set_rds_pi(pi)
|
||||
rds.set_pi(pi)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ecc" then
|
||||
local ecc = tonumber(value, 16)
|
||||
if not ecc then return "-\r\n" end
|
||||
set_rds_ecc(ecc)
|
||||
rds.set_ecc(ecc)
|
||||
return "+\r\n"
|
||||
elseif cmd == "pty" then
|
||||
local pty = tonumber(value)
|
||||
if not pty then return "-\r\n" end
|
||||
set_rds_pty(pty)
|
||||
rds.set_pty(pty)
|
||||
return "+\r\n"
|
||||
elseif cmd == "slcd" then
|
||||
local slc_data = tonumber(value, 16)
|
||||
if not slc_data then return "-\r\n" end
|
||||
set_rds_slc_data(slc_data)
|
||||
rds.set_slc_data(slc_data)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ct" then
|
||||
local ct = tonumber(value)
|
||||
if not ct then return "-\r\n" end
|
||||
set_rds_ct(ct ~= 0)
|
||||
rds.set_ct(ct ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "dpty" then
|
||||
local dpty = tonumber(value)
|
||||
if not dpty then return "-\r\n" end
|
||||
set_rds_dpty(dpty ~= 0)
|
||||
rds.set_dpty(dpty ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "tp" then
|
||||
local tp = tonumber(value)
|
||||
if not tp then return "-\r\n" end
|
||||
set_rds_tp(tp ~= 0)
|
||||
rds.set_tp(tp ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ta" then
|
||||
local ta = tonumber(value)
|
||||
if not ta then return "-\r\n" end
|
||||
set_rds_ta(ta ~= 0)
|
||||
rds.set_ta(ta ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rt1en" then
|
||||
local en = tonumber(value)
|
||||
if not en then return "-\r\n" end
|
||||
set_rds_rt1_enabled(en ~= 0)
|
||||
rds.set_rt1_enabled(en ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rt2en" then
|
||||
local en = tonumber(value)
|
||||
if not en then return "-\r\n" end
|
||||
set_rds_rt2_enabled(en ~= 0)
|
||||
rds.set_rt2_enabled(en ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ptynen" then
|
||||
local en = tonumber(value)
|
||||
if not en then return "-\r\n" end
|
||||
set_rds_ptyn_enabled(en ~= 0)
|
||||
rds.set_ptyn_enabled(en ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rttype" then
|
||||
local type = tonumber(value)
|
||||
if not type then return "-\r\n" end
|
||||
set_rds_rt_type(type)
|
||||
rds.set_rt_type(type)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rds2mod" then
|
||||
local type = tonumber(value)
|
||||
if not type then return "-\r\n" end
|
||||
set_rds2_mode(type)
|
||||
rds.set_rds2_mode(type)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rdsgen" then
|
||||
local type = tonumber(value)
|
||||
@@ -269,42 +269,42 @@ function data_handle(data)
|
||||
set_rds_streams(type)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ptyn" then
|
||||
set_rds_ptyn(value)
|
||||
rds.set_ptyn(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ps" then
|
||||
set_rds_ps(value)
|
||||
rds.set_ps(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "tps" then
|
||||
set_rds_tps(value)
|
||||
rds.set_tps(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rt1" or cmd == "text" then
|
||||
set_rds_rt1(value)
|
||||
rds.set_rt1(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rt2" then
|
||||
set_rds_rt2(value)
|
||||
rds.set_rt2(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "lps" then
|
||||
set_rds_lps(value)
|
||||
rds.set_lps(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "ert" then
|
||||
set_rds_ert(value)
|
||||
rds.ext.set_ert(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "link" then
|
||||
local link = tonumber(value)
|
||||
if not link then return "-\r\n" end
|
||||
set_rds_link(link ~= 0)
|
||||
rds.set_link(link ~= 0)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rtper" then
|
||||
local period = tonumber(value)
|
||||
if not period then return "-\r\n" end
|
||||
set_rds_rt_switching_period(period*60)
|
||||
rds.set_rt_switching_period(period*60)
|
||||
return "+\r\n"
|
||||
elseif cmd == "program" then
|
||||
local program = tonumber(value)
|
||||
if not program then return "-\r\n" end
|
||||
if program < 1 or program > max_programs then return "-\r\n" end
|
||||
set_rds_program(program-1)
|
||||
set_rds_ta(false)
|
||||
if program < 1 or program > dp.max_programs then return "-\r\n" end
|
||||
dp.set_rds_program(program-1)
|
||||
rds.set_ta(false)
|
||||
return "+\r\n"
|
||||
elseif cmd == "level" then
|
||||
local level = tonumber(value)
|
||||
@@ -314,20 +314,20 @@ function data_handle(data)
|
||||
elseif cmd == "dttmout" then
|
||||
local timeout = tonumber(value)
|
||||
if not timeout then return "-\r\n" end
|
||||
set_rds_rt_text_timeout(timeout*60)
|
||||
rds.set_rt_text_timeout(timeout*60)
|
||||
return "+\r\n"
|
||||
elseif cmd == "grpseq" then
|
||||
set_rds_grpseq(value)
|
||||
rds.set_grpseq(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "grpseq2" then
|
||||
set_rds_grpseq2(value)
|
||||
rds.set_grpseq2(value)
|
||||
return "+\r\n"
|
||||
elseif cmd == "rtp" or cmd == "ertp" then
|
||||
local is_ertp = (cmd == "ertp")
|
||||
local t1, s1, l1, t2, s2, l2 = value:match("(%d+),(%d+),(%d+),(%d+),(%d+),(%d+)")
|
||||
|
||||
if not l2 then return "-\r\n" end
|
||||
set_rds_rtplus_tags(
|
||||
rds.ext.set_rtplus_tags(
|
||||
is_ertp,
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
tonumber(t1), tonumber(s1), tonumber(l1), tonumber(t2), tonumber(s2), tonumber(l2)
|
||||
@@ -336,13 +336,13 @@ function data_handle(data)
|
||||
elseif cmd == "g" then
|
||||
local a, b, c, d = value:match("^(%x%x%x%x)(%x%x%x%x)(%x%x%x%x)(%x%x%x%x)$")
|
||||
if a and b and c and d then
|
||||
put_rds2_custom_group(tonumber(a, 16), tonumber(b, 16), tonumber(c, 16), tonumber(d, 16))
|
||||
rds.put_rds2_custom_group(tonumber(a, 16), tonumber(b, 16), tonumber(c, 16), tonumber(d, 16))
|
||||
return "+\r\n"
|
||||
end
|
||||
|
||||
local b1, c1, d1 = value:match("^(%x%x%x%x)(%x%x%x%x)(%x%x%x%x)$")
|
||||
if b1 and c1 and d1 then
|
||||
put_rds_custom_group(tonumber(b1, 16), tonumber(c1, 16), tonumber(d1, 16))
|
||||
rds.put_custom_group(tonumber(b1, 16), tonumber(c1, 16), tonumber(d1, 16))
|
||||
return "+\r\n"
|
||||
end
|
||||
|
||||
@@ -357,14 +357,14 @@ function data_handle(data)
|
||||
local f2 = tonumber(f2_str) or 0
|
||||
local running = (f1 & 1) ~= 0
|
||||
|
||||
set_rds_rtp_meta(is_ertp, running)
|
||||
if f2 ~= 0 then toggle_rds_rtp(is_ertp) end
|
||||
rds.ext.set_rtp_meta(is_ertp, running)
|
||||
if f2 ~= 0 then rds.ext.toggle_rtp(is_ertp) end
|
||||
return "+\r\n"
|
||||
elseif cmd == "af" then
|
||||
local af_table = {}
|
||||
|
||||
if value == "" or value == "0" then
|
||||
set_rds_af_group0({})
|
||||
rds.set_af({})
|
||||
return "+\r\n"
|
||||
end
|
||||
|
||||
@@ -376,13 +376,13 @@ function data_handle(data)
|
||||
|
||||
if #af_table > 25 then return "-\r\n" end
|
||||
|
||||
set_rds_af_group0(af_table)
|
||||
rds.set_af(af_table)
|
||||
return "+\r\n"
|
||||
elseif cmd == "afo" then
|
||||
local af_table = {}
|
||||
|
||||
if value == "" or value == "0" then
|
||||
set_rds_af_oda({})
|
||||
rds.ext.set_af_oda({})
|
||||
return "+\r\n"
|
||||
end
|
||||
|
||||
@@ -394,7 +394,7 @@ function data_handle(data)
|
||||
|
||||
if #af_table > 25 then return "-\r\n" end
|
||||
|
||||
set_rds_af_oda(af_table)
|
||||
rds.ext.set_af_oda(af_table)
|
||||
return "+\r\n"
|
||||
else
|
||||
return "?\r\n"
|
||||
|
||||
Reference in New Issue
Block a user