2002-10-04 14:43:02 +02:00
|
|
|
#ifndef Py_CSTRINGIO_H
|
|
|
|
#define Py_CSTRINGIO_H
|
2002-03-30 09:57:12 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
1996-12-06 00:30:48 +01: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
|
|
|
|
objects.
|
|
|
|
|
|
|
|
Before calling any of the functions or macros, you must initialize
|
|
|
|
the routines with:
|
|
|
|
|
1999-01-25 22:36:13 +01:00
|
|
|
PycString_IMPORT
|
1996-12-06 00:30:48 +01:00
|
|
|
|
|
|
|
This would typically be done in your init function.
|
|
|
|
|
1997-01-06 23:50:12 +01:00
|
|
|
*/
|
2002-08-05 20:20:01 +02:00
|
|
|
#define PycString_IMPORT \
|
|
|
|
PycStringIO = (struct PycStringIO_CAPI*)PyCObject_Import("cStringIO", \
|
|
|
|
"cStringIO_CAPI")
|
1996-12-06 00:30:48 +01:00
|
|
|
|
2000-07-16 14:04:32 +02:00
|
|
|
/* Basic functions to manipulate cStringIO objects from C */
|
1996-12-06 00:30:48 +01:00
|
|
|
|
1997-04-09 19:34:28 +02:00
|
|
|
static struct PycStringIO_CAPI {
|
|
|
|
|
2003-01-19 01:45:01 +01:00
|
|
|
/* Read a string from an input object. If the last argument
|
|
|
|
is -1, the remainder will be read.
|
|
|
|
*/
|
2006-02-15 18:27:45 +01:00
|
|
|
int(*cread)(PyObject *, char **, Py_ssize_t);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
2003-01-19 01:45:01 +01: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).
|
|
|
|
*/
|
2000-07-09 05:09:57 +02:00
|
|
|
int(*creadline)(PyObject *, char **);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
2003-01-19 01:45:01 +01:00
|
|
|
/* Write a string to an output object*/
|
2006-02-15 18:27:45 +01:00
|
|
|
int(*cwrite)(PyObject *, const char *, Py_ssize_t);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
2003-01-19 01:45:01 +01:00
|
|
|
/* Get the output object as a Python string (returns new reference). */
|
2000-07-09 05:09:57 +02:00
|
|
|
PyObject *(*cgetvalue)(PyObject *);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
1997-04-09 19:34:28 +02:00
|
|
|
/* Create a new output object */
|
2000-07-09 05:09:57 +02:00
|
|
|
PyObject *(*NewOutput)(int);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
2003-01-19 01:45:01 +01:00
|
|
|
/* Create an input object from a Python string
|
|
|
|
(copies the Python string reference).
|
|
|
|
*/
|
2000-07-09 05:09:57 +02:00
|
|
|
PyObject *(*NewInput)(PyObject *);
|
1996-12-06 00:30:48 +01:00
|
|
|
|
1997-04-09 19:34:28 +02:00
|
|
|
/* The Python types for cStringIO input and output objects.
|
|
|
|
Note that you can do input on an output object.
|
|
|
|
*/
|
|
|
|
PyTypeObject *InputType, *OutputType;
|
|
|
|
|
2002-08-05 20:20:01 +02:00
|
|
|
} *PycStringIO;
|
1996-12-06 00:30:48 +01:00
|
|
|
|
|
|
|
/* These can be used to test if you have one */
|
1997-01-06 23:50:12 +01:00
|
|
|
#define PycStringIO_InputCheck(O) \
|
Merged revisions 56467-56482 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56477 | martin.v.loewis | 2007-07-21 09:04:38 +0200 (Sa, 21 Jul 2007) | 11 lines
Merged revisions 56466-56476 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56476 | martin.v.loewis | 2007-07-21 08:55:02 +0200 (Sa, 21 Jul 2007) | 4 lines
PEP 3123: Provide forward compatibility with Python 3.0, while keeping
backwards compatibility. Add Py_Refcnt, Py_Type, Py_Size, and
PyVarObject_HEAD_INIT.
........
................
r56478 | martin.v.loewis | 2007-07-21 09:47:23 +0200 (Sa, 21 Jul 2007) | 2 lines
PEP 3123: Use proper C inheritance for PyObject.
................
r56479 | martin.v.loewis | 2007-07-21 10:06:55 +0200 (Sa, 21 Jul 2007) | 3 lines
Add longintrepr.h to Python.h, so that the compiler can
see that PyFalse is really some kind of PyObject*.
................
r56480 | martin.v.loewis | 2007-07-21 10:47:18 +0200 (Sa, 21 Jul 2007) | 2 lines
Qualify SHIFT, MASK, BASE.
................
r56482 | martin.v.loewis | 2007-07-21 19:10:57 +0200 (Sa, 21 Jul 2007) | 2 lines
Correctly refer to _ob_next.
................
2007-07-21 19:22:18 +02:00
|
|
|
(Py_Type(O)==PycStringIO->InputType)
|
1997-01-06 23:50:12 +01:00
|
|
|
#define PycStringIO_OutputCheck(O) \
|
Merged revisions 56467-56482 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
................
r56477 | martin.v.loewis | 2007-07-21 09:04:38 +0200 (Sa, 21 Jul 2007) | 11 lines
Merged revisions 56466-56476 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r56476 | martin.v.loewis | 2007-07-21 08:55:02 +0200 (Sa, 21 Jul 2007) | 4 lines
PEP 3123: Provide forward compatibility with Python 3.0, while keeping
backwards compatibility. Add Py_Refcnt, Py_Type, Py_Size, and
PyVarObject_HEAD_INIT.
........
................
r56478 | martin.v.loewis | 2007-07-21 09:47:23 +0200 (Sa, 21 Jul 2007) | 2 lines
PEP 3123: Use proper C inheritance for PyObject.
................
r56479 | martin.v.loewis | 2007-07-21 10:06:55 +0200 (Sa, 21 Jul 2007) | 3 lines
Add longintrepr.h to Python.h, so that the compiler can
see that PyFalse is really some kind of PyObject*.
................
r56480 | martin.v.loewis | 2007-07-21 10:47:18 +0200 (Sa, 21 Jul 2007) | 2 lines
Qualify SHIFT, MASK, BASE.
................
r56482 | martin.v.loewis | 2007-07-21 19:10:57 +0200 (Sa, 21 Jul 2007) | 2 lines
Correctly refer to _ob_next.
................
2007-07-21 19:22:18 +02:00
|
|
|
(Py_Type(O)==PycStringIO->OutputType)
|
1997-04-09 19:34:28 +02:00
|
|
|
|
2002-03-30 09:57:12 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2002-10-04 14:43:02 +02:00
|
|
|
#endif /* !Py_CSTRINGIO_H */
|