2020-07-01 17:46:35 +00:00
|
|
|
# NanoVNASaver
|
|
|
|
#
|
|
|
|
# A python program to view and export Touchstone data from a NanoVNA
|
|
|
|
# Copyright (C) 2019, 2020 Rune B. Broberg
|
2021-06-30 05:21:14 +00:00
|
|
|
# Copyright (C) 2020,2021 NanoVNA-Saver Authors
|
2020-07-01 17:46:35 +00:00
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
2020-07-04 10:08:54 +00:00
|
|
|
import logging
|
|
|
|
from threading import Lock
|
|
|
|
|
2020-07-01 17:46:35 +00:00
|
|
|
import serial
|
|
|
|
|
2020-07-04 10:08:54 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2020-07-12 19:33:19 +00:00
|
|
|
|
2020-07-01 17:46:35 +00:00
|
|
|
def drain_serial(serial_port: serial.Serial):
|
2020-07-07 10:33:32 +00:00
|
|
|
"""drain up to 64k outstanding data in the serial incoming buffer"""
|
2020-07-08 15:30:53 +00:00
|
|
|
# logger.debug("Draining: %s", serial_port)
|
2020-07-12 19:33:19 +00:00
|
|
|
timeout = serial_port.timeout
|
|
|
|
serial_port.timeout = 0.05
|
2020-07-07 10:33:32 +00:00
|
|
|
for _ in range(512):
|
|
|
|
cnt = len(serial_port.read(128))
|
|
|
|
if not cnt:
|
2020-07-12 19:33:19 +00:00
|
|
|
serial_port.timeout = timeout
|
2020-07-07 10:33:32 +00:00
|
|
|
return
|
2020-07-12 19:33:19 +00:00
|
|
|
serial_port.timeout = timeout
|
2020-07-07 10:33:32 +00:00
|
|
|
logger.warning("unable to drain all data")
|
2020-07-04 10:08:54 +00:00
|
|
|
|
2020-07-12 19:33:19 +00:00
|
|
|
|
2020-07-04 10:08:54 +00:00
|
|
|
class Interface(serial.Serial):
|
|
|
|
def __init__(self, interface_type: str, comment, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
assert interface_type in ('serial', 'usb', 'bt', 'network')
|
|
|
|
self.type = interface_type
|
|
|
|
self.comment = comment
|
|
|
|
self.port = None
|
|
|
|
self.baudrate = 115200
|
2020-07-12 19:33:19 +00:00
|
|
|
self.timeout = 0.05
|
2020-07-04 10:08:54 +00:00
|
|
|
self.lock = Lock()
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return f"{self.port} ({self.comment})"
|