diff options
| author | Edward Thomson <ethomson@microsoft.com> | 2013-05-04 12:04:39 -0500 |
|---|---|---|
| committer | Edward Thomson <ethomson@microsoft.com> | 2013-05-04 12:40:41 -0500 |
| commit | 00a4c4793890e9a8f6ad6f538d445111d6c73d54 (patch) | |
| tree | a44cf8fc0c5e3a5639ef06c88c85938fe36e7dca | |
| parent | dfec726bbae0e699b78db8f1b63372134c8467a6 (diff) | |
| download | libgit2-00a4c4793890e9a8f6ad6f538d445111d6c73d54.tar.gz | |
p_stat() should follow symlinks on windows
| -rw-r--r-- | src/win32/posix_w32.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/win32/posix_w32.c b/src/win32/posix_w32.c index 4d56299f7..da147ad0c 100644 --- a/src/win32/posix_w32.c +++ b/src/win32/posix_w32.c @@ -295,7 +295,18 @@ int p_getcwd(char *buffer_out, size_t size) int p_stat(const char* path, struct stat* buf) { - return do_lstat(path, buf, 0); + char target[GIT_WIN_PATH]; + int error = 0; + + error = do_lstat(path, buf, 0); + + /* We need not do this in a loop to unwind chains of symlinks since + * p_readlink calls GetFinalPathNameByHandle which does it for us. */ + if (error >= 0 && S_ISLNK(buf->st_mode) && + (error = p_readlink(path, target, GIT_WIN_PATH)) >= 0) + error = do_lstat(target, buf, 0); + + return error; } int p_chdir(const char* path) |
