PluginSystem: implement new PluginDescriptor option "needsRestart" to define if a...
authoracid-burn <acid-burn@opendreambox.org>
Mon, 7 Feb 2011 13:15:40 +0000 (14:15 +0100)
committeracid-burn <acid-burn@opendreambox.org>
Mon, 7 Feb 2011 13:15:40 +0000 (14:15 +0100)
Now new installed plugins are only direct accessible after installation if needsRestart=False is defined inside the plugins PluginDescriptor.
fixes #670

lib/python/Components/PluginComponent.py
lib/python/Plugins/Plugin.py

index 5e439fdfea437eb0402e121dbfdc40baea843825..60f767380cbe653baa25b86e53d404369b170210 100755 (executable)
@@ -8,6 +8,9 @@ from Plugins.Plugin import PluginDescriptor
 import keymapparser
 
 class PluginComponent:
+       firstRun = True
+       restartRequired = False
+       
        def __init__(self):
                self.plugins = {}
                self.pluginList = [ ]
@@ -18,12 +21,22 @@ class PluginComponent:
                self.prefix = prefix
 
        def addPlugin(self, plugin):
-               self.pluginList.append(plugin)
-               for x in plugin.where:
-                       self.plugins.setdefault(x, []).append(plugin)
-                       if x == PluginDescriptor.WHERE_AUTOSTART:
-                               plugin(reason=0)
-
+               if self.firstRun:
+                       self.pluginList.append(plugin)
+                       for x in plugin.where:
+                               self.plugins.setdefault(x, []).append(plugin)
+                               if x == PluginDescriptor.WHERE_AUTOSTART:
+                                       plugin(reason=0)
+               else:
+                       if plugin.needsRestart is False:
+                               self.pluginList.append(plugin)
+                               for x in plugin.where:
+                                       self.plugins.setdefault(x, []).append(plugin)
+                                       if x == PluginDescriptor.WHERE_AUTOSTART:
+                                               plugin(reason=0)                                
+                       else:
+                               self.restartRequired = True
+                               
        def removePlugin(self, plugin):
                self.pluginList.remove(plugin)
                for x in plugin.where:
@@ -81,12 +94,21 @@ class PluginComponent:
                # internally, the "fnc" argument will be compared with __eq__
                plugins_added = [p for p in new_plugins if p not in self.pluginList]
                plugins_removed = [p for p in self.pluginList if not p.internal and p not in new_plugins]
+               
+               #ignore already installed but reloaded plugins
+               for p in plugins_removed: 
+                       for pa in plugins_added:
+                               if pa.name == p.name and pa.where == p.where:
+                                       pa.needsRestart = False
 
                for p in plugins_removed:
                        self.removePlugin(p)
 
                for p in plugins_added:
                        self.addPlugin(p)
+               
+               if self.firstRun:
+                       self.firstRun = False
 
        def getPlugins(self, where):
                """Get list of plugins in a specific category"""
index 5a676cdadaf4ca8bfd2c5675f3bea90b81e11c80..9ecdbc26de3af3420ea47e8c7ac947ba239cf58a 100755 (executable)
@@ -61,9 +61,10 @@ class PluginDescriptor:
        WHERE_SOFTWAREMANAGER = 14
 
 
-       def __init__(self, name = "Plugin", where = [ ], description = "", icon = None, fnc = None, wakeupfnc = None, internal = False):
+       def __init__(self, name = "Plugin", where = [ ], description = "", icon = None, fnc = None, wakeupfnc = None, needsRestart = None, internal = False):
                self.name = name
                self.internal = internal
+               self.needsRestart = needsRestart
                if isinstance(where, list):
                        self.where = where
                else: