diff options
author | Vicent Marti <tanoku@gmail.com> | 2011-06-17 19:08:06 +0200 |
---|---|---|
committer | Vicent Marti <tanoku@gmail.com> | 2011-06-17 19:09:18 +0200 |
commit | 9c11bd0a060f96c9724418074f5cefd1e26ec2db (patch) | |
tree | 49604ccae484e5e8fdc2199722b9aeaa0665a6ca /src/fileops.c | |
parent | cb75ffea80c358323738bdc2e1763cfa15f0bb87 (diff) | |
download | libgit2-9c11bd0a060f96c9724418074f5cefd1e26ec2db.tar.gz |
fileops: Fix 'GetFinalPathNameByHandleA' in old platforms
Diffstat (limited to 'src/fileops.c')
-rw-r--r-- | src/fileops.c | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/src/fileops.c b/src/fileops.c index 58bc65c45..12b28bf02 100644 --- a/src/fileops.c +++ b/src/fileops.c @@ -689,9 +689,25 @@ int gitfo_lstat__w32(const char *file_name, struct stat *buf) int gitfo_readlink__w32(const char *link, char *target, size_t target_len) { + static DWORD (*pGetFinalPath)(HANDLE, LPTSTR, DWORD, DWORD) = NULL; HANDLE hFile; DWORD dwRet; + /* + * Try to load the pointer to pGetFinalPath dynamically, because + * it is not available in platforms older than Vista + */ + if (pGetFinalPath == NULL) { + HANDLE library = LoadLibrary("kernel32"); + + if (library != NULL) + pGetFinalPath = GetProcAddress(library, "GetFinalPathNameByHandleA"); + + if (pGetFinalPath == NULL) + return git__throw(GIT_EOSERR, + "'GetFinalPathNameByHandleA' is not available in this platform"); + } + hFile = CreateFile(link, // file to open GENERIC_READ, // open for reading FILE_SHARE_READ, // share for reading @@ -703,7 +719,7 @@ int gitfo_readlink__w32(const char *link, char *target, size_t target_len) if (hFile == INVALID_HANDLE_VALUE) return GIT_EOSERR; - dwRet = GetFinalPathNameByHandleA(hFile, target, target_len, VOLUME_NAME_DOS); + dwRet = pGetFinalPath(hFile, target, target_len, VOLUME_NAME_DOS); if (dwRet >= target_len) return GIT_ENOMEM; |