bazarr/libs/markupsafe/_native.py

64 lines
1.7 KiB
Python
Raw Normal View History

import typing as t
2019-12-11 04:09:51 +08:00
from . import Markup
def escape(s: t.Any) -> Markup:
2019-12-11 04:09:51 +08:00
"""Replace the characters ``&``, ``<``, ``>``, ``'``, and ``"`` in
the string with HTML-safe sequences. Use this if you need to display
text that might contain such characters in HTML.
If the object has an ``__html__`` method, it is called and the
return value is assumed to already be safe for HTML.
:param s: An object to be converted to a string and escaped.
:return: A :class:`Markup` string with the escaped text.
"""
if hasattr(s, "__html__"):
return Markup(s.__html__())
2019-12-11 04:09:51 +08:00
return Markup(
str(s)
2019-12-11 04:09:51 +08:00
.replace("&", "&amp;")
.replace(">", "&gt;")
.replace("<", "&lt;")
.replace("'", "&#39;")
.replace('"', "&#34;")
)
def escape_silent(s: t.Optional[t.Any]) -> Markup:
2019-12-11 04:09:51 +08:00
"""Like :func:`escape` but treats ``None`` as the empty string.
Useful with optional values, as otherwise you get the string
``'None'`` when the value is ``None``.
>>> escape(None)
Markup('None')
>>> escape_silent(None)
Markup('')
"""
if s is None:
return Markup()
2019-12-11 04:09:51 +08:00
return escape(s)
def soft_str(s: t.Any) -> str:
2019-12-11 04:09:51 +08:00
"""Convert an object to a string if it isn't already. This preserves
a :class:`Markup` string rather than converting it back to a basic
string, so it will still be marked as safe and won't be escaped
again.
>>> value = escape("<User 1>")
2019-12-11 04:09:51 +08:00
>>> value
Markup('&lt;User 1&gt;')
>>> escape(str(value))
Markup('&amp;lt;User 1&amp;gt;')
>>> escape(soft_str(value))
2019-12-11 04:09:51 +08:00
Markup('&lt;User 1&gt;')
"""
if not isinstance(s, str):
return str(s)
2019-12-11 04:09:51 +08:00
return s