From: Roumen Petrov Date: Sat, 23 Feb 2013 19:53:27 +0200 MINGW: init system calls diff -r 23f72be4b926 Modules/Setup.config.in --- a/Modules/Setup.config.in Mon Jun 06 00:38:20 2016 +0000 +++ b/Modules/Setup.config.in Mon Jun 06 00:59:28 2016 +0000 @@ -3,6 +3,9 @@ # The purpose of this file is to conditionally enable certain modules # based on configure-time options. +# init system calls(posix/nt/...) for INITFUNC (used by makesetup) +@INITSYS@ posixmodule.c + # Threading @USE_THREAD_MODULE@_thread _threadmodule.c diff -r 23f72be4b926 Modules/Setup.dist --- a/Modules/Setup.dist Mon Jun 06 00:38:20 2016 +0000 +++ b/Modules/Setup.dist Mon Jun 06 00:59:28 2016 +0000 @@ -105,7 +105,6 @@ # This only contains the minimal set of modules required to run the # setup.py script in the root of the Python source tree. -posix posixmodule.c # posix (UNIX) system calls errno errnomodule.c # posix (UNIX) errno values pwd pwdmodule.c # this is needed to find out the user's home dir # if $HOME is not set diff -r 23f72be4b926 Modules/posixmodule.c --- a/Modules/posixmodule.c Mon Jun 06 00:38:20 2016 +0000 +++ b/Modules/posixmodule.c Mon Jun 06 00:59:28 2016 +0000 @@ -162,6 +162,25 @@ #define HAVE_CWAIT 1 #define HAVE_FSYNC 1 #define fsync _commit +#elif defined(__MINGW32__) /* GCC for windows hosts */ +/* getlogin is detected by configure on mingw-w64 */ +#undef HAVE_GETLOGIN +/*#define HAVE_GETCWD 1 - detected by configure*/ +#define HAVE_GETPPID 1 +#define HAVE_GETLOGIN 1 +#define HAVE_SPAWNV 1 +/*#define HAVE_EXECV 1 - detected by configure*/ +#define HAVE_PIPE 1 +#define HAVE_POPEN 1 +#define HAVE_SYSTEM 1 +#define HAVE_CWAIT 1 +#define HAVE_FSYNC 1 +#define fsync _commit +#include +#include +#ifndef _MAX_ENV +#define _MAX_ENV 32767 +#endif #else /* Unix functions that the configure script doesn't check for */ #define HAVE_EXECV 1 @@ -282,7 +301,7 @@ #endif #endif -#ifdef _MSC_VER +#ifdef MS_WINDOWS #ifdef HAVE_DIRECT_H #include #endif @@ -1135,7 +1154,7 @@ */ #include static char **environ; -#elif !defined(_MSC_VER) && ( !defined(__WATCOMC__) || defined(__QNX__) ) +#elif !defined(MS_WINDOWS) && ( !defined(__WATCOMC__) || defined(__QNX__) ) extern char **environ; #endif /* !_MSC_VER */ diff -r 23f72be4b926 configure.ac --- a/configure.ac Mon Jun 06 00:38:20 2016 +0000 +++ b/configure.ac Mon Jun 06 00:59:28 2016 +0000 @@ -577,6 +577,14 @@ fi AC_MSG_RESULT($MACHDEP) +AC_MSG_CHECKING([for init system calls]) +AC_SUBST(INITSYS) +case $host in + *-*-mingw*) INITSYS=nt;; + *) INITSYS=posix;; +esac +AC_MSG_RESULT([$INITSYS]) + # Record the configure-time value of MACOSX_DEPLOYMENT_TARGET, # it may influence the way we can build extensions, so distutils # needs to check it