summaryrefslogtreecommitdiffstats
path: root/Objects/listobject.c
diff options
context:
space:
mode:
Diffstat (limited to 'Objects/listobject.c')
-rw-r--r--Objects/listobject.c27
1 files changed, 13 insertions, 14 deletions
diff --git a/Objects/listobject.c b/Objects/listobject.c
index b61d7da..6bb6d8c7 100644
--- a/Objects/listobject.c
+++ b/Objects/listobject.c
@@ -708,20 +708,6 @@ listextend_internal(PyListObject *self, PyObject *b)
}
static PyObject *
-list_inplace_concat(PyListObject *self, PyObject *other)
-{
- other = PySequence_Fast(other, "argument to += must be iterable");
- if (!other)
- return NULL;
-
- if (listextend_internal(self, other) < 0)
- return NULL;
-
- Py_INCREF(self);
- return (PyObject *)self;
-}
-
-static PyObject *
listextend(PyListObject *self, PyObject *b)
{
PyObject *it; /* iter(v) */
@@ -791,6 +777,19 @@ listextend(PyListObject *self, PyObject *b)
}
static PyObject *
+list_inplace_concat(PyListObject *self, PyObject *other)
+{
+ PyObject *result;
+
+ result = listextend(self, other);
+ if (result == NULL)
+ return result;
+ Py_DECREF(result);
+ Py_INCREF(self);
+ return (PyObject *)self;
+}
+
+static PyObject *
listpop(PyListObject *self, PyObject *args)
{
int i = -1;