]> granicus.if.org Git - python/commitdiff
Add an exact type match fast path for deque_copy().
authorRaymond Hettinger <python@rcn.com>
Sun, 13 Sep 2015 23:27:01 +0000 (19:27 -0400)
committerRaymond Hettinger <python@rcn.com>
Sun, 13 Sep 2015 23:27:01 +0000 (19:27 -0400)
Modules/_collectionsmodule.c

index 17233e4089450303400b24da0f17500c4a50445a..49a46a153eba12a492bb87b8163bd50d09ba124b 100644 (file)
@@ -1205,6 +1205,22 @@ deque_traverse(dequeobject *deque, visitproc visit, void *arg)
 static PyObject *
 deque_copy(PyObject *deque)
 {
+    if (Py_TYPE(deque) == &deque_type) {
+        dequeobject *new_deque;
+        PyObject *rv;
+
+        new_deque = (dequeobject *)deque_new(&deque_type, (PyObject *)NULL, (PyObject *)NULL);
+        if (new_deque == NULL)
+            return NULL;
+        new_deque->maxlen = ((dequeobject *)deque)->maxlen;
+        rv = deque_extend(new_deque, deque);
+        if (rv != NULL) {
+            Py_DECREF(rv);
+            return (PyObject *)new_deque;
+        }
+        Py_DECREF(new_deque);
+        return NULL;
+    }
     if (((dequeobject *)deque)->maxlen == -1)
         return PyObject_CallFunction((PyObject *)(Py_TYPE(deque)), "O", deque, NULL);
     else