diff options
| author | 2021-05-13 20:28:20 +0100 | |
|---|---|---|
| committer | 2021-05-13 20:28:20 +0100 | |
| commit | 196c435c586b3bc2d30aa6a9865b8d4498d9c5b8 (patch) | |
| tree | c9585d2a668d75bbbda0fab5c1b80962a9946bb7 /bot/group.py | |
| parent | Remove redundant comments in bookmark cog (diff) | |
| parent | Merge pull request #727 from python-discord/reddit-revoke (diff) | |
Merge branch 'main' into bookmark-react-for-copy
Diffstat (limited to 'bot/group.py')
| -rw-r--r-- | bot/group.py | 18 | 
1 files changed, 18 insertions, 0 deletions
| diff --git a/bot/group.py b/bot/group.py new file mode 100644 index 00000000..a7bc59b7 --- /dev/null +++ b/bot/group.py @@ -0,0 +1,18 @@ +from discord.ext import commands + + +class Group(commands.Group): +    """ +    A `discord.ext.commands.Group` subclass which supports root aliases. + +    A `root_aliases` keyword argument is added, which is a sequence of alias names that will act as +    top-level groups rather than being aliases of the command's group. It's stored as an attribute +    also named `root_aliases`. +    """ + +    def __init__(self, *args, **kwargs): +        super().__init__(*args, **kwargs) +        self.root_aliases = kwargs.get("root_aliases", []) + +        if not isinstance(self.root_aliases, (list, tuple)): +            raise TypeError("Root aliases of a group must be a list or a tuple of strings.") | 
