mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-27 17:30:51 +00:00
Minor CON optimization bs.
git-svn-id: https://svn.eduke32.com/eduke32@5786 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
85d0543763
commit
212e84ce21
2 changed files with 24 additions and 22 deletions
|
@ -71,7 +71,7 @@ int32_t VM_OnEventWithReturn_(int32_t iEventID, int32_t iActor, int32_t iPlayer,
|
||||||
int32_t VM_OnEventWithDist_(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist);
|
int32_t VM_OnEventWithDist_(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist);
|
||||||
int32_t VM_OnEvent_(int32_t iEventID, int32_t iActor, int32_t iPlayer);
|
int32_t VM_OnEvent_(int32_t iEventID, int32_t iActor, int32_t iPlayer);
|
||||||
|
|
||||||
static inline int32_t VM_HaveEvent(int32_t iEventID)
|
FORCE_INLINE int32_t VM_HaveEvent(int32_t iEventID)
|
||||||
{
|
{
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
return L_IsInitialized(&g_ElState) && El_HaveEvent(iEventID);
|
return L_IsInitialized(&g_ElState) && El_HaveEvent(iEventID);
|
||||||
|
@ -80,22 +80,22 @@ static inline int32_t VM_HaveEvent(int32_t iEventID)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int32_t VM_OnEventWithBoth(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist, int32_t iReturn)
|
FORCE_INLINE int32_t VM_OnEventWithBoth(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist, int32_t iReturn)
|
||||||
{
|
{
|
||||||
return VM_HaveEvent(iEventID) ? VM_OnEventWithBoth_(iEventID, iActor, iPlayer, lDist, iReturn) : iReturn;
|
return VM_HaveEvent(iEventID) ? VM_OnEventWithBoth_(iEventID, iActor, iPlayer, lDist, iReturn) : iReturn;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int32_t VM_OnEventWithReturn(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t iReturn)
|
FORCE_INLINE int32_t VM_OnEventWithReturn(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t iReturn)
|
||||||
{
|
{
|
||||||
return VM_HaveEvent(iEventID) ? VM_OnEventWithReturn_(iEventID, iActor, iPlayer, iReturn) : iReturn;
|
return VM_HaveEvent(iEventID) ? VM_OnEventWithReturn_(iEventID, iActor, iPlayer, iReturn) : iReturn;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int32_t VM_OnEventWithDist(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist)
|
FORCE_INLINE int32_t VM_OnEventWithDist(int32_t iEventID, int32_t iActor, int32_t iPlayer, int32_t lDist)
|
||||||
{
|
{
|
||||||
return VM_HaveEvent(iEventID) ? VM_OnEventWithDist_(iEventID, iActor, iPlayer, lDist) : 0;
|
return VM_HaveEvent(iEventID) ? VM_OnEventWithDist_(iEventID, iActor, iPlayer, lDist) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int32_t VM_OnEvent(int32_t iEventID, int32_t iActor, int32_t iPlayer)
|
FORCE_INLINE int32_t VM_OnEvent(int32_t iEventID, int32_t iActor, int32_t iPlayer)
|
||||||
{
|
{
|
||||||
return VM_HaveEvent(iEventID) ? VM_OnEvent_(iEventID, iActor, iPlayer) : 0;
|
return VM_HaveEvent(iEventID) ? VM_OnEvent_(iEventID, iActor, iPlayer) : 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -112,11 +112,12 @@ int32_t Gv_GetVarByLabel(const char *szGameLabel,int32_t const lDefault,int32_t
|
||||||
int32_t Gv_NewArray(const char *pszLabel,void *arrayptr,intptr_t asize,uint32_t dwFlags);
|
int32_t Gv_NewArray(const char *pszLabel,void *arrayptr,intptr_t asize,uint32_t dwFlags);
|
||||||
int32_t Gv_NewVar(const char *pszLabel,intptr_t lValue,uint32_t dwFlags);
|
int32_t Gv_NewVar(const char *pszLabel,intptr_t lValue,uint32_t dwFlags);
|
||||||
|
|
||||||
static inline void A_ResetVars(const int32_t iActor)
|
FORCE_INLINE void A_ResetVars(const int32_t iActor)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < g_gameVarCount; i++)
|
for (int i = 0; i < g_gameVarCount; ++i)
|
||||||
{
|
{
|
||||||
if ((aGameVars[i].dwFlags & (GAMEVAR_PERACTOR | GAMEVAR_NODEFAULT)) == GAMEVAR_PERACTOR)
|
if ((aGameVars[i].dwFlags & (GAMEVAR_PERACTOR | GAMEVAR_NODEFAULT)) != GAMEVAR_PERACTOR)
|
||||||
|
continue;
|
||||||
aGameVars[i].val.plValues[iActor] = aGameVars[i].lDefault;
|
aGameVars[i].val.plValues[iActor] = aGameVars[i].lDefault;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -138,7 +139,7 @@ void Gv_FinalizeWeaponDefaults(void);
|
||||||
|
|
||||||
#if !defined LUNATIC
|
#if !defined LUNATIC
|
||||||
#define VM_GAMEVAR_OPERATOR(func, operator) \
|
#define VM_GAMEVAR_OPERATOR(func, operator) \
|
||||||
static inline void __fastcall func(const int32_t id, const int32_t lValue) \
|
FORCE_INLINE void __fastcall func(const int32_t id, const int32_t lValue) \
|
||||||
{ \
|
{ \
|
||||||
switch (aGameVars[id].dwFlags & (GAMEVAR_USER_MASK | GAMEVAR_PTR_MASK)) \
|
switch (aGameVars[id].dwFlags & (GAMEVAR_USER_MASK | GAMEVAR_PTR_MASK)) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -160,22 +161,23 @@ void Gv_FinalizeWeaponDefaults(void);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(__arm__) || defined(LIBDIVIDE_ALWAYS)
|
#if defined(__arm__) || defined(LIBDIVIDE_ALWAYS)
|
||||||
static inline void __fastcall Gv_DivVar(const int32_t id, const int32_t lValue)
|
FORCE_INLINE void __fastcall Gv_DivVar(const int32_t id, const int32_t lValue)
|
||||||
{
|
{
|
||||||
static libdivide_s32_t sdiv;
|
if (EDUKE32_PREDICT_FALSE((aGameVars[id].dwFlags & GAMEVAR_PERPLAYER && (unsigned) vm.g_p > MAXPLAYERS - 1) ||
|
||||||
static int32_t lastlValue;
|
(aGameVars[id].dwFlags & GAMEVAR_PERACTOR && (unsigned) vm.g_i > MAXSPRITES - 1)))
|
||||||
libdivide_s32_t *dptr = &sdiv;
|
|
||||||
intptr_t *iptr = &aGameVars[id].val.lValue;
|
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE((aGameVars[id].dwFlags & GAMEVAR_PERPLAYER && (unsigned)vm.g_p > MAXPLAYERS - 1) ||
|
|
||||||
(aGameVars[id].dwFlags & GAMEVAR_PERACTOR && (unsigned)vm.g_i > MAXSPRITES - 1)))
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ((unsigned)lValue < DIVTABLESIZE)
|
static libdivide_s32_t sdiv;
|
||||||
dptr = (libdivide_s32_t *)&divtable32[lValue];
|
static int32_t lastlValue;
|
||||||
else if (lValue != lastlValue)
|
libdivide_s32_t *dptr = ((unsigned) lValue < DIVTABLESIZE) ? (libdivide_s32_t *) &divtable32[lValue] : &sdiv;
|
||||||
sdiv = libdivide_s32_gen(lValue), lastlValue = lValue;
|
intptr_t *iptr = &aGameVars[id].val.lValue;
|
||||||
|
|
||||||
|
if (lValue == lastlValue || dptr != &sdiv)
|
||||||
|
goto skip;
|
||||||
|
|
||||||
|
sdiv = libdivide_s32_gen((lastlValue = lValue));
|
||||||
|
|
||||||
|
skip:
|
||||||
switch (aGameVars[id].dwFlags & (GAMEVAR_USER_MASK | GAMEVAR_PTR_MASK))
|
switch (aGameVars[id].dwFlags & (GAMEVAR_USER_MASK | GAMEVAR_PTR_MASK))
|
||||||
{
|
{
|
||||||
case GAMEVAR_PERPLAYER: iptr = &aGameVars[id].val.plValues[vm.g_p];
|
case GAMEVAR_PERPLAYER: iptr = &aGameVars[id].val.plValues[vm.g_p];
|
||||||
|
|
Loading…
Reference in a new issue