67 lines
2.8 KiB
Cython
67 lines
2.8 KiB
Cython
|
from libc.stdio cimport FILE
|
|||
|
|
|||
|
cdef extern from "Python.h":
|
|||
|
|
|||
|
###########################################################################
|
|||
|
# Data marshalling support
|
|||
|
###########################################################################
|
|||
|
|
|||
|
const int Py_MARSHAL_VERSION
|
|||
|
|
|||
|
void PyMarshal_WriteLongToFile(long value, FILE *file, int version)
|
|||
|
# Marshal a long integer, value, to file. This will only write the
|
|||
|
# least-significant 32 bits of value, regardless of the size of the native
|
|||
|
# long type. version indicates the file format.
|
|||
|
|
|||
|
void PyMarshal_WriteObjectToFile(object value, FILE *file, int version)
|
|||
|
# Marshal a Python object, value, to file. version indicates the file
|
|||
|
# format.
|
|||
|
|
|||
|
bytes PyMarshal_WriteObjectToString(object value, int version)
|
|||
|
# Return value: New reference.
|
|||
|
# Return a bytes object containing the marshalled representation of value.
|
|||
|
# version indicates the file format.
|
|||
|
|
|||
|
long PyMarshal_ReadLongFromFile(FILE *file) except? -1
|
|||
|
# Return a C long from the data stream in a FILE* opened for reading. Only
|
|||
|
# a 32-bit value can be read in using this function, regardless of the
|
|||
|
# native size of long.
|
|||
|
|
|||
|
# On error, sets the appropriate exception (EOFError) and returns -1.
|
|||
|
|
|||
|
int PyMarshal_ReadShortFromFile(FILE *file) except? -1
|
|||
|
# Return a C short from the data stream in a FILE* opened for reading. Only
|
|||
|
# a 16-bit value can be read in using this function, regardless of the
|
|||
|
# native size of short.
|
|||
|
|
|||
|
# On error, sets the appropriate exception (EOFError) and returns -1.
|
|||
|
|
|||
|
object PyMarshal_ReadObjectFromFile(FILE *file)
|
|||
|
# Return value: New reference.
|
|||
|
# Return a Python object from the data stream in a FILE* opened for
|
|||
|
# reading.
|
|||
|
|
|||
|
# On error, sets the appropriate exception (EOFError, ValueError or
|
|||
|
# TypeError) and returns NULL.
|
|||
|
|
|||
|
object PyMarshal_ReadLastObjectFromFile(FILE *file)
|
|||
|
# Return value: New reference.
|
|||
|
# Return a Python object from the data stream in a FILE* opened for
|
|||
|
# reading. Unlike PyMarshal_ReadObjectFromFile(), this function assumes
|
|||
|
# that no further objects will be read from the file, allowing it to
|
|||
|
# aggressively load file data into memory so that the de-serialization can
|
|||
|
# operate from data in memory, rather than reading a byte at a time from the
|
|||
|
# file. Only use these variant if you are certain that you won’t be reading
|
|||
|
# anything else from the file.
|
|||
|
|
|||
|
# On error, sets the appropriate exception (EOFError, ValueError or
|
|||
|
# TypeError) and returns NULL.
|
|||
|
|
|||
|
object PyMarshal_ReadObjectFromString(const char *data, Py_ssize_t len)
|
|||
|
# Return value: New reference.
|
|||
|
# Return a Python object from the data stream in a byte buffer containing
|
|||
|
# len bytes pointed to by data.
|
|||
|
|
|||
|
# On error, sets the appropriate exception (EOFError, ValueError or
|
|||
|
# TypeError) and returns NULL.
|