diff options
-rw-r--r-- | Modules/arraymodule.c | 92 |
1 files changed, 27 insertions, 65 deletions
diff --git a/Modules/arraymodule.c b/Modules/arraymodule.c index 43be90c..7197147 100644 --- a/Modules/arraymodule.c +++ b/Modules/arraymodule.c @@ -1,4 +1,3 @@ - /* Array object implementation */ /* An array is a uniform list -- all items have the same type. @@ -19,6 +18,10 @@ struct arrayobject; /* Forward */ +/* All possible arraydescr values are defined in the vector "descriptors" + * below. That's defined later because the appropriate get and set + * functions aren't visible yet. + */ struct arraydescr { int typecode; int itemsize; @@ -36,17 +39,17 @@ staticforward PyTypeObject Arraytype; #define is_arrayobject(op) ((op)->ob_type == &Arraytype) -/* Forward */ -static PyObject *newarrayobject(int, struct arraydescr *); -#if 0 -static int getarraysize(PyObject *); -#endif -static PyObject *getarrayitem(PyObject *, int); -static int setarrayitem(PyObject *, int, PyObject *); -#if 0 -static int insarrayitem(PyObject *, int, PyObject *); -static int addarrayitem(PyObject *, PyObject *); -#endif +/**************************************************************************** +Get and Set functions for each type. +A Get function takes an arrayobject* and an integer index, returning the +array value at that index wrapped in an appropriate PyObject*. +A Set function takes an arrayobject, integer index, and PyObject*; sets +the array value at that index to the raw C data extracted from the PyObject*, +and returns 0 if successful, else nonzero on failure (PyObject* not of an +appropriate type or value). +Note that the basic Get and Set functions do NOT check that the index is +in bounds; that's the responsibility of the caller. +****************************************************************************/ static PyObject * c_getitem(arrayobject *ap, int i) @@ -208,7 +211,7 @@ II_setitem(arrayobject *ap, int i, PyObject *v) return -1; } x = (unsigned long)y; - + } if (x > UINT_MAX) { PyErr_SetString(PyExc_OverflowError, @@ -263,14 +266,14 @@ LL_setitem(arrayobject *ap, int i, PyObject *v) return -1; } x = (unsigned long)y; - + } if (x > ULONG_MAX) { PyErr_SetString(PyExc_OverflowError, "unsigned long is greater than maximum"); return -1; } - + if (i >= 0) ((unsigned long *)ap->ob_item)[i] = x; return 0; @@ -326,7 +329,10 @@ static struct arraydescr descriptors[] = { {'\0', 0, 0, 0} /* Sentinel */ }; /* If we ever allow items larger than double, we must change reverse()! */ - + +/**************************************************************************** +Implementations of array object methods. +****************************************************************************/ static PyObject * newarrayobject(int size, struct arraydescr *descr) @@ -360,26 +366,11 @@ newarrayobject(int size, struct arraydescr *descr) return (PyObject *) op; } -#if 0 -static int -getarraysize(PyObject *op) -{ - if (!is_arrayobject(op)) { - PyErr_BadInternalCall(); - return -1; - } - return ((arrayobject *)op) -> ob_size; -} -#endif - static PyObject * getarrayitem(PyObject *op, int i) { register arrayobject *ap; - if (!is_arrayobject(op)) { - PyErr_BadInternalCall(); - return NULL; - } + assert(is_arrayobject(op)); ap = (arrayobject *)op; if (i < 0 || i >= ap->ob_size) { PyErr_SetString(PyExc_IndexError, "array index out of range"); @@ -417,29 +408,6 @@ ins1(arrayobject *self, int where, PyObject *v) return (*self->ob_descr->setitem)(self, where, v); } -#if 0 -static int -insarrayitem(PyObject *op, int where, PyObject *newitem) -{ - if (!is_arrayobject(op)) { - PyErr_BadInternalCall(); - return -1; - } - return ins1((arrayobject *)op, where, newitem); -} - -static int -addarrayitem(PyObject *op, PyObject *newitem) -{ - if (!is_arrayobject(op)) { - PyErr_BadInternalCall(); - return -1; - } - return ins1((arrayobject *)op, - (int) ((arrayobject *)op)->ob_size, newitem); -} -#endif - /* Methods */ static void @@ -648,10 +616,7 @@ array_ass_item(arrayobject *a, int i, PyObject *v) static int setarrayitem(PyObject *a, int i, PyObject *v) { - if (!is_arrayobject(a)) { - PyErr_BadInternalCall(); - return -1; - } + assert(is_arrayobject(a)); return array_ass_item((arrayobject *)a, i, v); } @@ -783,10 +748,10 @@ array_extend(arrayobject *self, PyObject *args) { int size; PyObject *bb; - + if (!PyArg_ParseTuple(args, "O:extend", &bb)) return NULL; - + if (!is_arrayobject(bb)) { PyErr_Format(PyExc_TypeError, "can only extend array with array (not \"%.200s\")", @@ -951,7 +916,7 @@ array_reverse(arrayobject *self, PyObject *args) memmove(q, tmp, itemsize); } } - + Py_INCREF(Py_None); return Py_None; } @@ -1337,9 +1302,6 @@ static PyBufferProcs array_as_buffer = { (getsegcountproc)array_buffer_getsegcount, }; - - - static PyObject * a_array(PyObject *self, PyObject *args) { |