summaryrefslogtreecommitdiffstats
path: root/Utilities
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2023-12-05 14:20:51 (GMT)
committerKitware Robot <kwrobot@kitware.com>2023-12-05 14:21:12 (GMT)
commitf580271c027a9d557af327e3ccb514b3ad035d56 (patch)
tree9b23e09737e511e2a29b2a93d00d4a70a7b7414c /Utilities
parent60fa02de1c30cdc90b95bbaff4732314b3b57221 (diff)
parentfc6231bee53a8991a2da0529c541a1373ff1b721 (diff)
downloadCMake-f580271c027a9d557af327e3ccb514b3ad035d56.zip
CMake-f580271c027a9d557af327e3ccb514b3ad035d56.tar.gz
CMake-f580271c027a9d557af327e3ccb514b3ad035d56.tar.bz2
Merge topic 'execute_process-no-extension'
fc6231bee5 libuv: win/spawn: run executables with no file extension b37d9378de libuv: Revert "win/spawn: run executables with no file extension" Acked-by: Kitware Robot <kwrobot@kitware.com> Acked-by: Kyle Edwards <kyle.edwards@kitware.com> Merge-request: !9033
Diffstat (limited to 'Utilities')
-rw-r--r--Utilities/cmlibuv/src/win/process.c43
1 files changed, 30 insertions, 13 deletions
diff --git a/Utilities/cmlibuv/src/win/process.c b/Utilities/cmlibuv/src/win/process.c
index 02b6c26..7df3540 100644
--- a/Utilities/cmlibuv/src/win/process.c
+++ b/Utilities/cmlibuv/src/win/process.c
@@ -274,16 +274,19 @@ static WCHAR* path_search_walk_ext(const WCHAR *dir,
const WCHAR *name,
size_t name_len,
WCHAR *cwd,
- size_t cwd_len) {
+ size_t cwd_len,
+ int name_has_ext) {
WCHAR* result;
- /* Try the name itself first */
- result = search_path_join_test(dir, dir_len,
- name, name_len,
- L"", 0,
- cwd, cwd_len);
- if (result != NULL) {
- return result;
+ /* If the name itself has a nonempty extension, try this extension first */
+ if (name_has_ext) {
+ result = search_path_join_test(dir, dir_len,
+ name, name_len,
+ L"", 0,
+ cwd, cwd_len);
+ if (result != NULL) {
+ return result;
+ }
}
/* Try .com extension */
@@ -326,7 +329,10 @@ static WCHAR* path_search_walk_ext(const WCHAR *dir,
* - If there's really only a filename, check the current directory for file,
* then search all path directories.
*
- * - Search for the file exactly as specified first.
+ * - If a full path is specified, search for the exact filename first.
+ *
+ * - If filename specified has *any* extension, search for the file with the
+ * specified extension first.
*
* - If the literal filename is not found in a directory, try *appending*
* (not replacing) .com first and then .exe.
@@ -356,8 +362,10 @@ static WCHAR* search_path(const WCHAR *file,
int file_has_dir;
WCHAR* result = NULL;
WCHAR *file_name_start;
+ WCHAR *dot;
const WCHAR *dir_start, *dir_end, *dir_path;
size_t dir_len;
+ int name_has_ext;
size_t file_len = wcslen(file);
size_t cwd_len = wcslen(cwd);
@@ -381,12 +389,19 @@ static WCHAR* search_path(const WCHAR *file,
file_has_dir = file_name_start != file;
+ /* Check if the filename includes an extension */
+ dot = wcschr(file_name_start, L'.');
+ name_has_ext = (dot != NULL && dot[1] != L'\0');
+
if (file_has_dir) {
- /* The file has a path inside, don't use path */
+ /* The file has a path inside, don't use path
+ * Try the exact filename first, and then try standard extensions
+ */
result = path_search_walk_ext(
file, file_name_start - file,
file_name_start, file_len - (file_name_start - file),
- cwd, cwd_len);
+ cwd, cwd_len,
+ 1);
} else {
dir_end = path;
@@ -395,7 +410,8 @@ static WCHAR* search_path(const WCHAR *file,
/* The file is really only a name; look in cwd first, then scan path */
result = path_search_walk_ext(L"", 0,
file, file_len,
- cwd, cwd_len);
+ cwd, cwd_len,
+ name_has_ext);
}
while (result == NULL) {
@@ -444,7 +460,8 @@ static WCHAR* search_path(const WCHAR *file,
result = path_search_walk_ext(dir_path, dir_len,
file, file_len,
- cwd, cwd_len);
+ cwd, cwd_len,
+ name_has_ext);
}
}