From fd598744cdf0a0c08e2baeb53504b31a0e613e93 Mon Sep 17 00:00:00 2001 From: Daniel Gibson Date: Tue, 17 May 2022 01:13:23 +0200 Subject: [PATCH] MSVC: Treat pointer truncation warnings as errors, adjust idCVar for that All pointer<->integer conversion truncation warnings I'm aware of are now enabled for MSVC, to hopefully finally get that tool code 64bit-clean. I had to adjust the idCVar code for this - it should've been safe enough (highly unlikely that a valid pointer is exactly 0xFFFFFFFF on 64bit), but triggered those warnings - now it should behave the same as before but the warnings (which are now errors) are silenced. --- CMakeLists.txt | 2 ++ framework/CVarSystem.h | 8 +++++--- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 41ccc20..fcd1eea 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -218,6 +218,8 @@ elseif(MSVC) add_compile_options(/W4) add_compile_options(/we4840) # treat as error when passing a class to a vararg-function (probably printf-like) + # treat several kinds of truncating int<->pointer conversions as errors (for more 64bit-safety) + add_compile_options(/we4306 /we4311 /we4312 /we4302) add_compile_options(/wd4100) # unreferenced formal parameter add_compile_options(/wd4127) # conditional expression is constant add_compile_options(/wd4244) # possible loss of data diff --git a/framework/CVarSystem.h b/framework/CVarSystem.h index 1f1bd31..e0ae01c 100644 --- a/framework/CVarSystem.h +++ b/framework/CVarSystem.h @@ -182,6 +182,8 @@ private: static idCVar * staticVars; }; +static idCVar const * const staticCVarsInvalid = (const idCVar*)(uintptr_t)0xFFFFFFFF; + ID_INLINE idCVar::idCVar( const char *name, const char *value, int flags, const char *description, argCompletion_t valueCompletion ) { if ( !valueCompletion && ( flags & CVAR_BOOL ) ) { @@ -293,7 +295,7 @@ ID_INLINE void idCVar::Init( const char *name, const char *value, int flags, con this->integerValue = 0; this->floatValue = 0.0f; this->internalVar = this; - if ( staticVars != (idCVar *)0xFFFFFFFF ) { + if ( staticVars != staticCVarsInvalid ) { this->next = staticVars; staticVars = this; } else { @@ -302,11 +304,11 @@ ID_INLINE void idCVar::Init( const char *name, const char *value, int flags, con } ID_INLINE void idCVar::RegisterStaticVars( void ) { - if ( staticVars != (idCVar *)0xFFFFFFFF ) { + if ( staticVars != staticCVarsInvalid ) { for ( idCVar *cvar = staticVars; cvar; cvar = cvar->next ) { cvarSystem->Register( cvar ); } - staticVars = (idCVar *)0xFFFFFFFF; + staticVars = (idCVar *)staticCVarsInvalid; } }