Browse Source

Merge pull request #43068 from cooperra/rename-fix

Rémi Verschelde 3 years ago
parent
commit
d97f223350
1 changed files with 5 additions and 0 deletions
  1. 5 0
      drivers/windows/dir_access_windows.cpp

+ 5 - 0
drivers/windows/dir_access_windows.cpp

@@ -256,6 +256,11 @@ Error DirAccessWindows::rename(String p_path, String p_new_path) {
 
 	// If we're only changing file name case we need to do a little juggling
 	if (p_path.to_lower() == p_new_path.to_lower()) {
+		if (dir_exists(p_path)) {
+			// The path is a dir; just rename
+			return ::_wrename((LPCWSTR)(p_path.utf16().get_data()), (LPCWSTR)(p_new_path.utf16().get_data())) == 0 ? OK : FAILED;
+		}
+		// The path is a file; juggle
 		WCHAR tmpfile[MAX_PATH];
 
 		if (!GetTempFileNameW((LPCWSTR)(fix_path(get_current_dir()).utf16().get_data()), nullptr, 0, tmpfile)) {