kernel32: Improve GetVolumePathName stub.

Hans Leidekker hans at codeweavers.com
Wed Apr 22 05:47:06 CDT 2009


diff --git a/dlls/kernel32/volume.c b/dlls/kernel32/volume.c
index 9addeab..31490b9 100644
--- a/dlls/kernel32/volume.c
+++ b/dlls/kernel32/volume.c
@@ -1406,9 +1406,19 @@ BOOL WINAPI GetDiskFreeSpaceA( LPCSTR root, LPDWORD cluster_sectors,
  */
 BOOL WINAPI GetVolumePathNameA(LPCSTR filename, LPSTR volumepathname, DWORD buflen)
 {
+    BOOL ret;
+    WCHAR *filenameW = NULL, *volumeW;
+
     FIXME("(%s, %p, %d), stub!\n", debugstr_a(filename), volumepathname, buflen);
-    SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
-    return FALSE;
+
+    if (filename && !(filenameW = FILE_name_AtoW( filename, FALSE ))) return FALSE;
+    if (!(volumeW = HeapAlloc( GetProcessHeap(), 0, buflen * sizeof(WCHAR) ))) return FALSE;
+
+    if ((ret = GetVolumePathNameW( filenameW, volumeW, buflen )))
+        FILE_name_WtoA( volumeW, -1, volumepathname, buflen );
+
+    HeapFree( GetProcessHeap(), 0, volumeW );
+    return ret;
 }
 
 /***********************************************************************
@@ -1416,8 +1426,18 @@ BOOL WINAPI GetVolumePathNameA(LPCSTR filename, LPSTR volumepathname, DWORD bufl
  */
 BOOL WINAPI GetVolumePathNameW(LPCWSTR filename, LPWSTR volumepathname, DWORD buflen)
 {
+    const WCHAR *p = filename;
+
     FIXME("(%s, %p, %d), stub!\n", debugstr_w(filename), volumepathname, buflen);
-    SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
+
+    if (p && tolowerW(p[0]) >= 'a' && tolowerW(p[0]) <= 'z' && p[1] ==':' && p[2] == '\\' && buflen >= 4)
+    {
+        volumepathname[0] = p[0];
+        volumepathname[1] = ':';
+        volumepathname[2] = '\\';
+        volumepathname[3] = 0;
+        return TRUE;
+    }
     return FALSE;
 }
 



More information about the wine-patches mailing list