From f88d2e71b8aada6bbe98de292699a28be006e100 Mon Sep 17 00:00:00 2001 From: Luke <111022789+ldantek@users.noreply.github.com> Date: Thu, 19 Dec 2024 14:55:56 -0800 Subject: [PATCH] fix: allow empty returns from tsp_device.get_buffers() (#362) * fix: allow empty returns from tsp_device.get_buffers() --- CHANGELOG.md | 1 + src/tm_devices/driver_mixins/device_control/tsp_control.py | 4 +++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c656478e..09579dd0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -57,6 +57,7 @@ However, please read through all changes to be aware of what may potentially imp - A configuration function provides the ability to set different logging levels for stdout and file logging. - The config file and environment variable can also be used to control the logging functionality. - The debug logging from the `pyvisa` package is also included in the log file by default. +- Updated `get_buffers()` in `TSPControl` to not error out if query returns with empty string. ### Removed diff --git a/src/tm_devices/driver_mixins/device_control/tsp_control.py b/src/tm_devices/driver_mixins/device_control/tsp_control.py index 26ff0caa..d9f69a9a 100644 --- a/src/tm_devices/driver_mixins/device_control/tsp_control.py +++ b/src/tm_devices/driver_mixins/device_control/tsp_control.py @@ -116,7 +116,9 @@ def get_buffers(self, *args: str) -> Dict[str, List[float]]: if buffer_name.endswith(attr_name): buffer_size_name = buffer_name.rstrip(attr_name) break - buffer_str = self.query(f"printbuffer(1, {buffer_size_name}.n, {buffer_name})") + buffer_str = self.query( + f"printbuffer(1, {buffer_size_name}.n, {buffer_name})", allow_empty=True + ) buffer_data[buffer_name] = [float(x) for x in buffer_str.split(", ") if buffer_str] return buffer_data