aboutsummaryrefslogtreecommitdiffstats
path: root/bot
diff options
context:
space:
mode:
authorGravatar Scragly <[email protected]>2019-03-30 15:15:37 +1000
committerGravatar Scragly <[email protected]>2019-03-30 15:15:37 +1000
commit58b9e81f3576aafdd1f5cefd27b5e17b3867a851 (patch)
treebbd89a28db6a205b1502d8f40b7328acfdab4744 /bot
parentMerge pull request #142 from Suhail6inkling/timeleft (diff)
Always announce if docstring, better formatting.
Diffstat (limited to 'bot')
-rw-r--r--bot/seasons/season.py48
1 files changed, 25 insertions, 23 deletions
diff --git a/bot/seasons/season.py b/bot/seasons/season.py
index b7892606..c78de981 100644
--- a/bot/seasons/season.py
+++ b/bot/seasons/season.py
@@ -278,7 +278,18 @@ class SeasonBase:
channel = guild.get_channel(Channels.announcements)
mention = f"<@&{Roles.announcements}>"
- # collect seasonal cogs
+ # build cog info output
+ doc = inspect.getdoc(self)
+ announce = "\n\n".join(l.replace("\n", " ") for l in doc.split("\n\n"))
+
+ # no announcement message found
+ if not doc:
+ return
+
+ embed = discord.Embed(description=f"{announce}\n\n", colour=self.colour or guild.me.colour)
+ embed.set_author(name=self.greeting)
+
+ # find any seasonal commands
cogs = []
for cog in bot.cogs.values():
if "evergreen" in cog.__module__:
@@ -287,30 +298,21 @@ class SeasonBase:
if cog_name != "SeasonManager":
cogs.append(cog_name)
- # no cogs, so no seasonal commands
- if not cogs:
- return
+ if cogs:
+ def cog_name(cog):
+ return type(cog).__name__
- # build cog info output
- doc = inspect.getdoc(self)
- announce_text = doc + "\n\n" if doc else ""
-
- def cog_name(cog):
- return type(cog).__name__
-
- cog_info = []
- for cog in sorted(cogs, key=cog_name):
- doc = inspect.getdoc(bot.get_cog(cog))
- if doc:
- cog_info.append(f"**{cog}**\n*{doc}*")
- else:
- cog_info.append(f"**{cog}**")
+ cog_info = []
+ for cog in sorted(cogs, key=cog_name):
+ doc = inspect.getdoc(bot.get_cog(cog))
+ if doc:
+ cog_info.append(f"**{cog}**\n*{doc}*")
+ else:
+ cog_info.append(f"**{cog}**")
- embed = discord.Embed(description=announce_text, colour=self.colour or guild.me.colour)
- embed.set_author(name=self.greeting)
- cogs_text = "\n".join(cog_info)
- embed.add_field(name="New Command Categories", value=cogs_text)
- embed.set_footer(text="To see the new commands, use .help Category")
+ cogs_text = "\n".join(cog_info)
+ embed.add_field(name="New Command Categories", value=cogs_text)
+ embed.set_footer(text="To see the new commands, use .help Category")
await channel.send(mention, embed=embed)