48 lines
1.5 KiB
C
48 lines
1.5 KiB
C
/* File object interface (what's left of it -- see io.py) */
|
|
|
|
#ifndef Py_FILEOBJECT_H
|
|
#define Py_FILEOBJECT_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define PY_STDIOTEXTMODE "b"
|
|
|
|
PyAPI_FUNC(PyObject *) PyFile_FromFd(int, char *, char *, int, char *, char *,
|
|
char *, int);
|
|
PyAPI_FUNC(PyObject *) PyFile_GetLine(PyObject *, int);
|
|
PyAPI_FUNC(int) PyFile_WriteObject(PyObject *, PyObject *, int);
|
|
PyAPI_FUNC(int) PyFile_WriteString(const char *, PyObject *);
|
|
PyAPI_FUNC(int) PyObject_AsFileDescriptor(PyObject *);
|
|
PyAPI_FUNC(char *) Py_UniversalNewlineFgets(char *, int, FILE*, PyObject *);
|
|
|
|
/* The default encoding used by the platform file system APIs
|
|
If non-NULL, this is different than the default encoding for strings
|
|
*/
|
|
PyAPI_DATA(const char *) Py_FileSystemDefaultEncoding;
|
|
PyAPI_DATA(int) Py_HasFileSystemDefaultEncoding;
|
|
PyAPI_FUNC(int) _Py_SetFileSystemEncoding(PyObject *);
|
|
|
|
/* Internal API
|
|
|
|
The std printer acts as a preliminary sys.stderr until the new io
|
|
infrastructure is in place. */
|
|
PyAPI_FUNC(PyObject *) PyFile_NewStdPrinter(int);
|
|
PyAPI_DATA(PyTypeObject) PyStdPrinter_Type;
|
|
|
|
#if defined _MSC_VER && _MSC_VER >= 1400
|
|
/* A routine to check if a file descriptor is valid on Windows. Returns 0
|
|
* and sets errno to EBADF if it isn't. This is to avoid Assertions
|
|
* from various functions in the Windows CRT beginning with
|
|
* Visual Studio 2005
|
|
*/
|
|
int _PyVerify_fd(int fd);
|
|
#else
|
|
#define _PyVerify_fd(A) (1) /* dummy */
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* !Py_FILEOBJECT_H */
|