diff options
| author | 2023-07-08 15:01:10 +0100 | |
|---|---|---|
| committer | 2023-07-08 15:01:10 +0100 | |
| commit | 17303dffe1107d361138f8995702cff6ecc1e12d (patch) | |
| tree | 6dd83a6f6a6c5bf8fc6423302ff1907014f4e0b2 /bot/utils | |
| parent | Fix: stop using deprecated PIL .getsize method (diff) | |
Fix and simplify 'disambiguate' utility
Diffstat (limited to 'bot/utils')
| -rw-r--r-- | bot/utils/__init__.py | 51 | 
1 files changed, 15 insertions, 36 deletions
| diff --git a/bot/utils/__init__.py b/bot/utils/__init__.py index ddc2d111..f1ae0e75 100644 --- a/bot/utils/__init__.py +++ b/bot/utils/__init__.py @@ -7,6 +7,7 @@ from datetime import UTC, datetime  import discord  from discord.ext.commands import BadArgument, Context +from pydis_core.utils.scheduling import create_task  from bot.constants import Client, Month  from bot.utils.pagination import LinePaginator @@ -55,52 +56,30 @@ async def disambiguate(      choices = (f"{index}: {entry}" for index, entry in enumerate(entries, start=1))      def check(message: discord.Message) -> bool: -        return ( -            message.content.isdecimal() -            and message.author == ctx.author -            and message.channel == ctx.channel -        ) +        return message.author == ctx.author and message.channel == ctx.channel -    try: -        if embed is None: -            embed = discord.Embed() +    if embed is None: +        embed = discord.Embed() -        coro1 = ctx.bot.wait_for("message", check=check, timeout=timeout) -        coro2 = LinePaginator.paginate( +    # Run the paginator in the background, this means it will continue to work after the user has +    # selected an option, and stopping it wont prevent the user from selecting an option, both +    # of which are fine and make implementation simpler. +    create_task( +        LinePaginator.paginate(              choices, ctx, embed=embed, max_lines=entries_per_page, -            empty=empty, max_size=6000, timeout=9000 +            empty=empty, max_size=6000, timeout=timeout          ) +    ) -        # wait_for timeout will go to except instead of the wait_for thing as I expected -        futures = [asyncio.ensure_future(coro1), asyncio.ensure_future(coro2)] -        done, pending = await asyncio.wait(futures, return_when=asyncio.FIRST_COMPLETED, loop=ctx.bot.loop) - -        # :yert: -        result = list(done)[0].result() - -        # Pagination was canceled - result is None -        if result is None: -            for coro in pending: -                coro.cancel() -            raise BadArgument("Canceled.") - -        # Pagination was not initiated, only one page -        if result.author == ctx.bot.user: -            # Continue the wait_for -            result = await list(pending)[0] - -        # Love that duplicate code -        for coro in pending: -            coro.cancel() +    try: +        message = await ctx.bot.wait_for("message", check=check, timeout=timeout)      except asyncio.TimeoutError:          raise BadArgument("Timed out.") -    # Guaranteed to not error because of isdecimal() in check -    index = int(result.content) -      try: +        index = int(message.content)          return entries[index - 1] -    except IndexError: +    except (ValueError, IndexError):          raise BadArgument("Invalid choice.") | 
