Browse Source

Only escape characters as necessary in clean_content

Fixes #1885
pull/2049/head
CapnS 6 years ago
committed by Rapptz
parent
commit
24d3a5a48d
  1. 15
      discord/ext/commands/converter.py

15
discord/ext/commands/converter.py

@ -473,16 +473,11 @@ class clean_content(Converter):
result = pattern.sub(repl, argument)
if self.escape_markdown:
transformations = {
re.escape(c): '\\' + c
for c in ('*', '`', '_', '~', '\\', '||')
}
def replace(obj):
return transformations.get(re.escape(obj.group(0)), '')
pattern = re.compile('|'.join(transformations.keys()))
result = pattern.sub(replace, result)
result = re.sub(r'\\', r'\\\\', result)
for c in ('*', '`', '_', '~', '|'):
regex = r'\{0}(?=([\s\S]*((?<!\{0})\{0})))'.format(c)
replace = '\{0}'.format(c)
result = re.sub(regex, replace, result)
# Completely ensure no mentions escape:
return re.sub(r'@(everyone|here|[!&]?[0-9]{17,21})', '@\u200b\\1', result)

Loading…
Cancel
Save