summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2010-05-22 02:11:07 +0000
committerVictor Stinner <victor.stinner@haypocalc.com>2010-05-22 02:11:07 +0000
commitcd38a28d7c1574e52449d7f340afb088697bab42 (patch)
treeee50ac7d784379066f4e9df45a2948d402b4accd
parente2861d38d77b89b674d2dba061fd99e9def2d829 (diff)
downloadcpython-cd38a28d7c1574e52449d7f340afb088697bab42.tar.gz
Issue #6268: Fix seek() method of codecs.open(), don't read the BOM twice
after seek(0)
-rw-r--r--Lib/codecs.py4
-rw-r--r--Lib/test/test_codecs.py21
-rw-r--r--Misc/NEWS3
3 files changed, 28 insertions, 0 deletions
diff --git a/Lib/codecs.py b/Lib/codecs.py
index a67240a20f..e903f2e914 100644
--- a/Lib/codecs.py
+++ b/Lib/codecs.py
@@ -694,6 +694,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 f8563f61ae..306a3b2ee6 100644
--- a/Lib/test/test_codecs.py
+++ b/Lib/test/test_codecs.py
@@ -1496,6 +1496,26 @@ class WithStmtTest(unittest.TestCase):
self.assertEquals(srw.read(), u"\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', 'wt+', 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():
test_support.run_unittest(
UTF32Test,
@@ -1524,6 +1544,7 @@ def test_main():
BasicStrTest,
CharmapTest,
WithStmtTest,
+ BomTest,
)
diff --git a/Misc/NEWS b/Misc/NEWS
index 3656def6ca..021cac025b 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -29,6 +29,9 @@ C-API
Library
-------
+- Issue #6268: Fix seek() method of codecs.open(), don't read the BOM twice
+ after seek(0)
+
- Issue #5640: Fix Shift-JIS incremental encoder for error handlers different
than strict