This package contains a discord.py extension to provide classes to more easily use typed commands
pip install discord-ext-typed-commands
NOTE: Because discord.py
uses namespace packages for its extensions, mypy
must be configured to use namespace packages either with the --namespace-packages
command line flag, or by setting namespace_packages = True
in your mypy
configuration file. See the import discovery section of the mypy
documentation for more details.
The most common usage will be in connection with discord.py-stubs in order to allow bot authors to use the command classes from discord.py while also using the generics defined in the stubs:
from typing import Any, Type, TypeVar, Union, cast, overload
import discord
from discord.ext import typed_commands
OtherContextType = TypeVar('OtherContextType', bound=typed_commands.Context)
class MyContext(typed_commands.Context):
async def send_with_hello(self, text: str) -> None:
await self.send(f'Hello! {text}')
class MyCog(typed_commands.Cog[MyContext]):
@typed_commands.command()
async def speak(self, ctx: MyContext, text: str) -> None:
await ctx.send_with_hello(text)
class MyBot(typed_commands.Bot[MyContext]):
@overload
async def get_context(self, message: discord.Message) -> MyContext:
...
@overload
async def get_context(
self, message: discord.Message, *, cls: Type[OtherContextType]
) -> OtherContextType:
...
async def get_context(
self,
message: discord.Message,
*,
cls: Type[OtherContextType] = cast(Any, MyContext),
) -> Union[MyContext, OtherContextType]:
return await super().get_context(message, cls=cls)
my_bot = MyBot('$')
my_bot.add_cog(MyCog())
my_bot.run('...')
NOTE: Because it is not a runtime dependency, discord.py-stubs will need to be explicitly installed to type check a bot while it is being developed. It is recommended that the stubs be added as a development dependency using your preferred method of package management.
Make sure you have poetry installed.
poetry install
poetry run pre-commit install --hook-type pre-commit --hook-type post-checkout