Skip to content
This repository was archived by the owner on Nov 9, 2017. It is now read-only.

Commit 7ed7c52

Browse files
arobenkasal
authored andcommitted
Fix launching of externals from Unicode paths
If Git were installed in a path containing non-ASCII characters, commands such as git-am and git-submodule, which are implemented as externals, would fail to launch with the following error: > fatal: 'am' appears to be a git command, but we were not > able to execute it. Maybe git-am is broken? This was due to lookup_prog not being Unicode-aware. It was somehow missed in 2ee5a1a. Note that the only problem in this function was calling GetFileAttributes instead of GetFileAttributesW. The calls to access() were fine because access() is a macro which resolves to mingw_access, which already handles Unicode correctly. But I changed lookup_prog to use _waccess directly so that we only convert the path to UTF-16 once. Signed-off-by: Adam Roben <[email protected]>
1 parent 5868bd1 commit 7ed7c52

File tree

1 file changed

+9
-3
lines changed

1 file changed

+9
-3
lines changed

compat/mingw.c

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -957,14 +957,20 @@ static void free_path_split(char **path)
957957
static char *lookup_prog(const char *dir, const char *cmd, int isexe, int exe_only)
958958
{
959959
char path[MAX_PATH];
960+
wchar_t wpath[MAX_PATH];
960961
snprintf(path, sizeof(path), "%s\\%s.exe", dir, cmd);
961962

962-
if (!isexe && access(path, F_OK) == 0)
963+
if (xutftowcs_path(wpath, path) < 0)
964+
return NULL;
965+
966+
if (!isexe && _waccess(wpath, F_OK) == 0)
963967
return xstrdup(path);
964968
path[strlen(path)-4] = '\0';
965-
if ((!exe_only || isexe) && access(path, F_OK) == 0)
966-
if (!(GetFileAttributes(path) & FILE_ATTRIBUTE_DIRECTORY))
969+
if ((!exe_only || isexe) && _waccess(wpath, F_OK) == 0) {
970+
971+
if (!(GetFileAttributesW(wpath) & FILE_ATTRIBUTE_DIRECTORY))
967972
return xstrdup(path);
973+
}
968974
return NULL;
969975
}
970976

0 commit comments

Comments
 (0)