diff options
| author | Rapptz <[email protected]> | 2019-05-29 01:22:36 -0400 |
|---|---|---|
| committer | Rapptz <[email protected]> | 2019-05-29 01:22:53 -0400 |
| commit | 00a0856cc44549a29d5123b997db3a5e593f0896 (patch) | |
| tree | 48071f9464b906b2a39470e31a5013791f8c4da9 /discord/gateway.py | |
| parent | Speed-up utils.get for the common cases (diff) | |
| download | discord.py-00a0856cc44549a29d5123b997db3a5e593f0896.tar.xz discord.py-00a0856cc44549a29d5123b997db3a5e593f0896.zip | |
Use a dict instead of getattr for parsing events.
Probably not a significant difference but might as well use it here.
The basic idea is to cache the getattr calls instead of repeatedly
doing it (since they're around 105ns on my machine). The dictionary
lookup is about 41ns on my machine.
The next step in speeding up library code some more should be in
the parser bodies themselves but that's a problem to tackle another
day.
Diffstat (limited to 'discord/gateway.py')
| -rw-r--r-- | discord/gateway.py | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/discord/gateway.py b/discord/gateway.py index bf51377f..aa2c02ee 100644 --- a/discord/gateway.py +++ b/discord/gateway.py @@ -227,6 +227,7 @@ class DiscordWebSocket(websockets.client.WebSocketClientProtocol): # dynamically add attributes needed ws.token = client.http.token ws._connection = client._connection + ws._discord_parsers = client._connection.parsers ws._dispatch = client.dispatch ws.gateway = gateway ws.shard_id = shard_id @@ -414,11 +415,9 @@ class DiscordWebSocket(websockets.client.WebSocketClientProtocol): log.info('Shard ID %s has successfully RESUMED session %s under trace %s.', self.shard_id, self.session_id, ', '.join(trace)) - parser = 'parse_' + event.lower() - try: - func = getattr(self._connection, parser) - except AttributeError: + func = self._discord_parsers[event] + except KeyError: log.warning('Unknown event %s.', event) else: func(data) |