diff options
author | Simon Poirier <simpoir@gmail.com> | 2009-10-21 14:05:06 (GMT) |
---|---|---|
committer | Simon Poirier <simpoir@gmail.com> | 2009-10-21 14:05:06 (GMT) |
commit | 2ea94167aa5854840ff0b92242f96e1df8156888 (patch) | |
tree | 0955b66d313a5f850a068a0c1528cd7cc05ddc3d /tutorius/addon.py | |
parent | f093aac859b9a92f6296b3bb70b87678fe4d4b42 (diff) | |
parent | a3cf21dcced998951be41cef43e8815545c00cb8 (diff) |
Merge branch 'creator' into demo_audit_21_oct
Conflicts:
tutorius/core.py
Diffstat (limited to 'tutorius/addon.py')
-rw-r--r-- | tutorius/addon.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/tutorius/addon.py b/tutorius/addon.py index 15612c8..7ac68f7 100644 --- a/tutorius/addon.py +++ b/tutorius/addon.py @@ -38,6 +38,9 @@ import logging PREFIX = __name__+"s" PATH = re.sub("addon\\.py[c]$", "", __file__)+"addons" +TYPE_ACTION = 'action' +TYPE_EVENT = 'event' + _cache = None def _reload_addons(): @@ -47,9 +50,11 @@ def _reload_addons(): mod = __import__(PREFIX+'.'+re.sub("\\.py$", "", addon), {}, {}, [""]) if hasattr(mod, "__action__"): _cache[mod.__action__['name']] = mod.__action__ + mod.__action__['type'] = TYPE_ACTION continue if hasattr(mod, "__event__"): _cache[mod.__event__['name']] = mod.__event__ + mod.__event__['type'] = TYPE_EVENT def create(name, *args, **kwargs): global _cache @@ -78,4 +83,13 @@ def get_addon_meta(name): _reload_addons() return _cache[name] +def get_name_from_type(typ): + global _cache + if not _cache: + _reload_addons() + for addon in _cache.keys(): + if typ == _cache[addon]['class']: + return addon + return None + # vim:set ts=4 sts=4 sw=4 et: |