blob: 538cc704d2098784ea4b476d63241c95935a0176 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00002/* Tuple object implementation */
3
Guido van Rossumc0b618a1997-05-02 03:12:38 +00004#include "Python.h"
Guido van Rossum85a5fbb1990-10-14 12:07:46 +00005
Guido van Rossum5ce78f82000-04-21 21:15:05 +00006/* Speed optimization to avoid frequent malloc/free of small tuples */
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +00007#ifndef MAXSAVESIZE
Guido van Rossum5ce78f82000-04-21 21:15:05 +00008#define MAXSAVESIZE 20 /* Largest tuple to save on free list */
9#endif
10#ifndef MAXSAVEDTUPLES
11#define MAXSAVEDTUPLES 2000 /* Maximum number of tuples of each size to save */
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000012#endif
13
14#if MAXSAVESIZE > 0
Guido van Rossum5ce78f82000-04-21 21:15:05 +000015/* Entries 1 up to MAXSAVESIZE are free lists, entry 0 is the empty
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000016 tuple () of which at most one instance will be allocated.
17*/
Guido van Rossumc0b618a1997-05-02 03:12:38 +000018static PyTupleObject *free_tuples[MAXSAVESIZE];
Guido van Rossum5ce78f82000-04-21 21:15:05 +000019static int num_free_tuples[MAXSAVESIZE];
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000020#endif
21#ifdef COUNT_ALLOCS
22int fast_tuple_allocs;
23int tuple_zero_allocs;
24#endif
25
Guido van Rossumc0b618a1997-05-02 03:12:38 +000026PyObject *
Fred Drakeba096332000-07-09 07:04:36 +000027PyTuple_New(register int size)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000028{
29 register int i;
Guido van Rossumc0b618a1997-05-02 03:12:38 +000030 register PyTupleObject *op;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000031 if (size < 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +000032 PyErr_BadInternalCall();
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000033 return NULL;
34 }
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000035#if MAXSAVESIZE > 0
Sjoerd Mullender615194a1993-11-01 13:46:50 +000036 if (size == 0 && free_tuples[0]) {
37 op = free_tuples[0];
Guido van Rossumc0b618a1997-05-02 03:12:38 +000038 Py_INCREF(op);
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000039#ifdef COUNT_ALLOCS
40 tuple_zero_allocs++;
41#endif
Guido van Rossumc0b618a1997-05-02 03:12:38 +000042 return (PyObject *) op;
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000043 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +000044 if (0 < size && size < MAXSAVESIZE &&
45 (op = free_tuples[size]) != NULL)
46 {
47 free_tuples[size] = (PyTupleObject *) op->ob_item[0];
Guido van Rossum5ce78f82000-04-21 21:15:05 +000048 num_free_tuples[size]--;
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000049#ifdef COUNT_ALLOCS
50 fast_tuple_allocs++;
51#endif
Guido van Rossumb18618d2000-05-03 23:44:39 +000052 /* PyObject_InitVar is inlined */
Guido van Rossum68055ce1998-12-11 14:56:38 +000053#ifdef Py_TRACE_REFS
Guido van Rossum68055ce1998-12-11 14:56:38 +000054 op->ob_size = size;
Guido van Rossumb18618d2000-05-03 23:44:39 +000055 op->ob_type = &PyTuple_Type;
Guido van Rossum68055ce1998-12-11 14:56:38 +000056#endif
Guido van Rossumb18618d2000-05-03 23:44:39 +000057 _Py_NewReference((PyObject *)op);
Guido van Rossumfbbd57e1997-08-05 02:16:08 +000058 }
59 else
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000060#endif
61 {
Guido van Rossum5bc51f21999-07-12 23:06:58 +000062 int nbytes = size * sizeof(PyObject *);
63 /* Check for overflow */
64 if (nbytes / sizeof(PyObject *) != (size_t)size ||
Jeremy Hyltond08b4c42000-06-23 19:37:02 +000065 (nbytes += sizeof(PyTupleObject) - sizeof(PyObject *)
Jeremy Hyltonc5007aa2000-06-30 05:02:53 +000066 + PyGC_HEAD_SIZE)
Guido van Rossum5bc51f21999-07-12 23:06:58 +000067 <= 0)
68 {
69 return PyErr_NoMemory();
70 }
Guido van Rossumb18618d2000-05-03 23:44:39 +000071 /* PyObject_NewVar is inlined */
72 op = (PyTupleObject *) PyObject_MALLOC(nbytes);
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000073 if (op == NULL)
Guido van Rossumc0b618a1997-05-02 03:12:38 +000074 return PyErr_NoMemory();
Jeremy Hyltonc5007aa2000-06-30 05:02:53 +000075 op = (PyTupleObject *) PyObject_FROM_GC(op);
Guido van Rossumb18618d2000-05-03 23:44:39 +000076 PyObject_INIT_VAR(op, &PyTuple_Type, size);
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000077 }
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000078 for (i = 0; i < size; i++)
79 op->ob_item[i] = NULL;
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000080#if MAXSAVESIZE > 0
81 if (size == 0) {
Sjoerd Mullender615194a1993-11-01 13:46:50 +000082 free_tuples[0] = op;
Guido van Rossum5ce78f82000-04-21 21:15:05 +000083 ++num_free_tuples[0];
Guido van Rossumc0b618a1997-05-02 03:12:38 +000084 Py_INCREF(op); /* extra INCREF so that this is never freed */
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +000085 }
86#endif
Jeremy Hyltonc5007aa2000-06-30 05:02:53 +000087 PyObject_GC_Init(op);
Guido van Rossumc0b618a1997-05-02 03:12:38 +000088 return (PyObject *) op;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000089}
90
91int
Fred Drakeba096332000-07-09 07:04:36 +000092PyTuple_Size(register PyObject *op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000093{
Guido van Rossumc0b618a1997-05-02 03:12:38 +000094 if (!PyTuple_Check(op)) {
95 PyErr_BadInternalCall();
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000096 return -1;
97 }
98 else
Guido van Rossumc0b618a1997-05-02 03:12:38 +000099 return ((PyTupleObject *)op)->ob_size;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000100}
101
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000102PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000103PyTuple_GetItem(register PyObject *op, register int i)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000104{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000105 if (!PyTuple_Check(op)) {
106 PyErr_BadInternalCall();
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000107 return NULL;
108 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000109 if (i < 0 || i >= ((PyTupleObject *)op) -> ob_size) {
110 PyErr_SetString(PyExc_IndexError, "tuple index out of range");
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000111 return NULL;
112 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000113 return ((PyTupleObject *)op) -> ob_item[i];
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000114}
115
116int
Fred Drakeba096332000-07-09 07:04:36 +0000117PyTuple_SetItem(register PyObject *op, register int i, PyObject *newitem)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000118{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000119 register PyObject *olditem;
120 register PyObject **p;
Guido van Rossum787bdd31997-08-17 16:25:45 +0000121 if (!PyTuple_Check(op) || op->ob_refcnt != 1) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000122 Py_XDECREF(newitem);
123 PyErr_BadInternalCall();
Guido van Rossum2a9096b1990-10-21 22:15:08 +0000124 return -1;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000125 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000126 if (i < 0 || i >= ((PyTupleObject *)op) -> ob_size) {
127 Py_XDECREF(newitem);
128 PyErr_SetString(PyExc_IndexError,
129 "tuple assignment index out of range");
Guido van Rossum2a9096b1990-10-21 22:15:08 +0000130 return -1;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000131 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000132 p = ((PyTupleObject *)op) -> ob_item + i;
Guido van Rossum5fe60581995-03-09 12:12:50 +0000133 olditem = *p;
134 *p = newitem;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000135 Py_XDECREF(olditem);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000136 return 0;
137}
138
139/* Methods */
140
141static void
Fred Drakeba096332000-07-09 07:04:36 +0000142tupledealloc(register PyTupleObject *op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000143{
144 register int i;
Guido van Rossum5ce78f82000-04-21 21:15:05 +0000145 register int len = op->ob_size;
Guido van Rossumd724b232000-03-13 16:01:29 +0000146 Py_TRASHCAN_SAFE_BEGIN(op)
Jeremy Hyltonc5007aa2000-06-30 05:02:53 +0000147 PyObject_GC_Fini(op);
Guido van Rossum5ce78f82000-04-21 21:15:05 +0000148 if (len > 0) {
149 i = len;
Guido van Rossum1bb26871998-06-26 15:53:50 +0000150 while (--i >= 0)
151 Py_XDECREF(op->ob_item[i]);
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +0000152#if MAXSAVESIZE > 0
Guido van Rossum5ce78f82000-04-21 21:15:05 +0000153 if (len < MAXSAVESIZE && num_free_tuples[len] < MAXSAVEDTUPLES) {
154 op->ob_item[0] = (PyObject *) free_tuples[len];
155 num_free_tuples[len]++;
156 free_tuples[len] = op;
Guido van Rossumd724b232000-03-13 16:01:29 +0000157 goto done; /* return */
Guido van Rossum1bb26871998-06-26 15:53:50 +0000158 }
Sjoerd Mullender842d2cc1993-10-15 16:18:48 +0000159#endif
Guido van Rossum1bb26871998-06-26 15:53:50 +0000160 }
Guido van Rossum4cc6ac72000-07-01 01:00:38 +0000161 op = (PyTupleObject *) PyObject_AS_GC(op);
Guido van Rossumb18618d2000-05-03 23:44:39 +0000162 PyObject_DEL(op);
Guido van Rossumd724b232000-03-13 16:01:29 +0000163done:
164 Py_TRASHCAN_SAFE_END(op)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000165}
166
Guido van Rossum49e85141991-06-07 22:59:30 +0000167static int
Fred Drakeba096332000-07-09 07:04:36 +0000168tupleprint(PyTupleObject *op, FILE *fp, int flags)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000169{
170 int i;
171 fprintf(fp, "(");
Guido van Rossum49e85141991-06-07 22:59:30 +0000172 for (i = 0; i < op->ob_size; i++) {
173 if (i > 0)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000174 fprintf(fp, ", ");
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000175 if (PyObject_Print(op->ob_item[i], fp, 0) != 0)
Guido van Rossum49e85141991-06-07 22:59:30 +0000176 return -1;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000177 }
178 if (op->ob_size == 1)
179 fprintf(fp, ",");
180 fprintf(fp, ")");
Guido van Rossum49e85141991-06-07 22:59:30 +0000181 return 0;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000182}
183
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000184static PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000185tuplerepr(PyTupleObject *v)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000186{
Tim Petersa7259592001-06-16 05:11:17 +0000187 int i, n;
188 PyObject *s, *temp;
189 PyObject *pieces, *result = NULL;
190
191 n = v->ob_size;
192 if (n == 0)
193 return PyString_FromString("()");
194
195 pieces = PyTuple_New(n);
196 if (pieces == NULL)
197 return NULL;
198
199 /* Do repr() on each element. */
200 for (i = 0; i < n; ++i) {
201 s = PyObject_Repr(v->ob_item[i]);
202 if (s == NULL)
203 goto Done;
204 PyTuple_SET_ITEM(pieces, i, s);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000205 }
Tim Petersa7259592001-06-16 05:11:17 +0000206
207 /* Add "()" decorations to the first and last items. */
208 assert(n > 0);
209 s = PyString_FromString("(");
210 if (s == NULL)
211 goto Done;
212 temp = PyTuple_GET_ITEM(pieces, 0);
213 PyString_ConcatAndDel(&s, temp);
214 PyTuple_SET_ITEM(pieces, 0, s);
215 if (s == NULL)
216 goto Done;
217
218 s = PyString_FromString(n == 1 ? ",)" : ")");
219 if (s == NULL)
220 goto Done;
221 temp = PyTuple_GET_ITEM(pieces, n-1);
222 PyString_ConcatAndDel(&temp, s);
223 PyTuple_SET_ITEM(pieces, n-1, temp);
224 if (temp == NULL)
225 goto Done;
226
227 /* Paste them all together with ", " between. */
228 s = PyString_FromString(", ");
229 if (s == NULL)
230 goto Done;
231 result = _PyString_Join(s, pieces);
232 Py_DECREF(s);
233
234Done:
235 Py_DECREF(pieces);
236 return result;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000237}
238
Guido van Rossum9bfef441993-03-29 10:43:31 +0000239static long
Fred Drakeba096332000-07-09 07:04:36 +0000240tuplehash(PyTupleObject *v)
Guido van Rossum9bfef441993-03-29 10:43:31 +0000241{
242 register long x, y;
243 register int len = v->ob_size;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000244 register PyObject **p;
Guido van Rossum9bfef441993-03-29 10:43:31 +0000245 x = 0x345678L;
246 p = v->ob_item;
247 while (--len >= 0) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000248 y = PyObject_Hash(*p++);
Guido van Rossum9bfef441993-03-29 10:43:31 +0000249 if (y == -1)
250 return -1;
Guido van Rossum0969ad21996-12-16 17:55:46 +0000251 x = (1000003*x) ^ y;
Guido van Rossum9bfef441993-03-29 10:43:31 +0000252 }
253 x ^= v->ob_size;
254 if (x == -1)
255 x = -2;
256 return x;
257}
258
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000259static int
Fred Drakeba096332000-07-09 07:04:36 +0000260tuplelength(PyTupleObject *a)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000261{
262 return a->ob_size;
263}
264
Jeremy Hylton37b1a262000-04-27 21:41:03 +0000265static int
Fred Drakeba096332000-07-09 07:04:36 +0000266tuplecontains(PyTupleObject *a, PyObject *el)
Jeremy Hylton37b1a262000-04-27 21:41:03 +0000267{
268 int i, cmp;
269
270 for (i = 0; i < a->ob_size; ++i) {
Guido van Rossumf77bc622001-01-18 00:00:53 +0000271 cmp = PyObject_RichCompareBool(el, PyTuple_GET_ITEM(a, i),
272 Py_EQ);
273 if (cmp > 0)
Jeremy Hylton37b1a262000-04-27 21:41:03 +0000274 return 1;
Guido van Rossumf77bc622001-01-18 00:00:53 +0000275 else if (cmp < 0)
Jeremy Hylton37b1a262000-04-27 21:41:03 +0000276 return -1;
277 }
278 return 0;
279}
280
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000281static PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000282tupleitem(register PyTupleObject *a, register int i)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000283{
284 if (i < 0 || i >= a->ob_size) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000285 PyErr_SetString(PyExc_IndexError, "tuple index out of range");
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000286 return NULL;
287 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000288 Py_INCREF(a->ob_item[i]);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000289 return a->ob_item[i];
290}
291
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000292static PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000293tupleslice(register PyTupleObject *a, register int ilow, register int ihigh)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000294{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000295 register PyTupleObject *np;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000296 register int i;
297 if (ilow < 0)
298 ilow = 0;
299 if (ihigh > a->ob_size)
300 ihigh = a->ob_size;
301 if (ihigh < ilow)
302 ihigh = ilow;
303 if (ilow == 0 && ihigh == a->ob_size) {
304 /* XXX can only do this if tuples are immutable! */
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000305 Py_INCREF(a);
306 return (PyObject *)a;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000307 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000308 np = (PyTupleObject *)PyTuple_New(ihigh - ilow);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000309 if (np == NULL)
310 return NULL;
311 for (i = ilow; i < ihigh; i++) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000312 PyObject *v = a->ob_item[i];
313 Py_INCREF(v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000314 np->ob_item[i - ilow] = v;
315 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000316 return (PyObject *)np;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000317}
318
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000319PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000320PyTuple_GetSlice(PyObject *op, int i, int j)
Guido van Rossum7c36ad71992-01-14 18:45:33 +0000321{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000322 if (op == NULL || !PyTuple_Check(op)) {
323 PyErr_BadInternalCall();
Guido van Rossum7c36ad71992-01-14 18:45:33 +0000324 return NULL;
325 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000326 return tupleslice((PyTupleObject *)op, i, j);
Guido van Rossum7c36ad71992-01-14 18:45:33 +0000327}
328
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000329static PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000330tupleconcat(register PyTupleObject *a, register PyObject *bb)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000331{
332 register int size;
333 register int i;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000334 PyTupleObject *np;
335 if (!PyTuple_Check(bb)) {
Fred Drakeb6a9ada2000-06-01 03:12:13 +0000336 PyErr_Format(PyExc_TypeError,
Marc-André Lemburg29dc3812000-06-16 17:05:57 +0000337 "can only concatenate tuple (not \"%.200s\") to tuple",
Fred Drakeb6a9ada2000-06-01 03:12:13 +0000338 bb->ob_type->tp_name);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000339 return NULL;
340 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000341#define b ((PyTupleObject *)bb)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000342 size = a->ob_size + b->ob_size;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000343 np = (PyTupleObject *) PyTuple_New(size);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000344 if (np == NULL) {
Guido van Rossum49e85141991-06-07 22:59:30 +0000345 return NULL;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000346 }
347 for (i = 0; i < a->ob_size; i++) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000348 PyObject *v = a->ob_item[i];
349 Py_INCREF(v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000350 np->ob_item[i] = v;
351 }
352 for (i = 0; i < b->ob_size; i++) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000353 PyObject *v = b->ob_item[i];
354 Py_INCREF(v);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000355 np->ob_item[i + a->ob_size] = v;
356 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000357 return (PyObject *)np;
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000358#undef b
359}
360
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000361static PyObject *
Fred Drakeba096332000-07-09 07:04:36 +0000362tuplerepeat(PyTupleObject *a, int n)
Guido van Rossumb8393da1991-06-04 19:35:24 +0000363{
364 int i, j;
365 int size;
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000366 PyTupleObject *np;
367 PyObject **p;
Guido van Rossumb8393da1991-06-04 19:35:24 +0000368 if (n < 0)
369 n = 0;
Guido van Rossum5bc51f21999-07-12 23:06:58 +0000370 if (a->ob_size == 0 || n == 1) {
Guido van Rossumb8393da1991-06-04 19:35:24 +0000371 /* Since tuples are immutable, we can return a shared
372 copy in this case */
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000373 Py_INCREF(a);
374 return (PyObject *)a;
Guido van Rossumb8393da1991-06-04 19:35:24 +0000375 }
376 size = a->ob_size * n;
Guido van Rossum0eb55ac1999-07-13 05:41:12 +0000377 if (size/a->ob_size != n)
Guido van Rossum5bc51f21999-07-12 23:06:58 +0000378 return PyErr_NoMemory();
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000379 np = (PyTupleObject *) PyTuple_New(size);
Guido van Rossumb8393da1991-06-04 19:35:24 +0000380 if (np == NULL)
381 return NULL;
382 p = np->ob_item;
383 for (i = 0; i < n; i++) {
384 for (j = 0; j < a->ob_size; j++) {
385 *p = a->ob_item[j];
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000386 Py_INCREF(*p);
Guido van Rossumb8393da1991-06-04 19:35:24 +0000387 p++;
388 }
389 }
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000390 return (PyObject *) np;
Guido van Rossumb8393da1991-06-04 19:35:24 +0000391}
392
Jeremy Hylton8caad492000-06-23 14:18:11 +0000393static int
394tupletraverse(PyTupleObject *o, visitproc visit, void *arg)
395{
396 int i, err;
397 PyObject *x;
398
399 for (i = o->ob_size; --i >= 0; ) {
400 x = o->ob_item[i];
401 if (x != NULL) {
402 err = visit(x, arg);
403 if (err)
404 return err;
405 }
406 }
407 return 0;
408}
409
Guido van Rossumf77bc622001-01-18 00:00:53 +0000410static PyObject *
411tuplerichcompare(PyObject *v, PyObject *w, int op)
412{
413 PyTupleObject *vt, *wt;
414 int i;
Tim Petersd7ed3bf2001-05-15 20:12:59 +0000415 int vlen, wlen;
Guido van Rossumf77bc622001-01-18 00:00:53 +0000416
417 if (!PyTuple_Check(v) || !PyTuple_Check(w)) {
418 Py_INCREF(Py_NotImplemented);
419 return Py_NotImplemented;
420 }
421
422 vt = (PyTupleObject *)v;
423 wt = (PyTupleObject *)w;
424
Tim Petersd7ed3bf2001-05-15 20:12:59 +0000425 vlen = vt->ob_size;
426 wlen = wt->ob_size;
Guido van Rossumf77bc622001-01-18 00:00:53 +0000427
Tim Petersd7ed3bf2001-05-15 20:12:59 +0000428 /* Note: the corresponding code for lists has an "early out" test
429 * here when op is EQ or NE and the lengths differ. That pays there,
430 * but Tim was unable to find any real code where EQ/NE tuple
431 * compares don't have the same length, so testing for it here would
432 * have cost without benefit.
433 */
434
435 /* Search for the first index where items are different.
436 * Note that because tuples are immutable, it's safe to reuse
437 * vlen and wlen across the comparison calls.
438 */
439 for (i = 0; i < vlen && i < wlen; i++) {
Guido van Rossumf77bc622001-01-18 00:00:53 +0000440 int k = PyObject_RichCompareBool(vt->ob_item[i],
441 wt->ob_item[i], Py_EQ);
442 if (k < 0)
443 return NULL;
444 if (!k)
445 break;
446 }
447
Tim Petersd7ed3bf2001-05-15 20:12:59 +0000448 if (i >= vlen || i >= wlen) {
Guido van Rossumf77bc622001-01-18 00:00:53 +0000449 /* No more items to compare -- compare sizes */
Guido van Rossumf77bc622001-01-18 00:00:53 +0000450 int cmp;
451 PyObject *res;
452 switch (op) {
Tim Petersd7ed3bf2001-05-15 20:12:59 +0000453 case Py_LT: cmp = vlen < wlen; break;
454 case Py_LE: cmp = vlen <= wlen; break;
455 case Py_EQ: cmp = vlen == wlen; break;
456 case Py_NE: cmp = vlen != wlen; break;
457 case Py_GT: cmp = vlen > wlen; break;
458 case Py_GE: cmp = vlen >= wlen; break;
Guido van Rossumf77bc622001-01-18 00:00:53 +0000459 default: return NULL; /* cannot happen */
460 }
461 if (cmp)
462 res = Py_True;
463 else
464 res = Py_False;
465 Py_INCREF(res);
466 return res;
467 }
468
469 /* We have an item that differs -- shortcuts for EQ/NE */
470 if (op == Py_EQ) {
471 Py_INCREF(Py_False);
472 return Py_False;
473 }
474 if (op == Py_NE) {
475 Py_INCREF(Py_True);
476 return Py_True;
477 }
478
479 /* Compare the final item again using the proper operator */
480 return PyObject_RichCompare(vt->ob_item[i], wt->ob_item[i], op);
481}
482
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000483static PySequenceMethods tuple_as_sequence = {
Guido van Rossumf77bc622001-01-18 00:00:53 +0000484 (inquiry)tuplelength, /* sq_length */
485 (binaryfunc)tupleconcat, /* sq_concat */
486 (intargfunc)tuplerepeat, /* sq_repeat */
487 (intargfunc)tupleitem, /* sq_item */
488 (intintargfunc)tupleslice, /* sq_slice */
489 0, /* sq_ass_item */
490 0, /* sq_ass_slice */
491 (objobjproc)tuplecontains, /* sq_contains */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000492};
493
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000494PyTypeObject PyTuple_Type = {
495 PyObject_HEAD_INIT(&PyType_Type)
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000496 0,
497 "tuple",
Jeremy Hyltonc5007aa2000-06-30 05:02:53 +0000498 sizeof(PyTupleObject) - sizeof(PyObject *) + PyGC_HEAD_SIZE,
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000499 sizeof(PyObject *),
Guido van Rossumf77bc622001-01-18 00:00:53 +0000500 (destructor)tupledealloc, /* tp_dealloc */
501 (printfunc)tupleprint, /* tp_print */
502 0, /* tp_getattr */
503 0, /* tp_setattr */
504 0, /* tp_compare */
505 (reprfunc)tuplerepr, /* tp_repr */
506 0, /* tp_as_number */
507 &tuple_as_sequence, /* tp_as_sequence */
508 0, /* tp_as_mapping */
509 (hashfunc)tuplehash, /* tp_hash */
510 0, /* tp_call */
511 0, /* tp_str */
512 0, /* tp_getattro */
513 0, /* tp_setattro */
514 0, /* tp_as_buffer */
515 Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC, /* tp_flags */
516 0, /* tp_doc */
517 (traverseproc)tupletraverse, /* tp_traverse */
518 0, /* tp_clear */
519 tuplerichcompare, /* tp_richcompare */
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000520};
Guido van Rossum12d12c51993-10-26 17:58:25 +0000521
522/* The following function breaks the notion that tuples are immutable:
523 it changes the size of a tuple. We get away with this only if there
524 is only one module referencing the object. You can also think of it
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000525 as creating a new tuple object and destroying the old one, only more
526 efficiently. In any case, don't use this if the tuple may already be
Tim Peters4324aa32001-05-28 22:30:08 +0000527 known to some other part of the code. */
Guido van Rossum12d12c51993-10-26 17:58:25 +0000528
529int
Tim Peters4324aa32001-05-28 22:30:08 +0000530_PyTuple_Resize(PyObject **pv, int newsize)
Guido van Rossum12d12c51993-10-26 17:58:25 +0000531{
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000532 register PyTupleObject *v;
533 register PyTupleObject *sv;
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000534 int i;
535 int sizediff;
536
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000537 v = (PyTupleObject *) *pv;
Tim Peters4324aa32001-05-28 22:30:08 +0000538 if (v == NULL || !PyTuple_Check(v) ||
Thomas Wouters6a922372001-05-28 13:11:02 +0000539 (v->ob_size != 0 && v->ob_refcnt != 1)) {
Guido van Rossum12d12c51993-10-26 17:58:25 +0000540 *pv = 0;
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000541 Py_XDECREF(v);
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000542 PyErr_BadInternalCall();
Guido van Rossum12d12c51993-10-26 17:58:25 +0000543 return -1;
544 }
Guido van Rossum055968c1995-08-04 04:05:10 +0000545 sizediff = newsize - v->ob_size;
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000546 if (sizediff == 0)
547 return 0;
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000548
Thomas Wouters6a922372001-05-28 13:11:02 +0000549 if (v->ob_size == 0) {
550 /* Empty tuples are often shared, so we should never
551 resize them in-place even if we do own the only
552 (current) reference */
553 Py_DECREF(v);
554 *pv = PyTuple_New(newsize);
Thomas Wouters0dcea592001-05-29 07:58:45 +0000555 return *pv == NULL ? -1 : 0;
Thomas Wouters6a922372001-05-28 13:11:02 +0000556 }
557
Guido van Rossum12d12c51993-10-26 17:58:25 +0000558 /* XXX UNREF/NEWREF interface should be more symmetrical */
Guido van Rossum441e4ab1996-05-23 22:46:51 +0000559#ifdef Py_REF_DEBUG
Guido van Rossum6f9e4331995-03-29 16:57:48 +0000560 --_Py_RefTotal;
Guido van Rossum12d12c51993-10-26 17:58:25 +0000561#endif
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000562 _Py_ForgetReference((PyObject *) v);
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000563 for (i = newsize; i < v->ob_size; i++) {
Guido van Rossumc0b618a1997-05-02 03:12:38 +0000564 Py_XDECREF(v->ob_item[i]);
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000565 v->ob_item[i] = NULL;
566 }
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000567 PyObject_GC_Fini(v);
568 v = (PyTupleObject *) PyObject_AS_GC(v);
569 sv = (PyTupleObject *) PyObject_REALLOC((char *)v,
570 sizeof(PyTupleObject)
571 + PyGC_HEAD_SIZE
572 + newsize * sizeof(PyObject *));
573 if (sv == NULL) {
574 *pv = NULL;
575 PyObject_DEL(v);
576 PyErr_NoMemory();
577 return -1;
Guido van Rossum5ce78f82000-04-21 21:15:05 +0000578 }
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000579 sv = (PyTupleObject *) PyObject_FROM_GC(sv);
580 _Py_NewReference((PyObject *) sv);
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000581 for (i = sv->ob_size; i < newsize; i++)
582 sv->ob_item[i] = NULL;
Sjoerd Mullender615194a1993-11-01 13:46:50 +0000583 sv->ob_size = newsize;
Neil Schemenauer08b53e62000-10-05 19:36:49 +0000584 *pv = (PyObject *) sv;
585 PyObject_GC_Init(sv);
Guido van Rossum12d12c51993-10-26 17:58:25 +0000586 return 0;
587}
Guido van Rossumfbbd57e1997-08-05 02:16:08 +0000588
589void
Fred Drakeba096332000-07-09 07:04:36 +0000590PyTuple_Fini(void)
Guido van Rossumfbbd57e1997-08-05 02:16:08 +0000591{
592#if MAXSAVESIZE > 0
593 int i;
594
595 Py_XDECREF(free_tuples[0]);
596 free_tuples[0] = NULL;
597
598 for (i = 1; i < MAXSAVESIZE; i++) {
599 PyTupleObject *p, *q;
600 p = free_tuples[i];
601 free_tuples[i] = NULL;
602 while (p) {
603 q = p;
604 p = (PyTupleObject *)(p->ob_item[0]);
Guido van Rossum4cc6ac72000-07-01 01:00:38 +0000605 q = (PyTupleObject *) PyObject_AS_GC(q);
Guido van Rossumb18618d2000-05-03 23:44:39 +0000606 PyObject_DEL(q);
Guido van Rossumfbbd57e1997-08-05 02:16:08 +0000607 }
608 }
609#endif
610}