summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2010-05-22 02:16:27 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2010-05-22 02:16:27 (GMT)
commit3fed0870a6fec72665068e09200c674b574dabdb (patch)
tree8562dd597347a6a8336ba001f065d3ab3b712775 /Lib
parent7126dbc867e99e675ed29037c6b10681dbaa8dc9 (diff)
downloadcpython-3fed0870a6fec72665068e09200c674b574dabdb.zip
cpython-3fed0870a6fec72665068e09200c674b574dabdb.tar.gz
cpython-3fed0870a6fec72665068e09200c674b574dabdb.tar.bz2
Merged revisions 81459 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r81459 | victor.stinner | 2010-05-22 04:11:07 +0200 (sam., 22 mai 2010) | 3 lines Issue #6268: Fix seek() method of codecs.open(), don't read the BOM twice after seek(0) ........
Diffstat (limited to 'Lib')
-rw-r--r--Lib/codecs.py4
-rw-r--r--Lib/test/test_codecs.py21
2 files changed, 25 insertions, 0 deletions
diff --git a/Lib/codecs.py b/Lib/codecs.py
index f05c4f7..9490602 100644
--- a/Lib/codecs.py
+++ b/Lib/codecs.py
@@ -699,6 +699,10 @@ class StreamReaderWriter:
self.reader.reset()
self.writer.reset()
+ def seek(self, offset, whence=0):
+ self.reader.seek(offset, whence)
+ self.writer.seek(offset, whence)
+
def __getattr__(self, name,
getattr=getattr):
diff --git a/Lib/test/test_codecs.py b/Lib/test/test_codecs.py
index b17cded..6e7afc4 100644
--- a/Lib/test/test_codecs.py
+++ b/Lib/test/test_codecs.py
@@ -1594,6 +1594,26 @@ class SurrogateEscapeTest(unittest.TestCase):
b"\xe4\xeb\xef\xf6\xfc")
+class BomTest(unittest.TestCase):
+ def test_seek0(self):
+ data = "1234567890"
+ tests = ("utf-16",
+ "utf-16-le",
+ "utf-16-be",
+ "utf-32",
+ "utf-32-le",
+ "utf-32-be")
+ for encoding in tests:
+ with codecs.open('foo', 'w+', encoding=encoding) as f:
+ # Check if the BOM is written only once
+ f.write(data)
+ f.write(data)
+ f.seek(0)
+ self.assertEquals(f.read(), data * 2)
+ f.seek(0)
+ self.assertEquals(f.read(), data * 2)
+
+
def test_main():
support.run_unittest(
UTF32Test,
@@ -1621,6 +1641,7 @@ def test_main():
WithStmtTest,
TypesTest,
SurrogateEscapeTest,
+ BomTest,
)