X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/af574b481d63d4dea8cbef66680e597df5a27f1e..29f60fdaf6f0ff1dd112c9e0e913ec734b304bf1:/lib/python/Plugins/Plugin.py diff --git a/lib/python/Plugins/Plugin.py b/lib/python/Plugins/Plugin.py index d10a3fba..b2808c8e 100644 --- a/lib/python/Plugins/Plugin.py +++ b/lib/python/Plugins/Plugin.py @@ -1,3 +1,5 @@ +from enigma import loadPNG + class PluginDescriptor: """An object to describe a plugin.""" @@ -9,6 +11,8 @@ class PluginDescriptor: # servicereference # reason + # you have to ignore unknown kwargs! + # argument: session WHERE_BLUEMENU = 0 WHERE_MAINMENU = 1 @@ -21,6 +25,16 @@ class PluginDescriptor: # reason (0: start, 1: end) WHERE_AUTOSTART = 5 + # start as wizard. In that case, fnc must be a screen class! + WHERE_WIZARD = 6 + + # like autostart, but for a session. currently, only session starts are + # delivered, and only on pre-loaded plugins + WHERE_SESSIONSTART = 7 + + # start as teletext plugin. arguments: session, serviceref + WHERE_TELETEXT = 8 + def __init__(self, name = "Plugin", where = [ ], description = "", icon = None, fnc = None): self.name = name if type(where) is list: @@ -28,8 +42,20 @@ class PluginDescriptor: else: self.where = [ where ] self.description = description - if type(fnc) is str: - self.icon = loadPNG("..") + + if type(icon) is str or icon is None: + self.iconstr = icon + self.icon = None else: self.icon = icon + self.__call__ = fnc + + def updateIcon(self, path): + if type(self.iconstr) is str: + self.icon = loadPNG(path + "/" + self.iconstr) + else: + self.icon = None + + def __eq__(self, other): + return self.__call__ == other.__call__