fix inverted setting (meaning was inverted too)
[enigma2.git] / lib / python / Components / PluginComponent.py
index 172e33e32e60732ae65495ed9d0e0fe3cb86a622..26eadd10438b0bee0b22832915fb110be5777dad 100644 (file)
@@ -20,15 +20,19 @@ class PluginComponent:
 
                for x in dir:
                        path = resolveFilename(SCOPE_PLUGINS, x) + "/"
-                       #try:
+#                      try:
                        if os.path.exists(path):
                                if fileExists(path + "plugin.py"):
                                        pluginmodule = self.prefix + x + ".plugin"
                                        print "trying to import " + pluginmodule
                                        exec "import " + pluginmodule
                                        plugin = eval(pluginmodule)
-                                       picturepaths = plugin.getPicturePaths()
                                        plugins = plugin.getPlugins()
+                                       try: picturepaths = plugin.getPicturePaths()
+                                       except:
+                                               picturepaths = []
+                                               for p in plugins:
+                                                       picturepaths.append("")
                                        try:
                                                for menuEntry in plugin.getMenuRegistrationList():
                                                        self.menuEntries.append([menuEntry, pluginmodule])
@@ -36,36 +40,37 @@ class PluginComponent:
                                                pass
 
                                        for y in range(len(plugins)):
-                                               list.append((path + picturepaths[y], plugins[y][0] , x, plugins[y][1], plugins[y][2]))
+                                               if len(plugins[y]) < 5:
+                                                       list.append((path + picturepaths[y], plugins[y][0] , x, plugins[y][2], plugins[y][3], None, plugins[y][1]))
+                                               else:
+                                                       list.append((path + picturepaths[y], plugins[y][0] , x, plugins[y][2], plugins[y][3], plugins[y][4], plugins[y][1]))
                                        if runAutostartPlugins:
                                                try: plugin.autostart()
                                                except: pass
                                        if runAutoendPlugins:
                                                try: plugin.autoend()
                                                except: pass
-                                                       
-                       #except:
-                       #       print "Directory", path, "contains a faulty plugin"
+#                      except:
+#                              print "Directory", path, "contains a faulty plugin"
                self.menuUpdate()
                return list
        
        def menuDelete(self):
                for menuEntry in self.menuEntries:
-                       menuupdater.delMenuItem(menuEntry[0][0], menuEntry[0][2], menuEntry[1], menuEntry[0][3])
+                       menuupdater.delMenuItem(menuEntry[0][0], menuEntry[0][1], menuEntry[0][2], menuEntry[1], menuEntry[0][3])
 
        def menuUpdate(self):
                for menuEntry in self.menuEntries:
-                       menuupdater.addMenuItem(menuEntry[0][0], menuEntry[0][2], menuEntry[1], menuEntry[0][3])
+                       menuupdater.addMenuItem(menuEntry[0][0], menuEntry[0][1], menuEntry[0][2], menuEntry[1], menuEntry[0][3])
        
        def runPlugin(self, plugin, session):
-               #try:
+               try:
                        exec("import " + self.prefix + plugin[2] + ".plugin")
-                       print self.prefix + plugin[2] + ".plugin." + plugin[4]
                        if plugin[3] == "screen":
-                               session.open(eval(self.prefix + plugin[2] + ".plugin." + plugin[4]))
+                               session.open(eval(self.prefix + plugin[2] + ".plugin." + plugin[4]), plugin[5])
                        elif plugin[3] == "function":
-                               eval(self.prefix + plugin[2] + ".plugin." + plugin[4])(session)
-               #except:
-                       #print "exec of plugin failed!"
+                               eval(self.prefix + plugin[2] + ".plugin." + plugin[4])(session, plugin[5])
+               except:
+                       print "exec of plugin failed!"
 
 plugins = PluginComponent()