Check if we're closed before attempting to do a reconnect.

This commit is contained in:
Rapptz
2017-03-21 03:32:09 -04:00
parent a0cdb19c5f
commit 5461bfb475
2 changed files with 5 additions and 1 deletions

View File

@@ -399,6 +399,9 @@ class Client:
yield from self.close() yield from self.close()
raise raise
if self.is_closed():
return
# We should only get this when an unhandled close code happens, # We should only get this when an unhandled close code happens,
# such as a clean disconnect (1000) or a bad state (bad token, no sharding, etc) # such as a clean disconnect (1000) or a bad state (bad token, no sharding, etc)
# sometimes, discord sends us 1000 for unknown reasons so we should reconnect # sometimes, discord sends us 1000 for unknown reasons so we should reconnect

View File

@@ -234,11 +234,12 @@ class AutoShardedClient(Client):
if self.is_closed(): if self.is_closed():
return return
self._closed.set()
for shard in self.shards.values(): for shard in self.shards.values():
yield from shard.ws.close() yield from shard.ws.close()
yield from self.http.close() yield from self.http.close()
self._closed.set()
@asyncio.coroutine @asyncio.coroutine
def change_presence(self, *, game=None, status=None, afk=False, shard_id=None): def change_presence(self, *, game=None, status=None, afk=False, shard_id=None):