From 6a4870d7e654f0a22568078ad895f87d4d262e99 Mon Sep 17 00:00:00 2001 From: Askaholic Date: Fri, 24 Nov 2023 21:35:41 +0000 Subject: [PATCH] deploy: b908255012224dacd6689870d4e7e3ea225128c8 --- protocol/index.html | 94 +++++++++++++++++++++-------------- protocol/protocol.html | 35 +++++++++++++ protocol/qdatastream.html | 100 ++++++++++++++++++-------------------- protocol/simple_json.html | 13 ++++- 4 files changed, 149 insertions(+), 93 deletions(-) diff --git a/protocol/index.html b/protocol/index.html index 48421371c..dd4449927 100644 --- a/protocol/index.html +++ b/protocol/index.html @@ -345,6 +345,14 @@

Params

""" pass # pragma: no cover + @staticmethod + @abstractmethod + def decode_message(data: bytes) -> dict: + """ + Decode a message from raw bytes. + """ + pass # pragma: no cover + def is_connected(self) -> bool: """ Return whether or not the connection is still alive @@ -477,6 +485,24 @@

Subclasses

Static methods

+
+def decode_message(data: bytes) ‑> dict +
+
+

Decode a message from raw bytes.

+
+ +Expand source code + +
@staticmethod
+@abstractmethod
+def decode_message(data: bytes) -> dict:
+    """
+    Decode a message from raw bytes.
+    """
+    pass  # pragma: no cover
+
+
def encode_message(message: dict) ‑> bytes
@@ -843,6 +869,27 @@

Errors

return QDataStreamProtocol.pack_message(json_encoder.encode(message)) + @staticmethod + def decode_message(data: bytes) -> dict: + _, action = QDataStreamProtocol.read_qstring(data) + if action in ("PING", "PONG"): + return {"command": action.lower()} + + message = json.loads(action) + try: + for part in QDataStreamProtocol.read_block(data): + try: + message_part = json.loads(part) + if part != action: + message.update(message_part) + except (ValueError, TypeError): + if "legacy" not in message: + message["legacy"] = [] + message["legacy"].append(part) + except (KeyError, ValueError): + pass + return message + async def read_message(self): """ Read a message from the stream @@ -859,24 +906,7 @@

Errors

# Otherwise reraise raise - pos, action = self.read_qstring(block) - if action in ("PING", "PONG"): - return {"command": action.lower()} - - message = json.loads(action) - try: - for part in self.read_block(block): - try: - message_part = json.loads(part) - if part != action: - message.update(message_part) - except (ValueError, TypeError): - if "legacy" not in message: - message["legacy"] = [] - message["legacy"].append(part) - except (KeyError, ValueError): - pass - return message + return QDataStreamProtocol.decode_message(block)

Ancestors

@@ -1071,6 +1084,7 @@

Inherited members

  • Protocol: