summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-04-04 14:06:55 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2015-04-04 14:06:55 (GMT)
commit04e6dba7dc59d2afa072ee53160f90d7090ad72d (patch)
tree79011a32f07bbec589eaed7d16e2a29ee8aeec78 /Modules
parentb599ca8cff849e45c30a499bc2d38c25766694b8 (diff)
downloadcpython-04e6dba7dc59d2afa072ee53160f90d7090ad72d.zip
cpython-04e6dba7dc59d2afa072ee53160f90d7090ad72d.tar.gz
cpython-04e6dba7dc59d2afa072ee53160f90d7090ad72d.tar.bz2
Fixed the array module broken in issue #23492.
array_array_frombytes() is used in other functions, but it's signature was changed. Closes issue #23866.
Diffstat (limited to 'Modules')
-rw-r--r--Modules/arraymodule.c19
1 files changed, 4 insertions, 15 deletions
diff --git a/Modules/arraymodule.c b/Modules/arraymodule.c
index 3e9f297..6e20aaa 100644
--- a/Modules/arraymodule.c
+++ b/Modules/arraymodule.c
@@ -1403,7 +1403,7 @@ static PyObject *
array_array_fromfile_impl(arrayobject *self, PyObject *f, Py_ssize_t n)
/*[clinic end generated code: output=ec9f600e10f53510 input=e188afe8e58adf40]*/
{
- PyObject *args, *b, *res;
+ PyObject *b, *res;
Py_ssize_t itemsize = self->ob_descr->itemsize;
Py_ssize_t nbytes;
_Py_IDENTIFIER(read);
@@ -1432,13 +1432,8 @@ array_array_fromfile_impl(arrayobject *self, PyObject *f, Py_ssize_t n)
not_enough_bytes = (PyBytes_GET_SIZE(b) != nbytes);
- args = Py_BuildValue("(O)", b);
+ res = array_array_frombytes(self, b);
Py_DECREF(b);
- if (args == NULL)
- return NULL;
-
- res = array_array_frombytes(self, args);
- Py_DECREF(args);
if (res == NULL)
return NULL;
@@ -2672,15 +2667,9 @@ array_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
}
else if (initial != NULL && (PyByteArray_Check(initial) ||
PyBytes_Check(initial))) {
- PyObject *t_initial, *v;
- t_initial = PyTuple_Pack(1, initial);
- if (t_initial == NULL) {
- Py_DECREF(a);
- return NULL;
- }
+ PyObject *v;
v = array_array_frombytes((arrayobject *)a,
- t_initial);
- Py_DECREF(t_initial);
+ initial);
if (v == NULL) {
Py_DECREF(a);
return NULL;