2022-03-30 09:17:39 +00:00
|
|
|
#ifndef Py_CPYTHON_BYTEARRAYOBJECT_H
|
|
|
|
# error "this header file must not be included directly"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Object layout */
|
|
|
|
typedef struct {
|
|
|
|
PyObject_VAR_HEAD
|
|
|
|
Py_ssize_t ob_alloc; /* How many bytes allocated in ob_bytes */
|
|
|
|
char *ob_bytes; /* Physical backing buffer */
|
|
|
|
char *ob_start; /* Logical start inside ob_bytes */
|
|
|
|
Py_ssize_t ob_exports; /* How many buffer exports */
|
|
|
|
} PyByteArrayObject;
|
|
|
|
|
|
|
|
PyAPI_DATA(char) _PyByteArray_empty_string[];
|
2024-05-28 01:30:42 +00:00
|
|
|
|
|
|
|
/* Macros and static inline functions, trading safety for speed */
|
|
|
|
#define _PyByteArray_CAST(op) \
|
|
|
|
(assert(PyByteArray_Check(op)), _Py_CAST(PyByteArrayObject*, op))
|
|
|
|
|
|
|
|
static inline char* PyByteArray_AS_STRING(PyObject *op)
|
|
|
|
{
|
|
|
|
PyByteArrayObject *self = _PyByteArray_CAST(op);
|
|
|
|
if (Py_SIZE(self)) {
|
|
|
|
return self->ob_start;
|
|
|
|
}
|
|
|
|
return _PyByteArray_empty_string;
|
|
|
|
}
|
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 < 0x030b0000
|
|
|
|
# define PyByteArray_AS_STRING(self) PyByteArray_AS_STRING(_PyObject_CAST(self))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static inline Py_ssize_t PyByteArray_GET_SIZE(PyObject *op) {
|
|
|
|
PyByteArrayObject *self = _PyByteArray_CAST(op);
|
|
|
|
return Py_SIZE(self);
|
|
|
|
}
|
|
|
|
#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 < 0x030b0000
|
|
|
|
# define PyByteArray_GET_SIZE(self) PyByteArray_GET_SIZE(_PyObject_CAST(self))
|
|
|
|
#endif
|