| @@ -748,8 +748,10 @@ class Messageable(metaclass=abc.ABCMeta): | |||||||
|  |  | ||||||
|         Parameters |         Parameters | ||||||
|         ----------- |         ----------- | ||||||
|         limit: int |         limit: Optional[int] | ||||||
|             The number of messages to retrieve. |             The number of messages to retrieve. | ||||||
|  |             If ``None``, retrieves every message in the channel. Note, however, | ||||||
|  |             that this would make it a slow operation. | ||||||
|         before: :class:`Message` or `datetime` |         before: :class:`Message` or `datetime` | ||||||
|             Retrieve messages before this date or message. |             Retrieve messages before this date or message. | ||||||
|             If a date is provided it must be a timezone-naive datetime representing UTC time. |             If a date is provided it must be a timezone-naive datetime representing UTC time. | ||||||
|   | |||||||
| @@ -242,8 +242,10 @@ class HistoryIterator(_AsyncIterator): | |||||||
|         self.messages = asyncio.Queue(loop=self.state.loop) |         self.messages = asyncio.Queue(loop=self.state.loop) | ||||||
|  |  | ||||||
|         if self.around: |         if self.around: | ||||||
|  |             if self.limit is None: | ||||||
|  |                 raise ValueError('history does not support around with limit=None') | ||||||
|             if self.limit > 101: |             if self.limit > 101: | ||||||
|                 raise ValueError("LogsFrom max limit 101 when specifying around parameter") |                 raise ValueError("history max limit 101 when specifying around parameter") | ||||||
|             elif self.limit == 101: |             elif self.limit == 101: | ||||||
|                 self.limit = 100  # Thanks discord |                 self.limit = 100  # Thanks discord | ||||||
|             elif self.limit == 1: |             elif self.limit == 1: | ||||||
| @@ -278,6 +280,18 @@ class HistoryIterator(_AsyncIterator): | |||||||
|         except asyncio.QueueEmpty: |         except asyncio.QueueEmpty: | ||||||
|             raise NoMoreItems() |             raise NoMoreItems() | ||||||
|  |  | ||||||
|  |     def _get_retrieve(self): | ||||||
|  |         l = self.limit | ||||||
|  |         if l is None: | ||||||
|  |             r = 100 | ||||||
|  |         elif l <= 100: | ||||||
|  |             r = l | ||||||
|  |         else: | ||||||
|  |             r = 100 | ||||||
|  |  | ||||||
|  |         self.retrieve = r | ||||||
|  |         return r > 0 | ||||||
|  |  | ||||||
|     @asyncio.coroutine |     @asyncio.coroutine | ||||||
|     def flatten(self): |     def flatten(self): | ||||||
|         # this is similar to fill_messages except it uses a list instead |         # this is similar to fill_messages except it uses a list instead | ||||||
| @@ -285,9 +299,11 @@ class HistoryIterator(_AsyncIterator): | |||||||
|         result = [] |         result = [] | ||||||
|         channel = yield from self.messageable._get_channel() |         channel = yield from self.messageable._get_channel() | ||||||
|         self.channel = channel |         self.channel = channel | ||||||
|         while self.limit > 0: |         while self._get_retrieve(): | ||||||
|             retrieve = self.limit if self.limit <= 100 else 100 |             data = yield from self._retrieve_messages(self.retrieve) | ||||||
|             data = yield from self._retrieve_messages(retrieve) |             if self.limit is None and len(data) < 100: | ||||||
|  |                 self.limit = 0 # terminate the infinite loop | ||||||
|  |  | ||||||
|             if self.reverse: |             if self.reverse: | ||||||
|                 data = reversed(data) |                 data = reversed(data) | ||||||
|             if self._filter: |             if self._filter: | ||||||
| @@ -304,9 +320,11 @@ class HistoryIterator(_AsyncIterator): | |||||||
|             channel = yield from self.messageable._get_channel() |             channel = yield from self.messageable._get_channel() | ||||||
|             self.channel = channel |             self.channel = channel | ||||||
|  |  | ||||||
|         if self.limit > 0: |         if self._get_retrieve(): | ||||||
|             retrieve = self.limit if self.limit <= 100 else 100 |             data = yield from self._retrieve_messages(self.retrieve) | ||||||
|             data = yield from self._retrieve_messages(retrieve) |             if self.limit is None and len(data) < 100: | ||||||
|  |                 self.limit = 0 # terminate the infinite loop | ||||||
|  |  | ||||||
|             if self.reverse: |             if self.reverse: | ||||||
|                 data = reversed(data) |                 data = reversed(data) | ||||||
|             if self._filter: |             if self._filter: | ||||||
| @@ -327,7 +345,8 @@ class HistoryIterator(_AsyncIterator): | |||||||
|         before = self.before.id if self.before else None |         before = self.before.id if self.before else None | ||||||
|         data = yield from self.logs_from(self.channel.id, retrieve, before=before) |         data = yield from self.logs_from(self.channel.id, retrieve, before=before) | ||||||
|         if len(data): |         if len(data): | ||||||
|             self.limit -= retrieve |             if self.limit is not None: | ||||||
|  |                 self.limit -= retrieve | ||||||
|             self.before = Object(id=int(data[-1]['id'])) |             self.before = Object(id=int(data[-1]['id'])) | ||||||
|         return data |         return data | ||||||
|  |  | ||||||
| @@ -337,7 +356,8 @@ class HistoryIterator(_AsyncIterator): | |||||||
|         after = self.after.id if self.after else None |         after = self.after.id if self.after else None | ||||||
|         data = yield from self.logs_from(self.channel.id, retrieve, after=after) |         data = yield from self.logs_from(self.channel.id, retrieve, after=after) | ||||||
|         if len(data): |         if len(data): | ||||||
|             self.limit -= retrieve |             if self.limit is not None: | ||||||
|  |                 self.limit -= retrieve | ||||||
|             self.after = Object(id=int(data[0]['id'])) |             self.after = Object(id=int(data[0]['id'])) | ||||||
|         return data |         return data | ||||||
|  |  | ||||||
| @@ -345,7 +365,7 @@ class HistoryIterator(_AsyncIterator): | |||||||
|     def _retrieve_messages_around_strategy(self, retrieve): |     def _retrieve_messages_around_strategy(self, retrieve): | ||||||
|         """Retrieve messages using around parameter.""" |         """Retrieve messages using around parameter.""" | ||||||
|         if self.around: |         if self.around: | ||||||
|             after = self.after.id if self.after else None |             around = self.around.id if self.around else None | ||||||
|             data = yield from self.logs_from(self.channel.id, retrieve, around=around) |             data = yield from self.logs_from(self.channel.id, retrieve, around=around) | ||||||
|             self.around = None |             self.around = None | ||||||
|             return data |             return data | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user