]> granicus.if.org Git - python/commitdiff
Bug #1548891: The cStringIO.StringIO() constructor now encodes unicode
authorGeorg Brandl <georg@python.org>
Thu, 12 Oct 2006 09:47:12 +0000 (09:47 +0000)
committerGeorg Brandl <georg@python.org>
Thu, 12 Oct 2006 09:47:12 +0000 (09:47 +0000)
arguments with the system default encoding just like the write()
method does, instead of converting it to a raw buffer.

Lib/test/test_StringIO.py
Misc/NEWS
Modules/cStringIO.c

index cc3367fed8d16bdfa9a4b0c68c8b0832576fbf32..aa36b098443c336dd2b7e777ff82f81b4fd4e088 100644 (file)
@@ -120,6 +120,28 @@ 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 4a19fda83fc2c23840f73e73a9a3989ff764bb2f..605b1d82260b4d5cb106befde8f3063aad94c556 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -131,6 +131,10 @@ Library
 Extension Modules
 -----------------
 
+- 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 4debb7263bdf8a00489b2b153f14972ba6e6de0a..03ef4616021d2c7c1a761a73b91b5361f8666308 100644 (file)
@@ -657,11 +657,9 @@ newIobject(PyObject *s) {
   char *buf;
   Py_ssize_t size;
 
-  if (PyObject_AsReadBuffer(s, (const void **)&buf, &size)) {
-      PyErr_Format(PyExc_TypeError, "expected read buffer, %.200s found",
-                  s->ob_type->tp_name);
+  if (PyObject_AsCharBuffer(s, (const void **)&buf, &size) != 0)
       return NULL;
-  }
+
   self = PyObject_New(Iobject, &Itype);
   if (!self) return NULL;
   Py_INCREF(s);