Browse Source

Normalize thread names

Every thread now has a name and either a contextually relevant
identifier or their in hex to disambiguate multiple threads of the same
type.  Also finally gets rid of that old python 2 style init call.
pull/9553/head
Imayhaveborkedit 2 years ago
committed by GitHub
parent
commit
7bdfd454be
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 8
      discord/gateway.py
  2. 7
      discord/player.py

8
discord/gateway.py

@ -132,11 +132,12 @@ class KeepAliveHandler(threading.Thread):
shard_id: Optional[int] = None, shard_id: Optional[int] = None,
**kwargs: Any, **kwargs: Any,
) -> None: ) -> None:
super().__init__(*args, **kwargs) daemon: bool = kwargs.pop('daemon', True)
name: str = kwargs.pop('name', f'keep-alive-handler:shard-{shard_id}')
super().__init__(*args, daemon=daemon, name=name, **kwargs)
self.ws: DiscordWebSocket = ws self.ws: DiscordWebSocket = ws
self._main_thread_id: int = ws.thread_id self._main_thread_id: int = ws.thread_id
self.interval: Optional[float] = interval self.interval: Optional[float] = interval
self.daemon: bool = True
self.shard_id: Optional[int] = shard_id self.shard_id: Optional[int] = shard_id
self.msg: str = 'Keeping shard ID %s websocket alive with sequence %s.' self.msg: str = 'Keeping shard ID %s websocket alive with sequence %s.'
self.block_msg: str = 'Shard ID %s heartbeat blocked for more than %s seconds.' self.block_msg: str = 'Shard ID %s heartbeat blocked for more than %s seconds.'
@ -212,7 +213,8 @@ class KeepAliveHandler(threading.Thread):
class VoiceKeepAliveHandler(KeepAliveHandler): class VoiceKeepAliveHandler(KeepAliveHandler):
def __init__(self, *args: Any, **kwargs: Any) -> None: def __init__(self, *args: Any, **kwargs: Any) -> None:
super().__init__(*args, **kwargs) name: str = kwargs.pop('name', f'voice-keep-alive-handler:{id(self):#x}')
super().__init__(*args, name=name, **kwargs)
self.recent_ack_latencies: Deque[float] = deque(maxlen=20) self.recent_ack_latencies: Deque[float] = deque(maxlen=20)
self.msg: str = 'Keeping shard ID %s voice websocket alive with timestamp %s.' self.msg: str = 'Keeping shard ID %s voice websocket alive with timestamp %s.'
self.block_msg: str = 'Shard ID %s voice heartbeat blocked for more than %s seconds' self.block_msg: str = 'Shard ID %s voice heartbeat blocked for more than %s seconds'

7
discord/player.py

@ -187,13 +187,13 @@ class FFmpegAudio(AudioSource):
self._pipe_reader_thread: Optional[threading.Thread] = None self._pipe_reader_thread: Optional[threading.Thread] = None
if piping_stdin: if piping_stdin:
n = f'popen-stdin-writer:{id(self):#x}' n = f'popen-stdin-writer:pid-{self._process.pid}'
self._stdin = self._process.stdin self._stdin = self._process.stdin
self._pipe_writer_thread = threading.Thread(target=self._pipe_writer, args=(source,), daemon=True, name=n) self._pipe_writer_thread = threading.Thread(target=self._pipe_writer, args=(source,), daemon=True, name=n)
self._pipe_writer_thread.start() self._pipe_writer_thread.start()
if piping_stderr: if piping_stderr:
n = f'popen-stderr-reader:{id(self):#x}' n = f'popen-stderr-reader:pid-{self._process.pid}'
self._stderr = self._process.stderr self._stderr = self._process.stderr
self._pipe_reader_thread = threading.Thread(target=self._pipe_reader, args=(stderr,), daemon=True, name=n) self._pipe_reader_thread = threading.Thread(target=self._pipe_reader, args=(stderr,), daemon=True, name=n)
self._pipe_reader_thread.start() self._pipe_reader_thread.start()
@ -693,8 +693,7 @@ class AudioPlayer(threading.Thread):
*, *,
after: Optional[Callable[[Optional[Exception]], Any]] = None, after: Optional[Callable[[Optional[Exception]], Any]] = None,
) -> None: ) -> None:
threading.Thread.__init__(self) super().__init__(daemon=True, name=f'audio-player:{id(self):#x}')
self.daemon: bool = True
self.source: AudioSource = source self.source: AudioSource = source
self.client: VoiceClient = client self.client: VoiceClient = client
self.after: Optional[Callable[[Optional[Exception]], Any]] = after self.after: Optional[Callable[[Optional[Exception]], Any]] = after

Loading…
Cancel
Save