aboutsummaryrefslogtreecommitdiffstats
path: root/bot/group.py
diff options
context:
space:
mode:
authorGravatar ks129 <[email protected]>2021-04-30 12:14:37 +0300
committerGravatar GitHub <[email protected]>2021-04-30 12:14:37 +0300
commit9981c0b4f2af3fb0a91c4d1f49fcf4400a8bfc6b (patch)
treeb20a8cc425d98d2f4b2ffc11ac1fe665b62b8192 /bot/group.py
parentMerge pull request #709 from chincholikarsalil/fix-grammatical-error (diff)
parentMerge branch 'main' into Enforce-image-processing-concurrency (diff)
Merge pull request #597 from python-discord/Enforce-image-processing-concurrency
Move avatar commands into executors
Diffstat (limited to 'bot/group.py')
-rw-r--r--bot/group.py18
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.")