- cleaning out some trash from compat.h.

The header from hell...
This commit is contained in:
Christoph Oelckers 2020-08-30 23:34:40 +02:00
parent ba8dc788fe
commit b8258da997
18 changed files with 50 additions and 497 deletions

View file

@ -5097,7 +5097,6 @@ int MoveMissile(spritetype *pSprite)
if (pTarget->statnum == kStatDude && pXTarget && pXTarget->health > 0) if (pTarget->statnum == kStatDude && pXTarget && pXTarget->health > 0)
{ {
int nTargetAngle = getangle(-(pTarget->y-pSprite->y), pTarget->x-pSprite->x); int nTargetAngle = getangle(-(pTarget->y-pSprite->y), pTarget->x-pSprite->x);
int UNUSED(nAngle) = getangle(xvel[nSprite]>>12,yvel[nSprite]>>12);
int vx = missileInfo[pSprite->type - kMissileBase].velocity; int vx = missileInfo[pSprite->type - kMissileBase].velocity;
int vy = 0; int vy = 0;
RotatePoint(&vx, &vy, (nTargetAngle+1536)&2047, 0, 0); RotatePoint(&vx, &vy, (nTargetAngle+1536)&2047, 0, 0);

View file

@ -2500,7 +2500,7 @@ bool condCmpb(int val, int arg1, int arg2, int comOp) {
void condError(XSPRITE* pXCond, const char* pzFormat, ...) { void condError(XSPRITE* pXCond, const char* pzFormat, ...) {
char buffer[256]; char buffer2[512]; char buffer[256]; char buffer2[512];
Bsprintf(buffer, "\nCONDITION RX: %d, TX: %d, SPRITE: #%d RETURNS:\n----------\n\n", pXCond->rxID, pXCond->txID, pXCond->reference); sprintf(buffer, "\nCONDITION RX: %d, TX: %d, SPRITE: #%d RETURNS:\n----------\n\n", pXCond->rxID, pXCond->txID, pXCond->reference);
va_list args; va_list args;
va_start(args, pzFormat); va_start(args, pzFormat);
vsprintf(buffer2, pzFormat, args); vsprintf(buffer2, pzFormat, args);

View file

@ -7,7 +7,6 @@
#define VPX_CODEC_DISABLE_COMPAT 1 #define VPX_CODEC_DISABLE_COMPAT 1
#ifndef ANIMVPX_STANDALONE #ifndef ANIMVPX_STANDALONE
# undef UNUSED
# include <vpx/vpx_decoder.h> # include <vpx/vpx_decoder.h>
//#include <vpx/vp8dx.h> //#include <vpx/vp8dx.h>
#endif #endif
@ -93,14 +92,14 @@ void animvpx_print_stats(const animvpx_codec_ctx *codec);
static inline int32_t animvpx_check_header(const animvpx_ivf_header_t *hdr) static inline int32_t animvpx_check_header(const animvpx_ivf_header_t *hdr)
{ {
if (Bmemcmp(hdr->magic,"DKIF",4)) if (memcmp(hdr->magic,"DKIF",4))
return 2; // "not an IVF file" return 2; // "not an IVF file"
if (hdr->version != 0) if (hdr->version != 0)
return 3; // "unrecognized IVF version" return 3; // "unrecognized IVF version"
// fourcc is left as-is // fourcc is left as-is
if (Bmemcmp(hdr->fourcc, "VP80", 4)) if (memcmp(hdr->fourcc, "VP80", 4))
return 4; // "only VP8 supported" return 4; // "only VP8 supported"
return 0; return 0;

View file

@ -741,10 +741,10 @@ int32_t krand(void);
#endif #endif
int32_t ksqrt(uint32_t num); int32_t ksqrt(uint32_t num);
int32_t __fastcall getangle(int32_t xvect, int32_t yvect); int32_t getangle(int32_t xvect, int32_t yvect);
fix16_t __fastcall gethiq16angle(int32_t xvect, int32_t yvect); fix16_t gethiq16angle(int32_t xvect, int32_t yvect);
static FORCE_INLINE fix16_t __fastcall getq16angle(int32_t xvect, int32_t yvect) static FORCE_INLINE fix16_t getq16angle(int32_t xvect, int32_t yvect)
{ {
return fix16_from_int(getangle(xvect, yvect)); return fix16_from_int(getangle(xvect, yvect));
} }

View file

@ -10,6 +10,7 @@
#include "xs_Float.h" #include "xs_Float.h"
#include "m_alloc.h" #include "m_alloc.h"
#include "intvec.h" #include "intvec.h"
#include "m_swap.h"
////////// Compiler detection ////////// ////////// Compiler detection //////////
@ -95,26 +96,12 @@
# endif # endif
#endif #endif
#ifdef __GNUC__
# define UNUSED(x) UNUSED_ ## x __attribute__((unused))
# define PRINTF_FORMAT(stringindex, firstargindex) __attribute__((format (printf, stringindex, firstargindex)))
#else
# define UNUSED(x) x
# define PRINTF_FORMAT(stringindex, firstargindex)
#endif
#if defined __GNUC__ || defined __clang__ #if defined __GNUC__ || defined __clang__
# define ATTRIBUTE(attrlist) __attribute__(attrlist) # define ATTRIBUTE(attrlist) __attribute__(attrlist)
#else #else
# define ATTRIBUTE(attrlist) # define ATTRIBUTE(attrlist)
#endif #endif
#if !defined __clang__ && !defined USING_LTO
# define ATTRIBUTE_OPTIMIZE(str) ATTRIBUTE((optimize(str)))
#else
# define ATTRIBUTE_OPTIMIZE(str)
#endif
#if EDUKE32_GCC_PREREQ(4,0) #if EDUKE32_GCC_PREREQ(4,0)
# define WARN_UNUSED_RESULT __attribute__((warn_unused_result)) # define WARN_UNUSED_RESULT __attribute__((warn_unused_result))
#else #else
@ -145,39 +132,13 @@
# endif # endif
#endif #endif
#ifndef _MSC_VER
# ifndef __fastcall
# if defined(__GNUC__) && defined(__i386__)
# define __fastcall __attribute__((fastcall))
# else
# define __fastcall
# endif
# endif
#endif
#ifndef DISABLE_INLINING
# define EXTERN_INLINE static inline
# define EXTERN_INLINE_HEADER static inline
#else
# define EXTERN_INLINE __fastcall
# define EXTERN_INLINE_HEADER extern __fastcall
#endif
#if 0 && defined(__OPTIMIZE__) && (defined __GNUC__ || __has_builtin(__builtin_expect)) #if 0 && defined(__OPTIMIZE__) && (defined __GNUC__ || __has_builtin(__builtin_expect))
#define EDUKE32_PREDICT_TRUE(x) __builtin_expect(!!(x),1)
#define EDUKE32_PREDICT_FALSE(x) __builtin_expect(!!(x),0) #define EDUKE32_PREDICT_FALSE(x) __builtin_expect(!!(x),0)
#else #else
#define EDUKE32_PREDICT_TRUE(x) (x)
#define EDUKE32_PREDICT_FALSE(x) (x) #define EDUKE32_PREDICT_FALSE(x) (x)
#endif #endif
#if EDUKE32_GCC_PREREQ(4,5) || __has_builtin(__builtin_unreachable)
#define EDUKE32_UNREACHABLE_SECTION(...) __builtin_unreachable()
#elif _MSC_VER
#define EDUKE32_UNREACHABLE_SECTION(...) __assume(0)
#else
#define EDUKE32_UNREACHABLE_SECTION(...) __VA_ARGS__
#endif
#if EDUKE32_GCC_PREREQ(2,0) || defined _MSC_VER #if EDUKE32_GCC_PREREQ(2,0) || defined _MSC_VER
# define EDUKE32_FUNCTION __FUNCTION__ # define EDUKE32_FUNCTION __FUNCTION__
@ -257,111 +218,15 @@
#endif #endif
////////// Platform detection //////////
#if defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ || defined __bsdi__ || defined __DragonFly__
# define EDUKE32_BSD
#endif
#ifdef __APPLE__
# include <TargetConditionals.h>
# if TARGET_OS_IPHONE || TARGET_IPHONE_SIMULATOR
# define EDUKE32_IOS
# else
# define EDUKE32_OSX
# endif
#endif
////////// Architecture detection ////////// ////////// Architecture detection //////////
#if defined _LP64 || defined __LP64__ || defined __64BIT__ || _ADDR64 || defined _WIN64 || defined __arch64__ || \ #ifdef WORDS_BIGENDIAN
__WORDSIZE == 64 || (defined __sparc && defined __sparcv9) || defined __x86_64 || defined __amd64 || \
defined __x86_64__ || defined __amd64__ || defined _M_X64 || defined _M_IA64 || defined __ia64 || defined __IA64__
# define BITNESS64
#endif
#if defined(__linux)
# include <endian.h>
# if __BYTE_ORDER == __LITTLE_ENDIAN
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif __BYTE_ORDER == __BIG_ENDIAN
# define B_LITTLE_ENDIAN 0 # define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1 # define B_BIG_ENDIAN 1
# endif #else
#elif defined(GEKKO) || defined(__ANDROID__)
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
#elif defined(__OpenBSD__)
# include <machine/endian.h>
# if _BYTE_ORDER == _LITTLE_ENDIAN
# define B_LITTLE_ENDIAN 1 # define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0 # define B_BIG_ENDIAN 0
# elif _BYTE_ORDER == _BIG_ENDIAN
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
#elif defined EDUKE32_BSD
# include <sys/endian.h>
# if _BYTE_ORDER == _LITTLE_ENDIAN
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif _BYTE_ORDER == _BIG_ENDIAN
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
#elif defined(__APPLE__)
# if defined(__LITTLE_ENDIAN__)
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif defined(__BIG_ENDIAN__)
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
# include <libkern/OSByteOrder.h>
#elif defined(__BEOS__)
# include <posix/endian.h>
# if LITTLE_ENDIAN != 0
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif BIG_ENDIAN != 0
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
#elif defined(__QNX__)
# if defined __LITTLEENDIAN__
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif defined __BIGENDIAN__
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
#elif defined(__sun)
# if defined _LITTLE_ENDIAN
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
# elif defined _BIG_ENDIAN
# define B_LITTLE_ENDIAN 0
# define B_BIG_ENDIAN 1
# endif
#elif defined(_WIN32) || defined(SKYOS) || defined(__SYLLABLE__)
# define B_LITTLE_ENDIAN 1
# define B_BIG_ENDIAN 0
#endif
#if !defined(B_LITTLE_ENDIAN) || !defined(B_BIG_ENDIAN)
# error Unknown endianness
#endif #endif
@ -437,26 +302,13 @@ defined __x86_64__ || defined __amd64__ || defined _M_X64 || defined _M_IA64 ||
////////// DEPRECATED: Standard library prefixing ////////// ////////// DEPRECATED: Standard library prefixing //////////
#ifdef _MSC_VER typedef intptr_t ssize_t;
# if defined _M_AMD64 || defined _M_ARM64 || defined _M_X64 || defined _WIN64
typedef int64_t ssize_t;
# else
typedef int32_t ssize_t;
# endif
#endif
typedef size_t bsize_t; typedef size_t bsize_t;
typedef ssize_t bssize_t; typedef ssize_t bssize_t;
#define BMAX_PATH 256 #define BMAX_PATH 256
#define Bassert assert
#define Brand rand
#define Balloca alloca
#define Bmalloc malloc
#define Bcalloc calloc
#define Brealloc realloc
#define Bstrcpy strcpy #define Bstrcpy strcpy
#define Bstrncpy strncpy #define Bstrncpy strncpy
#define Bstrcmp strcmp #define Bstrcmp strcmp
@ -470,15 +322,8 @@ typedef ssize_t bssize_t;
#define Bstrtoul strtoul #define Bstrtoul strtoul
#define Bstrtod strtod #define Bstrtod strtod
#define Bstrstr strstr #define Bstrstr strstr
#define Bislower islower
#define Bisupper isupper
#define Bisdigit isdigit
#define Btoupper toupper
#define Btolower tolower
#define Bmemcpy memcpy #define Bmemcpy memcpy
#define Bmemset memset #define Bmemset memset
#define Bmemcmp memcmp
#define Bsprintf sprintf
////////// Standard library wrappers ////////// ////////// Standard library wrappers //////////
@ -510,121 +355,18 @@ static inline int Blrintf(const double x)
# define Bsqrtf sqrtf # define Bsqrtf sqrtf
#endif #endif
inline void Bexit(int a)
{
throw CExitEvent(a);
}
////////// Standard library monkey patching //////////
#ifndef NULL
# define NULL ((void *)0)
#endif
#ifndef O_BINARY
# define O_BINARY 0
#endif
#ifndef O_TEXT
# define O_TEXT 0
#endif
#ifndef F_OK
# define F_OK 0
#endif
////////// Metaprogramming structs ////////// ////////// Metaprogramming structs //////////
#ifdef __cplusplus
# ifdef HAVE_CXX11_HEADERS
using std::is_integral;
template <typename T>
struct is_signed
{
static constexpr bool value = std::is_signed<T>::value;
};
template <typename T>
struct is_unsigned
{
static constexpr bool value = std::is_unsigned<T>::value;
};
# endif
# if CXXSTD >= 2014 # if CXXSTD >= 2014
using std::enable_if_t; using std::enable_if_t;
using std::conditional_t;
using std::make_signed_t;
using std::make_unsigned_t;
using std::remove_pointer_t;
# elif defined HAVE_CXX11_HEADERS # elif defined HAVE_CXX11_HEADERS
template <bool B, class T = void> template <bool B, class T = void>
using enable_if_t = typename std::enable_if<B, T>::type; using enable_if_t = typename std::enable_if<B, T>::type;
template<bool B, class T, class F>
using conditional_t = typename std::conditional<B, T, F>::type;
template <typename T>
using make_signed_t = typename std::make_signed<T>::type;
template <typename T>
using make_unsigned_t = typename std::make_unsigned<T>::type;
template <class T>
using remove_pointer_t = typename std::remove_pointer<T>::type;
# endif # endif
# ifdef HAVE_CXX11_HEADERS
template <typename type, typename other_type_with_sign>
using take_sign_t = conditional_t< is_signed<other_type_with_sign>::value, make_signed_t<type>, make_unsigned_t<type> >;
# endif
template <size_t size> using native_t = intptr_t;
struct integers_of_size { };
template <>
struct integers_of_size<sizeof(int8_t)>
{
typedef int8_t i;
typedef uint8_t u;
};
template <>
struct integers_of_size<sizeof(int16_t)>
{
typedef int16_t i;
typedef uint16_t u;
};
template <>
struct integers_of_size<sizeof(int32_t)>
{
typedef int32_t i;
typedef uint32_t u;
};
template <>
struct integers_of_size<sizeof(int64_t)>
{
typedef int64_t i;
typedef uint64_t u;
};
#endif
////////// Typedefs //////////
#if defined(__x86_64__)
// for 32-bit pointers in x86_64 code, such as `gcc -mx32`
typedef uint64_t reg_t;
typedef int64_t sreg_t;
#else
typedef size_t reg_t;
typedef ssize_t sreg_t;
#endif
#ifdef HAVE_CXX11_HEADERS
using native_t = typename integers_of_size<sizeof(reg_t)>::i;
using unative_t = typename integers_of_size<sizeof(reg_t)>::u;
#else
typedef sreg_t native_t;
typedef reg_t unative_t;
#endif
EDUKE32_STATIC_ASSERT(sizeof(native_t) == sizeof(unative_t));
typedef struct MAY_ALIAS { typedef struct MAY_ALIAS {
int32_t x, y; int32_t x, y;
@ -677,49 +419,14 @@ typedef struct {
EDUKE32_STATIC_ASSERT(sizeof(vec3d_t) == sizeof(double) * 3); EDUKE32_STATIC_ASSERT(sizeof(vec3d_t) == sizeof(double) * 3);
typedef struct {
float x, y, z, w;
} vec4f_t;
typedef struct {
float x, y, z, w;
} vec4d_t;
////////// Language tricks that depend on size_t ////////// ////////// Language tricks that depend on size_t //////////
#include "basics.h" #include "basics.h"
# define ARRAY_SIZE(arr) countof(arr) # define ARRAY_SIZE(arr) countof(arr)
#define ARRAY_SSIZE(arr) (native_t)ARRAY_SIZE(arr)
////////// Memory management //////////
#if !defined NO_ALIGNED_MALLOC
static FORCE_INLINE void *Baligned_alloc(const size_t alignment, const size_t size)
{
#ifdef _WIN32
void *ptr = _aligned_malloc(size, alignment);
#elif defined __APPLE__ || defined EDUKE32_BSD
void *ptr = NULL;
posix_memalign(&ptr, alignment, size);
#else
void *ptr = memalign(alignment, size);
#endif
return ptr;
}
#else
# define Baligned_alloc(alignment, size) Bmalloc(size)
#endif
#if defined _WIN32 && !defined NO_ALIGNED_MALLOC
# define Baligned_free _aligned_free
#else
# define Baligned_free free
#endif
////////// Pointer management ////////// ////////// Pointer management //////////
@ -727,106 +434,18 @@ static FORCE_INLINE void *Baligned_alloc(const size_t alignment, const size_t si
Xfree(var); (var) = NULL; \ Xfree(var); (var) = NULL; \
} while (0) } while (0)
#define ALIGNED_FREE_AND_NULL(var) do { \
Xaligned_free(var); (var) = NULL; \
} while (0)
////////// Data serialization ////////// ////////// Data serialization //////////
static FORCE_INLINE CONSTEXPR uint16_t B_SWAP16_impl(uint16_t value) inline int32_t B_LITTLE32(int32_t val) { return LittleLong(val); }
{ inline uint32_t B_LITTLE32(uint32_t val) { return LittleLong(val); }
return inline int32_t B_LITTLE16(int16_t val) { return LittleShort(val); }
((value & 0xFF00u) >> 8u) | inline uint32_t B_LITTLE16(uint16_t val) { return LittleShort(val); }
((value & 0x00FFu) << 8u);
}
static FORCE_INLINE CONSTEXPR uint32_t B_SWAP32_impl(uint32_t value)
{
return
((value & 0xFF000000u) >> 24u) |
((value & 0x00FF0000u) >> 8u) |
((value & 0x0000FF00u) << 8u) |
((value & 0x000000FFu) << 24u);
}
static FORCE_INLINE CONSTEXPR uint64_t B_SWAP64_impl(uint64_t value)
{
return
((value & 0xFF00000000000000ULL) >> 56ULL) |
((value & 0x00FF000000000000ULL) >> 40ULL) |
((value & 0x0000FF0000000000ULL) >> 24ULL) |
((value & 0x000000FF00000000ULL) >> 8ULL) |
((value & 0x00000000FF000000ULL) << 8ULL) |
((value & 0x0000000000FF0000ULL) << 24ULL) |
((value & 0x000000000000FF00ULL) << 40ULL) |
((value & 0x00000000000000FFULL) << 56ULL);
}
/* The purpose of B_PASS* as functions, as opposed to macros, is to prevent them from being used as lvalues. */
#if CXXSTD >= 2011 || EDUKE32_MSVC_PREREQ(1900)
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int16_t, T> B_SWAP16(T x)
{
return static_cast< take_sign_t<int16_t, T> >(B_SWAP16_impl(static_cast<uint16_t>(x)));
}
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int32_t, T> B_SWAP32(T x)
{
return static_cast< take_sign_t<int32_t, T> >(B_SWAP32_impl(static_cast<uint32_t>(x)));
}
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int64_t, T> B_SWAP64(T x)
{
return static_cast< take_sign_t<int64_t, T> >(B_SWAP64_impl(static_cast<uint64_t>(x)));
}
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int16_t, T> B_PASS16(T x)
{
return static_cast< take_sign_t<int16_t, T> >(x);
}
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int32_t, T> B_PASS32(T x)
{
return static_cast< take_sign_t<int32_t, T> >(x);
}
template <typename T>
static FORCE_INLINE CONSTEXPR take_sign_t<int64_t, T> B_PASS64(T x)
{
return static_cast< take_sign_t<int64_t, T> >(x);
}
#else
#define B_SWAP16(x) B_SWAP16_impl(x)
#define B_SWAP32(x) B_SWAP32_impl(x)
#define B_SWAP64(x) B_SWAP64_impl(x)
static FORCE_INLINE CONSTEXPR uint16_t B_PASS16(uint16_t const x) { return x; }
static FORCE_INLINE CONSTEXPR uint32_t B_PASS32(uint32_t const x) { return x; }
static FORCE_INLINE CONSTEXPR uint64_t B_PASS64(uint64_t const x) { return x; }
#endif
#if B_LITTLE_ENDIAN == 1
# define B_LITTLE64(x) B_PASS64(x)
# define B_BIG64(x) B_SWAP64(x)
# define B_LITTLE32(x) B_PASS32(x)
# define B_BIG32(x) B_SWAP32(x)
# define B_LITTLE16(x) B_PASS16(x)
# define B_BIG16(x) B_SWAP16(x)
#elif B_BIG_ENDIAN == 1
# define B_LITTLE64(x) B_SWAP64(x)
# define B_BIG64(x) B_PASS64(x)
# define B_LITTLE32(x) B_SWAP32(x)
# define B_BIG32(x) B_PASS32(x)
# define B_LITTLE16(x) B_SWAP16(x)
# define B_BIG16(x) B_PASS16(x)
#endif
static FORCE_INLINE void B_BUF16(void * const buf, uint16_t const x) { *(uint16_t *) buf = x; }
static FORCE_INLINE void B_BUF32(void * const buf, uint32_t const x) { *(uint32_t *) buf = x; } static FORCE_INLINE void B_BUF32(void * const buf, uint32_t const x) { *(uint32_t *) buf = x; }
static FORCE_INLINE void B_BUF64(void * const buf, uint64_t const x) { *(uint64_t *) buf = x; }
static FORCE_INLINE CONSTEXPR uint16_t B_UNBUF16(void const * const buf) { return *(uint16_t const *) buf; }
static FORCE_INLINE CONSTEXPR uint32_t B_UNBUF32(void const * const buf) { return *(uint32_t const *) buf; } static FORCE_INLINE CONSTEXPR uint32_t B_UNBUF32(void const * const buf) { return *(uint32_t const *) buf; }
static FORCE_INLINE CONSTEXPR uint64_t B_UNBUF64(void const * const buf) { return *(uint64_t const *) buf; } static FORCE_INLINE CONSTEXPR uint16_t B_UNBUF16(void const * const buf) { return *(uint16_t const *) buf; }
////////// Abstract data operations ////////// ////////// Abstract data operations //////////
@ -838,52 +457,6 @@ template <typename T, typename X, typename Y> ABSTRACT_DECL T clamp2(T in, X min
using std::min; using std::min;
using std::max; using std::max;
////////// Mathematical operations //////////
#ifdef __cplusplus
#ifdef HAVE_CXX11_HEADERS
template <typename T>
struct DivResult
{
T q; // quotient
T r; // remainder
};
template <typename T>
FORCE_INLINE CONSTEXPR DivResult<T> divide(T lhs, T rhs)
{
return DivResult<T>{(T)(lhs / rhs), (T)(lhs % rhs)};
}
template <native_t base, typename T>
FORCE_INLINE CONSTEXPR DivResult<T> divrhs(T lhs)
{
return divide(lhs, (T)base);
}
template <typename T, typename T2>
static FORCE_INLINE CONSTEXPR_CXX14 enable_if_t<is_signed<T>::value, T> NEGATE_ON_CONDITION(T value, T2 condition)
{
T const invert = !!condition;
return (value ^ -invert) + invert;
}
#endif
template <size_t base, typename T>
CONSTEXPR size_t logbase(T n)
{
return n < static_cast<T>(base) ? 1 : 1 + logbase<base>(n / static_cast<T>(base));
}
// hackish version to work around the impossibility of representing abs(INT*_MIN)
template <size_t base, typename T>
CONSTEXPR size_t logbasenegative(T n)
{
return n > static_cast<T>(-(native_t)base) ? 1 : 1 + logbase<base>(n / static_cast<T>(-(native_t)base));
}
#endif
#define isPow2OrZero(v) (((v) & ((v) - 1)) == 0)
#define isPow2(v) (isPow2OrZero(v) && (v))
////////// Bitfield manipulation ////////// ////////// Bitfield manipulation //////////
#if 0 #if 0
@ -941,10 +514,7 @@ static FORCE_INLINE char *Bstrncpyz(char *dst, const char *src, bsize_t n)
#define Xmalloc(size) (M_Malloc(size)) #define Xmalloc(size) (M_Malloc(size))
#define Xcalloc(nmemb, size) (M_Calloc(nmemb, size)) #define Xcalloc(nmemb, size) (M_Calloc(nmemb, size))
#define Xrealloc(ptr, size) (M_Realloc(ptr, size)) #define Xrealloc(ptr, size) (M_Realloc(ptr, size))
#define Xaligned_alloc(alignment, size) (M_Malloc(size))
#define Xaligned_calloc(alignment, count, size) (M_Calloc(count, size))
#define Xfree(ptr) (M_Free(ptr)) #define Xfree(ptr) (M_Free(ptr))
#define Xaligned_free(ptr) (M_Free(ptr))
////////// Inlined external libraries ////////// ////////// Inlined external libraries //////////

View file

@ -71,7 +71,7 @@ static FORCE_INLINE int check_nonpow2(int32_t const x)
static inline float polymost_invsqrt_approximation(float x) static inline float polymost_invsqrt_approximation(float x)
{ {
#ifdef B_LITTLE_ENDIAN #if !B_BIG_ENDIAN
float const haf = x * .5f; float const haf = x * .5f;
union { float f; uint32_t i; } n = { x }; union { float f; uint32_t i; } n = { x };
n.i = 0x5f375a86 - (n.i >> 1); n.i = 0x5f375a86 - (n.i >> 1);

View file

@ -48,8 +48,8 @@ int32_t animvpx_read_ivf_header(FileReader & inhandle, animvpx_ivf_header_t *hdr
hdr->width = B_LITTLE16(hdr->width); hdr->width = B_LITTLE16(hdr->width);
hdr->height = B_LITTLE16(hdr->height); hdr->height = B_LITTLE16(hdr->height);
hdr->fpsnumer = B_LITTLE16(hdr->fpsnumer); hdr->fpsnumer = B_LITTLE32(hdr->fpsnumer);
hdr->fpsdenom = B_LITTLE16(hdr->fpsdenom); hdr->fpsdenom = B_LITTLE32(hdr->fpsdenom);
hdr->numframes = B_LITTLE32(hdr->numframes); hdr->numframes = B_LITTLE32(hdr->numframes);
@ -209,11 +209,7 @@ const char *animvpx_nextpic_errmsg[] = {
// retrieves one picture-frame from the stream // retrieves one picture-frame from the stream
// pic format: lines of [Y U V 0] pixels // pic format: lines of [Y U V 0] pixels
// *picptr==NULL means EOF has been reached // *picptr==NULL means EOF has been reached
#ifdef DEBUGGINGAIDS
ATTRIBUTE_OPTIMIZE("O1")
#else
ATTRIBUTE_OPTIMIZE("O3")
#endif
int32_t animvpx_nextpic(animvpx_codec_ctx *codec, uint8_t **picptr) int32_t animvpx_nextpic(animvpx_codec_ctx *codec, uint8_t **picptr)
{ {
int32_t ret, corrupted; int32_t ret, corrupted;

View file

@ -206,7 +206,7 @@ int32_t getflorzofslope_old(int32_t sectnum, int32_t dax, int32_t day)
// Returns: should clip? // Returns: should clip?
static int cliptestsector(int const dasect, int const nextsect, int32_t const flordist, int32_t const ceildist, vec2_t const pos, int32_t const posz) static int cliptestsector(int const dasect, int const nextsect, int32_t const flordist, int32_t const ceildist, vec2_t const pos, int32_t const posz)
{ {
Bassert((unsigned)dasect < (unsigned)numsectors && (unsigned)nextsect < (unsigned)numsectors); assert((unsigned)dasect < (unsigned)numsectors && (unsigned)nextsect < (unsigned)numsectors);
auto const sec2 = (usectorptr_t)&sector[nextsect]; auto const sec2 = (usectorptr_t)&sector[nextsect];

View file

@ -2032,7 +2032,7 @@ static int32_t defsparser(scriptfile *script)
{ {
char msgend[BMAX_PATH+64]; char msgend[BMAX_PATH+64];
Bsprintf(msgend, "for palookup definition near line %s:%d", sprintf(msgend, "for palookup definition near line %s:%d",
script->filename, scriptfile_getlinum(script,starttokptr)); script->filename, scriptfile_getlinum(script,starttokptr));
if (EDUKE32_PREDICT_FALSE((havepal & HAVE_PAL)==0)) if (EDUKE32_PREDICT_FALSE((havepal & HAVE_PAL)==0))

View file

@ -740,7 +740,7 @@ int32_t insertsprite(int16_t sectnum, int16_t statnum)
if (newspritenum >= 0) if (newspritenum >= 0)
{ {
Bassert((unsigned)sectnum < MAXSECTORS); assert((unsigned)sectnum < MAXSECTORS);
do_insertsprite_at_headofsect(newspritenum, sectnum); do_insertsprite_at_headofsect(newspritenum, sectnum);
Numsprites++; Numsprites++;
@ -760,7 +760,7 @@ int32_t deletesprite(int16_t spritenum)
polymost_deletesprite(spritenum); polymost_deletesprite(spritenum);
if (deletesprite_replace) if (deletesprite_replace)
return deletesprite_replace(spritenum); return deletesprite_replace(spritenum);
Bassert((sprite[spritenum].statnum == MAXSTATUS) assert((sprite[spritenum].statnum == MAXSTATUS)
== (sprite[spritenum].sectnum == MAXSECTORS)); == (sprite[spritenum].sectnum == MAXSECTORS));
if (sprite[spritenum].statnum == MAXSTATUS) if (sprite[spritenum].statnum == MAXSTATUS)
@ -988,7 +988,7 @@ int32_t rintersect(int32_t x1, int32_t y1, int32_t z1,
t = (topu<<16) / bot; t = (topu<<16) / bot;
Bassert((unsigned)t < 65536); assert((unsigned)t < 65536);
return t; return t;
} }
@ -1304,7 +1304,7 @@ int32_t renderDrawRoomsQ16(int32_t daposx, int32_t daposy, int32_t daposz,
auto owner = w.picnum + animateoffs(w.picnum, 16384); auto owner = w.picnum + animateoffs(w.picnum, 16384);
tile.newtile = TileFiles.tileCreateRotated(owner); tile.newtile = TileFiles.tileCreateRotated(owner);
Bassert(tile.newtile != -1); assert(tile.newtile != -1);
RotTile(tile.newtile).owner = w.picnum+animateoffs(w.picnum,16384); RotTile(tile.newtile).owner = w.picnum+animateoffs(w.picnum,16384);
@ -2218,7 +2218,7 @@ static int32_t engineFinishLoadBoard(const vec3_t *dapos, int16_t *dacursectnum,
numremoved = (numsprites-realnumsprites); numremoved = (numsprites-realnumsprites);
numsprites = realnumsprites; numsprites = realnumsprites;
Bassert(numsprites == Numsprites); assert(numsprites == Numsprites);
//Must be after loading sectors, etc! //Must be after loading sectors, etc!
updatesector(dapos->x, dapos->y, dacursectnum); updatesector(dapos->x, dapos->y, dacursectnum);
@ -2334,7 +2334,7 @@ int32_t engineLoadBoard(const char *filename, char flags, vec3_t *dapos, int16_t
#ifdef NEW_MAP_FORMAT #ifdef NEW_MAP_FORMAT
// Check for map-text first. // Check for map-text first.
if (!Bmemcmp(&mapversion, "--ED", 4)) if (!memcmp(&mapversion, "--ED", 4))
{ {
mapversion = 10; mapversion = 10;
ok = 1; ok = 1;
@ -2466,8 +2466,6 @@ int32_t engineLoadBoard(const char *filename, char flags, vec3_t *dapos, int16_t
artSetupMapArt(filename); artSetupMapArt(filename);
} }
// Printf("Loaded map \"%s\" (md4sum: %08x%08x%08x%08x)\n", filename, B_BIG32(*((int32_t*)&md4out[0])), B_BIG32(*((int32_t*)&md4out[4])), B_BIG32(*((int32_t*)&md4out[8])), B_BIG32(*((int32_t*)&md4out[12])));
return engineFinishLoadBoard(dapos, dacursectnum, numsprites, myflags); return engineFinishLoadBoard(dapos, dacursectnum, numsprites, myflags);
} }
@ -2913,7 +2911,7 @@ int32_t inside(int32_t x, int32_t y, int16_t sectnum)
return -1; return -1;
} }
int32_t __fastcall getangle(int32_t xvect, int32_t yvect) int32_t getangle(int32_t xvect, int32_t yvect)
{ {
int32_t rv; int32_t rv;
@ -2934,7 +2932,7 @@ int32_t __fastcall getangle(int32_t xvect, int32_t yvect)
return rv; return rv;
} }
fix16_t __fastcall gethiq16angle(int32_t xvect, int32_t yvect) fix16_t gethiq16angle(int32_t xvect, int32_t yvect)
{ {
fix16_t rv; fix16_t rv;

View file

@ -990,7 +990,7 @@ static md3model_t *md3load(FileReader & fil)
// NOTE: We assume that NULL is represented by all-zeros. // NOTE: We assume that NULL is represented by all-zeros.
// surfs[0].geometry is for POLYMER_MD_PROCESS_CHECK (else: crashes). // surfs[0].geometry is for POLYMER_MD_PROCESS_CHECK (else: crashes).
// surfs[i].geometry is for FREE_SURFS_GEOMETRY. // surfs[i].geometry is for FREE_SURFS_GEOMETRY.
Bassert(m->head.surfs[0].geometry == NULL); assert(m->head.surfs[0].geometry == NULL);
#if B_BIG_ENDIAN != 0 #if B_BIG_ENDIAN != 0
{ {

View file

@ -8,7 +8,7 @@ usermaphack_t g_loadedMapHack; // used only for the MD4 part
int compare_usermaphacks(const void *a, const void *b) int compare_usermaphacks(const void *a, const void *b)
{ {
return Bmemcmp(((usermaphack_t const *) a)->md4, ((usermaphack_t const *) b)->md4, 16); return memcmp(((usermaphack_t const *) a)->md4, ((usermaphack_t const *) b)->md4, 16);
} }
usermaphack_t *usermaphacks; usermaphack_t *usermaphacks;
int32_t num_usermaphacks; int32_t num_usermaphacks;

View file

@ -305,7 +305,7 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
setgotpic(globalpicnum); setgotpic(globalpicnum);
vec2_t tsiz = { tilesize.x, tilesize.y }; vec2_t tsiz = { tilesize.x, tilesize.y };
Bassert(n <= MAX_DRAWPOLY_VERTS); assert(n <= MAX_DRAWPOLY_VERTS);
int j = 0; int j = 0;
float px[8], py[8], dd[8], uu[8], vv[8]; float px[8], py[8], dd[8], uu[8], vv[8];
@ -2058,7 +2058,7 @@ static void polymost_drawalls(int32_t const bunch)
float const ogux = xtex.u, oguy = ytex.u, oguo = otex.u; float const ogux = xtex.u, oguy = ytex.u, oguo = otex.u;
Bassert(domostpolymethod == DAMETH_NOMASK); assert(domostpolymethod == DAMETH_NOMASK);
domostpolymethod = DAMETH_WALL; domostpolymethod = DAMETH_WALL;
if (nextsectnum >= 0) if (nextsectnum >= 0)
@ -2269,7 +2269,7 @@ void polymost_scansector(int32_t sectnum)
int const nextsectnum = wal->nextsector; //Scan close sectors int const nextsectnum = wal->nextsector; //Scan close sectors
if (nextsectnum >= 0 && !(wal->cstat&32) && sectorbordercnt < ARRAY_SSIZE(sectorborder)) if (nextsectnum >= 0 && !(wal->cstat&32) && sectorbordercnt < countof(sectorborder))
if ((gotsector[nextsectnum>>3]&pow2char[nextsectnum&7]) == 0) if ((gotsector[nextsectnum>>3]&pow2char[nextsectnum&7]) == 0)
{ {
double const d = fp1.x*fp2.y - fp2.x*fp1.y; double const d = fp1.x*fp2.y - fp2.x*fp1.y;
@ -2584,7 +2584,7 @@ void polymost_drawrooms()
maskwallcnt = 0; maskwallcnt = 0;
// NOTE: globalcursectnum has been already adjusted in ADJUST_GLOBALCURSECTNUM. // NOTE: globalcursectnum has been already adjusted in ADJUST_GLOBALCURSECTNUM.
Bassert((unsigned)globalcursectnum < MAXSECTORS); assert((unsigned)globalcursectnum < MAXSECTORS);
polymost_scansector(globalcursectnum); polymost_scansector(globalcursectnum);
grhalfxdown10x = grhalfxdown10; grhalfxdown10x = grhalfxdown10;

View file

@ -614,7 +614,7 @@ static void read_pal(FileReader &fil, int32_t pal[256])
char c[3]; char c[3];
fil.Read(c, 3); fil.Read(c, 3);
//#if B_BIG_ENDIAN != 0 //#if B_BIG_ENDIAN != 0
pal[i] = B_LITTLE32((c[0]<<18) + (c[1]<<10) + (c[2]<<2) + (i<<24)); pal[i] = B_LITTLE32(unsigned((c[0]<<18) + (c[1]<<10) + (c[2]<<2) + (i<<24)));
//#endif //#endif
} }
} }
@ -942,7 +942,7 @@ voxmodel_t *loadkvxfrombuf(const char *kvxbuffer, int32_t length)
{ {
const char *c = &paloff[i*3]; const char *c = &paloff[i*3];
//#if B_BIG_ENDIAN != 0 //#if B_BIG_ENDIAN != 0
pal[i] = B_LITTLE32((c[0]<<18) + (c[1]<<10) + (c[2]<<2) + (i<<24)); pal[i] = B_LITTLE32(int((c[0]<<18) + (c[1]<<10) + (c[2]<<2) + (i<<24)));
//#endif //#endif
} }

View file

@ -955,7 +955,7 @@ bool AddINIFile(const char* pzFile, bool bForce = false)
pINIIter->pNext = NULL; pINIIter->pNext = NULL;
pINIIter->pDescription = NULL; pINIIter->pDescription = NULL;
Bstrncpy(pINIIter->zName, pzFile, BMAX_PATH); Bstrncpy(pINIIter->zName, pzFile, BMAX_PATH);
for (int i = 0; i < ARRAY_SSIZE(gINIDescription); i++) for (int i = 0; i < countof(gINIDescription); i++)
{ {
if (!Bstrncasecmp(pINIIter->zName, gINIDescription[i].pzFilename, BMAX_PATH)) if (!Bstrncasecmp(pINIIter->zName, gINIDescription[i].pzFilename, BMAX_PATH))
{ {

View file

@ -71,7 +71,7 @@ int viewSetInterpolation(int32_t *const posptr)
if (g_interpolationCnt >= MAXINTERPOLATIONS) if (g_interpolationCnt >= MAXINTERPOLATIONS)
return 1; return 1;
for (bssize_t i = 0; i < g_interpolationCnt; ++i) for (int i = 0; i < g_interpolationCnt; ++i)
if (curipos[i] == posptr) if (curipos[i] == posptr)
return 0; return 0;
@ -83,7 +83,7 @@ int viewSetInterpolation(int32_t *const posptr)
void viewStopInterpolation(const int32_t * const posptr) void viewStopInterpolation(const int32_t * const posptr)
{ {
for (bssize_t i = 0; i < g_interpolationCnt; ++i) for (int i = 0; i < g_interpolationCnt; ++i)
if (curipos[i] == posptr) if (curipos[i] == posptr)
{ {
g_interpolationCnt--; g_interpolationCnt--;
@ -97,7 +97,7 @@ void viewDoInterpolations(int smoothRatio)
{ {
int32_t ndelta = 0; int32_t ndelta = 0;
for (bssize_t i = 0, j = 0; i < g_interpolationCnt; ++i) for (int i = 0, j = 0; i < g_interpolationCnt; ++i)
{ {
int32_t const odelta = ndelta; int32_t const odelta = ndelta;
bakipos[i] = *curipos[i]; bakipos[i] = *curipos[i];
@ -110,7 +110,7 @@ void viewDoInterpolations(int smoothRatio)
void viewUpdateInterpolations(void) //Stick at beginning of G_DoMoveThings void viewUpdateInterpolations(void) //Stick at beginning of G_DoMoveThings
{ {
for (bssize_t i=g_interpolationCnt-1; i>=0; i--) oldipos[i] = *curipos[i]; for (int i=g_interpolationCnt-1; i>=0; i--) oldipos[i] = *curipos[i];
} }
void viewRestoreInterpolations(void) //Stick at end of drawscreen void viewRestoreInterpolations(void) //Stick at end of drawscreen

View file

@ -341,11 +341,6 @@ void GameInterface::DrawCenteredTextScreen(const DVector2 &origin, const char *t
::GameInterface::DrawCenteredTextScreen(origin, text, position, bg); ::GameInterface::DrawCenteredTextScreen(origin, text, position, bg);
} }
static int GetPlayerColor(int color)
{
return 0;
}
void GameInterface::DrawPlayerSprite(const DVector2& origin, bool onteam) void GameInterface::DrawPlayerSprite(const DVector2& origin, bool onteam)
{ {
int mclock = I_GetBuildTime(); int mclock = I_GetBuildTime();

View file

@ -230,15 +230,11 @@ extern SWBOOL MenuInputMode;
#define MK_FIXED(msw,lsw) (((int32_t)(msw)<<16)|(lsw)) #define MK_FIXED(msw,lsw) (((int32_t)(msw)<<16)|(lsw))
#define FIXED(msw,lsw) MK_FIXED(msw,lsw) #define FIXED(msw,lsw) MK_FIXED(msw,lsw)
#if B_LITTLE_ENDIAN != 0 // Ouch...
# define MSW_VAR(fixed) (*(((uint16_t*)&(fixed)) + 1)) #if B_BIG_ENDIAN == 0
# define LSW_VAR(fixed) (*((uint16_t*)&(fixed)))
# define MSB_VAR(fixed) (*(((uint8_t*)&(fixed)) + 1)) # define MSB_VAR(fixed) (*(((uint8_t*)&(fixed)) + 1))
# define LSB_VAR(fixed) (*((uint8_t*)&(fixed))) # define LSB_VAR(fixed) (*((uint8_t*)&(fixed)))
#else #else
# define LSW_VAR(fixed) (*(((uint16_t*)&(fixed)) + 1))
# define MSW_VAR(fixed) (*((uint16_t*)&(fixed)))
# define LSB_VAR(fixed) (*(((uint8_t*)&(fixed)) + 1)) # define LSB_VAR(fixed) (*(((uint8_t*)&(fixed)) + 1))
# define MSB_VAR(fixed) (*((uint8_t*)&(fixed))) # define MSB_VAR(fixed) (*((uint8_t*)&(fixed)))
@ -263,8 +259,8 @@ extern SWBOOL MenuInputMode;
#define SP_TAG13(sp) B_LITTLE16(*((short*)&(sp)->xoffset)) #define SP_TAG13(sp) B_LITTLE16(*((short*)&(sp)->xoffset))
#define SP_TAG14(sp) B_LITTLE16(*((short*)&(sp)->xrepeat)) #define SP_TAG14(sp) B_LITTLE16(*((short*)&(sp)->xrepeat))
#define SP_TAG15(sp) ((sp)->z) #define SP_TAG15(sp) ((sp)->z)
#define SET_SP_TAG13(sp,val) (*((short*)&(sp)->xoffset)) = B_LITTLE16(val) #define SET_SP_TAG13(sp,val) (*((short*)&(sp)->xoffset)) = B_LITTLE16((short)val)
#define SET_SP_TAG14(sp,val) (*((short*)&(sp)->xrepeat)) = B_LITTLE16(val) #define SET_SP_TAG14(sp,val) (*((short*)&(sp)->xrepeat)) = B_LITTLE16((short)val)
#define SPRITE_TAG1(sp) (sprite[sp].hitag) #define SPRITE_TAG1(sp) (sprite[sp].hitag)
#define SPRITE_TAG2(sp) (sprite[sp].lotag) #define SPRITE_TAG2(sp) (sprite[sp].lotag)
@ -281,8 +277,8 @@ extern SWBOOL MenuInputMode;
#define SPRITE_TAG13(sp) B_LITTLE16(*((short*)&sprite[sp].xoffset)) #define SPRITE_TAG13(sp) B_LITTLE16(*((short*)&sprite[sp].xoffset))
#define SPRITE_TAG14(sp) B_LITTLE16(*((short*)&sprite[sp].xrepeat)) #define SPRITE_TAG14(sp) B_LITTLE16(*((short*)&sprite[sp].xrepeat))
#define SPRITE_TAG15(sp) (sprite[sp].z) #define SPRITE_TAG15(sp) (sprite[sp].z)
#define SET_SPRITE_TAG13(sp,val) (*((short*)&sprite[sp].xoffset)) = B_LITTLE16(val) #define SET_SPRITE_TAG13(sp,val) (*((short*)&sprite[sp].xoffset)) = B_LITTLE16((short)val)
#define SET_SPRITE_TAG14(sp,val) (*((short*)&sprite[sp].xrepeat)) = B_LITTLE16(val) #define SET_SPRITE_TAG14(sp,val) (*((short*)&sprite[sp].xrepeat)) = B_LITTLE16((short)val)
// OVER and UNDER water macros // OVER and UNDER water macros
#define SpriteInDiveArea(sp) (TEST(sector[(sp)->sectnum].extra, SECTFX_DIVE_AREA) ? TRUE : FALSE) #define SpriteInDiveArea(sp) (TEST(sector[(sp)->sectnum].extra, SECTFX_DIVE_AREA) ? TRUE : FALSE)