cpython/Include/cStringIO.h

74 lines
2.0 KiB
C
Raw Normal View History

#ifndef Py_CSTRINGIO_H
#define Py_CSTRINGIO_H
#ifdef __cplusplus
extern "C" {
#endif
1996-12-05 19:30:48 -04:00
/*
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
1996-12-05 19:30:48 -04:00
objects.
Before calling any of the functions or macros, you must initialize
the routines with:
PycString_IMPORT
1996-12-05 19:30:48 -04:00
This would typically be done in your init function.
1997-01-06 18:50:12 -04:00
*/
#define PycStringIO_CAPSULE_NAME "cStringIO.cStringIO_CAPI"
#define PycString_IMPORT \
PycStringIO = ((struct PycStringIO_CAPI*)PyCapsule_Import(\
PycStringIO_CAPSULE_NAME, 0))
1996-12-05 19:30:48 -04:00
/* Basic functions to manipulate cStringIO objects from C */
1996-12-05 19:30:48 -04:00
static struct PycStringIO_CAPI {
/* Read a string from an input object. If the last argument
is -1, the remainder will be read.
*/
2006-02-15 13:27:45 -04:00
int(*cread)(PyObject *, char **, Py_ssize_t);
1996-12-05 19:30:48 -04:00
/* 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 **);
1996-12-05 19:30:48 -04:00
/* Write a string to an output object*/
2006-02-15 13:27:45 -04:00
int(*cwrite)(PyObject *, const char *, Py_ssize_t);
1996-12-05 19:30:48 -04:00
/* Get the output object as a Python string (returns new reference). */
PyObject *(*cgetvalue)(PyObject *);
1996-12-05 19:30:48 -04:00
/* Create a new output object */
PyObject *(*NewOutput)(int);
1996-12-05 19:30:48 -04:00
/* Create an input object from a Python string
(copies the Python string reference).
*/
PyObject *(*NewInput)(PyObject *);
1996-12-05 19:30:48 -04:00
/* The Python types for cStringIO input and output objects.
Note that you can do input on an output object.
*/
PyTypeObject *InputType, *OutputType;
} *PycStringIO;
1996-12-05 19:30:48 -04:00
/* These can be used to test if you have one */
1997-01-06 18:50:12 -04:00
#define PycStringIO_InputCheck(O) \
(Py_TYPE(O)==PycStringIO->InputType)
1997-01-06 18:50:12 -04:00
#define PycStringIO_OutputCheck(O) \
(Py_TYPE(O)==PycStringIO->OutputType)
#ifdef __cplusplus
}
#endif
#endif /* !Py_CSTRINGIO_H */