diff options
author | mathieui <mathieui@mathieui.net> | 2014-04-13 23:13:18 +0200 |
---|---|---|
committer | mathieui <mathieui@mathieui.net> | 2014-04-13 23:13:18 +0200 |
commit | e3859c2862b441059012e51cbd9e7eccc6b13470 (patch) | |
tree | 0b3cc50dd224144dc85642e5dbc56f4353dfa857 /src/plugin.py | |
parent | 9c2203e7e37f1eefea2bbd20ce22d107bee93636 (diff) | |
download | poezio-e3859c2862b441059012e51cbd9e7eccc6b13470.tar.gz poezio-e3859c2862b441059012e51cbd9e7eccc6b13470.tar.bz2 poezio-e3859c2862b441059012e51cbd9e7eccc6b13470.tar.xz poezio-e3859c2862b441059012e51cbd9e7eccc6b13470.zip |
Do not load a plugin if its init() traceback
and show a somehow helpful error message in this case
Diffstat (limited to 'src/plugin.py')
-rw-r--r-- | src/plugin.py | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/src/plugin.py b/src/plugin.py index dfb0fff1..49f79ad5 100644 --- a/src/plugin.py +++ b/src/plugin.py @@ -10,6 +10,8 @@ from timed_events import TimedEvent, DelayedEvent import config import inspect import traceback +import logging +log = logging.getLogger(__name__) class PluginConfig(config.Config): """ @@ -81,7 +83,8 @@ class SafetyMetaclass(type): def __new__(meta, name, bases, class_dict): for k, v in class_dict.items(): if inspect.isfunction(v): - class_dict[k] = SafetyMetaclass.safe_func(v) + if k != '__init__' and k != 'init': + class_dict[k] = SafetyMetaclass.safe_func(v) return type.__new__(meta, name, bases, class_dict) class PluginWrap(object): |