|
|
@@ -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) |
|
|
|