X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=keymapparser.py;h=f8aa07f49f4892f352eb7eb6f5c7f363e0ff242a;hb=1a2572289b607810dfc4a91970a4576034c2e58a;hp=23cd5a86a536907c79e46325fbd9d2983e351225;hpb=f7c13b8fcc4373f972387a0e7928658b818392b9;p=vuplus_dvbapp diff --git a/keymapparser.py b/keymapparser.py index 23cd5a8..f8aa07f 100644 --- a/keymapparser.py +++ b/keymapparser.py @@ -1,5 +1,6 @@ import xml.dom.minidom import enigma +from Tools.XMLTools import elementsWithTag from keyids import KEYIDS; @@ -8,8 +9,7 @@ from Tools.KeyBindings import addKeyBinding def readKeymap(): - p = enigma.eActionMapPtr() - enigma.eActionMap.getInstance(p) + p = enigma.eActionMap.getInstance() assert p filename1 = "data/keymap.xml" @@ -28,19 +28,16 @@ def readKeymap(): except: raise "keymap not well-formed." - try: - keymap = dom.getElementsByTagName("keymap")[0] - except: - raise "no keymap defined." + keymap = dom.childNodes[0] - maps = keymap.getElementsByTagName("map") + maps = elementsWithTag(keymap.childNodes, "map") for cmap in maps: context = str(cmap.getAttribute("context")) assert context != "", "map must have context" def parseKeys(device, keys): - for x in keys.getElementsByTagName("key"): + for x in elementsWithTag(keys.childNodes, "key"): mapto = str(x.getAttribute("mapto")) id = x.getAttribute("id") flags = x.getAttribute("flags") @@ -78,6 +75,6 @@ def readKeymap(): parseKeys("generic", cmap) - for device in cmap.getElementsByTagName("device"): + for device in elementsWithTag(cmap.childNodes, "device"): parseKeys(str(device.getAttribute("name")), device)