forked from eden-emu/eden
		
	hex_util: Replace logic_errors with LOG_CRITICAL
Makes it so malformed hex strings do not crash the entire program.
This commit is contained in:
		
							parent
							
								
									0dce6d7008
								
							
						
					
					
						commit
						06487c2c8d
					
				
					 1 changed files with 17 additions and 5 deletions
				
			
		|  | @ -3,6 +3,7 @@ | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
| #include "common/hex_util.h" | #include "common/hex_util.h" | ||||||
|  | #include "common/logging/log.h" | ||||||
| 
 | 
 | ||||||
| namespace Common { | namespace Common { | ||||||
| 
 | 
 | ||||||
|  | @ -13,18 +14,29 @@ u8 ToHexNibble(char c1) { | ||||||
|         return c1 - 87; |         return c1 - 87; | ||||||
|     if (c1 >= 48 && c1 <= 57) |     if (c1 >= 48 && c1 <= 57) | ||||||
|         return c1 - 48; |         return c1 - 48; | ||||||
|     throw std::logic_error("Invalid hex digit"); |     LOG_ERROR(Common, "Invalid hex digit: 0x{:02X}", c1); | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::array<u8, 16> operator""_array16(const char* str, size_t len) { | std::array<u8, 16> operator""_array16(const char* str, size_t len) { | ||||||
|     if (len != 32) |     if (len != 32) { | ||||||
|         throw std::logic_error("Not of correct size."); |         LOG_ERROR(Common, | ||||||
|  |                   "Attempting to parse string to array that is not of correct size (expected=32, " | ||||||
|  |                   "actual={}).", | ||||||
|  |                   len); | ||||||
|  |         return {}; | ||||||
|  |     } | ||||||
|     return HexStringToArray<16>(str); |     return HexStringToArray<16>(str); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::array<u8, 32> operator""_array32(const char* str, size_t len) { | std::array<u8, 32> operator""_array32(const char* str, size_t len) { | ||||||
|     if (len != 64) |     if (len != 64) { | ||||||
|         throw std::logic_error("Not of correct size."); |         LOG_ERROR(Common, | ||||||
|  |                   "Attempting to parse string to array that is not of correct size (expected=64, " | ||||||
|  |                   "actual={}).", | ||||||
|  |                   len); | ||||||
|  |         return {}; | ||||||
|  |     } | ||||||
|     return HexStringToArray<32>(str); |     return HexStringToArray<32>(str); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zach Hilman
						Zach Hilman