Buckets:
ktongue/docker_container / .vscode-server /extensions /ms-python.python-2026.4.0 /python_files /testing_tools /socket_manager.py
| # Copyright (c) Microsoft Corporation. All rights reserved. | |
| # Licensed under the MIT License. | |
| import contextlib | |
| import socket | |
| import sys | |
| # set the socket before it gets blocked or overwritten by a user tests | |
| _SOCKET = socket.socket | |
| class PipeManager: | |
| def __init__(self, name): | |
| self.name = name | |
| def __enter__(self): | |
| return self.connect() | |
| def __exit__(self, *_): | |
| self.close() | |
| def connect(self): | |
| self._writer = open(self.name, "w", encoding="utf-8") # noqa: SIM115, PTH123 | |
| # reader created in read method | |
| return self | |
| def close(self): | |
| self._writer.close() | |
| if hasattr(self, "_reader"): | |
| self._reader.close() | |
| def write(self, data: str): | |
| try: | |
| # for windows, is should only use \n\n | |
| request = f"""content-length: {len(data)}\ncontent-type: application/json\n\n{data}""" | |
| self._writer.write(request) | |
| self._writer.flush() | |
| except Exception as e: | |
| print("error attempting to write to pipe", e) | |
| raise (e) | |
| def read(self, bufsize=1024) -> str: | |
| """Read data from the socket. | |
| Args: | |
| bufsize (int): Number of bytes to read from the socket. | |
| Returns: | |
| data (str): Data received from the socket. | |
| """ | |
| # returns a string automatically from read | |
| if not hasattr(self, "_reader"): | |
| self._reader = open(self.name, encoding="utf-8") # noqa: SIM115, PTH123 | |
| return self._reader.read(bufsize) | |
| class SocketManager: | |
| """Create a socket and connect to the given address. | |
| The address is a (host: str, port: int) tuple. | |
| Example usage: | |
| ``` | |
| with SocketManager(("localhost", 6767)) as sock: | |
| request = json.dumps(payload) | |
| result = s.socket.sendall(request.encode("utf-8")) | |
| ``` | |
| """ | |
| def __init__(self, addr): | |
| self.addr = addr | |
| self.socket = None | |
| def __enter__(self): | |
| return self.connect() | |
| def __exit__(self, *_): | |
| self.close() | |
| def connect(self): | |
| self.socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM, socket.IPPROTO_TCP) | |
| if sys.platform == "win32": | |
| addr_use = socket.SO_EXCLUSIVEADDRUSE | |
| else: | |
| addr_use = socket.SO_REUSEADDR | |
| self.socket.setsockopt(socket.SOL_SOCKET, addr_use, 1) | |
| self.socket.connect(self.addr) | |
| return self | |
| def close(self): | |
| if self.socket: | |
| with contextlib.suppress(Exception): | |
| self.socket.shutdown(socket.SHUT_RDWR) | |
| self.socket.close() | |
Xet Storage Details
- Size:
- 2.63 kB
- Xet hash:
- 551b6c65ebf8d696d240de935859da503e16ce1c6773488dc0ba0003027a7715
·
Xet efficiently stores files, intelligently splitting them into unique chunks and accelerating uploads and downloads. More info.