From cfc2e47b4f25bde3ed21365b6507f023b7b39977 Mon Sep 17 00:00:00 2001 From: slice Date: Fri, 15 Feb 2019 23:19:45 -0800 Subject: [PATCH] Manually calculate millisceond epoch rather than bitshifting Implementation by Danny. --- discord/message.py | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/discord/message.py b/discord/message.py index 74b096243..2a41c2fab 100644 --- a/discord/message.py +++ b/discord/message.py @@ -25,6 +25,7 @@ DEALINGS IN THE SOFTWARE. """ import asyncio +import datetime import re from . import utils @@ -514,10 +515,11 @@ class Message: "Roses are red, violets are blue, {0} joined this server with you", ] - # we can't use snowflake_time here because we need the millisecond - # precision from snowflakes in order to calculate the correct format - index = ((self.id >> 22) + utils.DISCORD_EPOCH) % len(formats) - return formats[index].format(self.author.name) + # manually reconstruct the epoch with millisecond precision, because + # datetime.datetime.timestamp() doesn't return the exact posix + # timestamp with the precision that we need + created_at_ms = int((self.created_at - datetime.datetime(1970, 1, 1)).total_seconds() * 1000) + return formats[created_at_ms % len(formats)].format(self.author.name) if self.type is MessageType.call: # we're at the call message type now, which is a bit more complicated.