diff options
| author | Michael W. Hudson <mwh@python.net> | 2002-06-11 10:55:12 +0000 | 
|---|---|---|
| committer | Michael W. Hudson <mwh@python.net> | 2002-06-11 10:55:12 +0000 | 
| commit | 5efaf7eac8c1dbbf82a96dc5d9b87fddd5d17b58 (patch) | |
| tree | 7358a0479ab98893ad5a5457ae0df328d0e60251 /Objects/tupleobject.c | |
| parent | f90ae20354ceb501f0ba0b6459df17f1a8005a47 (diff) | |
| download | cpython-git-5efaf7eac8c1dbbf82a96dc5d9b87fddd5d17b58.tar.gz | |
This is my nearly two year old patch
[ 400998 ] experimental support for extended slicing on lists
somewhat spruced up and better tested than it was when I wrote it.
Includes docs & tests.  The whatsnew section needs expanding, and arrays
should support extended slices -- later.
Diffstat (limited to 'Objects/tupleobject.c')
| -rw-r--r-- | Objects/tupleobject.c | 59 | 
1 files changed, 58 insertions, 1 deletions
| diff --git a/Objects/tupleobject.c b/Objects/tupleobject.c index 581ccf9c6a..203801ec83 100644 --- a/Objects/tupleobject.c +++ b/Objects/tupleobject.c @@ -541,6 +541,63 @@ static PySequenceMethods tuple_as_sequence = {  	(objobjproc)tuplecontains,		/* sq_contains */  }; +static PyObject* +tuplesubscript(PyTupleObject* self, PyObject* item) +{ +	if (PyInt_Check(item)) { +		long i = PyInt_AS_LONG(item); +		if (i < 0) +			i += PyTuple_GET_SIZE(self); +		return tupleitem(self, i); +	} +	else if (PyLong_Check(item)) { +		long i = PyLong_AsLong(item); +		if (i == -1 && PyErr_Occurred()) +			return NULL; +		if (i < 0) +			i += PyTuple_GET_SIZE(self); +		return tupleitem(self, i); +	} +	else if (PySlice_Check(item)) { +		int start, stop, step, slicelength, cur, i; +		PyObject* result; +		PyObject* it; + +		if (PySlice_GetIndicesEx((PySliceObject*)item, +				 PyTuple_GET_SIZE(self), +				 &start, &stop, &step, &slicelength) < 0) { +			return NULL; +		} + +		if (slicelength <= 0) { +			return PyTuple_New(0); +		} +		else { +			result = PyTuple_New(slicelength); + +			for (cur = start, i = 0; i < slicelength;  +			     cur += step, i++) { +				it = PyTuple_GET_ITEM(self, cur); +				Py_INCREF(it); +				PyTuple_SET_ITEM(result, i, it); +			} +			 +			return result; +		} +	} +	else { +		PyErr_SetString(PyExc_TypeError,  +				"tuple indices must be integers"); +		return NULL; +	} +} + +static PyMappingMethods tuple_as_mapping = { +	(inquiry)tuplelength, +	(binaryfunc)tuplesubscript, +	0 +}; +  PyTypeObject PyTuple_Type = {  	PyObject_HEAD_INIT(&PyType_Type)  	0, @@ -555,7 +612,7 @@ PyTypeObject PyTuple_Type = {  	(reprfunc)tuplerepr,			/* tp_repr */  	0,					/* tp_as_number */  	&tuple_as_sequence,			/* tp_as_sequence */ -	0,					/* tp_as_mapping */ +	&tuple_as_mapping,			/* tp_as_mapping */  	(hashfunc)tuplehash,			/* tp_hash */  	0,					/* tp_call */  	0,					/* tp_str */ | 
