raze-gles/source/games/duke/src/inlines.h

211 lines
4.1 KiB
C
Raw Normal View History

2020-07-06 20:23:18 +00:00
#pragma once
#include "mathutil.h"
#include "glbackend/glbackend.h"
#include "global.h"
2020-07-06 20:23:18 +00:00
// all inline functions.
BEGIN_DUKE_NS
inline int rnd(int X)
{
2020-07-20 21:21:27 +00:00
return ((krand() >> 8) >= (255 - (X)));
}
2020-07-06 16:08:31 +00:00
inline bool AFLAMABLE(int X)
{
2020-07-20 21:21:27 +00:00
return (X == TILE_BOX || X == TILE_TREE1 || X == TILE_TREE2 || X == TILE_TIRE || X == TILE_CONE);
2020-07-06 16:08:31 +00:00
}
2020-07-06 20:23:18 +00:00
inline int badguypic(int const tileNum)
{
2020-07-20 21:21:27 +00:00
return ((actorinfo[tileNum].flags & (SFLAG_INTERNAL_BADGUY | SFLAG_BADGUY)) != 0);
2020-07-06 20:23:18 +00:00
}
inline int badguy(void const * const pSprite)
{
2020-07-20 21:21:27 +00:00
return badguypic(((uspritetype const *) pSprite)->picnum);
2020-07-06 20:23:18 +00:00
}
2020-07-06 16:08:31 +00:00
inline int actorflag(int spritenum, int mask)
{
2020-07-20 21:21:27 +00:00
return (((actorinfo[sprite[spritenum].picnum].flags/* ^ hittype[spritenum].flags*/) & mask) != 0);
2020-07-06 16:08:31 +00:00
}
inline int actorfella(int spnum)
{
2020-07-20 21:21:27 +00:00
return actorflag(spnum, SFLAG_KILLCOUNT);
2020-07-06 16:08:31 +00:00
}
inline void setflag(int flag, const std::initializer_list<short>& types)
{
2020-07-20 21:21:27 +00:00
for (auto val : types)
{
actorinfo[val].flags |= flag;
}
2020-07-06 16:08:31 +00:00
}
inline bool inventory(spritetype* S)
{
2020-07-20 21:21:27 +00:00
return !!(actorinfo[S->picnum].flags & SFLAG_INVENTORY);
2020-07-06 16:08:31 +00:00
}
inline void settileflag(int flag, const std::initializer_list<short>& types)
{
2020-07-20 21:21:27 +00:00
for (auto val : types)
{
tileinfo[val].flags |= flag;
}
2020-07-06 16:08:31 +00:00
}
inline bool wallswitchcheck(int s)
{
2020-07-25 08:54:46 +00:00
return !!(tileinfo[sprite[s].picnum].flags & TFLAG_WALLSWITCH);
2020-07-06 16:08:31 +00:00
}
2020-07-06 20:23:18 +00:00
inline int checkcursectnums(int se)
{
2020-07-20 21:21:27 +00:00
int i;
for(i=connecthead;i>=0;i=connectpoint2[i])
if((unsigned)ps[i].i < MAXSPRITES && sprite[ps[i].i].sectnum == se ) return i;
return -1;
2020-07-06 20:23:18 +00:00
}
// These are from duke's sector.c
inline int ldist(const spritetype* s1, const spritetype* s2)
{
2020-07-20 21:21:27 +00:00
int vx, vy;
vx = s1->x - s2->x;
vy = s1->y - s2->y;
return(FindDistance2D(vx, vy) + 1);
2020-07-06 20:23:18 +00:00
}
inline int ldist(const spritetype* s1, const tspritetype* s2)
{
2020-07-20 21:21:27 +00:00
int vx, vy;
vx = s1->x - s2->x;
vy = s1->y - s2->y;
return(FindDistance2D(vx, vy) + 1);
2020-07-06 20:23:18 +00:00
}
inline int dist(const spritetype* s1, const spritetype* s2)
{
2020-07-20 21:21:27 +00:00
int vx, vy, vz;
vx = s1->x - s2->x;
vy = s1->y - s2->y;
vz = s1->z - s2->z;
return(FindDistance3D(vx, vy, vz >> 4));
2020-07-06 20:23:18 +00:00
}
inline bool isIn(int value, int first)
{
2020-07-20 21:21:27 +00:00
return value == first;
2020-07-06 20:23:18 +00:00
}
template<typename... Args>
bool isIn(int value, int first, Args... args)
{
2020-07-20 21:21:27 +00:00
return value == first || isIn(value, args...);
2020-07-06 20:23:18 +00:00
}
inline bool isIn(int value, const std::initializer_list<int>& list)
{
2020-07-20 21:21:27 +00:00
for (auto v : list) if (v == value) return true;
return false;
2020-07-06 20:23:18 +00:00
}
// these are mainly here to avoid directly accessing the input data so that it can be more easily refactored later.
inline bool PlayerInput(int pl, ESyncBits bit)
{
2020-07-20 21:21:27 +00:00
return (!!((sync[pl].bits) & bit));
2020-07-06 20:23:18 +00:00
}
inline void PlayerSetInput(int pl, ESyncBits bit)
{
2020-07-20 21:21:27 +00:00
sync[pl].bits |= bit;
2020-07-06 20:23:18 +00:00
}
inline void PlayerClearInput(int pl, ESyncBits bit)
{
2020-07-20 21:21:27 +00:00
sync[pl].bits &= ~bit;
2020-07-06 20:23:18 +00:00
}
inline ESyncBits PlayerInputBits(int pl, ESyncBits bits)
{
2020-07-20 21:21:27 +00:00
return (sync[pl].bits & bits);
2020-07-06 20:23:18 +00:00
}
inline int PlayerInputSideVel(int pl)
{
2020-07-20 21:21:27 +00:00
return sync[pl].svel;
2020-07-06 20:23:18 +00:00
}
inline int PlayerInputForwardVel(int pl)
{
2020-07-20 21:21:27 +00:00
return sync[pl].fvel;
2020-07-06 20:23:18 +00:00
}
inline fixed_t PlayerInputAngVel(int pl)
{
2020-07-20 21:21:27 +00:00
return sync[pl].q16avel;
2020-07-06 20:23:18 +00:00
}
2020-07-06 19:10:20 +00:00
inline void clearfriction()
{
2020-07-20 21:21:27 +00:00
for (int i = 0; i != -1; i = connectpoint2[i])
{
ps[i].fric.x = ps[i].fric.y = 0;
}
2020-07-06 19:10:20 +00:00
}
inline void SetPlayerPal(player_struct* p, PalEntry pe)
{
2020-07-20 21:21:27 +00:00
p->pals = pe;
}
2020-07-06 19:10:20 +00:00
inline bool playrunning()
{
return (paused == 0 || (paused == 1 && (ud.recstat == 2 || ud.multimode > 1)));
}
2020-07-07 21:01:34 +00:00
inline int calc_smoothratio(ClockTicks totalclk, ClockTicks ototalclk)
{
if (!playrunning())
2020-07-20 21:21:27 +00:00
{
return 65536;
}
return CalcSmoothRatio(totalclk, ototalclk, REALGAMETICSPERSEC);
2020-07-07 21:01:34 +00:00
}
2020-07-07 15:56:20 +00:00
// These should be the only places converting between level numbers and volume/map pairs
2020-07-07 11:19:09 +00:00
constexpr inline int levelnum(int vol, int map)
{
2020-07-20 21:21:27 +00:00
return vol * 1000 + map;
2020-07-07 11:19:09 +00:00
}
constexpr inline int volfromlevelnum(int num)
2020-07-07 15:56:20 +00:00
{
2020-07-20 21:21:27 +00:00
return num > 0 ? num / 1000 : 0;
2020-07-07 15:56:20 +00:00
}
constexpr inline int mapfromlevelnum(int num)
2020-07-07 15:56:20 +00:00
{
2020-07-20 21:21:27 +00:00
return num > 0 ? num % 1000 : -1;
2020-07-07 15:56:20 +00:00
}
2020-07-06 20:23:18 +00:00
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
inline void hud_draw(double x, double y, int tilenum, int shade, int orientation)
2020-07-06 20:23:18 +00:00
{
2020-07-20 21:21:27 +00:00
int p = sector[ps[screenpeek].cursectnum].floorpal;
hud_drawsprite(x, y, 65536, 0, tilenum, shade, p, 2 | orientation);
2020-07-06 20:23:18 +00:00
}
END_DUKE_NS