summaryrefslogtreecommitdiffstats
path: root/Modules/posixmodule.c
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1994-08-23 13:48:48 (GMT)
committerGuido van Rossum <guido@python.org>1994-08-23 13:48:48 (GMT)
commit794d81313b5a986ae3063899df6f7c93c99921a7 (patch)
tree91fecc6dbffda7931f4a4dd687f6fb33dc32a32a /Modules/posixmodule.c
parent9731d4470fc78cb2d050530b9024fe31cdd12da4 (diff)
downloadcpython-794d81313b5a986ae3063899df6f7c93c99921a7.zip
cpython-794d81313b5a986ae3063899df6f7c93c99921a7.tar.gz
cpython-794d81313b5a986ae3063899df6f7c93c99921a7.tar.bz2
* Modules/posixmodule.c: some more NT changes
Diffstat (limited to 'Modules/posixmodule.c')
-rw-r--r--Modules/posixmodule.c23
1 files changed, 20 insertions, 3 deletions
diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c
index 5f26b62..7bf69e7 100644
--- a/Modules/posixmodule.c
+++ b/Modules/posixmodule.c
@@ -116,6 +116,7 @@ extern int symlink();
#include <process.h>
#include <windows.h>
#define popen _popen
+#define pclose _pclose
#endif /* NT */
#ifdef OS2
@@ -730,6 +731,7 @@ posix_execve(self, args)
return NULL;
}
+#ifndef NT
static object *
posix_fork(self, args)
object *self;
@@ -763,6 +765,7 @@ posix_geteuid(self, args)
return NULL;
return newintobject((long)geteuid());
}
+#endif /* !NT */
static object *
posix_getgid(self, args)
@@ -820,6 +823,7 @@ posix_setpgrp(self, args)
#endif /* HAVE_SETPGRP */
+#ifndef NT
static object *
posix_getppid(self, args)
object *self;
@@ -853,6 +857,7 @@ posix_kill(self, args)
INCREF(None);
return None;
}
+#endif /* !NT */
static object *
posix_popen(self, args)
@@ -922,6 +927,7 @@ posix_waitpid(self, args)
}
#endif /* HAVE_WAITPID */
+#ifndef NT
static object *
posix_wait(self, args)
object *self;
@@ -936,6 +942,7 @@ posix_wait(self, args)
else
return mkvalue("ii", pid, sts);
}
+#endif /* !NT */
static object *
posix_lstat(self, args)
@@ -1260,6 +1267,7 @@ posix_pipe(self, args)
object *self;
object *args;
{
+#ifndef NT
int fds[2];
int res;
if (!getargs(args, ""))
@@ -1270,6 +1278,18 @@ posix_pipe(self, args)
if (res != 0)
return posix_error();
return mkvalue("(ii)", fds[0], fds[1]);
+#else /* NT */
+ HANDLE read, write;
+ BOOL ok;
+ if (!getargs(args, ""))
+ return NULL;
+ BGN_SAVE
+ ok = CreatePipe( &read, &write, NULL, 0);
+ END_SAVE
+ if (!ok)
+ return posix_error();
+ return mkvalue("(ii)", read, write);
+#endif /* NT */
}
static struct methodlist posix_methods[] = {
@@ -1362,10 +1382,7 @@ static struct methodlist posix_methods[] = {
{"write", posix_write},
{"fstat", posix_fstat},
{"fdopen", posix_fdopen},
-#ifndef NT
{"pipe", posix_pipe},
-#endif /* !NT */
-
{NULL, NULL} /* Sentinel */
};