PEP8: Fix whitespace
[openblackhole/openblackhole-enigma2.git] / keymapparser.py
1 import enigma
2 import xml.etree.cElementTree
3
4 from keyids import KEYIDS
5
6 # these are only informational (for help)...
7 from Tools.KeyBindings import addKeyBinding
8
9 class KeymapError(Exception):
10     def __init__(self, message):
11         self.msg = message
12
13     def __str__(self):
14         return self.msg
15
16 def getKeyId(id):
17         if len(id) == 1:
18                 keyid = ord(id) | 0x8000
19         elif id[0] == '\\':
20                 if id[1] == 'x':
21                         keyid = int(id[2:], 0x10) | 0x8000
22                 elif id[1] == 'd':
23                         keyid = int(id[2:]) | 0x8000
24                 else:
25                         raise KeymapError("[keymapparser] key id '" + str(id) + "' is neither hex nor dec")
26         else:
27                 try:
28                         keyid = KEYIDS[id]
29                 except:
30                         raise KeymapError("[keymapparser] key id '" + str(id) + "' is illegal")
31
32         return keyid
33
34
35 def parseKeys(context, filename, actionmap, device, keys):
36         for x in keys.findall("key"):
37                 get_attr = x.attrib.get
38                 mapto = get_attr("mapto")
39                 id = get_attr("id")
40                 flags = get_attr("flags")
41
42                 flag_ascii_to_id = lambda x: {'m':1,'b':2,'r':4,'l':8}[x]
43
44                 flags = sum(map(flag_ascii_to_id, flags))
45
46                 assert mapto, "[keymapparser] %s: must specify mapto in context %s, id '%s'" % (filename, context, id)
47                 assert id, "[keymapparser] %s: must specify id in context %s, mapto '%s'" % (filename, context, mapto)
48                 assert flags, "[keymapparser] %s: must specify at least one flag in context %s, id '%s'" % (filename, context, id)
49
50                 keyid = getKeyId(id)
51 #                               print "[keymapparser] " + context + "::" + mapto + " -> " + device + "." + hex(keyid)
52                 actionmap.bindKey(filename, device, keyid, flags, context, mapto)
53                 addKeyBinding(filename, keyid, context, mapto, flags)
54
55
56 def parseTrans(filename, actionmap, device, keys):
57         for x in keys.findall("toggle"):
58                 get_attr = x.attrib.get
59                 toggle_key = get_attr("from")
60                 toggle_key = getKeyId(toggle_key)
61                 actionmap.bindToggle(filename, device, toggle_key)
62
63         for x in keys.findall("key"):
64                 get_attr = x.attrib.get
65                 keyin = get_attr("from")
66                 keyout = get_attr("to")
67                 toggle = get_attr("toggle") or "0"
68                 assert keyin, "[keymapparser] %s: must specify key to translate from '%s'" % (filename, keyin)
69                 assert keyout, "[keymapparser] %s: must specify key to translate to '%s'" % (filename, keyout)
70
71                 keyin  = getKeyId(keyin)
72                 keyout = getKeyId(keyout)
73                 toggle = int(toggle)
74                 actionmap.bindTranslation(filename, device, keyin, keyout, toggle)
75
76
77 def readKeymap(filename):
78         p = enigma.eActionMap.getInstance()
79         assert p
80
81         try:
82                 source = open(filename)
83         except:
84                 print "[keymapparser] keymap file " + filename + " not found"
85                 return
86
87         try:
88                 dom = xml.etree.cElementTree.parse(source)
89         except:
90                 raise KeymapError("[keymapparser] keymap %s not well-formed." % filename)
91
92         keymap = dom.getroot()
93
94         for cmap in keymap.findall("map"):
95                 context = cmap.attrib.get("context")
96                 assert context, "[keymapparser] map must have context"
97
98                 parseKeys(context, filename, p, "generic", cmap)
99
100                 for device in cmap.findall("device"):
101                         parseKeys(context, filename, p, device.attrib.get("name"), device)
102
103         for ctrans in keymap.findall("translate"):
104                 for device in ctrans.findall("device"):
105                         parseTrans(filename, p, device.attrib.get("name"), device)
106
107 def removeKeymap(filename):
108         p = enigma.eActionMap.getInstance()
109         p.unbindKeyDomain(filename)