mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-30 21:30:04 +00:00 
			
		
		
		
	Port #709 from yuzu: "common/misc: Deduplicate code in GetLastErrorMsg()"
This commit is contained in:
		
							parent
							
								
									07a78a6dd2
								
							
						
					
					
						commit
						3ad1ee65ad
					
				
					 2 changed files with 8 additions and 12 deletions
				
			
		|  | @ -4,6 +4,8 @@ | |||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
| #if !defined(ARCHITECTURE_x86_64) | ||||
| #include <cstdlib> // for exit | ||||
| #endif | ||||
|  | @ -95,4 +97,4 @@ __declspec(dllimport) void __stdcall DebugBreak(void); | |||
| // Call directly after the command or use the error num.
 | ||||
| // This function might change the error code.
 | ||||
| // Defined in Misc.cpp.
 | ||||
| const char* GetLastErrorMsg(); | ||||
| std::string GetLastErrorMsg(); | ||||
|  |  | |||
|  | @ -4,34 +4,28 @@ | |||
| 
 | ||||
| #include <cstddef> | ||||
| #ifdef _WIN32 | ||||
| #include <windows.h> | ||||
| #include <Windows.h> | ||||
| #else | ||||
| #include <cerrno> | ||||
| #include <cstring> | ||||
| #endif | ||||
| 
 | ||||
| // Neither Android nor OS X support TLS
 | ||||
| #if defined(__APPLE__) || (ANDROID && __clang__) | ||||
| #define __thread | ||||
| #endif | ||||
| #include "common/common_funcs.h" | ||||
| 
 | ||||
| // Generic function to get last error message.
 | ||||
| // Call directly after the command or use the error num.
 | ||||
| // This function might change the error code.
 | ||||
| const char* GetLastErrorMsg() { | ||||
| std::string GetLastErrorMsg() { | ||||
|     static const size_t buff_size = 255; | ||||
|     char err_str[buff_size]; | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
|     static __declspec(thread) char err_str[buff_size] = {}; | ||||
| 
 | ||||
|     FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, nullptr, GetLastError(), | ||||
|                    MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), err_str, buff_size, nullptr); | ||||
| #else | ||||
|     static __thread char err_str[buff_size] = {}; | ||||
| 
 | ||||
|     // Thread safe (XSI-compliant)
 | ||||
|     strerror_r(errno, err_str, buff_size); | ||||
| #endif | ||||
| 
 | ||||
|     return err_str; | ||||
|     return std::string(err_str, buff_size); | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue