diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2006-01-31 21:49:39 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2006-01-31 21:49:39 +0000 |
commit | 4b84e3dceab3c8a9004ae2f2aac53741ce24b308 (patch) | |
tree | e59f6d7794be8b844e72f46047928502891f2bc0 /winsup/cygwin/spawn.cc | |
parent | fd34affe5d4d0ee0a168ea6d721eb9d037305d92 (diff) | |
download | cygnal-4b84e3dceab3c8a9004ae2f2aac53741ce24b308.tar.gz cygnal-4b84e3dceab3c8a9004ae2f2aac53741ce24b308.tar.bz2 cygnal-4b84e3dceab3c8a9004ae2f2aac53741ce24b308.zip |
* dlfcn.cc (check_path_access): Call find_exec with FE_DLL option.
* path.h (enum fe_types): Add FE_DLL value.
* spawn.cc (std_suffixes): Remove.
(exe_suffixes): New suffix_info for executing files.
(dll_suffixes): New suffix_info for searching shared libraries.
(perhaps_suffix): Add opt argument. Use dll_suffixes if FE_DLL
option is given, exe_suffixes otherwise.
(find_exec): Propagate opt argument to perhaps_suffix. Drop suffix
check when testing execute permission.
(spawn_guts): Call perhaps_suffix with FE_NADA opt argument.
Diffstat (limited to 'winsup/cygwin/spawn.cc')
-rw-r--r-- | winsup/cygwin/spawn.cc | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/winsup/cygwin/spawn.cc b/winsup/cygwin/spawn.cc index f906dce68..b56d8bb65 100644 --- a/winsup/cygwin/spawn.cc +++ b/winsup/cygwin/spawn.cc @@ -37,11 +37,16 @@ details. */ #define LINE_BUF_CHUNK (CYG_MAX_PATH * 2) #define MAXWINCMDLEN 32767 -static suffix_info std_suffixes[] = +static suffix_info exe_suffixes[] = { suffix_info (".exe", 1), suffix_info ("", 1), - suffix_info (".com"), suffix_info (".cmd"), - suffix_info (".bat"), suffix_info (".dll"), + suffix_info (".com"), + suffix_info (NULL) +}; + +static suffix_info dll_suffixes[] = +{ + suffix_info (".dll"), suffix_info (NULL) }; @@ -55,13 +60,14 @@ DWORD dwExeced; Returns (possibly NULL) suffix */ static const char * -perhaps_suffix (const char *prog, path_conv& buf, int& err) +perhaps_suffix (const char *prog, path_conv& buf, int& err, unsigned opt) { char *ext; err = 0; debug_printf ("prog '%s'", prog); - buf.check (prog, PC_SYM_FOLLOW | PC_NULLEMPTY, std_suffixes); + buf.check (prog, PC_SYM_FOLLOW | PC_NULLEMPTY, + (opt & FE_DLL) ? dll_suffixes : exe_suffixes); if (buf.isdir ()) { @@ -106,7 +112,7 @@ find_exec (const char *name, path_conv& buf, const char *mywinenv, Win32 systems always check . first, but PATH may not be set up to do this. */ if ((has_slash || opt & FE_CWD) - && (suffix = perhaps_suffix (name, buf, err)) != NULL) + && (suffix = perhaps_suffix (name, buf, err, opt)) != NULL) { if (posix && !has_slash) { @@ -160,11 +166,9 @@ find_exec (const char *name, path_conv& buf, const char *mywinenv, debug_printf ("trying %s", tmp); - if ((suffix = perhaps_suffix (tmp, buf, err)) != NULL) + if ((suffix = perhaps_suffix (tmp, buf, err, opt)) != NULL) { - if (buf.has_acls () && allow_ntsec - && (*suffix == '\0' || strcmp (suffix, ".exe")) - && check_file_access (buf, X_OK)) + if (buf.has_acls () && allow_ntsec && check_file_access (buf, X_OK)) continue; if (posix == tmp) @@ -469,7 +473,7 @@ spawn_guts (const char * prog_arg, const char *const *argv, int err; const char *ext; - if ((ext = perhaps_suffix (prog_arg, real_path, err)) == NULL) + if ((ext = perhaps_suffix (prog_arg, real_path, err, FE_NADA)) == NULL) { set_errno (err); res = -1; |