3 from Tools.XMLTools import elementsWithTag
5 from keyids import KEYIDS;
7 # these are only informational (for help)...
8 from Tools.KeyBindings import addKeyBinding
12 p = enigma.eActionMapPtr()
13 enigma.eActionMap.getInstance(p)
16 filename1 = "data/keymap.xml"
17 filename2 = "/usr/share/enigma2/keymap.xml"
20 source = open(filename1)
23 source = open(filename2)
25 # raise "couldn't open keymap.xml!"
28 dom = xml.dom.minidom.parse(source)
30 raise "keymap not well-formed."
32 keymap = dom.childNodes[0]
34 maps = elementsWithTag(keymap.childNodes, "map")
37 context = str(cmap.getAttribute("context"))
38 assert context != "", "map must have context"
40 def parseKeys(device, keys):
41 for x in elementsWithTag(keys.childNodes, "key"):
42 mapto = str(x.getAttribute("mapto"))
43 id = x.getAttribute("id")
44 flags = x.getAttribute("flags")
46 flag_ascii_to_id = lambda x: {'m':1,'b':2,'r':4}[x]
49 flags = sum(map(flag_ascii_to_id, flags))
50 # print "-> " + str(flags)
52 # raise str("%s: illegal flags '%s' specificed in context %s, id '%s'" % (filename, flags, context, id))
54 assert mapto != "", "%s: must specify mapto in context %s, id '%s'" % (filename, context, id)
55 assert id != "", "%s: must specify id in context %s, mapto '%s'" % (filename, context, mapto)
56 assert flags != 0, "%s: must specify at least one flag in context %s, id '%s'" % (filename, context, id)
59 keyid = ord(id) | 0x8000
62 keyid = int(id[2:], 0x10) | 0x8000
64 keyid = int(id[2:]) | 0x8000
66 raise "key id '" + str(id) + "' is neither hex nor dec"
71 raise "key id '" + str(id) + "' is illegal"
73 # print context + "::" + mapto + " -> " + device + "." + hex(keyid)
74 p.bindKey(device, keyid, flags, context, mapto)
75 addKeyBinding(keyid, context, mapto)
77 parseKeys("generic", cmap)
79 for device in elementsWithTag(cmap.childNodes, "device"):
80 parseKeys(str(device.getAttribute("name")), device)