2023-02-18 21:25:51 +00:00
|
|
|
from pyhon.parameter import HonParameterFixed, HonParameterEnum, HonParameterRange, HonParameterProgram
|
2023-02-13 00:41:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
class HonCommand:
|
2023-03-11 00:10:27 +00:00
|
|
|
def __init__(self, name, attributes, connector, device, multi=None, program=""):
|
2023-02-13 00:41:38 +00:00
|
|
|
self._connector = connector
|
|
|
|
self._device = device
|
|
|
|
self._name = name
|
2023-02-18 21:25:51 +00:00
|
|
|
self._multi = multi or {}
|
2023-03-11 00:10:27 +00:00
|
|
|
self._program = program
|
2023-02-13 00:41:38 +00:00
|
|
|
self._description = attributes.get("description", "")
|
|
|
|
self._parameters = self._create_parameters(attributes.get("parameters", {}))
|
|
|
|
self._ancillary_parameters = self._create_parameters(attributes.get("ancillaryParameters", {}))
|
2023-02-18 21:25:51 +00:00
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
return f"{self._name} command"
|
2023-02-13 00:41:38 +00:00
|
|
|
|
|
|
|
def _create_parameters(self, parameters):
|
|
|
|
result = {}
|
|
|
|
for parameter, attributes in parameters.items():
|
|
|
|
match attributes.get("typology"):
|
|
|
|
case "range":
|
|
|
|
result[parameter] = HonParameterRange(parameter, attributes)
|
|
|
|
case "enum":
|
|
|
|
result[parameter] = HonParameterEnum(parameter, attributes)
|
|
|
|
case "fixed":
|
|
|
|
result[parameter] = HonParameterFixed(parameter, attributes)
|
2023-02-18 21:25:51 +00:00
|
|
|
if self._multi:
|
2023-02-19 02:30:48 +00:00
|
|
|
result["program"] = HonParameterProgram("program", self)
|
2023-02-13 00:41:38 +00:00
|
|
|
return result
|
|
|
|
|
|
|
|
@property
|
|
|
|
def parameters(self):
|
2023-03-06 18:45:46 +00:00
|
|
|
return self._parameters
|
2023-02-13 00:41:38 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def ancillary_parameters(self):
|
|
|
|
return {key: parameter.value for key, parameter in self._ancillary_parameters.items()}
|
|
|
|
|
|
|
|
async def send(self):
|
2023-03-08 22:01:40 +00:00
|
|
|
parameters = {name: parameter.value for name, parameter in self._parameters.items()}
|
2023-03-06 18:45:46 +00:00
|
|
|
return await self._connector.send_command(self._device, self._name, parameters, self.ancillary_parameters)
|
2023-02-13 00:41:38 +00:00
|
|
|
|
2023-02-19 02:30:48 +00:00
|
|
|
def get_programs(self):
|
2023-02-13 00:41:38 +00:00
|
|
|
return self._multi
|
|
|
|
|
2023-02-19 02:30:48 +00:00
|
|
|
def set_program(self, program):
|
2023-02-13 00:41:38 +00:00
|
|
|
self._device.commands[self._name] = self._multi[program]
|
2023-02-18 21:25:51 +00:00
|
|
|
|
|
|
|
def _get_settings_keys(self, command=None):
|
|
|
|
command = command or self
|
|
|
|
keys = []
|
|
|
|
for key, parameter in command._parameters.items():
|
|
|
|
if isinstance(parameter, HonParameterFixed):
|
|
|
|
continue
|
|
|
|
if key not in keys:
|
|
|
|
keys.append(key)
|
|
|
|
return keys
|
|
|
|
|
|
|
|
@property
|
|
|
|
def setting_keys(self):
|
|
|
|
if not self._multi:
|
|
|
|
return self._get_settings_keys()
|
|
|
|
result = [key for cmd in self._multi.values() for key in self._get_settings_keys(cmd)]
|
|
|
|
return list(set(result + ["program"]))
|
|
|
|
|
|
|
|
@property
|
|
|
|
def settings(self):
|
2023-03-04 21:19:48 +00:00
|
|
|
"""Parameters with typology enum and range"""
|
2023-02-18 21:25:51 +00:00
|
|
|
return {s: self._parameters[s] for s in self.setting_keys}
|
|
|
|
|