Spaces:
Build error
Build error
# Please see the Python header files (object.h/abstract.h) for docs | |
cdef extern from "Python.h": | |
cdef enum: | |
PyBUF_MAX_NDIM | |
cdef enum: | |
PyBUF_SIMPLE, | |
PyBUF_WRITABLE, | |
PyBUF_WRITEABLE, # backwards compatibility | |
PyBUF_FORMAT, | |
PyBUF_ND, | |
PyBUF_STRIDES, | |
PyBUF_C_CONTIGUOUS, | |
PyBUF_F_CONTIGUOUS, | |
PyBUF_ANY_CONTIGUOUS, | |
PyBUF_INDIRECT, | |
PyBUF_CONTIG, | |
PyBUF_CONTIG_RO, | |
PyBUF_STRIDED, | |
PyBUF_STRIDED_RO, | |
PyBUF_RECORDS, | |
PyBUF_RECORDS_RO, | |
PyBUF_FULL, | |
PyBUF_FULL_RO, | |
PyBUF_READ, | |
PyBUF_WRITE, | |
PyBUF_SHADOW | |
bint PyObject_CheckBuffer(object obj) | |
# Return 1 if obj supports the buffer interface otherwise 0. | |
int PyObject_GetBuffer(object obj, Py_buffer *view, int flags) except -1 | |
# Export obj into a Py_buffer, view. These arguments must never be | |
# NULL. The flags argument is a bit field indicating what kind of | |
# buffer the caller is prepared to deal with and therefore what | |
# kind of buffer the exporter is allowed to return. The buffer | |
# interface allows for complicated memory sharing possibilities, | |
# but some caller may not be able to handle all the complexity but | |
# may want to see if the exporter will let them take a simpler | |
# view to its memory. | |
# Some exporters may not be able to share memory in every possible | |
# way and may need to raise errors to signal to some consumers | |
# that something is just not possible. These errors should be a | |
# BufferError unless there is another error that is actually | |
# causing the problem. The exporter can use flags information to | |
# simplify how much of the Py_buffer structure is filled in with | |
# non-default values and/or raise an error if the object can’t | |
# support a simpler view of its memory. | |
# 0 is returned on success and -1 on error. | |
void PyBuffer_Release(Py_buffer *view) | |
# Release the buffer view. This should be called when the buffer | |
# is no longer being used as it may free memory from it. | |
void* PyBuffer_GetPointer(Py_buffer *view, Py_ssize_t *indices) | |
# ?? | |
Py_ssize_t PyBuffer_SizeFromFormat(char *) # actually const char | |
# Return the implied ~Py_buffer.itemsize from the struct-stype | |
# ~Py_buffer.format | |
int PyBuffer_ToContiguous(void *buf, Py_buffer *view, Py_ssize_t len, char fort) | |
# ?? | |
int PyBuffer_FromContiguous(Py_buffer *view, void *buf, Py_ssize_t len, char fort) | |
# ?? | |
int PyObject_CopyToObject(object obj, void *buf, Py_ssize_t len, char fortran) except -1 | |
# Copy len bytes of data pointed to by the contiguous chunk of | |
# memory pointed to by buf into the buffer exported by obj. The | |
# buffer must of course be writable. Return 0 on success and | |
# return -1 and raise an error on failure. If the object does not | |
# have a writable buffer, then an error is raised. If fortran is | |
# 'F', then if the object is multi-dimensional, then the data will | |
# be copied into the array in Fortran-style (first dimension | |
# varies the fastest). If fortran is 'C', then the data will be | |
# copied into the array in C-style (last dimension varies the | |
# fastest). If fortran is 'A', then it does not matter and the | |
# copy will be made in whatever way is more efficient. | |
int PyObject_CopyData(object dest, object src) except -1 | |
# Copy the data from the src buffer to the buffer of destination | |
bint PyBuffer_IsContiguous(Py_buffer *view, char fort) | |
# Return 1 if the memory defined by the view is C-style (fortran | |
# is 'C') or Fortran-style (fortran is 'F') contiguous or either | |
# one (fortran is 'A'). Return 0 otherwise. | |
void PyBuffer_FillContiguousStrides(int ndims, | |
Py_ssize_t *shape, | |
Py_ssize_t *strides, | |
Py_ssize_t itemsize, | |
char fort) | |
# Fill the strides array with byte-strides of a contiguous | |
# (Fortran-style if fort is 'F' or C-style otherwise) array of the | |
# given shape with the given number of bytes per element. | |
int PyBuffer_FillInfo(Py_buffer *view, object exporter, void *buf, | |
Py_ssize_t len, int readonly, int flags) except -1 | |
# Fill in a buffer-info structure, view, correctly for an exporter | |
# that can only share a contiguous chunk of memory of “unsigned | |
# bytes” of the given length. Return 0 on success and -1 (with | |
# raising an error) on error. | |
# DEPRECATED HERE: do not cimport from here, cimport from cpython.object instead | |
object PyObject_Format(object obj, object format_spec) | |
# Takes an arbitrary object and returns the result of calling | |
# obj.__format__(format_spec). | |