Commit 2c11feb2 authored by Andreas Jung's avatar Andreas Jung

preferred ZPT encoding (for backward compatibility) can be defined as $ZPT_PREFERRED_ENCODING

parent 200006dc
...@@ -41,6 +41,9 @@ from zope.pagetemplate.pagetemplatefile import sniff_type ...@@ -41,6 +41,9 @@ from zope.pagetemplate.pagetemplatefile import sniff_type
# regular expression to extract the encoding from the XML preamble # regular expression to extract the encoding from the XML preamble
encoding_reg= re.compile('<\?xml.*?encoding="(.*?)".*?\?>', re.M) encoding_reg= re.compile('<\?xml.*?encoding="(.*?)".*?\?>', re.M)
preferred_encodings = ['utf-8', 'iso-8859-15']
if os.environ.has_key('ZPT_PREFERRED_ENCODING'):
preferred_encodings.insert(0, os.environ['ZPT_PREFERRED_ENCODING'])
class SecureModuleImporter: class SecureModuleImporter:
__allow_access_to_unprotected_subobjects__ = 1 __allow_access_to_unprotected_subobjects__ = 1
...@@ -372,7 +375,7 @@ class ZopePageTemplate(Script, PageTemplate, Historical, Cacheable, ...@@ -372,7 +375,7 @@ class ZopePageTemplate(Script, PageTemplate, Historical, Cacheable,
if not isinstance(text, unicode): if not isinstance(text, unicode):
# ATT: the encoding guessing should be made more flexible # ATT: the encoding guessing should be made more flexible
for encoding in ('iso-8859-15', 'utf-8'): for encoding in preferred_encodings:
try: try:
state['_text'] = unicode(text, encoding) state['_text'] = unicode(text, encoding)
self.__dict__.update(state) self.__dict__.update(state)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment