don't need this
[synarere.git] / core / module.py
blob614f0599b51d7dc95bfc64946c93f233b3f1d01f
1 # synarere -- a highly modular and stable IRC bot.
2 # Copyright (C) 2010 Michael Rodriguez.
3 # Rights to this code are documented in docs/LICENSE.
5 '''Module operations.'''
7 # Import required Python function.
8 from imp import load_source
10 # Import required core modules.
11 import logger, var, event
13 def load(module):
14 '''Load a module.'''
16 try:
17 mod = load_source(module, module)
18 except ImportError, e:
19 logger.error('load(): unable to load module %s: %s' % (module, e))
20 return
22 # Check to make sure the module has init/fini functions.
23 if not hasattr(mod, 'module_init'):
24 logger.error('load(): unable to use module %s: no entry point has been defined' % mod.__name__)
25 return
27 if not hasattr(mod, 'module_fini'):
28 logger.error('load(): unable to use module %s: no exit point has been defined' % mod.__name__)
29 return
31 mod.module_init()
32 logger.info('load(): module %s loaded' % mod.__name__)
34 # Add the module to the loaded modules list.
35 var.modules_loaded.append(mod)
36 event.dispatch('OnModuleLoad', module)
38 def unload(module):
39 '''Unload a module.'''
41 # Make sure it is in the modules loaded list.
42 if module not in var.modules_loaded:
43 logger.warning('unload(): %s is not in the loaded modules list' % module)
44 return
46 module.module_fini()
48 # Remove the module from the loaded modules list.
49 var.modules_loaded.remove(module)
50 event.dispatch('OnModuleUnload', module)
52 def load_all():
53 '''Load all modules listed in the configuration.'''
55 try:
56 for i in var.conf.get('module'):
57 name = i.get('name')
59 if name != None:
60 load(name)
62 event.dispatch('OnLoadAllModules', name)
63 except:
64 pass # Means they dont want modules.
66 def unload_all():
67 '''Unload all loaded modules.'''
69 for i in var.modules_loaded:
70 unload(i)
72 event.dispatch('OnUnloadAllModules')