From 8aec30178cf4b1c1b843d4a12ee6e309ee4accb7 Mon Sep 17 00:00:00 2001 From: Mark Jessop Date: Sun, 8 Jan 2023 10:31:20 +1100 Subject: [PATCH] Handle repeated GPSD position packets --- chasemapper/__init__.py | 2 +- chasemapper/gpsd.py | 7 ++++++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/chasemapper/__init__.py b/chasemapper/__init__.py index cd8b09a..ac217c8 100644 --- a/chasemapper/__init__.py +++ b/chasemapper/__init__.py @@ -8,4 +8,4 @@ # Now using Semantic Versioning (https://semver.org/) MAJOR.MINOR.PATCH -__version__ = "1.5.1" +__version__ = "1.5.2" diff --git a/chasemapper/gpsd.py b/chasemapper/gpsd.py index 802915b..2ea4a2b 100644 --- a/chasemapper/gpsd.py +++ b/chasemapper/gpsd.py @@ -366,6 +366,8 @@ def gpsd_process_thread(self): _gpsd_socket.watch(gpsd_protocol="json") logging.info("GPSD - Connected to GPSD instance at %s" % self.hostname) + _old_state = {} + while self.gpsd_thread_running: # We should be getting GPS data every second. # If this isn't the case, we should close the connection and re-connect. @@ -403,7 +405,10 @@ def gpsd_process_thread(self): "valid": True, } - self.send_to_callback(_gps_state) + if _gps_state != _old_state: + self.send_to_callback(_gps_state) + + _old_state = _gps_state # Close the GPSD connection. try: