aboutsummaryrefslogtreecommitdiff
path: root/lib/python
diff options
context:
space:
mode:
Diffstat (limited to 'lib/python')
-rw-r--r--lib/python/Plugins/Extensions/MediaPlayer/plugin.py2
-rw-r--r--lib/python/Plugins/Plugin.py2
-rw-r--r--lib/python/Plugins/SystemPlugins/PositionerSetup/plugin.py2
-rw-r--r--lib/python/Plugins/SystemPlugins/SatelliteEquipmentControl/plugin.py2
-rw-r--r--lib/python/Plugins/SystemPlugins/Satfinder/plugin.py2
-rwxr-xr-xlib/python/Plugins/SystemPlugins/SkinSelector/plugin.py2
-rw-r--r--lib/python/Screens/Menu.py28
7 files changed, 23 insertions, 17 deletions
diff --git a/lib/python/Plugins/Extensions/MediaPlayer/plugin.py b/lib/python/Plugins/Extensions/MediaPlayer/plugin.py
index 7efd33e2..019f2164 100644
--- a/lib/python/Plugins/Extensions/MediaPlayer/plugin.py
+++ b/lib/python/Plugins/Extensions/MediaPlayer/plugin.py
@@ -707,7 +707,7 @@ def main(session, **kwargs):
def menu(menuid, **kwargs):
if menuid == "mainmenu":
- return [(_("Media player"), main, "media_player")]
+ return [(_("Media player"), main, "media_player", None)]
return []
def filescan_open(list, session, **kwargs):
diff --git a/lib/python/Plugins/Plugin.py b/lib/python/Plugins/Plugin.py
index b3886723..b01b9b8f 100644
--- a/lib/python/Plugins/Plugin.py
+++ b/lib/python/Plugins/Plugin.py
@@ -22,7 +22,7 @@ class PluginDescriptor:
WHERE_PLUGINMENU = 2
# argument: session, serviceref (currently selected)
WHERE_MOVIELIST = 3
- # argument: menuid. Fnc must return list with menuitems (3-tuple of name, fnc to call, entryid or None)
+ # argument: menuid. Fnc must return list with menuitems (4-tuple of name, fnc to call, entryid or None, weight or None)
WHERE_MENU = 4
# reason (0: start, 1: end)
diff --git a/lib/python/Plugins/SystemPlugins/PositionerSetup/plugin.py b/lib/python/Plugins/SystemPlugins/PositionerSetup/plugin.py
index 45764810..fccd2625 100644
--- a/lib/python/Plugins/SystemPlugins/PositionerSetup/plugin.py
+++ b/lib/python/Plugins/SystemPlugins/PositionerSetup/plugin.py
@@ -569,7 +569,7 @@ def PositionerMain(session, **kwargs):
def PositionerSetupStart(menuid, **kwargs):
if menuid == "scan":
- return [(_("Positioner setup"), PositionerMain, "positioner_setup")]
+ return [(_("Positioner setup"), PositionerMain, "positioner_setup", None)]
else:
return []
diff --git a/lib/python/Plugins/SystemPlugins/SatelliteEquipmentControl/plugin.py b/lib/python/Plugins/SystemPlugins/SatelliteEquipmentControl/plugin.py
index 17f8fa2e..6cf7c8fe 100644
--- a/lib/python/Plugins/SystemPlugins/SatelliteEquipmentControl/plugin.py
+++ b/lib/python/Plugins/SystemPlugins/SatelliteEquipmentControl/plugin.py
@@ -61,7 +61,7 @@ def SecSetupStart(menuid):
# only show if DVB-S frontends are available
for slot in nimmgr.nim_slots:
if slot.isCompatible("DVB-S"):
- return [(_("Satellite Equipment Setup"), SecSetupMain, "satellite_equipment_setup")]
+ return [(_("Satellite Equipment Setup"), SecSetupMain, "satellite_equipment_setup", None)]
return [ ]
diff --git a/lib/python/Plugins/SystemPlugins/Satfinder/plugin.py b/lib/python/Plugins/SystemPlugins/Satfinder/plugin.py
index fc7855f8..50182a9e 100644
--- a/lib/python/Plugins/SystemPlugins/Satfinder/plugin.py
+++ b/lib/python/Plugins/SystemPlugins/Satfinder/plugin.py
@@ -272,7 +272,7 @@ def SatfinderMain(session, **kwargs):
def SatfinderStart(menuid, **kwargs):
if menuid == "scan":
- return [(_("Satfinder"), SatfinderMain, "satfinder")]
+ return [(_("Satfinder"), SatfinderMain, "satfinder", None)]
else:
return []
diff --git a/lib/python/Plugins/SystemPlugins/SkinSelector/plugin.py b/lib/python/Plugins/SystemPlugins/SkinSelector/plugin.py
index eeebf704..5b29b0d5 100755
--- a/lib/python/Plugins/SystemPlugins/SkinSelector/plugin.py
+++ b/lib/python/Plugins/SystemPlugins/SkinSelector/plugin.py
@@ -131,7 +131,7 @@ def SkinSelMain(session, **kwargs):
def SkinSelSetup(menuid, **kwargs):
if menuid == "system":
- return [("Skin...", SkinSelMain, "skin_selector")]
+ return [("Skin...", SkinSelMain, "skin_selector", None)]
else:
return []
diff --git a/lib/python/Screens/Menu.py b/lib/python/Screens/Menu.py
index 2b8ac05d..bba64040 100644
--- a/lib/python/Screens/Menu.py
+++ b/lib/python/Screens/Menu.py
@@ -35,13 +35,13 @@ class MenuUpdater:
def __init__(self):
self.updatedMenuItems = {}
- def addMenuItem(self, id, pos, text, module, screen):
+ def addMenuItem(self, id, pos, text, module, screen, weight):
if not self.updatedMenuAvailable(id):
self.updatedMenuItems[id] = []
- self.updatedMenuItems[id].append([text, pos, module, screen])
+ self.updatedMenuItems[id].append([text, pos, module, screen, weight])
- def delMenuItem(self, id, pos, text, module, screen):
- self.updatedMenuItems[id].remove([text, pos, module, screen])
+ def delMenuItem(self, id, pos, text, module, screen, weight):
+ self.updatedMenuItems[id].remove([text, pos, module, screen, weight])
def updatedMenuAvailable(self, id):
return self.updatedMenuItems.has_key(id)
@@ -102,13 +102,14 @@ class Menu(Screen):
def addMenu(self, destList, node):
MenuTitle = _(node.getAttribute("text").encode("UTF-8") or "??")
entryID = node.getAttribute("entryID") or "undefined"
+ weight = node.getAttribute("weight") or 50
x = node.getAttribute("flushConfigOnClose")
if x:
a = boundFunction(self.session.openWithCallback, self.menuClosedWithConfigFlush, Menu, node, node.childNodes)
else:
a = boundFunction(self.session.openWithCallback, self.menuClosed, Menu, node, node.childNodes)
#TODO add check if !empty(node.childNodes)
- destList.append((MenuTitle, a, entryID))
+ destList.append((MenuTitle, a, entryID, weight))
def menuClosedWithConfigFlush(self, *res):
configfile.save()
@@ -121,6 +122,7 @@ class Menu(Screen):
def addItem(self, destList, node):
item_text = node.getAttribute("text").encode("UTF-8")
entryID = node.getAttribute("entryID") or "undefined"
+ weight = node.getAttribute("weight") or 50
for x in node.childNodes:
if x.nodeType != xml.dom.minidom.Element.nodeType:
continue
@@ -142,10 +144,10 @@ class Menu(Screen):
args = XMLTools.mergeText(x.childNodes)
screen += ", " + args
- destList.append((_(item_text or "??"), boundFunction(self.runScreen, (module, screen)), entryID))
+ destList.append((_(item_text or "??"), boundFunction(self.runScreen, (module, screen)), entryID, weight))
return
elif x.tagName == 'code':
- destList.append((_(item_text or "??"), boundFunction(self.execText, XMLTools.mergeText(x.childNodes)), entryID))
+ destList.append((_(item_text or "??"), boundFunction(self.execText, XMLTools.mergeText(x.childNodes)), entryID, weight))
return
elif x.tagName == 'setup':
id = x.getAttribute("id")
@@ -153,9 +155,9 @@ class Menu(Screen):
item_text = _(getSetupTitle(id)) + "..."
else:
item_text = _(item_text)
- destList.append((item_text, boundFunction(self.openSetup, id), entryID))
+ destList.append((item_text, boundFunction(self.openSetup, id), entryID, weight))
return
- destList.append((item_text, self.nothing, entryID))
+ destList.append((item_text, self.nothing, entryID, weight))
def __init__(self, session, parent, childNode):
@@ -182,13 +184,14 @@ class Menu(Screen):
if menuupdater.updatedMenuAvailable(menuID):
for x in menuupdater.getUpdatedMenu(menuID):
if x[1] == count:
- list.append((x[0], boundFunction(self.runScreen, (x[2], x[3] + ", "))))
+ list.append((x[0], boundFunction(self.runScreen, (x[2], x[3] + ", ")), x[4]))
count += 1
if menuID is not None:
# plugins
for l in plugins.getPluginsForMenu(menuID):
- list.append((l[0], boundFunction(l[1], self.session), l[2]))
+ list.append((l[0], boundFunction(l[1], self.session), l[2], l[3] or 50))
+
# for the skin: first try a menu_<menuID>, then Menu
self.skinName = [ ]
@@ -196,6 +199,9 @@ class Menu(Screen):
self.skinName.append("menu_" + menuID)
self.skinName.append("Menu")
+ # Sort by Weight
+ list.sort(key=lambda x: int(x[3]))
+
self["menu"] = List(list)
self["actions"] = ActionMap(["OkCancelActions", "MenuActions"],