Compare commits

...

2 Commits

Author SHA1 Message Date
sammyette 466ca06f79
feat: implement message managing functions 2023-04-11 19:31:37 -04:00
sammyette 34a5b2aedd
fix: update message counter 2023-04-11 19:17:10 -04:00
1 changed files with 39 additions and 6 deletions

View File

@ -34,23 +34,56 @@ end
function hilbish.messages.send(message)
expect(message, 'text')
expect(message, 'title')
message.index = counter + 1
counter = counter + 1
message.index = counter
message.read = false
M._messages[message.index] = message
bait.throw('hilbish.notification', message)
end
function hilbish.messages.read(idx)
local msg = M._messages[idx]
if msg then
M._messages[idx].read = true
end
end
function hilbish.messages.readAll(idx)
for _, msg in ipairs(hilbish.messages.all()) do
hilbish.messages.read(msg.index)
end
end
function hilbish.messages.delete(idx)
local msg = M._messages[idx]
if not msg then
error(string.format('invalid message index %d', idx or -1))
end
M._messages[idx] = nil
end
function hilbish.messages.clear()
for _, msg in ipairs(hilbish.messages.all()) do
hilbish.messages.delete(msg.index)
end
end
function hilbish.messages.all()
return M._messages
end
commander.register('messages', function(_, sinks)
for _, msg in ipairs(hilbish.messages.all()) do
for idx = counter, 1, -1 do
local msg = M._messages[idx]
if msg then
local heading = lunacolors.format(string.format('Message {cyan}#%d{reset}: %s', msg.index, msg.title))
sinks.out:writeln(heading)
sinks.out:writeln(string.rep('=', string.len(heading)))
sinks.out:writeln(msg.text)
end
end
end)
return M