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 | |
| parent | cb75ffea80c358323738bdc2e1763cfa15f0bb87 (diff) | |
| download | libgit2-9c11bd0a060f96c9724418074f5cefd1e26ec2db.tar.gz | |
fileops: Fix 'GetFinalPathNameByHandleA' in old platforms
Diffstat (limited to 'src')
| -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; | 
