Mercurial > hg
changeset 8014:6a77ba181bc6
templatefilters: split out jsonescape() function
author | Dirkjan Ochtman <dirkjan@ochtman.nl> |
---|---|
date | Mon, 06 Apr 2009 10:51:45 +0200 |
parents | 9ec25db32b4e |
children | b5db7dcc1497 |
files | mercurial/templatefilters.py |
diffstat | 1 files changed, 8 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/templatefilters.py Mon Apr 06 10:51:27 2009 +0200 +++ b/mercurial/templatefilters.py Mon Apr 06 10:51:45 2009 +0200 @@ -129,15 +129,18 @@ ('\r', '\\r'), ('\f', '\\f'), ('\b', '\\b'), ] +def jsonescape(s): + for k, v in _escapes: + s = s.replace(k, v) + return s + def json(obj): if obj is None or obj is False or obj is True: return {None: 'null', False: 'false', True: 'true'}[obj] elif isinstance(obj, int) or isinstance(obj, float): return str(obj) elif isinstance(obj, str): - for k, v in _escapes: - obj = obj.replace(k, v) - return '"%s"' % obj + return '"%s"' % jsonescape(obj) elif isinstance(obj, unicode): return json(obj.encode('utf-8')) elif hasattr(obj, 'keys'): @@ -169,6 +172,8 @@ "hgdate": lambda x: "%d %d" % x, "isodate": lambda x: util.datestr(x, '%Y-%m-%d %H:%M %1%2'), "isodatesec": lambda x: util.datestr(x, '%Y-%m-%d %H:%M:%S %1%2'), + "json": json, + "jsonescape": jsonescape, "obfuscate": obfuscate, "permissions": permissions, "person": person, @@ -182,5 +187,4 @@ "user": lambda x: util.shortuser(x), "stringescape": lambda x: x.encode('string_escape'), "xmlescape": xmlescape, - "json": json, }