Commit a883a3d5 authored by Guido van Rossum's avatar Guido van Rossum

See discussion at SF bug 547537.

Unicode objects are currently taken as binary data by the write()
method.  This is not what Unicode users expect, nor what the
StringIO.py code does.  Until somebody adds a way to specify binary or
text mode for cStringIO objects, change the format string to use "t#"
instead of "s#", so that it will request the "text buffer" version.
This will try the default encoding for Unicode objects.

This is *not* a 2.2 bugfix (since it *is* a semantic change).
parent 81b9251d
......@@ -376,7 +376,7 @@ O_write(Oobject *self, PyObject *args) {
char *c;
int l;
UNLESS (PyArg_ParseTuple(args, "s#:write", &c, &l)) return NULL;
UNLESS (PyArg_ParseTuple(args, "t#:write", &c, &l)) return NULL;
if (O_cwrite((PyObject*)self,c,l) < 0) return NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment