| #ifndef Py_CSTRINGIO_H | |
| #define Py_CSTRINGIO_H | |
| #ifdef __cplusplus | |
| extern "C" { | |
| #endif | |
| /* | |
| This header provides access to cStringIO objects from C. | |
| Functions are provided for calling cStringIO objects and | |
| macros are provided for testing whether you have cStringIO | |
| objects. | |
| Before calling any of the functions or macros, you must initialize | |
| the routines with: | |
| PycString_IMPORT | |
| This would typically be done in your init function. | |
| */ | |
| #define PycStringIO_CAPSULE_NAME "cStringIO.cStringIO_CAPI" | |
| #define PycString_IMPORT \ | |
| PycStringIO = ((struct PycStringIO_CAPI*)PyCapsule_Import(\ | |
| PycStringIO_CAPSULE_NAME, 0)) | |
| /* Basic functions to manipulate cStringIO objects from C */ | |
| static struct PycStringIO_CAPI { | |
| /* Read a string from an input object. If the last argument | |
| is -1, the remainder will be read. | |
| */ | |
| int(*cread)(PyObject *, char **, Py_ssize_t); | |
| /* Read a line from an input object. Returns the length of the read | |
| line as an int and a pointer inside the object buffer as char** (so | |
| the caller doesn't have to provide its own buffer as destination). | |
| */ | |
| int(*creadline)(PyObject *, char **); | |
| /* Write a string to an output object*/ | |
| int(*cwrite)(PyObject *, const char *, Py_ssize_t); | |
| /* Get the output object as a Python string (returns new reference). */ | |
| PyObject *(*cgetvalue)(PyObject *); | |
| /* Create a new output object */ | |
| PyObject *(*NewOutput)(int); | |
| /* Create an input object from a Python string | |
| (copies the Python string reference). | |
| */ | |
| PyObject *(*NewInput)(PyObject *); | |
| /* The Python types for cStringIO input and output objects. | |
| Note that you can do input on an output object. | |
| */ | |
| PyTypeObject *InputType, *OutputType; | |
| } *PycStringIO; | |
| /* These can be used to test if you have one */ | |
| #define PycStringIO_InputCheck(O) \ | |
| (Py_TYPE(O)==PycStringIO->InputType) | |
| #define PycStringIO_OutputCheck(O) \ | |
| (Py_TYPE(O)==PycStringIO->OutputType) | |
| #ifdef __cplusplus | |
| } | |
| #endif | |
| #endif /* !Py_CSTRINGIO_H */ |