2020-01-19 16:06:21 +01:00
|
|
|
import importlib
|
|
|
|
import logging
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
2020-01-19 15:36:52 +01:00
|
|
|
|
|
|
|
def load(module_name):
|
2020-01-19 16:06:21 +01:00
|
|
|
try:
|
|
|
|
mod = importlib.import_module('modules.{}'.format(module_name))
|
|
|
|
except ImportError as error:
|
|
|
|
log.fatal('failed to import {}: {}'.format(module_name, str(error)))
|
|
|
|
return Error(module_name)
|
|
|
|
return getattr(mod, 'Module')()
|
2020-01-19 15:36:52 +01:00
|
|
|
|
|
|
|
class Module(object):
|
|
|
|
def update(self):
|
|
|
|
pass
|
|
|
|
|
2020-01-19 16:06:21 +01:00
|
|
|
class Error(Module):
|
|
|
|
def __init__(self, loaded_module_name):
|
|
|
|
self._loaded_module_name = loaded_module_name
|
|
|
|
|
2020-01-19 15:36:52 +01:00
|
|
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|