Commit 0f27c211 authored by Stefan Behnel's avatar Stefan Behnel

clean up getbuffer code in array.pxd

parent 87eae658
...@@ -46,13 +46,13 @@ ...@@ -46,13 +46,13 @@
: 2012-05-02 andreasvc : 2012-05-02 andreasvc
: (see revision control) : (see revision control)
""" """
from libc cimport stdlib
from libc.string cimport strcat, strncat, \ from libc.string cimport strcat, strncat, \
memset, memchr, memcmp, memcpy, memmove memset, memchr, memcmp, memcpy, memmove
from cpython.object cimport Py_SIZE from cpython.object cimport Py_SIZE
from cpython.ref cimport PyTypeObject, Py_TYPE from cpython.ref cimport PyTypeObject, Py_TYPE
from cpython.exc cimport PyErr_BadArgument from cpython.exc cimport PyErr_BadArgument
from cpython.mem cimport PyMem_Malloc, PyMem_Free
cdef extern from *: # Hard-coded utility code hack. cdef extern from *: # Hard-coded utility code hack.
ctypedef class array.array [object arrayobject] ctypedef class array.array [object arrayobject]
...@@ -82,7 +82,7 @@ cdef extern from *: # Hard-coded utility code hack. ...@@ -82,7 +82,7 @@ cdef extern from *: # Hard-coded utility code hack.
ctypedef class array.array [object arrayobject]: ctypedef class array.array [object arrayobject]:
cdef __cythonbufferdefaults__ = {'ndim' : 1, 'mode':'c'} cdef __cythonbufferdefaults__ = {'ndim' : 1, 'mode':'c'}
cdef: cdef:
Py_ssize_t ob_size Py_ssize_t ob_size
arraydescr* ob_descr # struct arraydescr *ob_descr; arraydescr* ob_descr # struct arraydescr *ob_descr;
...@@ -93,31 +93,29 @@ cdef extern from *: # Hard-coded utility code hack. ...@@ -93,31 +93,29 @@ cdef extern from *: # Hard-coded utility code hack.
# requirements, and does not yet fullfill the PEP. # requirements, and does not yet fullfill the PEP.
# In particular strided access is always provided regardless # In particular strided access is always provided regardless
# of flags # of flags
cdef unsigned rows, columns, itemsize item_count = Py_SIZE(self)
info.suboffsets = NULL info.suboffsets = NULL
info.buf = self.data.as_chars info.buf = self.data.as_chars
info.readonly = 0 info.readonly = 0
info.ndim = 1 info.ndim = 1
info.itemsize = itemsize = self.ob_descr.itemsize # e.g. sizeof(float) info.itemsize = self.ob_descr.itemsize # e.g. sizeof(float)
info.len = info.itemsize * item_count
info.strides = <Py_ssize_t*> \
stdlib.malloc(sizeof(Py_ssize_t) * info.ndim * 2 + 2) info.shape = <Py_ssize_t*> PyMem_Malloc(sizeof(Py_ssize_t) + 2)
info.shape = info.strides + 1 if not info.shape:
info.shape[0] = Py_SIZE(self) # number of items raise MemoryError()
info.strides[0] = info.itemsize info.shape[0] = item_count # constant regardless of resizing
info.strides = &info.itemsize
info.format = <char*>(info.strides + 2 * info.ndim)
info.format = <char*> (info.shape + 1)
info.format[0] = self.ob_descr.typecode info.format[0] = self.ob_descr.typecode
info.format[1] = 0 info.format[1] = 0
info.obj = self info.obj = self
def __releasebuffer__(array self, Py_buffer* info): def __releasebuffer__(array self, Py_buffer* info):
#if PyArray_HASFIELDS(self): PyMem_Free(info.shape)
# stdlib.free(info.format)
#if sizeof(npy_intp) != sizeof(Py_ssize_t):
stdlib.free(info.strides)
array newarrayobject(PyTypeObject* type, Py_ssize_t size, arraydescr *descr) array newarrayobject(PyTypeObject* type, Py_ssize_t size, arraydescr *descr)
# fast resize/realloc # fast resize/realloc
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment