|
@ -6,8 +6,8 @@ import traceback |
|
|
|
|
|
|
|
|
log = CPLog(__name__) |
|
|
log = CPLog(__name__) |
|
|
|
|
|
|
|
|
class Loader(object): |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Loader(object): |
|
|
plugins = {} |
|
|
plugins = {} |
|
|
providers = {} |
|
|
providers = {} |
|
|
modules = {} |
|
|
modules = {} |
|
@ -98,14 +98,16 @@ class Loader(object): |
|
|
|
|
|
|
|
|
for cur_file in glob.glob(os.path.join(dir_name, '*')): |
|
|
for cur_file in glob.glob(os.path.join(dir_name, '*')): |
|
|
name = os.path.basename(cur_file) |
|
|
name = os.path.basename(cur_file) |
|
|
if os.path.isdir(os.path.join(dir_name, name)): |
|
|
if os.path.isdir(os.path.join(dir_name, name)) and name != 'static': |
|
|
module_name = '%s.%s' % (module, name) |
|
|
module_name = '%s.%s' % (module, name) |
|
|
self.addModule(priority, plugin_type, module_name, name) |
|
|
self.addModule(priority, plugin_type, module_name, name) |
|
|
|
|
|
|
|
|
def loadSettings(self, module, name, save = True): |
|
|
def loadSettings(self, module, name, save = True): |
|
|
|
|
|
|
|
|
if not hasattr(module, 'config'): |
|
|
if not hasattr(module, 'config'): |
|
|
log.warning('Skip loading settings for plugin %s as it has no config section' % module.__file__) |
|
|
log.debug('Skip loading settings for plugin %s as it has no config section' % module.__file__) |
|
|
return False |
|
|
return False |
|
|
|
|
|
|
|
|
try: |
|
|
try: |
|
|
for section in module.config: |
|
|
for section in module.config: |
|
|
fireEvent('settings.options', section['name'], section) |
|
|
fireEvent('settings.options', section['name'], section) |
|
@ -120,8 +122,9 @@ class Loader(object): |
|
|
return False |
|
|
return False |
|
|
|
|
|
|
|
|
def loadPlugins(self, module, name): |
|
|
def loadPlugins(self, module, name): |
|
|
|
|
|
|
|
|
if not hasattr(module, 'start'): |
|
|
if not hasattr(module, 'start'): |
|
|
log.warning('Skip startup for plugin %s as it has no start section' % module.__file__) |
|
|
log.debug('Skip startup for plugin %s as it has no start section' % module.__file__) |
|
|
return False |
|
|
return False |
|
|
try: |
|
|
try: |
|
|
module.start() |
|
|
module.start() |
|
@ -150,7 +153,7 @@ class Loader(object): |
|
|
m = getattr(m, sub) |
|
|
m = getattr(m, sub) |
|
|
return m |
|
|
return m |
|
|
except ImportError: |
|
|
except ImportError: |
|
|
log.warning("Skip loading module plugin '%s' as it seems not to be a module." % name) |
|
|
log.debug('Skip loading module plugin %s: %s', (name, traceback.format_exc())) |
|
|
return None |
|
|
return None |
|
|
except: |
|
|
except: |
|
|
raise |
|
|
raise |
|
|