mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-29 06:20:56 +00:00
Work around reparse point stat issues
In theory, p_stat should never return an S_ISLNK result, but due to the current implementation on Windows with mount points it is possible that it will. For now, work around that by allowing a link in the path to a directory being created. If it is really a problem, then the issue will be caught on the next iteration of the loop, but typically this will be the right thing to do.
This commit is contained in:
parent
8294e8cfff
commit
32c12ea6a9
@ -348,7 +348,8 @@ int git_futils_mkdir(
|
|||||||
int tmp_errno = errno;
|
int tmp_errno = errno;
|
||||||
|
|
||||||
/* ignore error if directory already exists */
|
/* ignore error if directory already exists */
|
||||||
if (p_stat(make_path.ptr, &st) < 0 || !S_ISDIR(st.st_mode)) {
|
if (p_stat(make_path.ptr, &st) < 0 ||
|
||||||
|
!(S_ISDIR(st.st_mode) || S_ISLNK(st.st_mode))) {
|
||||||
errno = tmp_errno;
|
errno = tmp_errno;
|
||||||
giterr_set(GITERR_OS, "Failed to make directory '%s'", make_path.ptr);
|
giterr_set(GITERR_OS, "Failed to make directory '%s'", make_path.ptr);
|
||||||
goto done;
|
goto done;
|
||||||
|
Loading…
Reference in New Issue
Block a user