mirror of
https://github.com/django/django.git
synced 2025-10-31 09:41:08 +00:00
Fixed #24257 -- Corrected i18n handling of percent signs.
Refactored tests to use a sample project.
Updated extraction:
* Removed special handling of single percent signs.
* When extracting messages from template text, doubled all percent signs
so they are not interpreted by gettext as string format flags. All
strings extracted by gettext, if containing a percent sign, will now
be labeled "#, python-format".
Updated translation:
* Used "%%" for "%" in template text before calling gettext.
* Updated {% trans %} rendering to restore "%" from "%%".
This commit is contained in:
@@ -825,10 +825,13 @@ class Variable(object):
|
||||
# We're dealing with a literal, so it's already been "resolved"
|
||||
value = self.literal
|
||||
if self.translate:
|
||||
is_safe = isinstance(value, SafeData)
|
||||
msgid = value.replace('%', '%%')
|
||||
msgid = mark_safe(msgid) if is_safe else msgid
|
||||
if self.message_context:
|
||||
return pgettext_lazy(self.message_context, value)
|
||||
return pgettext_lazy(self.message_context, msgid)
|
||||
else:
|
||||
return ugettext_lazy(value)
|
||||
return ugettext_lazy(msgid)
|
||||
return value
|
||||
|
||||
def __repr__(self):
|
||||
|
||||
Reference in New Issue
Block a user