@@ -1242,18 +1242,16 @@ char *mingw_getcwd(char *pointer, int len)
1242
1242
{
1243
1243
wchar_t cwd [MAX_PATH ], wpointer [MAX_PATH ];
1244
1244
DWORD ret = GetCurrentDirectoryW (ARRAY_SIZE (cwd ), cwd );
1245
+ HANDLE hnd ;
1245
1246
1246
1247
if (!ret || ret >= ARRAY_SIZE (cwd )) {
1247
1248
errno = ret ? ENAMETOOLONG : err_win_to_posix (GetLastError ());
1248
1249
return NULL ;
1249
1250
}
1250
- ret = GetLongPathNameW (cwd , wpointer , ARRAY_SIZE (wpointer ));
1251
- if (!ret && GetLastError () == ERROR_ACCESS_DENIED ) {
1252
- HANDLE hnd = CreateFileW (cwd , 0 ,
1253
- FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , NULL ,
1254
- OPEN_EXISTING , FILE_FLAG_BACKUP_SEMANTICS , NULL );
1255
- if (hnd == INVALID_HANDLE_VALUE )
1256
- return NULL ;
1251
+ hnd = CreateFileW (cwd , 0 ,
1252
+ FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , NULL ,
1253
+ OPEN_EXISTING , FILE_FLAG_BACKUP_SEMANTICS , NULL );
1254
+ if (hnd != INVALID_HANDLE_VALUE ) {
1257
1255
ret = GetFinalPathNameByHandleW (hnd , wpointer , ARRAY_SIZE (wpointer ), 0 );
1258
1256
CloseHandle (hnd );
1259
1257
if (!ret || ret >= ARRAY_SIZE (wpointer ))
@@ -1262,13 +1260,11 @@ char *mingw_getcwd(char *pointer, int len)
1262
1260
return NULL ;
1263
1261
return pointer ;
1264
1262
}
1265
- if (!ret || ret >= ARRAY_SIZE (wpointer ))
1266
- return NULL ;
1267
- if (GetFileAttributesW (wpointer ) == INVALID_FILE_ATTRIBUTES ) {
1263
+ if (GetFileAttributesW (cwd ) == INVALID_FILE_ATTRIBUTES ) {
1268
1264
errno = ENOENT ;
1269
1265
return NULL ;
1270
1266
}
1271
- if (xwcstoutf (pointer , wpointer , len ) < 0 )
1267
+ if (xwcstoutf (pointer , cwd , len ) < 0 )
1272
1268
return NULL ;
1273
1269
convert_slashes (pointer );
1274
1270
return pointer ;
0 commit comments