* exec.cc: Include pinfo.h.

* winf.h: Move definitions of _P_PATH_TYPE_EXEC and _P_MODE from here...
	* pinfo.h: ...to here.
	(_P_PATH_TYPE_EXEC): Redefine to be bigger than _P_SYSTEM.
	(_P_MODE): Redefine so as not to mask out _P_SYSTEM.
	* spawn.cc (spawnlp): Add _P_PATH_TYPE_EXEC flag in call to spawnve.
	(spawnlpe): Ditto.
	(spawnvp): Ditto.
This commit is contained in:
Corinna Vinschen 2011-01-20 11:09:21 +00:00
parent 9b68968b21
commit 2aba945c95
5 changed files with 30 additions and 16 deletions

View File

@ -1,3 +1,14 @@
2011-01-20 Corinna Vinschen <corinna@vinschen.de>
* exec.cc: Include pinfo.h.
* winf.h: Move definitions of _P_PATH_TYPE_EXEC and _P_MODE from here...
* pinfo.h: ...to here.
(_P_PATH_TYPE_EXEC): Redefine to be bigger than _P_SYSTEM.
(_P_MODE): Redefine so as not to mask out _P_SYSTEM.
* spawn.cc (spawnlp): Add _P_PATH_TYPE_EXEC flag in call to spawnve.
(spawnlpe): Ditto.
(spawnvp): Ditto.
2011-01-19 Corinna Vinschen <corinna@vinschen.de> 2011-01-19 Corinna Vinschen <corinna@vinschen.de>
* spawn.cc (av::fixup): Reenable #! handling for all exec functions. * spawn.cc (av::fixup): Reenable #! handling for all exec functions.

View File

@ -16,6 +16,7 @@ details. */
#include "sync.h" #include "sync.h"
#include "fhandler.h" #include "fhandler.h"
#include "dtable.h" #include "dtable.h"
#include "pinfo.h"
#include "cygheap.h" #include "cygheap.h"
#include "winf.h" #include "winf.h"

View File

@ -1,7 +1,7 @@
/* pinfo.h: process table info /* pinfo.h: process table info
Copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Copyright 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
Red Hat, Inc. 2011 Red Hat, Inc.
This file is part of Cygwin. This file is part of Cygwin.
@ -226,6 +226,16 @@ extern pinfo myself;
#define _P_VFORK 0 #define _P_VFORK 0
#define _P_SYSTEM 512 #define _P_SYSTEM 512
/* Add this flag in calls to spawn_guts if the calling function is one of
'p' type functions: execlp, execvp, spawnlp, spawnvp. Per POSIX, only
these p-type functions fall back to call /bin/sh if the file is not a
binary. The setting of _P_PATH_TYPE_EXEC is used as a bool value in
av::fixup to decide if the file should be evaluated as a script, or if
ENOEXEC should be returned. */
#define _P_PATH_TYPE_EXEC 0x1000
/* Helper macro to mask actual mode and drop additional flags defined above. */
#define _P_MODE(x) ((x) & 0xfff)
#define __ctty() _ctty ((char *) alloca (sizeof ("ctty /dev/tty") + 20)) #define __ctty() _ctty ((char *) alloca (sizeof ("ctty /dev/tty") + 20))
#define myctty() myself->__ctty () #define myctty() myself->__ctty ()

View File

@ -969,8 +969,8 @@ spawnlp (int mode, const char *file, const char *arg0, ...)
va_end (args); va_end (args);
return spawnve (mode, find_exec (file, buf), (char * const *) argv, return spawnve (mode | _P_PATH_TYPE_EXEC, find_exec (file, buf),
cur_environ ()); (char * const *) argv, cur_environ ());
} }
extern "C" int extern "C" int
@ -993,7 +993,8 @@ spawnlpe (int mode, const char *file, const char *arg0, ...)
envp = va_arg (args, const char * const *); envp = va_arg (args, const char * const *);
va_end (args); va_end (args);
return spawnve (mode, find_exec (file, buf), (char * const *) argv, envp); return spawnve (mode | _P_PATH_TYPE_EXEC, find_exec (file, buf),
(char * const *) argv, envp);
} }
extern "C" int extern "C" int
@ -1006,7 +1007,8 @@ extern "C" int
spawnvp (int mode, const char *file, const char * const *argv) spawnvp (int mode, const char *file, const char * const *argv)
{ {
path_conv buf; path_conv buf;
return spawnve (mode, find_exec (file, buf), argv, cur_environ ()); return spawnve (mode | _P_PATH_TYPE_EXEC, find_exec (file, buf), argv,
cur_environ ());
} }
extern "C" int extern "C" int

View File

@ -20,16 +20,6 @@ details. */
#define MAXWINCMDLEN 32767 #define MAXWINCMDLEN 32767
#define LINE_BUF_CHUNK (MAX_PATH * 2) #define LINE_BUF_CHUNK (MAX_PATH * 2)
/* Add this flag in calls to spawn_guts if the calling function is one of
'p' type functions: execlp, execvp, spawnlp, spawnvp. Per POSIX, only
these p-type functions fall back to call /bin/sh if the file is not a
binary. The setting of _P_PATH_TYPE_EXEC is used as a bool value in
av::fixup to decide if the file should be evaluated as a script, or if
ENOEXEC should be returned. */
#define _P_PATH_TYPE_EXEC 0x100
/* Helper macro to mask actual mode and drop additional flags defined above. */
#define _P_MODE(x) ((x) & 0xff)
class av class av
{ {
char **argv; char **argv;