blob: 9c11624bdc59f294f99f592ca6fc9c3fa8e7b1cf [file] [log] [blame]
Guido van Rossum4dfe8a12006-04-22 23:28:04 +00001/* Bytes object interface */
2
3#ifndef Py_BYTESOBJECT_H
4#define Py_BYTESOBJECT_H
5#ifdef __cplusplus
6extern "C" {
7#endif
8
9#include <stdarg.h>
10
11/* Type PyBytesObject represents a mutable array of bytes.
12 * The Python API is that of a sequence;
13 * the bytes are mapped to ints in [0, 256).
14 * Bytes are not characters; they may be used to encode characters.
15 * The only way to go between bytes and str/unicode is via encoding
16 * and decoding.
17 * For the concenience of C programmers, the bytes type is considered
18 * to contain a char pointer, not an unsigned char pointer.
19 */
20
21/* Object layout */
22typedef struct {
23 PyObject_VAR_HEAD
24 char *ob_sval;
25} PyBytesObject;
26
27/* Type object */
28PyAPI_DATA(PyTypeObject) PyBytes_Type;
29
30/* Type check macros */
31#define PyBytes_Check(self) PyObject_TypeCheck(self, &PyBytes_Type)
32#define PyBytes_CheckExact(self) ((self)->ob_type == &PyBytes_Type)
33
34/* Direct API functions */
35PyAPI_FUNC(PyObject *) PyBytes_FromStringAndSize(const char *, Py_ssize_t);
36PyAPI_FUNC(Py_ssize_t) PyBytes_Size(PyObject *);
37PyAPI_FUNC(char *) PyBytes_AsString(PyObject *);
38PyAPI_FUNC(int) PyBytes_Resize(PyObject *, Py_ssize_t);
39
40/* Macros, trading safety for speed */
41#define PyBytes_AS_STRING(self) (((PyBytesObject *)(self))->ob_sval)
42#define PyBytes_GET_SIZE(self) (((PyBytesObject *)(self))->ob_size)
43
44#ifdef __cplusplus
45}
46#endif
47#endif /* !Py_BYTESOBJECT_H */