mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 10:44:55 +00:00 
			
		
		
		
	 638437ff4d
			
		
	
	
		638437ff4d
		
	
	
	
	
		
			
			Don't pollute the namespace when protecting against multiple header inclusion. Prefix with Py_ and use standard naming convention Py_FILENAME_H.
		
			
				
	
	
		
			63 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #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 PycString_IMPORT \
 | |
|   PycStringIO = (struct PycStringIO_CAPI*)PyCObject_Import("cStringIO", \
 | |
|                                                            "cStringIO_CAPI")
 | |
| 
 | |
| /* Basic functions to manipulate cStringIO objects from C */
 | |
| 
 | |
| static struct PycStringIO_CAPI {
 | |
|   
 | |
|   /* Read a string.  If the last argument is -1, the remainder will be read. */
 | |
|   int(*cread)(PyObject *, char **, int);
 | |
| 
 | |
|   /* Read a line */
 | |
|   int(*creadline)(PyObject *, char **);
 | |
| 
 | |
|   /* Write a string */
 | |
|   int(*cwrite)(PyObject *, char *, int);
 | |
| 
 | |
|   /* Get the cStringIO object as a Python string */
 | |
|   PyObject *(*cgetvalue)(PyObject *);
 | |
| 
 | |
|   /* Create a new output object */
 | |
|   PyObject *(*NewOutput)(int);
 | |
| 
 | |
|   /* Create an input object from a Python string */
 | |
|   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) \
 | |
|   ((O)->ob_type==PycStringIO->InputType)
 | |
| #define PycStringIO_OutputCheck(O) \
 | |
|   ((O)->ob_type==PycStringIO->OutputType)
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| #endif /* !Py_CSTRINGIO_H */
 |