blob: 3cbfe5bcaa74991ec247ee1c0308b5638585cbc5 [file] [log] [blame]
Georg Brandl54a3faa2008-01-20 09:30:57 +00001.. highlightlang:: c
2
3.. _tupleobjects:
4
5Tuple Objects
6-------------
7
8.. index:: object: tuple
9
10
Georg Brandl60203b42010-10-06 10:11:56 +000011.. c:type:: PyTupleObject
Georg Brandl54a3faa2008-01-20 09:30:57 +000012
Georg Brandl60203b42010-10-06 10:11:56 +000013 This subtype of :c:type:`PyObject` represents a Python tuple object.
Georg Brandl54a3faa2008-01-20 09:30:57 +000014
15
Georg Brandl60203b42010-10-06 10:11:56 +000016.. c:var:: PyTypeObject PyTuple_Type
Georg Brandl54a3faa2008-01-20 09:30:57 +000017
Georg Brandl2aff3352010-10-17 10:59:41 +000018 This instance of :c:type:`PyTypeObject` represents the Python tuple type; it
19 is the same object as :class:`tuple` in the Python layer.
Georg Brandl54a3faa2008-01-20 09:30:57 +000020
21
Georg Brandl60203b42010-10-06 10:11:56 +000022.. c:function:: int PyTuple_Check(PyObject *p)
Georg Brandl54a3faa2008-01-20 09:30:57 +000023
24 Return true if *p* is a tuple object or an instance of a subtype of the tuple
25 type.
26
27
Georg Brandl60203b42010-10-06 10:11:56 +000028.. c:function:: int PyTuple_CheckExact(PyObject *p)
Georg Brandl54a3faa2008-01-20 09:30:57 +000029
30 Return true if *p* is a tuple object, but not an instance of a subtype of the
31 tuple type.
32
33
Georg Brandl60203b42010-10-06 10:11:56 +000034.. c:function:: PyObject* PyTuple_New(Py_ssize_t len)
Georg Brandl54a3faa2008-01-20 09:30:57 +000035
36 Return a new tuple object of size *len*, or *NULL* on failure.
37
38
Georg Brandl60203b42010-10-06 10:11:56 +000039.. c:function:: PyObject* PyTuple_Pack(Py_ssize_t n, ...)
Georg Brandl54a3faa2008-01-20 09:30:57 +000040
41 Return a new tuple object of size *n*, or *NULL* on failure. The tuple values
42 are initialized to the subsequent *n* C arguments pointing to Python objects.
43 ``PyTuple_Pack(2, a, b)`` is equivalent to ``Py_BuildValue("(OO)", a, b)``.
44
45
Georg Brandl60203b42010-10-06 10:11:56 +000046.. c:function:: Py_ssize_t PyTuple_Size(PyObject *p)
Georg Brandl54a3faa2008-01-20 09:30:57 +000047
48 Take a pointer to a tuple object, and return the size of that tuple.
49
50
Georg Brandl60203b42010-10-06 10:11:56 +000051.. c:function:: Py_ssize_t PyTuple_GET_SIZE(PyObject *p)
Georg Brandl54a3faa2008-01-20 09:30:57 +000052
53 Return the size of the tuple *p*, which must be non-*NULL* and point to a tuple;
54 no error checking is performed.
55
56
Georg Brandl60203b42010-10-06 10:11:56 +000057.. c:function:: PyObject* PyTuple_GetItem(PyObject *p, Py_ssize_t pos)
Georg Brandl54a3faa2008-01-20 09:30:57 +000058
59 Return the object at position *pos* in the tuple pointed to by *p*. If *pos* is
60 out of bounds, return *NULL* and sets an :exc:`IndexError` exception.
61
62
Georg Brandl60203b42010-10-06 10:11:56 +000063.. c:function:: PyObject* PyTuple_GET_ITEM(PyObject *p, Py_ssize_t pos)
Georg Brandl54a3faa2008-01-20 09:30:57 +000064
Georg Brandl60203b42010-10-06 10:11:56 +000065 Like :c:func:`PyTuple_GetItem`, but does no checking of its arguments.
Georg Brandl54a3faa2008-01-20 09:30:57 +000066
67
Georg Brandl60203b42010-10-06 10:11:56 +000068.. c:function:: PyObject* PyTuple_GetSlice(PyObject *p, Py_ssize_t low, Py_ssize_t high)
Georg Brandl54a3faa2008-01-20 09:30:57 +000069
70 Take a slice of the tuple pointed to by *p* from *low* to *high* and return it
71 as a new tuple.
72
73
Georg Brandl60203b42010-10-06 10:11:56 +000074.. c:function:: int PyTuple_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)
Georg Brandl54a3faa2008-01-20 09:30:57 +000075
76 Insert a reference to object *o* at position *pos* of the tuple pointed to by
77 *p*. Return ``0`` on success.
78
79 .. note::
80
81 This function "steals" a reference to *o*.
82
83
Georg Brandl60203b42010-10-06 10:11:56 +000084.. c:function:: void PyTuple_SET_ITEM(PyObject *p, Py_ssize_t pos, PyObject *o)
Georg Brandl54a3faa2008-01-20 09:30:57 +000085
Georg Brandl60203b42010-10-06 10:11:56 +000086 Like :c:func:`PyTuple_SetItem`, but does no error checking, and should *only* be
Georg Brandl54a3faa2008-01-20 09:30:57 +000087 used to fill in brand new tuples.
88
89 .. note::
90
91 This function "steals" a reference to *o*.
92
93
Georg Brandl60203b42010-10-06 10:11:56 +000094.. c:function:: int _PyTuple_Resize(PyObject **p, Py_ssize_t newsize)
Georg Brandl54a3faa2008-01-20 09:30:57 +000095
96 Can be used to resize a tuple. *newsize* will be the new length of the tuple.
97 Because tuples are *supposed* to be immutable, this should only be used if there
98 is only one reference to the object. Do *not* use this if the tuple may already
99 be known to some other part of the code. The tuple will always grow or shrink
100 at the end. Think of this as destroying the old tuple and creating a new one,
101 only more efficiently. Returns ``0`` on success. Client code should never
102 assume that the resulting value of ``*p`` will be the same as before calling
103 this function. If the object referenced by ``*p`` is replaced, the original
104 ``*p`` is destroyed. On failure, returns ``-1`` and sets ``*p`` to *NULL*, and
105 raises :exc:`MemoryError` or :exc:`SystemError`.
Christian Heimesa156e092008-02-16 07:38:31 +0000106
Jeroen Ruigrok van der Wervenbd875522009-04-26 21:06:15 +0000107
Georg Brandl60203b42010-10-06 10:11:56 +0000108.. c:function:: int PyTuple_ClearFreeList()
Christian Heimesa156e092008-02-16 07:38:31 +0000109
110 Clear the free list. Return the total number of freed items.