From 828a243437d2dafc1432bd7c0cb497ad077010c7 Mon Sep 17 00:00:00 2001 From: Dorin Date: Fri, 2 Feb 2024 16:17:54 +0200 Subject: [PATCH] Fix socket recv timeout: None:blocking, 0:non-blocking, >0:timeout --- adafruit_wiznet5k/adafruit_wiznet5k_socket.py | 21 ++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/adafruit_wiznet5k/adafruit_wiznet5k_socket.py b/adafruit_wiznet5k/adafruit_wiznet5k_socket.py index e0687a0..ef4c052 100644 --- a/adafruit_wiznet5k/adafruit_wiznet5k_socket.py +++ b/adafruit_wiznet5k/adafruit_wiznet5k_socket.py @@ -17,7 +17,7 @@ from __future__ import annotations try: - from typing import TYPE_CHECKING, Optional, Tuple, List, Union + from typing import TYPE_CHECKING, List, Optional, Tuple, Union if TYPE_CHECKING: from adafruit_wiznet5k.adafruit_wiznet5k import WIZNET5K @@ -27,6 +27,7 @@ import gc import time from sys import byteorder + from micropython import const import adafruit_wiznet5k as wiznet5k @@ -79,7 +80,7 @@ def setdefaulttimeout(_timeout: Optional[float]) -> None: :param Optional[float] _timeout: The default timeout in seconds or None. """ global _default_socket_timeout # pylint: disable=global-statement - if _timeout is None or (isinstance(_timeout, (int, float)) and _timeout >= 0): + if _timeout is None or _timeout >= 0: _default_socket_timeout = _timeout else: raise ValueError("Timeout must be None, 0.0 or a positive numeric value.") @@ -496,7 +497,11 @@ def recv( :return bytes: Data from the socket. """ buf = bytearray(bufsize) - self.recv_into(buf, bufsize) + nread = self.recv_into(buf, bufsize) + if nread == 0: + return b"" + if nread < bufsize: + return bytes(buf[:nread]) return bytes(buf) def _embed_recv( @@ -595,7 +600,13 @@ def recv_into(self, buffer: bytearray, nbytes: int = 0, flags: int = 0) -> int: # We got a message, but there are no more bytes to read, so we can stop. break # No bytes yet, or more bytes requested. - if self._timeout > 0 and time.monotonic() - last_read_time > self._timeout: + if self._timeout is None: + # blocking mode + continue + if self._timeout == 0: + # non-blocking mode + break + if time.monotonic() - last_read_time > self._timeout: raise timeout("timed out") return num_read @@ -688,7 +699,7 @@ def settimeout(self, value: Optional[float]) -> None: :param Optional[float] value: Socket read timeout in seconds. """ - if value is None or (isinstance(value, (int, float)) and value >= 0): + if value is None or value >= 0: self._timeout = value else: raise ValueError("Timeout must be None, 0.0 or a positive numeric value.")