mirror of
				https://git.zaroz.cloud/nintendo-back-up/yuzu/yuzu.git
				synced 2025-05-12 00:45:25 +00:00 
			
		
		
		
	common/misc: Deduplicate code in GetLastErrorMsg()
Android and macOS have supported thread_local for quite a while, but most importantly is that we don't even really need it. Instead of using a thread-local buffer, we can just return a non-static buffer as a std::string, avoiding the need for that quality entirely.
This commit is contained in:
		
							parent
							
								
									cd4fca8447
								
							
						
					
					
						commit
						e0b8a35937
					
				| @ -4,6 +4,8 @@ | |||||||
| 
 | 
 | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include <string> | ||||||
|  | 
 | ||||||
| #if !defined(ARCHITECTURE_x86_64) && !defined(ARCHITECTURE_ARM) | #if !defined(ARCHITECTURE_x86_64) && !defined(ARCHITECTURE_ARM) | ||||||
| #include <cstdlib> // for exit | #include <cstdlib> // for exit | ||||||
| #endif | #endif | ||||||
| @ -90,7 +92,7 @@ __declspec(dllimport) void __stdcall DebugBreak(void); | |||||||
| // Call directly after the command or use the error num.
 | // Call directly after the command or use the error num.
 | ||||||
| // This function might change the error code.
 | // This function might change the error code.
 | ||||||
| // Defined in Misc.cpp.
 | // Defined in Misc.cpp.
 | ||||||
| const char* GetLastErrorMsg(); | std::string GetLastErrorMsg(); | ||||||
| 
 | 
 | ||||||
| namespace Common { | namespace Common { | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4,34 +4,28 @@ | |||||||
| 
 | 
 | ||||||
| #include <cstddef> | #include <cstddef> | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
| #include <windows.h> | #include <Windows.h> | ||||||
| #else | #else | ||||||
| #include <cerrno> | #include <cerrno> | ||||||
| #include <cstring> | #include <cstring> | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| // Neither Android nor OS X support TLS
 | #include "common/common_funcs.h" | ||||||
| #if defined(__APPLE__) || (ANDROID && __clang__) |  | ||||||
| #define __thread |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
| // Generic function to get last error message.
 | // Generic function to get last error message.
 | ||||||
| // Call directly after the command or use the error num.
 | // Call directly after the command or use the error num.
 | ||||||
| // This function might change the error code.
 | // This function might change the error code.
 | ||||||
| const char* GetLastErrorMsg() { | std::string GetLastErrorMsg() { | ||||||
|     static const size_t buff_size = 255; |     static const size_t buff_size = 255; | ||||||
|  |     char err_str[buff_size]; | ||||||
| 
 | 
 | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
|     static __declspec(thread) char err_str[buff_size] = {}; |  | ||||||
| 
 |  | ||||||
|     FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, nullptr, GetLastError(), |     FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, nullptr, GetLastError(), | ||||||
|                    MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), err_str, buff_size, nullptr); |                    MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), err_str, buff_size, nullptr); | ||||||
| #else | #else | ||||||
|     static __thread char err_str[buff_size] = {}; |  | ||||||
| 
 |  | ||||||
|     // Thread safe (XSI-compliant)
 |     // Thread safe (XSI-compliant)
 | ||||||
|     strerror_r(errno, err_str, buff_size); |     strerror_r(errno, err_str, buff_size); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|     return err_str; |     return std::string(err_str, buff_size); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Lioncash
						Lioncash