diff options
author | Benjamin Peterson <benjamin@python.org> | 2009-12-13 19:25:34 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2009-12-13 19:25:34 (GMT) |
commit | bf5ff765970a15255a06e4a4ee7f18b5745079ad (patch) | |
tree | ac106a4885c12c27a624f296ee0a08d5d6b195c4 /Modules/_io/iobase.c | |
parent | 229663775dd6c869e8daceea6d92af638afa520f (diff) | |
download | cpython-bf5ff765970a15255a06e4a4ee7f18b5745079ad.zip cpython-bf5ff765970a15255a06e4a4ee7f18b5745079ad.tar.gz cpython-bf5ff765970a15255a06e4a4ee7f18b5745079ad.tar.bz2 |
Merged revisions 76805 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r76805 | benjamin.peterson | 2009-12-13 13:19:07 -0600 (Sun, 13 Dec 2009) | 7 lines
accept None as the same as having passed no argument in file types #7349
This is for consistency with imitation file objects like StringIO and BytesIO.
This commit also adds a few tests, where they were lacking for concerned
methods.
........
Diffstat (limited to 'Modules/_io/iobase.c')
-rw-r--r-- | Modules/_io/iobase.c | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/Modules/_io/iobase.c b/Modules/_io/iobase.c index 28042c6..53cc2a3 100644 --- a/Modules/_io/iobase.c +++ b/Modules/_io/iobase.c @@ -455,7 +455,7 @@ iobase_readline(PyObject *self, PyObject *args) PyObject *buffer, *result; Py_ssize_t old_size = -1; - if (!PyArg_ParseTuple(args, "|n:readline", &limit)) { + if (!PyArg_ParseTuple(args, "|O&:readline", &_PyIO_ConvertSsize_t, &limit)) { return NULL; } @@ -579,14 +579,9 @@ iobase_readlines(PyObject *self, PyObject *args) Py_ssize_t hint = -1, length = 0; PyObject *hintobj = Py_None, *result; - if (!PyArg_ParseTuple(args, "|O:readlines", &hintobj)) { + if (!PyArg_ParseTuple(args, "|O&:readlines", &_PyIO_ConvertSsize_t, &hint)) { return NULL; } - if (hintobj != Py_None) { - hint = PyNumber_AsSsize_t(hintobj, PyExc_ValueError); - if (hint == -1 && PyErr_Occurred()) - return NULL; - } result = PyList_New(0); if (result == NULL) |