Merge branch 'cpp-11' into crashlog_improvements
This commit is contained in:
		@@ -365,13 +365,32 @@ static inline T ROR(const T x, const uint8 n)
 | 
				
			|||||||
	 * (since it will use hardware swapping if available).
 | 
						 * (since it will use hardware swapping if available).
 | 
				
			||||||
	 * Even though they should return uint16 and uint32, we get
 | 
						 * Even though they should return uint16 and uint32, we get
 | 
				
			||||||
	 * warnings if we don't cast those (why?) */
 | 
						 * warnings if we don't cast those (why?) */
 | 
				
			||||||
 | 
						#define BSWAP64(x) ((uint64)CFSwapInt64(x))
 | 
				
			||||||
	#define BSWAP32(x) ((uint32)CFSwapInt32(x))
 | 
						#define BSWAP32(x) ((uint32)CFSwapInt32(x))
 | 
				
			||||||
	#define BSWAP16(x) ((uint16)CFSwapInt16(x))
 | 
						#define BSWAP16(x) ((uint16)CFSwapInt16(x))
 | 
				
			||||||
#elif defined(_MSC_VER)
 | 
					#elif defined(_MSC_VER)
 | 
				
			||||||
	/* MSVC has intrinsics for swapping, resulting in faster code */
 | 
						/* MSVC has intrinsics for swapping, resulting in faster code */
 | 
				
			||||||
 | 
						#define BSWAP64(x) (_byteswap_uint64(x))
 | 
				
			||||||
	#define BSWAP32(x) (_byteswap_ulong(x))
 | 
						#define BSWAP32(x) (_byteswap_ulong(x))
 | 
				
			||||||
	#define BSWAP16(x) (_byteswap_ushort(x))
 | 
						#define BSWAP16(x) (_byteswap_ushort(x))
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
 | 
						/**
 | 
				
			||||||
 | 
						 * Perform a 64 bits endianness bitswap on x.
 | 
				
			||||||
 | 
						 * @param x the variable to bitswap
 | 
				
			||||||
 | 
						 * @return the bitswapped value.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						static inline uint64 BSWAP64(uint64 x)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					#if !defined(__ICC) && (defined(__GNUC__) || defined(__clang__))
 | 
				
			||||||
 | 
							/* GCC >= 4.3 provides a builtin, resulting in faster code */
 | 
				
			||||||
 | 
							return (uint64)__builtin_bswap64((uint64)x);
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
							return ((x >> 56) & 0xFFULL) | ((x >> 40) & 0xFF00ULL) | ((x >> 24) & 0xFF0000ULL) | ((x >> 8) & 0xFF000000ULL) |
 | 
				
			||||||
 | 
									((x << 8) & 0xFF00000000ULL) | ((x << 24) & 0xFF0000000000ULL) | ((x << 40) & 0xFF000000000000ULL) | ((x << 56) & 0xFF000000000000ULL);
 | 
				
			||||||
 | 
									;
 | 
				
			||||||
 | 
					#endif /* __GNUC__ || __clang__ */
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/**
 | 
						/**
 | 
				
			||||||
	 * Perform a 32 bits endianness bitswap on x.
 | 
						 * Perform a 32 bits endianness bitswap on x.
 | 
				
			||||||
	 * @param x the variable to bitswap
 | 
						 * @param x the variable to bitswap
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,25 +19,33 @@
 | 
				
			|||||||
#if TTD_ENDIAN == TTD_BIG_ENDIAN
 | 
					#if TTD_ENDIAN == TTD_BIG_ENDIAN
 | 
				
			||||||
	#define FROM_BE16(x) (x)
 | 
						#define FROM_BE16(x) (x)
 | 
				
			||||||
	#define FROM_BE32(x) (x)
 | 
						#define FROM_BE32(x) (x)
 | 
				
			||||||
 | 
						#define FROM_BE64(x) (x)
 | 
				
			||||||
	#define TO_BE16(x)   (x)
 | 
						#define TO_BE16(x)   (x)
 | 
				
			||||||
	#define TO_BE32(x)   (x)
 | 
						#define TO_BE32(x)   (x)
 | 
				
			||||||
	#define TO_BE32X(x)  (x)
 | 
						#define TO_BE32X(x)  (x)
 | 
				
			||||||
 | 
						#define TO_BE64(x)   (x)
 | 
				
			||||||
	#define FROM_LE16(x) BSWAP16(x)
 | 
						#define FROM_LE16(x) BSWAP16(x)
 | 
				
			||||||
	#define FROM_LE32(x) BSWAP32(x)
 | 
						#define FROM_LE32(x) BSWAP32(x)
 | 
				
			||||||
 | 
						#define FROM_LE64(x) BSWAP64(x)
 | 
				
			||||||
	#define TO_LE16(x)   BSWAP16(x)
 | 
						#define TO_LE16(x)   BSWAP16(x)
 | 
				
			||||||
	#define TO_LE32(x)   BSWAP32(x)
 | 
						#define TO_LE32(x)   BSWAP32(x)
 | 
				
			||||||
	#define TO_LE32X(x)  BSWAP32(x)
 | 
						#define TO_LE32X(x)  BSWAP32(x)
 | 
				
			||||||
 | 
						#define TO_LE64(x)   BSWAP64(x)
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
	#define FROM_BE16(x) BSWAP16(x)
 | 
						#define FROM_BE16(x) BSWAP16(x)
 | 
				
			||||||
	#define FROM_BE32(x) BSWAP32(x)
 | 
						#define FROM_BE32(x) BSWAP32(x)
 | 
				
			||||||
 | 
						#define FROM_BE64(x) BSWAP64(x)
 | 
				
			||||||
	#define TO_BE16(x)   BSWAP16(x)
 | 
						#define TO_BE16(x)   BSWAP16(x)
 | 
				
			||||||
	#define TO_BE32(x)   BSWAP32(x)
 | 
						#define TO_BE32(x)   BSWAP32(x)
 | 
				
			||||||
	#define TO_BE32X(x)  BSWAP32(x)
 | 
						#define TO_BE32X(x)  BSWAP32(x)
 | 
				
			||||||
 | 
						#define TO_BE64(x)   BSWAP64(x)
 | 
				
			||||||
	#define FROM_LE16(x) (x)
 | 
						#define FROM_LE16(x) (x)
 | 
				
			||||||
	#define FROM_LE32(x) (x)
 | 
						#define FROM_LE32(x) (x)
 | 
				
			||||||
 | 
						#define FROM_LE64(x) (x)
 | 
				
			||||||
	#define TO_LE16(x)   (x)
 | 
						#define TO_LE16(x)   (x)
 | 
				
			||||||
	#define TO_LE32(x)   (x)
 | 
						#define TO_LE32(x)   (x)
 | 
				
			||||||
	#define TO_LE32X(x)  (x)
 | 
						#define TO_LE32X(x)  (x)
 | 
				
			||||||
 | 
						#define TO_LE64(x)   (x)
 | 
				
			||||||
#endif /* TTD_ENDIAN == TTD_BIG_ENDIAN */
 | 
					#endif /* TTD_ENDIAN == TTD_BIG_ENDIAN */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static inline uint16 ReadLE16Aligned(const void *x)
 | 
					static inline uint16 ReadLE16Aligned(const void *x)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -12,6 +12,8 @@
 | 
				
			|||||||
#ifndef SCOPE_H
 | 
					#ifndef SCOPE_H
 | 
				
			||||||
#define SCOPE_H
 | 
					#define SCOPE_H
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <utility>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
template <typename T>
 | 
					template <typename T>
 | 
				
			||||||
class scope_exit_obj {
 | 
					class scope_exit_obj {
 | 
				
			||||||
	T f;
 | 
						T f;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								src/stdafx.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/stdafx.h
									
									
									
									
									
								
							@@ -426,6 +426,16 @@ assert_compile(SIZE_MAX >= UINT32_MAX);
 | 
				
			|||||||
#define unlikely(x)     (x)
 | 
					#define unlikely(x)     (x)
 | 
				
			||||||
#endif /* __GNUC__ || __clang__ */
 | 
					#endif /* __GNUC__ || __clang__ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if defined(__GNUC__) || defined(__clang__)
 | 
				
			||||||
 | 
					__attribute__((aligned(1))) typedef uint16 unaligned_uint16;
 | 
				
			||||||
 | 
					__attribute__((aligned(1))) typedef uint32 unaligned_uint32;
 | 
				
			||||||
 | 
					__attribute__((aligned(1))) typedef uint64 unaligned_uint64;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					typedef uint16 unaligned_uint16;
 | 
				
			||||||
 | 
					typedef uint32 unaligned_uint32;
 | 
				
			||||||
 | 
					typedef uint64 unaligned_uint64;
 | 
				
			||||||
 | 
					#endif /* __GNUC__ || __clang__ */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void NORETURN CDECL usererror(const char *str, ...) WARN_FORMAT(1, 2);
 | 
					void NORETURN CDECL usererror(const char *str, ...) WARN_FORMAT(1, 2);
 | 
				
			||||||
void NORETURN CDECL error(const char *str, ...) WARN_FORMAT(1, 2);
 | 
					void NORETURN CDECL error(const char *str, ...) WARN_FORMAT(1, 2);
 | 
				
			||||||
void NORETURN CDECL assert_msg_error(int line, const char *file, const char *expr, const char *extra, const char *str, ...) WARN_FORMAT(5, 6);
 | 
					void NORETURN CDECL assert_msg_error(int line, const char *file, const char *expr, const char *extra, const char *str, ...) WARN_FORMAT(5, 6);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user