wacom: rework the file data prefix handling
We know how it's supposed to look like, so let's hardcode it a bit better. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
This commit is contained in:
parent
116589d28d
commit
6d718f16b5
|
@ -1066,32 +1066,24 @@ class WacomProtocolIntuosPro(WacomProtocolSlate):
|
||||||
def parse_pen_data_prefix(self, data):
|
def parse_pen_data_prefix(self, data):
|
||||||
file_format = b'\x67\x82\x69\x65'
|
file_format = b'\x67\x82\x69\x65'
|
||||||
prefix = data[:4]
|
prefix = data[:4]
|
||||||
offset = len(prefix)
|
|
||||||
if bytes(prefix) != file_format:
|
if bytes(prefix) != file_format:
|
||||||
logger.debug(f'Unsupported file format {prefix} (require {file_format})')
|
logger.debug(f'Unsupported file format {prefix} (require {file_format})')
|
||||||
return False, 0
|
return False, 0
|
||||||
|
|
||||||
# This is the time the button was pressed after drawing, i.e. the
|
# This is the time the button was pressed after drawing, i.e. the
|
||||||
# end of the drawing
|
# end of the drawing
|
||||||
t = self.time_from_bytes(data[offset:])
|
t = self.time_from_bytes(data[4:10])
|
||||||
offset += 6
|
|
||||||
|
|
||||||
# Confirmed it's LE for at least 2 bytes (that was fun...), but
|
# four bytes for the stroke count
|
||||||
# could be 4 or more. Are 0xffff strokes enough for everybody?
|
nstrokes = int.from_bytes(data[10:14], byteorder='little')
|
||||||
nstrokes = int.from_bytes(data[offset:offset + 2], byteorder='little')
|
|
||||||
offset += 2
|
|
||||||
|
|
||||||
timestamp = time.strftime('%Y%m%d-%H%M%S', t)
|
timestamp = time.strftime('%Y%m%d-%H%M%S', t)
|
||||||
logger.debug(f'Drawing timestamp: {timestamp}, {nstrokes} strokes')
|
logger.debug(f'Drawing timestamp: {timestamp}, {nstrokes} strokes')
|
||||||
|
|
||||||
# Can't have enough zeroes. They'll come in handy one day
|
# Two trailing zero bytes we don't care about because we know what a
|
||||||
expected_header = b'\x00\x00\x00\x00'
|
# zero looks like.
|
||||||
data_header = data[offset:offset + len(expected_header)]
|
|
||||||
if bytes(data_header) != expected_header:
|
|
||||||
logger.debug(f'Missing zeroes, got {data_header}')
|
|
||||||
offset += 4
|
|
||||||
|
|
||||||
return True, offset
|
return True, 16
|
||||||
|
|
||||||
|
|
||||||
class WacomDevice(GObject.Object):
|
class WacomDevice(GObject.Object):
|
||||||
|
|
Loading…
Reference in New Issue