| #ifndef MULTIPROCESSING_H | 
 | #define MULTIPROCESSING_H | 
 |  | 
 | #define PY_SSIZE_T_CLEAN | 
 |  | 
 | #ifdef __sun | 
 | /* The control message API is only available on Solaris  | 
 |    if XPG 4.2 or later is requested. */ | 
 | #define _XOPEN_SOURCE 500 | 
 | #endif | 
 |  | 
 | #include "Python.h" | 
 | #include "structmember.h" | 
 | #include "pythread.h" | 
 |  | 
 | /* | 
 |  * Platform includes and definitions | 
 |  */ | 
 |  | 
 | #ifdef MS_WINDOWS | 
 | #  define WIN32_LEAN_AND_MEAN | 
 | #  include <windows.h> | 
 | #  include <winsock2.h> | 
 | #  include <process.h>               /* getpid() */ | 
 | #  ifdef Py_DEBUG | 
 | #    include <crtdbg.h> | 
 | #  endif | 
 | #  define SEM_HANDLE HANDLE | 
 | #  define SEM_VALUE_MAX LONG_MAX | 
 | #else | 
 | #  include <fcntl.h>                 /* O_CREAT and O_EXCL */ | 
 | #  include <netinet/in.h> | 
 | #  include <sys/socket.h> | 
 | #  include <sys/uio.h> | 
 | #  include <arpa/inet.h>             /* htonl() and ntohl() */ | 
 | #  if defined(HAVE_SEM_OPEN) && !defined(POSIX_SEMAPHORES_NOT_ENABLED) | 
 | #    include <semaphore.h> | 
 |      typedef sem_t *SEM_HANDLE; | 
 | #  endif | 
 | #  define HANDLE int | 
 | #  define SOCKET int | 
 | #  define BOOL int | 
 | #  define UINT32 uint32_t | 
 | #  define INT32 int32_t | 
 | #  define TRUE 1 | 
 | #  define FALSE 0 | 
 | #  define INVALID_HANDLE_VALUE (-1) | 
 | #endif | 
 |  | 
 | /* | 
 |  * Issue 3110 - Solaris does not define SEM_VALUE_MAX | 
 |  */ | 
 | #ifndef SEM_VALUE_MAX | 
 |     #if defined(HAVE_SYSCONF) && defined(_SC_SEM_VALUE_MAX) | 
 |         # define SEM_VALUE_MAX sysconf(_SC_SEM_VALUE_MAX) | 
 |     #elif defined(_SEM_VALUE_MAX) | 
 |         # define SEM_VALUE_MAX _SEM_VALUE_MAX | 
 |     #elif defined(_POSIX_SEM_VALUE_MAX) | 
 |         # define SEM_VALUE_MAX _POSIX_SEM_VALUE_MAX | 
 |     #else | 
 |         # define SEM_VALUE_MAX INT_MAX | 
 |     #endif | 
 | #endif | 
 |  | 
 |  | 
 | /* | 
 |  * Make sure Py_ssize_t available | 
 |  */ | 
 |  | 
 | #if PY_VERSION_HEX < 0x02050000 && !defined(PY_SSIZE_T_MIN) | 
 |    typedef int Py_ssize_t; | 
 | #  define PY_SSIZE_T_MAX INT_MAX | 
 | #  define PY_SSIZE_T_MIN INT_MIN | 
 | #  define F_PY_SSIZE_T "i" | 
 | #  define PyInt_FromSsize_t(n) PyInt_FromLong((long)n) | 
 | #else | 
 | #  define F_PY_SSIZE_T "n" | 
 | #endif | 
 |  | 
 | /* | 
 |  * Format codes | 
 |  */ | 
 |  | 
 | #if SIZEOF_VOID_P == SIZEOF_LONG | 
 | #  define F_POINTER "k" | 
 | #  define T_POINTER T_ULONG | 
 | #elif defined(HAVE_LONG_LONG) && (SIZEOF_VOID_P == SIZEOF_LONG_LONG) | 
 | #  define F_POINTER "K" | 
 | #  define T_POINTER T_ULONGLONG | 
 | #else | 
 | #  error "can't find format code for unsigned integer of same size as void*" | 
 | #endif | 
 |  | 
 | #ifdef MS_WINDOWS | 
 | #  define F_HANDLE F_POINTER | 
 | #  define T_HANDLE T_POINTER | 
 | #  define F_SEM_HANDLE F_HANDLE | 
 | #  define T_SEM_HANDLE T_HANDLE | 
 | #  define F_DWORD "k" | 
 | #  define T_DWORD T_ULONG | 
 | #else | 
 | #  define F_HANDLE "i" | 
 | #  define T_HANDLE T_INT | 
 | #  define F_SEM_HANDLE F_POINTER | 
 | #  define T_SEM_HANDLE T_POINTER | 
 | #endif | 
 |  | 
 | #if PY_VERSION_HEX >= 0x03000000 | 
 | #  define F_RBUFFER "y" | 
 | #else | 
 | #  define F_RBUFFER "s" | 
 | #endif | 
 |  | 
 | /* | 
 |  * Error codes which can be returned by functions called without GIL | 
 |  */ | 
 |  | 
 | #define MP_SUCCESS (0) | 
 | #define MP_STANDARD_ERROR (-1) | 
 | #define MP_MEMORY_ERROR (-1001) | 
 | #define MP_END_OF_FILE (-1002) | 
 | #define MP_EARLY_END_OF_FILE (-1003) | 
 | #define MP_BAD_MESSAGE_LENGTH (-1004) | 
 | #define MP_SOCKET_ERROR (-1005) | 
 | #define MP_EXCEPTION_HAS_BEEN_SET (-1006) | 
 |  | 
 | PyObject *mp_SetError(PyObject *Type, int num); | 
 |  | 
 | /* | 
 |  * Externs - not all will really exist on all platforms | 
 |  */ | 
 |  | 
 | extern PyObject *pickle_dumps; | 
 | extern PyObject *pickle_loads; | 
 | extern PyObject *pickle_protocol; | 
 | extern PyObject *BufferTooShort; | 
 | extern PyTypeObject SemLockType; | 
 | extern PyTypeObject ConnectionType; | 
 | extern PyTypeObject PipeConnectionType; | 
 | extern HANDLE sigint_event; | 
 |  | 
 | /* | 
 |  * Py3k compatibility | 
 |  */ | 
 |  | 
 | #if PY_VERSION_HEX >= 0x03000000 | 
 | #  define PICKLE_MODULE "pickle" | 
 | #  define FROM_FORMAT PyUnicode_FromFormat | 
 | #  define PyInt_FromLong PyLong_FromLong | 
 | #  define PyInt_FromSsize_t PyLong_FromSsize_t | 
 | #else | 
 | #  define PICKLE_MODULE "cPickle" | 
 | #  define FROM_FORMAT PyString_FromFormat | 
 | #endif | 
 |  | 
 | #ifndef PyVarObject_HEAD_INIT | 
 | #  define PyVarObject_HEAD_INIT(type, size) PyObject_HEAD_INIT(type) size, | 
 | #endif | 
 |  | 
 | #ifndef Py_TPFLAGS_HAVE_WEAKREFS | 
 | #  define Py_TPFLAGS_HAVE_WEAKREFS 0 | 
 | #endif | 
 |  | 
 | /* | 
 |  * Connection definition | 
 |  */ | 
 |  | 
 | #define CONNECTION_BUFFER_SIZE 1024 | 
 |  | 
 | typedef struct { | 
 |     PyObject_HEAD | 
 |     HANDLE handle; | 
 |     int flags; | 
 |     PyObject *weakreflist; | 
 |     char buffer[CONNECTION_BUFFER_SIZE]; | 
 | } ConnectionObject; | 
 |  | 
 | /* | 
 |  * Miscellaneous | 
 |  */ | 
 |  | 
 | #define MAX_MESSAGE_LENGTH 0x7fffffff | 
 |  | 
 | #ifndef MIN | 
 | #  define MIN(x, y) ((x) < (y) ? x : y) | 
 | #  define MAX(x, y) ((x) > (y) ? x : y) | 
 | #endif | 
 |  | 
 | #endif /* MULTIPROCESSING_H */ |