forked from eden-emu/eden
		
	[network] Error handling reform
`network.cpp` has several error paths which either:
- report "Unhandled host socket error=n" and return `SUCCESS`, or
- switch on a few possible errors, log them, and translate them to
  Errno; the same switch statement is copied and pasted in multiple
  places in the code
Convert these paths to use a helper function `GetAndLogLastError`, which
is roughly the equivalent of one of the switch statements, but:
- handling more cases (both ones that were already in `Errno`, and a few
  more I added), and
- using OS functions to convert the error to a string when logging, so
  it'll describe the error even if it's not one of the ones in the
  switch statement.
  - To handle this, refactor the logic in `GetLastErrorMsg` to expose a
    new function `NativeErrorToString` which takes the error number
    explicitly as an argument.  And improve the Windows version a bit.
Also, add a test which exercises two random error paths.
			
			
This commit is contained in:
		
							parent
							
								
									9e9341f4b4
								
							
						
					
					
						commit
						2910aa77b2
					
				
					 6 changed files with 147 additions and 111 deletions
				
			
		|  | @ -52,9 +52,13 @@ __declspec(dllimport) void __stdcall DebugBreak(void); | |||
| // Generic function to get last error message.
 | ||||
| // Call directly after the command or use the error num.
 | ||||
| // This function might change the error code.
 | ||||
| // Defined in Misc.cpp.
 | ||||
| // Defined in misc.cpp.
 | ||||
| [[nodiscard]] std::string GetLastErrorMsg(); | ||||
| 
 | ||||
| // Like GetLastErrorMsg(), but passing an explicit error code.
 | ||||
| // Defined in misc.cpp.
 | ||||
| [[nodiscard]] std::string NativeErrorToString(int e); | ||||
| 
 | ||||
| #define DECLARE_ENUM_FLAG_OPERATORS(type)                                                          \ | ||||
|     [[nodiscard]] constexpr type operator|(type a, type b) noexcept {                              \ | ||||
|         using T = std::underlying_type_t<type>;                                                    \ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 comex
						comex