Improved GetMessages with cache enabled
This commit is contained in:
@@ -11,25 +11,42 @@ namespace Discord.WebSocket
|
||||
public static IAsyncEnumerable<IReadOnlyCollection<IMessage>> GetMessagesAsync(SocketChannel channel, DiscordSocketClient discord, MessageCache messages,
|
||||
ulong? fromMessageId, Direction dir, int limit, CacheMode mode, RequestOptions options)
|
||||
{
|
||||
IReadOnlyCollection<SocketMessage> cachedMessages;
|
||||
IAsyncEnumerable<IReadOnlyCollection<IMessage>> result;
|
||||
if (dir == Direction.Around)
|
||||
throw new NotImplementedException(); //TODO: Impl
|
||||
|
||||
if (messages != null) //Cache enabled
|
||||
cachedMessages = messages.GetMany(fromMessageId, dir, limit);
|
||||
else
|
||||
cachedMessages = ImmutableArray.Create<SocketMessage>();
|
||||
|
||||
result = ImmutableArray.Create(cachedMessages).ToAsyncEnumerable<IReadOnlyCollection<IMessage>>();
|
||||
limit -= cachedMessages.Count;
|
||||
if (mode == CacheMode.CacheOnly || limit <= 0)
|
||||
return result;
|
||||
IReadOnlyCollection<SocketMessage> cachedMessages = null;
|
||||
IAsyncEnumerable<IReadOnlyCollection<IMessage>> result = null;
|
||||
|
||||
if (dir == Direction.After && fromMessageId == null)
|
||||
return AsyncEnumerable.Empty<IReadOnlyCollection<IMessage>>();
|
||||
|
||||
if (dir == Direction.Before || mode == CacheMode.CacheOnly)
|
||||
{
|
||||
if (messages != null) //Cache enabled
|
||||
cachedMessages = messages.GetMany(fromMessageId, dir, limit);
|
||||
else
|
||||
cachedMessages = ImmutableArray.Create<SocketMessage>();
|
||||
result = ImmutableArray.Create(cachedMessages).ToAsyncEnumerable<IReadOnlyCollection<IMessage>>();
|
||||
}
|
||||
|
||||
if (dir == Direction.Before)
|
||||
fromMessageId = cachedMessages.Min(x => x.Id);
|
||||
{
|
||||
limit -= cachedMessages.Count;
|
||||
if (mode == CacheMode.CacheOnly || limit <= 0)
|
||||
return result;
|
||||
|
||||
//Download remaining messages
|
||||
var downloadedMessages = ChannelHelper.GetMessagesAsync(channel, discord, cachedMessages.Min(x => x.Id), dir, limit, options);
|
||||
return result.Concat(downloadedMessages);
|
||||
}
|
||||
else
|
||||
fromMessageId = cachedMessages.Max(x => x.Id);
|
||||
var downloadedMessages = ChannelHelper.GetMessagesAsync(channel, discord, fromMessageId, dir, limit, options);
|
||||
return result.Concat(downloadedMessages);
|
||||
{
|
||||
if (mode == CacheMode.CacheOnly)
|
||||
return result;
|
||||
|
||||
//Dont use cache in this case
|
||||
return ChannelHelper.GetMessagesAsync(channel, discord, fromMessageId, dir, limit, options);
|
||||
}
|
||||
}
|
||||
public static IReadOnlyCollection<SocketMessage> GetCachedMessages(SocketChannel channel, DiscordSocketClient discord, MessageCache messages,
|
||||
ulong? fromMessageId, Direction dir, int limit)
|
||||
|
||||
Reference in New Issue
Block a user