Fix invalid Python escape sequences

(cherry picked from commit 4986d6d317)
This commit is contained in:
Mikael Klasson 2023-12-06 11:51:41 +09:00 committed by Rémi Verschelde
parent 304f453b01
commit 62858097aa
No known key found for this signature in database
GPG Key ID: C3336907360768E1

View File

@ -1557,9 +1557,9 @@ def format_text_block(
post_text = text[endurl_pos + 6 :] post_text = text[endurl_pos + 6 :]
if pre_text and pre_text[-1] not in MARKUP_ALLOWED_PRECEDENT: if pre_text and pre_text[-1] not in MARKUP_ALLOWED_PRECEDENT:
pre_text += "\ " pre_text += "\\ "
if post_text and post_text[0] not in MARKUP_ALLOWED_SUBSEQUENT: if post_text and post_text[0] not in MARKUP_ALLOWED_SUBSEQUENT:
post_text = "\ " + post_text post_text = "\\ " + post_text
text = pre_text + tag_text + post_text text = pre_text + tag_text + post_text
pos = len(pre_text) + len(tag_text) pos = len(pre_text) + len(tag_text)
@ -1636,9 +1636,9 @@ def format_text_block(
# Properly escape things like `[Node]s` # Properly escape things like `[Node]s`
if escape_pre and pre_text and pre_text[-1] not in MARKUP_ALLOWED_PRECEDENT: if escape_pre and pre_text and pre_text[-1] not in MARKUP_ALLOWED_PRECEDENT:
pre_text += "\ " pre_text += "\\ "
if escape_post and post_text and post_text[0] not in MARKUP_ALLOWED_SUBSEQUENT: if escape_post and post_text and post_text[0] not in MARKUP_ALLOWED_SUBSEQUENT:
post_text = "\ " + post_text post_text = "\\ " + post_text
next_brac_pos = post_text.find("[", 0) next_brac_pos = post_text.find("[", 0)
iter_pos = 0 iter_pos = 0
@ -1646,7 +1646,7 @@ def format_text_block(
iter_pos = post_text.find("*", iter_pos, next_brac_pos) iter_pos = post_text.find("*", iter_pos, next_brac_pos)
if iter_pos == -1: if iter_pos == -1:
break break
post_text = f"{post_text[:iter_pos]}\*{post_text[iter_pos + 1 :]}" post_text = f"{post_text[:iter_pos]}\\*{post_text[iter_pos + 1 :]}"
iter_pos += 2 iter_pos += 2
iter_pos = 0 iter_pos = 0
@ -1655,7 +1655,7 @@ def format_text_block(
if iter_pos == -1: if iter_pos == -1:
break break
if not post_text[iter_pos + 1].isalnum(): # don't escape within a snake_case word if not post_text[iter_pos + 1].isalnum(): # don't escape within a snake_case word
post_text = f"{post_text[:iter_pos]}\_{post_text[iter_pos + 1 :]}" post_text = f"{post_text[:iter_pos]}\\_{post_text[iter_pos + 1 :]}"
iter_pos += 2 iter_pos += 2
else: else:
iter_pos += 1 iter_pos += 1
@ -1696,7 +1696,7 @@ def escape_rst(text: str, until_pos: int = -1) -> str:
pos = text.find("*", pos, until_pos) pos = text.find("*", pos, until_pos)
if pos == -1: if pos == -1:
break break
text = f"{text[:pos]}\*{text[pos + 1 :]}" text = f"{text[:pos]}\\*{text[pos + 1 :]}"
pos += 2 pos += 2
# Escape _ character at the end of a word to avoid interpreting it as an inline hyperlink # Escape _ character at the end of a word to avoid interpreting it as an inline hyperlink
@ -1706,7 +1706,7 @@ def escape_rst(text: str, until_pos: int = -1) -> str:
if pos == -1: if pos == -1:
break break
if not text[pos + 1].isalnum(): # don't escape within a snake_case word if not text[pos + 1].isalnum(): # don't escape within a snake_case word
text = f"{text[:pos]}\_{text[pos + 1 :]}" text = f"{text[:pos]}\\_{text[pos + 1 :]}"
pos += 2 pos += 2
else: else:
pos += 1 pos += 1