]> granicus.if.org Git - python/commitdiff
Revert the fix for #1548891, it broke backwards compatibility with arbitrary read...
authorGeorg Brandl <georg@python.org>
Wed, 8 Aug 2007 13:03:41 +0000 (13:03 +0000)
committerGeorg Brandl <georg@python.org>
Wed, 8 Aug 2007 13:03:41 +0000 (13:03 +0000)
Fixes #1730114.

Doc/lib/libstringio.tex
Lib/test/test_StringIO.py
Misc/NEWS
Modules/cStringIO.c

index 24312518f37279d38c235798798c1d61a69ef3d4..73ff0e4c3c27e5778fc229fff6c63101d1a85d7f 100644 (file)
@@ -78,6 +78,10 @@ Unlike the memory files implemented by the \refmodule{StringIO}
 module, those provided by this module are not able to accept Unicode
 strings that cannot be encoded as plain \ASCII{} strings.
 
+Calling \function{StringIO()} with a Unicode string parameter populates
+the object with the buffer representation of the Unicode string, instead of
+encoding the string.
+
 Another difference from the \refmodule{StringIO} module is that calling
 \function{StringIO()} with a string parameter creates a read-only object.
 Unlike an object created without a string parameter, it does not have
index 9f79b02e16c8812f0780d8e43e52d03b218b2d1c..58cbec06f85901e010f53f0058930a93c208c049 100644 (file)
@@ -121,28 +121,6 @@ class TestStringIO(TestGenericStringIO):
 class TestcStringIO(TestGenericStringIO):
     MODULE = cStringIO
 
-    def test_unicode(self):
-
-        if not test_support.have_unicode: return
-
-        # The cStringIO module converts Unicode strings to character
-        # strings when writing them to cStringIO objects.
-        # Check that this works.
-
-        f = self.MODULE.StringIO()
-        f.write(unicode(self._line[:5]))
-        s = f.getvalue()
-        self.assertEqual(s, 'abcde')
-        self.assertEqual(type(s), types.StringType)
-
-        f = self.MODULE.StringIO(unicode(self._line[:5]))
-        s = f.getvalue()
-        self.assertEqual(s, 'abcde')
-        self.assertEqual(type(s), types.StringType)
-
-        self.assertRaises(UnicodeEncodeError, self.MODULE.StringIO,
-                          unicode('\xf4', 'latin-1'))
-
 import sys
 if sys.platform.startswith('java'):
     # Jython doesn't have a buffer object, so we just do a useless
index 30bb985882f86db649ab1c8bac23564f17d76784..375fb34c9d8db5aab9bc99e46c7455391a40440f 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -782,10 +782,6 @@ Extension Modules
 
 - Patch #1576166: Support os.utime for directories on Windows NT+.
 
-- Bug #1548891: The cStringIO.StringIO() constructor now encodes unicode
-  arguments with the system default encoding just like the write()
-  method does, instead of converting it to a raw buffer.
-
 - Patch #1572724: fix typo ('=' instead of '==') in _msi.c.
 
 - Bug #1572832: fix a bug in ISO-2022 codecs which may cause segfault
index 5834e2027330d5963a615cf9a32fee9ec2bafdd9..0cc9c6bb804ca2dcb03b19364ba66990810e4588 100644 (file)
@@ -673,8 +673,11 @@ newIobject(PyObject *s) {
   char *buf;
   Py_ssize_t size;
 
-  if (PyObject_AsCharBuffer(s, (const char **)&buf, &size) != 0)
-      return NULL;
+  if (PyObject_AsReadBuffer(s, (const char **)&buf, &size)) {
+    PyErr_Format(PyExc_TypeError, "expected read buffer, %.200s found",
+                 s->ob_type->tp_name);
+    return NULL;
+  }
 
   self = PyObject_New(Iobject, &Itype);
   if (!self) return NULL;