properly unload old plugins and load new plugins
authorFelix Domke <tmbinc@elitedvb.net>
Thu, 23 Feb 2006 02:59:37 +0000 (02:59 +0000)
committerFelix Domke <tmbinc@elitedvb.net>
Thu, 23 Feb 2006 02:59:37 +0000 (02:59 +0000)
lib/python/Components/PluginComponent.py
lib/python/Plugins/Plugin.py
lib/python/Screens/PluginBrowser.py

index e55bbd4d303096f0dec01e75f48f0791bead2ff6..e5ceb90d5b5a37ca272b959a417d59177d970d24 100644 (file)
@@ -34,38 +34,48 @@ class PluginComponent:
                        if x == PluginDescriptor.WHERE_AUTOSTART:
                                plugin(reason=1)
        
                        if x == PluginDescriptor.WHERE_AUTOSTART:
                                plugin(reason=1)
        
-       def reReadPluginList(self, directory, depth = 1):
-               print "re-reading plugin list"
-               self.clearPluginList()
-               self.readPluginList(directory=directory, depth=depth)
-       
-       def readPluginList(self, directory, modules = [], depth = 1):
+       def readPluginList(self, directory):
                """enumerates plugins"""
                
                """enumerates plugins"""
                
-               directories = os.listdir(directory)
+               categories = os.listdir(directory)
+               
+               new_plugins = [ ]
+               
+               for c in categories:
+                       directory_category = directory + c
+                       if not os.path.isdir(directory_category):
+                               continue
+                       open(directory_category + "/__init__.py", "a").close()
+                       for x in os.listdir(directory_category):
+                               path = directory_category + "/" + x + "/"
+                               if os.path.isdir(path):
+                                       if fileExists(path + "plugin.py"):
+                                               plugin = my_import('.'.join(["Plugins", c, x, "plugin"]))
+
+                                               if not plugin.__dict__.has_key("Plugins"):
+                                                       print "Plugin %s doesn't have 'Plugin'-call." % (x)
+                                                       continue
+
+                                               plugins = plugin.Plugins()
+
+                                               # allow single entry not to be a list
+                                               if type(plugins) is not list:
+                                                       plugins = [ plugins ]
+
+                                               for p in plugins:
+                                                       p.updateIcon(path)
+                                                       new_plugins.append(p)
+               
+               # build a diff between the old list of plugins and the new one
+               # 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 p not in new_plugins]
+               
+               for p in plugins_removed:
+                       self.removePlugin(p)
                
                
-               for x in directories:
-                       path = directory + x + "/"
-                       if os.path.isdir(path):
-                               if fileExists(path + "plugin.py"):
-                                       plugin = my_import('.'.join(["Plugins"] + modules + [x, "plugin"]))
-                                       
-                                       if not plugin.__dict__.has_key("Plugins"):
-                                               print "Plugin %s doesn't have 'Plugin'-call." % (x)
-                                               continue
-                                       
-                                       plugins = plugin.Plugins()
-                                       
-                                       # allow single entry not to be a list
-                                       if type(plugins) is not list:
-                                               plugins = [ plugins ]
-                                       
-                                       for p in plugins:
-                                               p.updateIcon(path)
-                                               self.addPlugin(p);
-                               else:
-                                       open(path + "__init__.py", "a").close()
-                                       self.readPluginList(path, modules + [x], depth - 1)
+               for p in plugins_added:
+                       self.addPlugin(p)
 
        def getPlugins(self, where):
                """Get list of plugins in a specific category"""
 
        def getPlugins(self, where):
                """Get list of plugins in a specific category"""
index 0378ce4cc206b72187f266a912047ba98b3d4d7f..4b5b7e2a8d062bbdede1a78619a5c323787d276a 100644 (file)
@@ -44,3 +44,6 @@ class PluginDescriptor:
                        self.icon = loadPNG(path + self.iconstr)
                else:
                        self.icon = None
                        self.icon = loadPNG(path + self.iconstr)
                else:
                        self.icon = None
+
+       def __eq__(self, other):
+               return self.__call__ == other.__call__
index a21dde8041f5b9dff088bf5e870c7c354f7bfcc9..99c0ac24d261267bbc8952c45d0e556229ae9b24 100644 (file)
@@ -112,7 +112,7 @@ class PluginDownloadBrowser(Screen):
                self.container.execute("ipkg update")
                
        def installFinished(self):
                self.container.execute("ipkg update")
                
        def installFinished(self):
-               plugins.reReadPluginList(resolveFilename(SCOPE_PLUGINS))
+               plugins.readPluginList(resolveFilename(SCOPE_PLUGINS))
                self.close()
                
        def runFinished(self, retval):
                self.close()
                
        def runFinished(self, retval):