diff options
Diffstat (limited to 'bot/exts/info/source.py')
| -rw-r--r-- | bot/exts/info/source.py | 48 | 
1 files changed, 9 insertions, 39 deletions
| diff --git a/bot/exts/info/source.py b/bot/exts/info/source.py index ef07c77a1..e3e7029ca 100644 --- a/bot/exts/info/source.py +++ b/bot/exts/info/source.py @@ -2,45 +2,15 @@ import inspect  from pathlib import Path  from typing import Optional, Tuple, Union -from discord import Embed, utils +from discord import Embed  from discord.ext import commands  from bot.bot import Bot  from bot.constants import URLs +from bot.converters import SourceConverter +from bot.exts.info.tags import TagIdentifier -SourceType = Union[commands.HelpCommand, commands.Command, commands.Cog, str, commands.ExtensionNotLoaded] - - -class SourceConverter(commands.Converter): -    """Convert an argument into a help command, tag, command, or cog.""" - -    @staticmethod -    async def convert(ctx: commands.Context, argument: str) -> SourceType: -        """Convert argument into source object.""" -        if argument.lower() == "help": -            return ctx.bot.help_command - -        cog = ctx.bot.get_cog(argument) -        if cog: -            return cog - -        cmd = ctx.bot.get_command(argument) -        if cmd: -            return cmd - -        tags_cog = ctx.bot.get_cog("Tags") -        show_tag = True - -        if not tags_cog: -            show_tag = False -        elif argument.lower() in tags_cog._cache: -            return argument.lower() - -        escaped_arg = utils.escape_markdown(argument) - -        raise commands.BadArgument( -            f"Unable to convert '{escaped_arg}' to valid command{', tag,' if show_tag else ''} or Cog." -        ) +SourceType = Union[commands.HelpCommand, commands.Command, commands.Cog, TagIdentifier, commands.ExtensionNotLoaded]  class BotSource(commands.Cog): @@ -72,9 +42,9 @@ class BotSource(commands.Cog):              source_item = inspect.unwrap(source_item.callback)              src = source_item.__code__              filename = src.co_filename -        elif isinstance(source_item, str): +        elif isinstance(source_item, TagIdentifier):              tags_cog = self.bot.get_cog("Tags") -            filename = tags_cog._cache[source_item]["location"] +            filename = tags_cog.tags[source_item].file_path          else:              src = type(source_item)              try: @@ -82,7 +52,7 @@ class BotSource(commands.Cog):              except TypeError:                  raise commands.BadArgument("Cannot get source for a dynamically-created object.") -        if not isinstance(source_item, str): +        if not isinstance(source_item, TagIdentifier):              try:                  lines, first_line_no = inspect.getsourcelines(src)              except OSError: @@ -95,7 +65,7 @@ class BotSource(commands.Cog):          # Handle tag file location differently than others to avoid errors in some cases          if not first_line_no: -            file_location = Path(filename).relative_to("/bot/") +            file_location = Path(filename).relative_to("bot/")          else:              file_location = Path(filename).relative_to(Path.cwd()).as_posix() @@ -113,7 +83,7 @@ class BotSource(commands.Cog):          elif isinstance(source_object, commands.Command):              description = source_object.short_doc              title = f"Command: {source_object.qualified_name}" -        elif isinstance(source_object, str): +        elif isinstance(source_object, TagIdentifier):              title = f"Tag: {source_object}"              description = ""          else: | 
