wacom: move device state debugging to the functions themselves

This commit is contained in:
Peter Hutterer 2019-07-15 10:57:24 +10:00 committed by Benjamin Tissoires
parent aff38c26a3
commit a1e3e8eafb
1 changed files with 19 additions and 17 deletions

View File

@ -739,7 +739,9 @@ class WacomProtocolBase(WacomProtocolLowLevelComm):
def get_battery_info(self): def get_battery_info(self):
data = self.send_nordic_command_sync(command=0xb9, data = self.send_nordic_command_sync(command=0xb9,
expected_opcode=0xba) expected_opcode=0xba)
return int(data[0]), data[1] == 1 battery, charging = int(data[0]), data[1] == 1
logger.info(f'device battery: {battery}% ({"dis" if not charging else ""}charging)')
return battery, charging
def get_firmware_version(self, arg): def get_firmware_version(self, arg):
hi = self.send_nordic_command_sync(command=0xb7, hi = self.send_nordic_command_sync(command=0xb7,
@ -750,12 +752,16 @@ class WacomProtocolBase(WacomProtocolLowLevelComm):
arguments=(1,)) arguments=(1,))
fw_hi = ''.join([hex(d)[2:] for d in hi[1:]]) fw_hi = ''.join([hex(d)[2:] for d in hi[1:]])
fw_lo = ''.join([hex(d)[2:] for d in lo[1:]]) fw_lo = ''.join([hex(d)[2:] for d in lo[1:]])
return f'{fw_hi}-{fw_lo}' fw = f'{fw_hi}-{fw_lo}'
logger.info(f'firmware is {fw}')
return fw
def get_name(self): def get_name(self):
data = self.send_nordic_command_sync(command=0xbb, data = self.send_nordic_command_sync(command=0xbb,
expected_opcode=0xbc) expected_opcode=0xbc)
return bytes(data) name = bytes(data)
logger.info(f'device name is {name}')
return name
def get_dimensions(self): def get_dimensions(self):
args = [3, 0x00] # width args = [3, 0x00] # width
@ -776,6 +782,8 @@ class WacomProtocolBase(WacomProtocolLowLevelComm):
raise WacomCorruptDataException(f'unexpected answer for get_dimensions: {str_data}') raise WacomCorruptDataException(f'unexpected answer for get_dimensions: {str_data}')
height = int.from_bytes(data[2:4], byteorder='little') height = int.from_bytes(data[2:4], byteorder='little')
logger.info(f'dimensions: {width}x{height}')
return width, height return width, height
def ec_command(self): def ec_command(self):
@ -868,7 +876,6 @@ class WacomProtocolBase(WacomProtocolLowLevelComm):
self.e3_command() self.e3_command()
self.set_time() self.set_time()
battery, charging = self.get_battery_info() battery, charging = self.get_battery_info()
logger.debug(f'device battery: {battery}% ({"dis" if not charging else ""}charging)')
self.emit('battery-status', battery, charging) self.emit('battery-status', battery, charging)
if self.read_offline_data() == 0: if self.read_offline_data() == 0:
logger.info('no data to retrieve') logger.info('no data to retrieve')
@ -992,9 +999,7 @@ class WacomProtocolBase(WacomProtocolLowLevelComm):
self.set_time() self.set_time()
self.read_time() self.read_time()
name = self.get_name() name = self.get_name()
logger.info(f'device name is {name}') self.get_firmware_version()
fw = self.get_firmware_version()
logger.info(f'firmware is {fw}')
def live_mode(self, mode, uhid): def live_mode(self, mode, uhid):
try: try:
@ -1092,18 +1097,14 @@ class WacomProtocolSlate(WacomProtocolSpark):
self.read_time() self.read_time()
self.ec_command() self.ec_command()
name = self.get_name() name = self.get_name()
logger.info(f'device name is {name}')
w, h = self.get_dimensions() w, h = self.get_dimensions()
logger.debug(f'dimensions: {w}x{h}')
if self.width != w or self.height != h: if self.width != w or self.height != h:
logger.error(f'incompatible dimensions: {w}x{h}') logger.error(f'incompatible dimensions: {w}x{h}')
self.notify('dimensions') self.notify('dimensions')
fw = self.get_firmware_version() self.get_firmware_version()
logger.info(f'firmware is {fw}')
battery, charging = self.get_battery_info() battery, charging = self.get_battery_info()
logger.debug(f'device battery: {battery}% ({"dis" if not charging else ""}charging)')
self.emit('battery-status', battery, charging) self.emit('battery-status', battery, charging)
def retrieve_data(self): def retrieve_data(self):
@ -1111,16 +1112,13 @@ class WacomProtocolSlate(WacomProtocolSpark):
self.check_connection() self.check_connection()
self.set_time() self.set_time()
battery, charging = self.get_battery_info() battery, charging = self.get_battery_info()
logger.debug(f'device battery: {battery}% ({"dis" if not charging else ""}charging)')
self.emit('battery-status', battery, charging) self.emit('battery-status', battery, charging)
w, h = self.get_dimensions() w, h = self.get_dimensions()
self.width = w self.width = w
self.height = h self.height = h
self.notify('dimensions') self.notify('dimensions')
logger.debug(f'dimensions: {w}x{h}')
fw = self.get_firmware_version() fw = self.get_firmware_version()
logger.debug(f'firmware is {fw}')
self.ec_command() self.ec_command()
if self.read_offline_data() == 0: if self.read_offline_data() == 0:
logger.info('no data to retrieve') logger.info('no data to retrieve')
@ -1194,12 +1192,16 @@ class WacomProtocolIntuosPro(WacomProtocolSlate):
arguments=(1,)) arguments=(1,))
fw_hi = ''.join([chr(d) for d in hi[1:]]) fw_hi = ''.join([chr(d) for d in hi[1:]])
fw_lo = ''.join([chr(d) for d in lo[1:]]) fw_lo = ''.join([chr(d) for d in lo[1:]])
return f'{fw_hi}-{fw_lo}' fw = f'{fw_hi}-{fw_lo}'
logger.info(f'firmware is {fw}')
return fw
def get_name(self): def get_name(self):
data = self.send_nordic_command_sync(command=0xdb, data = self.send_nordic_command_sync(command=0xdb,
expected_opcode=0xbc) expected_opcode=0xbc)
return bytes(data) name = bytes(data)
logger.info(f'device name is {name}')
return name
def set_name(self, name): def set_name(self, name):
args = [ord(c) for c in name] args = [ord(c) for c in name]