From beae7e44d883cd669b39ae249201aead635d2a70 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micka=C3=ABl=20Gu=C3=A9rin?= Date: Mon, 28 May 2018 12:17:15 +0200 Subject: [PATCH] Percent signs escaping in templatetags Closes https://github.com/python-babel/django-babel/issues/43 In Django >= 1.9, `%` signs are escaped to `%%` during extraction then replaced by `%` during the rendering. [1] The extraction now behaves in the same way. [1] https://github.com/django/django/commit/b7508896fbe19ec2cdeb81565cd587091b6b68d0 --- django_babel/extract.py | 6 ++++-- tests/test_extract.py | 10 ++++++++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/django_babel/extract.py b/django_babel/extract.py index edb42c7..c90e1f0 100644 --- a/django_babel/extract.py +++ b/django_babel/extract.py @@ -112,10 +112,11 @@ def extract_django(fileobj, keywords, comment_tags, options): else: singular.append('%%(%s)s' % t.contents) elif t.token_type == TOKEN_TEXT: + contents = t.contents.replace('%', '%%') if inplural: - plural.append(t.contents) + plural.append(contents) else: - singular.append(t.contents) + singular.append(contents) else: if t.token_type == TOKEN_BLOCK: imatch = inline_re.match(t.contents) @@ -124,6 +125,7 @@ def extract_django(fileobj, keywords, comment_tags, options): if imatch: g = imatch.group(1) g = strip_quotes(g) + g = g.replace('%', '%%') message_context = imatch.group(3) if message_context: # strip quotes diff --git a/tests/test_extract.py b/tests/test_extract.py index aca1a58..0dca0fb 100644 --- a/tests/test_extract.py +++ b/tests/test_extract.py @@ -218,3 +218,13 @@ def test_blocktrans_with_whitespace_trimmed(self): buf = BytesIO(test_tmpl) messages = list(extract_django(buf, default_keys, [], {})) self.assertEqual([(4, None, u'foo bar', [])], messages) + + def test_extract_trans_percents(self): + buf = BytesIO(b'{% trans "100% Bunny" %}') + messages = list(extract_django(buf, default_keys, [], {})) + self.assertEqual([(1, None, u'100%% Bunny', [])], messages) + + def test_extract_blocktrans_percents(self): + buf = BytesIO(b'{% blocktrans %}100% Bunny{% endblocktrans %}') + messages = list(extract_django(buf, default_keys, [], {})) + self.assertEqual([(1, None, u'100%% Bunny', [])], messages)