Unload a module now unsubscribe auto-registered hooks

This commit is contained in:
Némunaire 2012-09-01 11:23:41 +02:00
parent 4055025160
commit fc396ef313
3 changed files with 35 additions and 5 deletions

3
bot.py
View File

@ -158,6 +158,9 @@ class Bot:
self.modules[name].save()
if hasattr(self.modules[name], "unload"):
self.modules[name].unload()
# Remove registered hooks
for (s, h) in self.modules[name].REGISTERED_HOOKS:
self.hooks.del_hook(s, h)
# Remove from the dict
del self.modules[name]
return True

View File

@ -42,15 +42,15 @@ class MessagesHook:
self.msg_default = list()
def add_hook(self, store, hook):
def add_hook(self, store, hook, module_src=None):
"""Insert in the right place a hook into the given store"""
if store in self.context.hooks_cache:
del self.context.hooks_cache[store]
attr = getattr(self, store)
if attr is None:
if not hasattr(self, store):
print ("Warning: unrecognized hook store type")
return
attr = getattr(self, store)
if isinstance(attr, dict) and hook.name is not None:
if hook.name not in attr:
@ -60,14 +60,19 @@ class MessagesHook:
attr.append(hook)
else:
print ("Warning: unrecognized hook store type")
return
if module_src is not None:
module_src.REGISTERED_HOOKS.append((store, hook))
def register_hook_attributes(self, store, module, node):
if node.hasAttribute("name"):
self.add_hook(store + "_hook", Hook(getattr(module, node["call"]),
node["name"]))
node["name"]),
module)
elif node.hasAttribute("regexp"):
self.add_hook(store + "_rgxp", Hook(getattr(module, node["call"]),
None, None, node["regexp"]))
None, None, node["regexp"]),
module)
def register_hook(self, module, node):
"""Create a hook from configuration node"""
@ -82,6 +87,21 @@ class MessagesHook:
node["type"] == "all"):
self.register_hook_attributes("answer", module, node)
def del_hook(self, store, hook):
"""Remove a registered hook from a given store"""
if store in self.context.hooks_cache:
del self.context.hooks_cache[store]
if not hasattr(self, store):
print ("Warning: unrecognized hook store type")
return
attr = getattr(self, store)
if isinstance(attr, dict) and hook.name is not None:
if hook.name in attr:
attr[hook.name].remove(hook)
else:
attr.remove(hook)
class Hook:
"""Class storing hook informations"""

View File

@ -22,6 +22,7 @@ import imp
import os
import sys
import event
from hooks import Hook
import response
import xmlparser
@ -141,10 +142,12 @@ class ModuleLoader(SourceLoader):
module.__LOADED__ = True
# Set module common functions and datas
module.REGISTERED_HOOKS = list()
module.DEBUG = False
module.name = fullname
module.print = lambda msg: print("[%s] %s"%(module.name, msg))
module.print_debug = lambda msg: mod_print_dbg(module, msg)
module.send_response = lambda srv, res: mod_send_response(context, srv, res)
if not hasattr(module, "NODATA"):
module.DATAS = xmlparser.parse_file(self.context.datas_path
@ -157,6 +160,7 @@ class ModuleLoader(SourceLoader):
module.has_access = lambda msg: mod_has_access(module,
module.CONF, msg)
module.ModuleEvent = event.ModuleEvent
module.ModuleState = xmlparser.module_state.ModuleState
module.Response = response.Response
@ -243,3 +247,6 @@ def mod_has_access(mod, config, msg):
return False
else:
return True
def mod_send_response(context, server, res):
context.servers[server].send_response(res)