2013-03-13 12:52:13 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
"""
|
|
|
|
markupsafe._native
|
|
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Native Python implementation the C module is not compiled.
|
|
|
|
|
|
|
|
:copyright: (c) 2010 by Armin Ronacher.
|
|
|
|
:license: BSD, see LICENSE for more details.
|
|
|
|
"""
|
2013-06-18 09:27:09 +02:00
|
|
|
from _compat import text_type
|
2013-03-13 12:52:13 +01:00
|
|
|
|
|
|
|
|
|
|
|
def escape(s):
|
|
|
|
"""Convert the characters &, <, >, ' and " in string s to HTML-safe
|
|
|
|
sequences. Use this if you need to display text that might contain
|
|
|
|
such characters in HTML. Marks return value as markup string.
|
|
|
|
"""
|
|
|
|
if hasattr(s, '__html__'):
|
|
|
|
return s.__html__()
|
2013-06-18 09:27:09 +02:00
|
|
|
return Markup(text_type(s)
|
2013-03-13 12:52:13 +01:00
|
|
|
.replace('&', '&')
|
|
|
|
.replace('>', '>')
|
|
|
|
.replace('<', '<')
|
|
|
|
.replace("'", ''')
|
|
|
|
.replace('"', '"')
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def escape_silent(s):
|
|
|
|
"""Like :func:`escape` but converts `None` into an empty
|
|
|
|
markup string.
|
|
|
|
"""
|
|
|
|
if s is None:
|
|
|
|
return Markup()
|
|
|
|
return escape(s)
|
|
|
|
|
|
|
|
|
|
|
|
def soft_unicode(s):
|
|
|
|
"""Make a string unicode if it isn't already. That way a markup
|
|
|
|
string is not converted back to unicode.
|
|
|
|
"""
|
2013-06-18 09:27:09 +02:00
|
|
|
if not isinstance(s, text_type):
|
|
|
|
s = text_type(s)
|
2013-03-13 12:52:13 +01:00
|
|
|
return s
|