From 34d9076fc6d7d4da68dcbf855cd222d3de5b580c Mon Sep 17 00:00:00 2001 From: Mathieu Virbel Date: Sat, 27 Oct 2012 12:50:31 +0200 Subject: [PATCH] Revert "lang: use codecs.open() instead of open() for reading the kv file in UTF-8. closes #762" This reverts commit ac70a266d38ec2b1bc7595efb7799495e5828fca. --- kivy/lang.py | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/kivy/lang.py b/kivy/lang.py index 98d97b572..60765f672 100644 --- a/kivy/lang.py +++ b/kivy/lang.py @@ -37,7 +37,7 @@ Syntax of a kv File .. highlight:: kv -A Kivy language file must have ``.kv`` as filename extension, encoded in UTF-8. +A Kivy language file must have ``.kv`` as filename extension. The content of the file must always start with the Kivy header, where `version` must be replaced with the Kivy language version you're using. For now, use @@ -1106,9 +1106,20 @@ class BuilderBase(object): ''' if __debug__: trace('Builder: load file %s' % filename) - with codecs.open(filename, 'r', 'utf8') as fd: + with open(filename, 'r') as fd: kwargs['filename'] = filename data = fd.read() + + # remove bom ? + if data.startswith(codecs.BOM_UTF16_LE) or \ + data.startswith(codecs.BOM_UTF16_BE): + raise ValueError('Unsupported UTF16 for kv files.') + if data.startswith(codecs.BOM_UTF32_LE) or \ + data.startswith(codecs.BOM_UTF32_BE): + raise ValueError('Unsupported UTF32 for kv files.') + if data.startswith(codecs.BOM_UTF8): + data = data[len(codecs.BOM_UTF8):] + return self.load_string(data, **kwargs) def unload_file(self, filename):