forked from BenDol/otclient-candybot
-
Notifications
You must be signed in to change notification settings - Fork 2
/
listeners.lua
152 lines (128 loc) · 4.07 KB
/
listeners.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
--[[
@Authors: Ben Dol (BeniS)
@Details: Listener handler for module listeners.
]]
ListenerHandler = {}
function ListenerHandler.init()
--
end
function ListenerHandler.terminate()
--
end
function ListenerHandler.getListener(moduleId, listenerId)
local module = Modules.getModule(moduleId)
if not module then
return nil
end
local listeners = module:getListeners()
for k, listener in pairs(listeners) do
if k == listenerId and listener ~= nil then return listener end
end
return nil
end
function ListenerHandler.isListenerRegistered(moduleId, listenerId)
return ListenerHandler.getListener(moduleId, listenerId) ~= nil
end
function ListenerHandler.isListenerConnected(moduleId, listenerId)
local module = Modules.getModule(moduleId)
if not module then
return false
end
local listeners = module:getListeners()
for k, listener in pairs(listeners) do
if k == listenerId then
return listener:isConnected()
end
end
return false
end
function ListenerHandler.registerListener(moduleId, listenerId, callbacks, state)
if ListenerHandler.isListenerRegistered(moduleId, listenerId) then
error("This listener has already been registered for module '"..moduleId.."'")
return false
end
local module = Modules.getModule(moduleId)
local listener = CandyListener.create(listenerId, callbacks, state)
module:addListener(listenerId, listener)
return true
end
function ListenerHandler.unregisterListener(moduleId, listenerId, stop)
if ListenerHandler.isListenerRegistered(moduleId, listenerId) then
local module = Modules.getModule(moduleId)
module:removeListener(listenerId, stop or true)
end
end
function ListenerHandler.unregisterListeners(moduleId)
if Modules.isModuleRegistered(moduleId) then
local module = Modules.getModule(moduleId)
for k, listener in pairs(module:getListeners()) do
if listener then ListenerHandler.unregisterListener(moduleId, k) end
end
end
end
function ListenerHandler.connectListener(moduleId, listenerId, state)
if ListenerHandler.isListenerConnected(moduleId, listenerId) then
error("This listener has already been connected for module '"..moduleId.."'")
return false
end
local state = state or false
local module = Modules.getModule(moduleId)
local listener = module:getListener(listenerId)
if listener then
listener:connect()
listener:setState(state)
end
return true
end
function ListenerHandler.disconnectListener(moduleId, listenerId, state)
if ListenerHandler.isListenerRegistered(moduleId, listenerId) then
local state = state or false
local module = Modules.getModule(moduleId)
local listener = module:getListener(listenerId)
if listener then
listener:disconnect()
listener:setState(state)
end
end
end
function ListenerHandler.stopListeners(moduleId)
if Modules.isModuleRegistered(moduleId) then
local module = Modules.getModule(moduleId)
for id, listener in pairs(module:getListeners()) do
if listener then module:disconnectListeners() end
end
end
end
function ListenerHandler.signal(ignore)
local ignores = Modules.getListenerSignalIgnores()
if not table.empty(ignore) then
table.merge(ignores, ignore)
end
for k, module in pairs(Modules.getModules()) do
if module then
for i, listener in pairs(module:getListeners()) do
if not ignores[k][i] then
module:notify(module:getListenerInfo(i).option, listener:getState())
end
end
end
end
end
function ListenerHandler.response(moduleId, listeners, key, state)
if type(state) == 'string' then
state = (state ~= "")
end
for listener, data in pairs(listeners) do
if key == data.option then
local register = not ListenerHandler.isListenerRegistered(moduleId, listener)
if register then
ListenerHandler.registerListener(moduleId, listener,
{data.connect, data.disconnect}, state)
end
ListenerHandler.disconnectListener(moduleId, listener, state)
if state then
ListenerHandler.connectListener(moduleId, listener, state)
end
end
end
end