[Python-checkins] r74316 - in python/branches/py3k: Lib/test/test_memoryio.py Modules/_io/bytesio.c
alexandre.vassalotti
python-checkins at python.org
Wed Aug 5 01:19:14 CEST 2009
Author: alexandre.vassalotti
Date: Wed Aug 5 01:19:13 2009
New Revision: 74316
Log:
Issue 5449: Fix io.BytesIO to not accept arbitrary keywords
Patch contributed by Erick Tryzelaar.
Modified:
python/branches/py3k/Lib/test/test_memoryio.py
python/branches/py3k/Modules/_io/bytesio.c
Modified: python/branches/py3k/Lib/test/test_memoryio.py
==============================================================================
--- python/branches/py3k/Lib/test/test_memoryio.py (original)
+++ python/branches/py3k/Lib/test/test_memoryio.py Wed Aug 5 01:19:13 2009
@@ -461,6 +461,11 @@
self.assertEqual(memio.write(a), 10)
self.assertEqual(memio.getvalue(), buf)
+ def test_issue5449(self):
+ buf = self.buftype("1234567890")
+ self.ioclass(initial_bytes=buf)
+ self.assertRaises(TypeError, self.ioclass, buf, foo=None)
+
class TextIOTestMixin:
Modified: python/branches/py3k/Modules/_io/bytesio.c
==============================================================================
--- python/branches/py3k/Modules/_io/bytesio.c (original)
+++ python/branches/py3k/Modules/_io/bytesio.c Wed Aug 5 01:19:13 2009
@@ -759,9 +759,11 @@
static int
bytesio_init(bytesio *self, PyObject *args, PyObject *kwds)
{
+ char *kwlist[] = {"initial_bytes", NULL};
PyObject *initvalue = NULL;
- if (!PyArg_ParseTuple(args, "|O:BytesIO", &initvalue))
+ if (!PyArg_ParseTupleAndKeywords(args, kwds, "|O:BytesIO", kwlist,
+ &initvalue))
return -1;
/* In case, __init__ is called multiple times. */
More information about the Python-checkins
mailing list