@ -2,7 +2,7 @@ import logging
import pathlib
import pathlib
import re
import re
import string
import string
from typing import Optional
from typing import Optional , Union
import discord
import discord
from redbot . core import Config , commands
from redbot . core import Config , commands
@ -26,15 +26,17 @@ def markdown_link_replace(match, starts_with_text=None):
text = match . group ( 1 )
text = match . group ( 1 )
url = match . group ( 2 )
url = match . group ( 2 )
if starts_with_text and url . startswith ( starts_with_text ) :
if starts_with_text and url . startswith ( starts_with_text ) :
url = url [ len ( starts_with_text ) : ]
i = len ( starts_with_text )
url = url [ : url . find ( ' . ' ) ]
url = url [ i : ]
i = url . find ( " . " )
url = url [ : i ]
return f " :ref:` { text } < { url } >` "
return f " :ref:` { text } < { url } >` "
return f " { text } : { url } "
return f " { text } : { url } "
def prepare_description ( comm and: commands . Command ) :
def prepare_description ( comm _or_cog: Union [ commands . Command , Cog ] ) :
description = comm and. description or command . help
description = comm _or_cog. description or comm_or_cog . help
description = description . replace ( " ` " , " `` " )
description = description . replace ( " ` " , " `` " )
pattern = re . compile ( r " \ [(.+)] \ s? \ ((https?: \ / \ /[ \ w \ d. \ /?=#]+) \ ) " )
pattern = re . compile ( r " \ [(.+)] \ s? \ ((https?: \ / \ /[ \ w \ d. \ /?=#]+) \ ) " )
description = pattern . sub ( markdown_link_replace , description )
description = pattern . sub ( markdown_link_replace , description )
@ -51,7 +53,9 @@ class CogGuide(commands.Cog):
def __init__ ( self , bot : Red ) :
def __init__ ( self , bot : Red ) :
super ( ) . __init__ ( )
super ( ) . __init__ ( )
self . bot = bot
self . bot = bot
self . config = Config . get_conf ( self , identifier = 6711110371117105100101 , force_registration = True )
self . config = Config . get_conf (
self , identifier = 6711110371117105100101 , force_registration = True
)
default_global = { " starts_with " : None }
default_global = { " starts_with " : None }
self . config . register_global ( * * default_global )
self . config . register_global ( * * default_global )
@ -146,7 +150,7 @@ find detailed docs about usage and commands.
Usage
Usage
- - - - -
- - - - -
{ cog. description if cog . description else " This is a general description of what the cog does. This should be a very basic explanation, addressing the core purpose of the cog. This is some additional information about what this cog can do. Try to answer *the* most frequently asked question. " }
{ prepare_description( cog ) }
"""
"""
cog_commands_intro = f """
cog_commands_intro = f """
@ -177,7 +181,12 @@ Commands
. . code - block : : none
. . code - block : : none
[ p ] { command . qualified_name } { command . signature }
[ p ] { command . qualified_name } { command . signature }
"""
if command . aliases :
cog_command + = f """
. . tip : : Alias { ' es ' if len ( command . aliases ) > 1 else ' ' } : { ' , ' . join ( f " { alias } " for alias in command . aliases ) }
"""
cog_command + = f """
* * Description * *
* * Description * *
{ description }
{ description }