aboutsummaryrefslogtreecommitdiffstats
path: root/klippy/serialhdl.py
diff options
context:
space:
mode:
authorKevin O'Connor <kevin@koconnor.net>2018-02-27 14:16:16 -0500
committerKevin O'Connor <kevin@koconnor.net>2018-02-27 21:06:16 -0500
commitb139a8561f54b7a764faa54b117a8544b8451d41 (patch)
tree1d23fd730928f3db60d8d5838b0cded936fbb655 /klippy/serialhdl.py
parent8518da9824ffa4c8b0f41be140eecf3973126d10 (diff)
downloadkutter-b139a8561f54b7a764faa54b117a8544b8451d41.tar.gz
kutter-b139a8561f54b7a764faa54b117a8544b8451d41.tar.xz
kutter-b139a8561f54b7a764faa54b117a8544b8451d41.zip
serialhdl: Add a wrapper around the results of lookup_command()
Add a lookup_command() method to the SerialReader class that provides a wrapper that stores the serial and commandqueue references. This makes it easier to run the send() method. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
Diffstat (limited to 'klippy/serialhdl.py')
-rw-r--r--klippy/serialhdl.py42
1 files changed, 27 insertions, 15 deletions
diff --git a/klippy/serialhdl.py b/klippy/serialhdl.py
index 6040f3ab..75c61346 100644
--- a/klippy/serialhdl.py
+++ b/klippy/serialhdl.py
@@ -126,17 +126,17 @@ class SerialReader:
with self.lock:
del self.handlers[name, oid]
# Command sending
- def send(self, cmd, minclock=0, reqclock=0, cq=None):
+ def raw_send(self, cmd, minclock, reqclock, cmd_queue):
+ self.ffi_lib.serialqueue_send(
+ self.serialqueue, cmd_queue, cmd, len(cmd), minclock, reqclock)
+ def send(self, msg, minclock=0, reqclock=0):
+ cmd = self.msgparser.create_command(msg)
+ self.raw_send(cmd, minclock, reqclock, self.default_cmd_queue)
+ def lookup_command(self, msgformat, cq=None):
if cq is None:
cq = self.default_cmd_queue
- self.ffi_lib.serialqueue_send(
- self.serialqueue, cq, cmd, len(cmd), minclock, reqclock)
- def encode_and_send(self, data, minclock, reqclock, cq):
- self.ffi_lib.serialqueue_encode_and_send(
- self.serialqueue, cq, data, len(data), minclock, reqclock)
- def send_with_response(self, cmd, name, oid=None):
- src = SerialRetryCommand(self, cmd, name, oid)
- return src.get_response()
+ cmd = self.msgparser.lookup_command(msgformat)
+ return SerialCommand(self, cq, cmd)
def alloc_command_queue(self):
return self.ffi_main.gc(self.ffi_lib.serialqueue_alloc_commandqueue(),
self.ffi_lib.serialqueue_free_commandqueue)
@@ -175,6 +175,20 @@ class SerialReader:
def __del__(self):
self.disconnect()
+# Wrapper around command sending
+class SerialCommand:
+ def __init__(self, serial, cmd_queue, cmd):
+ self.serial = serial
+ self.cmd_queue = cmd_queue
+ self.cmd = cmd
+ def send(self, data=(), minclock=0, reqclock=0):
+ cmd = self.cmd.encode(data)
+ self.serial.raw_send(cmd, minclock, reqclock, self.cmd_queue)
+ def send_with_response(self, data=(), response=None, response_oid=None):
+ cmd = self.cmd.encode(data)
+ src = SerialRetryCommand(self.serial, cmd, response, response_oid)
+ return src.get_response()
+
# Class to retry sending of a query command until a given response is received
class SerialRetryCommand:
TIMEOUT_TIME = 5.0
@@ -195,7 +209,7 @@ class SerialRetryCommand:
def send_event(self, eventtime):
if self.response is not None:
return self.serial.reactor.NEVER
- self.serial.send(self.cmd)
+ self.serial.raw_send(self.cmd, 0, 0, self.serial.default_cmd_queue)
return eventtime + self.RETRY_TIME
def handle_callback(self, params):
last_sent_time = params['#sent_time']
@@ -217,7 +231,7 @@ class SerialBootStrap:
def __init__(self, serial):
self.serial = serial
self.identify_data = ""
- self.identify_cmd = self.serial.msgparser.lookup_command(
+ self.identify_cmd = self.serial.lookup_command(
"identify offset=%u count=%c")
self.is_done = False
self.serial.register_callback(self.handle_identify, 'identify_response')
@@ -241,13 +255,11 @@ class SerialBootStrap:
self.is_done = True
return
self.identify_data += msgdata
- imsg = self.identify_cmd.encode(len(self.identify_data), 40)
- self.serial.send(imsg)
+ self.identify_cmd.send([len(self.identify_data), 40])
def send_event(self, eventtime):
if self.is_done:
return self.serial.reactor.NEVER
- imsg = self.identify_cmd.encode(len(self.identify_data), 40)
- self.serial.send(imsg)
+ self.identify_cmd.send([len(self.identify_data), 40])
return eventtime + self.RETRY_TIME
def handle_unknown(self, params):
logging.debug("Unknown message %d (len %d) while identifying",