mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
Utilize the types added in the previous commit
This patch is a bit large. git-svn-id: https://svn.eduke32.com/eduke32@7603 1a8010ca-5511-0410-912e-c29ae57300e0 # Conflicts: # source/build/include/mdsprite.h # source/build/src/build.cpp # source/build/src/polymer.cpp # source/build/src/polymost.cpp # source/build/src/voxmodel.cpp
This commit is contained in:
parent
5948513d76
commit
301ac48ccd
21 changed files with 227 additions and 223 deletions
|
@ -592,7 +592,7 @@ EXTERN wallext_t *wallext;
|
||||||
EXTERN sectortype *sector;
|
EXTERN sectortype *sector;
|
||||||
EXTERN walltype *wall;
|
EXTERN walltype *wall;
|
||||||
EXTERN spritetype *sprite;
|
EXTERN spritetype *sprite;
|
||||||
EXTERN uspritetype *tsprite;
|
EXTERN tspriteptr_t tsprite;
|
||||||
#else
|
#else
|
||||||
EXTERN spriteext_t spriteext[MAXSPRITES+MAXUNIQHUDID];
|
EXTERN spriteext_t spriteext[MAXSPRITES+MAXUNIQHUDID];
|
||||||
EXTERN spritesmooth_t spritesmooth[MAXSPRITES+MAXUNIQHUDID];
|
EXTERN spritesmooth_t spritesmooth[MAXSPRITES+MAXUNIQHUDID];
|
||||||
|
@ -673,7 +673,7 @@ static FORCE_INLINE void sprite_tracker_hook(uintptr_t const address)
|
||||||
|
|
||||||
EXTERN int16_t maskwall[MAXWALLSB], maskwallcnt;
|
EXTERN int16_t maskwall[MAXWALLSB], maskwallcnt;
|
||||||
EXTERN int16_t thewall[MAXWALLSB];
|
EXTERN int16_t thewall[MAXWALLSB];
|
||||||
EXTERN uspritetype *tspriteptr[MAXSPRITESONSCREEN + 1];
|
EXTERN tspriteptr_t tspriteptr[MAXSPRITESONSCREEN + 1];
|
||||||
|
|
||||||
EXTERN int32_t wx1, wy1, wx2, wy2;
|
EXTERN int32_t wx1, wy1, wx2, wy2;
|
||||||
EXTERN int32_t xdim, ydim, numpages, upscalefactor;
|
EXTERN int32_t xdim, ydim, numpages, upscalefactor;
|
||||||
|
@ -1170,7 +1170,7 @@ void updatesectorz(int32_t const x, int32_t const y, int32_t const z, int16_t *
|
||||||
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
||||||
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day, uint8_t flags);
|
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day, uint8_t flags);
|
||||||
void setfirstwall(int16_t sectnum, int16_t newfirstwall);
|
void setfirstwall(int16_t sectnum, int16_t newfirstwall);
|
||||||
int32_t try_facespr_intersect(uspritetype const * const spr, const vec3_t *refpos,
|
int32_t try_facespr_intersect(uspriteptr_t const spr, const vec3_t *refpos,
|
||||||
int32_t vx, int32_t vy, int32_t vz,
|
int32_t vx, int32_t vy, int32_t vz,
|
||||||
vec3_t *intp, int32_t strictly_smaller_than_p);
|
vec3_t *intp, int32_t strictly_smaller_than_p);
|
||||||
|
|
||||||
|
@ -1210,29 +1210,29 @@ void rotatepoint(vec2_t const pivot, vec2_t p, int16_t const daang, vec2_t * con
|
||||||
int32_t lastwall(int16_t point);
|
int32_t lastwall(int16_t point);
|
||||||
int32_t nextsectorneighborz(int16_t sectnum, int32_t refz, int16_t topbottom, int16_t direction);
|
int32_t nextsectorneighborz(int16_t sectnum, int32_t refz, int16_t topbottom, int16_t direction);
|
||||||
|
|
||||||
int32_t getceilzofslopeptr(const usectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
int32_t getceilzofslopeptr(usectorptr_t sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
||||||
int32_t getflorzofslopeptr(const usectortype *sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
int32_t getflorzofslopeptr(usectorptr_t sec, int32_t dax, int32_t day) ATTRIBUTE((nonnull(1)));
|
||||||
void getzsofslopeptr(const usectortype *sec, int32_t dax, int32_t day,
|
void getzsofslopeptr(usectorptr_t sec, int32_t dax, int32_t day,
|
||||||
int32_t *ceilz, int32_t *florz) ATTRIBUTE((nonnull(1,4,5)));
|
int32_t *ceilz, int32_t *florz) ATTRIBUTE((nonnull(1,4,5)));
|
||||||
|
|
||||||
static FORCE_INLINE int32_t getceilzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
static FORCE_INLINE int32_t getceilzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
return getceilzofslopeptr((usectortype *)§or[sectnum], dax, day);
|
return getceilzofslopeptr((usectorptr_t)§or[sectnum], dax, day);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE int32_t getflorzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
static FORCE_INLINE int32_t getflorzofslope(int16_t sectnum, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
return getflorzofslopeptr((usectortype *)§or[sectnum], dax, day);
|
return getflorzofslopeptr((usectorptr_t)§or[sectnum], dax, day);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE void getzsofslope(int16_t sectnum, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
static FORCE_INLINE void getzsofslope(int16_t sectnum, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
||||||
{
|
{
|
||||||
getzsofslopeptr((usectortype *)§or[sectnum], dax, day, ceilz, florz);
|
getzsofslopeptr((usectorptr_t)§or[sectnum], dax, day, ceilz, florz);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is <wal> a red wall in a safe fashion, i.e. only if consistency invariant
|
// Is <wal> a red wall in a safe fashion, i.e. only if consistency invariant
|
||||||
// ".nextsector >= 0 iff .nextwall >= 0" holds.
|
// ".nextsector >= 0 iff .nextwall >= 0" holds.
|
||||||
static FORCE_INLINE CONSTEXPR int32_t redwallp(const uwalltype *wal)
|
static FORCE_INLINE CONSTEXPR int32_t redwallp(uwallptr_t wal)
|
||||||
{
|
{
|
||||||
return (wal->nextwall >= 0 && wal->nextsector >= 0);
|
return (wal->nextwall >= 0 && wal->nextsector >= 0);
|
||||||
}
|
}
|
||||||
|
@ -1242,7 +1242,7 @@ static FORCE_INLINE CONSTEXPR int32_t E_SpriteIsValid(const int32_t i)
|
||||||
return ((unsigned)i < MAXSPRITES && sprite[i].statnum != MAXSTATUS);
|
return ((unsigned)i < MAXSPRITES && sprite[i].statnum != MAXSTATUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
int clipshape_idx_for_sprite(uspritetype const * curspr, int curidx);
|
int clipshape_idx_for_sprite(uspriteptr_t curspr, int curidx);
|
||||||
|
|
||||||
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
||||||
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z);
|
||||||
|
@ -1273,10 +1273,10 @@ int32_t changespritestat(int16_t spritenum, int16_t newstatnum);
|
||||||
int32_t setsprite(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
int32_t setsprite(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
||||||
int32_t setspritez(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
int32_t setspritez(int16_t spritenum, const vec3_t *) ATTRIBUTE((nonnull(2)));
|
||||||
|
|
||||||
int32_t spriteheightofsptr(const uspritetype *spr, int32_t *height, int32_t alsotileyofs);
|
int32_t spriteheightofsptr(uspriteptr_t spr, int32_t *height, int32_t alsotileyofs);
|
||||||
static FORCE_INLINE int32_t spriteheightofs(int16_t i, int32_t *height, int32_t alsotileyofs)
|
static FORCE_INLINE int32_t spriteheightofs(int16_t i, int32_t *height, int32_t alsotileyofs)
|
||||||
{
|
{
|
||||||
return spriteheightofsptr((uspritetype *)&sprite[i], height, alsotileyofs);
|
return spriteheightofsptr((uspriteptr_t)&sprite[i], height, alsotileyofs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int videoCaptureScreen(const char *filename, char inverseit) ATTRIBUTE((nonnull(1)));
|
int videoCaptureScreen(const char *filename, char inverseit) ATTRIBUTE((nonnull(1)));
|
||||||
|
|
|
@ -56,8 +56,8 @@ typedef struct
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
int16_t numsectors, numwalls;
|
int16_t numsectors, numwalls;
|
||||||
usectortype *sector;
|
usectorptr_t sector;
|
||||||
uwalltype *wall;
|
uwallptr_t wall;
|
||||||
} mapinfo_t;
|
} mapinfo_t;
|
||||||
|
|
||||||
extern int32_t quickloadboard;
|
extern int32_t quickloadboard;
|
||||||
|
|
|
@ -207,13 +207,13 @@ typedef struct
|
||||||
|
|
||||||
EXTERN mdmodel_t **models;
|
EXTERN mdmodel_t **models;
|
||||||
|
|
||||||
void updateanimation(md2model_t *m, const uspritetype *tspr, uint8_t lpal);
|
void updateanimation(md2model_t *m, tspriteptr_t tspr, uint8_t lpal);
|
||||||
FHardwareTexture *mdloadskin(md2model_t *m, int32_t number, int32_t pal, int32_t surf);
|
FHardwareTexture *mdloadskin(md2model_t *m, int32_t number, int32_t pal, int32_t surf);
|
||||||
void mdinit(void);
|
void mdinit(void);
|
||||||
void freeallmodels(void);
|
void freeallmodels(void);
|
||||||
void clearskins(int32_t type);
|
void clearskins(int32_t type);
|
||||||
int32_t polymost_mddraw(const uspritetype *tspr);
|
int32_t polymost_mddraw(tspriteptr_t tspr);
|
||||||
EXTERN void md3_vox_calcmat_common(const uspritetype *tspr, const vec3f_t *a0, float f, float mat[16]);
|
EXTERN void md3_vox_calcmat_common(tspriteptr_t tspr, const vec3f_t *a0, float f, float mat[16]);
|
||||||
|
|
||||||
EXTERN int32_t mdpause;
|
EXTERN int32_t mdpause;
|
||||||
EXTERN int32_t nextmodelid;
|
EXTERN int32_t nextmodelid;
|
||||||
|
@ -221,7 +221,7 @@ EXTERN voxmodel_t *voxmodels[MAXVOXELS];
|
||||||
|
|
||||||
void voxfree(voxmodel_t *m);
|
void voxfree(voxmodel_t *m);
|
||||||
voxmodel_t *voxload(const char *filnam);
|
voxmodel_t *voxload(const char *filnam);
|
||||||
int32_t polymost_voxdraw(voxmodel_t *m, const uspritetype *tspr);
|
int32_t polymost_voxdraw(voxmodel_t *m, tspriteptr_t const tspr);
|
||||||
|
|
||||||
int md3postload_polymer(md3model_t* m);
|
int md3postload_polymer(md3model_t* m);
|
||||||
//int32_t md_thinoutmodel(int32_t modelid, uint8_t *usedframebitmap);
|
//int32_t md_thinoutmodel(int32_t modelid, uint8_t *usedframebitmap);
|
||||||
|
|
|
@ -112,11 +112,11 @@ static inline float getshadefactor(int32_t const shade)
|
||||||
|
|
||||||
#define POLYMOST_CHOOSE_FOG_PAL(fogpal, pal) \
|
#define POLYMOST_CHOOSE_FOG_PAL(fogpal, pal) \
|
||||||
((fogpal) ? (fogpal) : (pal))
|
((fogpal) ? (fogpal) : (pal))
|
||||||
static FORCE_INLINE int32_t get_floor_fogpal(usectortype const * const sec)
|
static FORCE_INLINE int32_t get_floor_fogpal(usectorptr_t const sec)
|
||||||
{
|
{
|
||||||
return POLYMOST_CHOOSE_FOG_PAL(sec->fogpal, sec->floorpal);
|
return POLYMOST_CHOOSE_FOG_PAL(sec->fogpal, sec->floorpal);
|
||||||
}
|
}
|
||||||
static FORCE_INLINE int32_t get_ceiling_fogpal(usectortype const * const sec)
|
static FORCE_INLINE int32_t get_ceiling_fogpal(usectorptr_t const sec)
|
||||||
{
|
{
|
||||||
return POLYMOST_CHOOSE_FOG_PAL(sec->fogpal, sec->ceilingpal);
|
return POLYMOST_CHOOSE_FOG_PAL(sec->fogpal, sec->ceilingpal);
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,8 +40,8 @@ void engineSetClipMap(mapinfo_t *bak, mapinfo_t *newmap)
|
||||||
{
|
{
|
||||||
numsectors = newmap->numsectors;
|
numsectors = newmap->numsectors;
|
||||||
numwalls = newmap->numwalls;
|
numwalls = newmap->numwalls;
|
||||||
sector = (sectortype *) newmap->sector;
|
sector = const_cast<sectortype *>((sectortype const *)newmap->sector);
|
||||||
wall = (walltype *) newmap->wall;
|
wall = const_cast<walltype *>((walltype const *)newmap->wall);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -524,7 +524,7 @@ int32_t engineLoadClipMaps(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int clipshape_idx_for_sprite(uspritetype const * const curspr, int curidx)
|
int clipshape_idx_for_sprite(uspriteptr_t const curspr, int curidx)
|
||||||
{
|
{
|
||||||
// per-sprite init
|
// per-sprite init
|
||||||
curidx = (curidx < 0) ? pictoidx[curspr->picnum] : clipinfo[curidx].next;
|
curidx = (curidx < 0) ? pictoidx[curspr->picnum] : clipinfo[curidx].next;
|
||||||
|
@ -535,7 +535,7 @@ int clipshape_idx_for_sprite(uspritetype const * const curspr, int curidx)
|
||||||
return curidx;
|
return curidx;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
int32_t clipshape_idx_for_sprite(uspritetype const * const curspr, int32_t curidx)
|
int32_t clipshape_idx_for_sprite(uspriteptr_t const curspr, int32_t curidx)
|
||||||
{
|
{
|
||||||
(void)curspr;
|
(void)curspr;
|
||||||
UNREFERENCED_PARAMETER(curidx);
|
UNREFERENCED_PARAMETER(curidx);
|
||||||
|
@ -553,11 +553,13 @@ int32_t clipmoveboxtracenum = 3;
|
||||||
//
|
//
|
||||||
int clipinsidebox(vec2_t *vect, int wallnum, int walldist)
|
int clipinsidebox(vec2_t *vect, int wallnum, int walldist)
|
||||||
{
|
{
|
||||||
int const r = walldist << 1;
|
int const r = walldist << 1;
|
||||||
auto const * wal = (uwalltype *)&wall[wallnum];
|
|
||||||
vec2_t const v1 = { wal->x + walldist - vect->x, wal->y + walldist - vect->y };
|
auto const wal1 = (uwallptr_t)&wall[wallnum];
|
||||||
wal = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal1->point2];
|
||||||
vec2_t v2 = { wal->x + walldist - vect->x, wal->y + walldist - vect->y };
|
|
||||||
|
vec2_t const v1 = { wal1->x + walldist - vect->x, wal1->y + walldist - vect->y };
|
||||||
|
vec2_t v2 = { wal2->x + walldist - vect->x, wal2->y + walldist - vect->y };
|
||||||
|
|
||||||
if (((v1.x < 0) && (v2.x < 0)) || ((v1.y < 0) && (v2.y < 0)) || ((v1.x >= r) && (v2.x >= r)) || ((v1.y >= r) && (v2.y >= r)))
|
if (((v1.x < 0) && (v2.x < 0)) || ((v1.y < 0) && (v2.y < 0)) || ((v1.x >= r) && (v2.x >= r)) || ((v1.y >= r) && (v2.y >= r)))
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -625,7 +627,7 @@ static inline void addclipsect(int const sectnum)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
int32_t clipsprite_try(uspritetype const * const spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
int32_t clipsprite_try(uspriteptr_t const spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
||||||
{
|
{
|
||||||
// try and see whether this sprite's picnum has sector-like clipping data
|
// try and see whether this sprite's picnum has sector-like clipping data
|
||||||
int32_t i = pictoidx[spr->picnum];
|
int32_t i = pictoidx[spr->picnum];
|
||||||
|
@ -667,7 +669,7 @@ int32_t clipsprite_try(uspritetype const * const spr, int32_t xmin, int32_t ymin
|
||||||
}
|
}
|
||||||
|
|
||||||
// return: -1 if curspr has x-flip xor y-flip (in the horizontal map plane!), 1 else
|
// return: -1 if curspr has x-flip xor y-flip (in the horizontal map plane!), 1 else
|
||||||
int32_t clipsprite_initindex(int32_t curidx, uspritetype const * const curspr, int32_t *clipsectcnt, const vec3_t *vect)
|
int32_t clipsprite_initindex(int32_t curidx, uspriteptr_t const curspr, int32_t *clipsectcnt, const vec3_t *vect)
|
||||||
{
|
{
|
||||||
int32_t k, daz = curspr->z;
|
int32_t k, daz = curspr->z;
|
||||||
int32_t scalex, scaley, scalez, flipx, flipy;
|
int32_t scalex, scaley, scalez, flipx, flipy;
|
||||||
|
@ -713,7 +715,7 @@ int32_t clipsprite_initindex(int32_t curidx, uspritetype const * const curspr, i
|
||||||
for (k=clipinfo[curidx].qbeg; k<=clipinfo[curidx].qend; k++)
|
for (k=clipinfo[curidx].qbeg; k<=clipinfo[curidx].qend; k++)
|
||||||
{
|
{
|
||||||
int32_t const j = sectq[k];
|
int32_t const j = sectq[k];
|
||||||
auto const sec = (usectortype *)§or[j];
|
auto const sec = §or[j];
|
||||||
|
|
||||||
int32_t const startwall = sec->wallptr, endwall = startwall+sec->wallnum;
|
int32_t const startwall = sec->wallptr, endwall = startwall+sec->wallnum;
|
||||||
|
|
||||||
|
@ -779,7 +781,7 @@ static FORCE_INLINE void clipmove_tweak_pos(const vec3_t *pos, int32_t gx, int32
|
||||||
static int32_t check_floor_curb(int32_t dasect, int32_t nextsect, int32_t flordist, int32_t posz,
|
static int32_t check_floor_curb(int32_t dasect, int32_t nextsect, int32_t flordist, int32_t posz,
|
||||||
int32_t dax, int32_t day)
|
int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
auto const sec2 = (usectortype *)§or[nextsect];
|
auto const sec2 = (usectorptr_t)§or[nextsect];
|
||||||
int32_t const daz2 = getflorzofslope(nextsect, dax, day);
|
int32_t const daz2 = getflorzofslope(nextsect, dax, day);
|
||||||
|
|
||||||
return ((sec2->floorstat&1) == 0 && // parallaxed floor curbs don't clip
|
return ((sec2->floorstat&1) == 0 && // parallaxed floor curbs don't clip
|
||||||
|
@ -929,7 +931,7 @@ static void clipupdatesector(vec2_t const &pos, int16_t * const sectnum, int con
|
||||||
auto const sec = §or[listsectnum];
|
auto const sec = §or[listsectnum];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = sec->wallptr + sec->wallnum;
|
int const endwall = sec->wallptr + sec->wallnum;
|
||||||
auto uwal = (uwalltype *)&wall[startwall];
|
auto uwal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
for (int j = startwall; j < endwall; j++, uwal++)
|
for (int j = startwall; j < endwall; j++, uwal++)
|
||||||
if (uwal->nextsector >= 0 && bitmap_test(clipsectormap, uwal->nextsector))
|
if (uwal->nextsector >= 0 && bitmap_test(clipsectormap, uwal->nextsector))
|
||||||
|
@ -953,7 +955,7 @@ static void clipupdatesector(vec2_t const &pos, int16_t * const sectnum, int con
|
||||||
auto const sec = §or[listsectnum];
|
auto const sec = §or[listsectnum];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = sec->wallptr + sec->wallnum;
|
int const endwall = sec->wallptr + sec->wallnum;
|
||||||
auto uwal = (uwalltype *)&wall[startwall];
|
auto uwal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
// check floor curbs here?
|
// check floor curbs here?
|
||||||
|
|
||||||
|
@ -974,7 +976,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
if ((xvect|yvect) == 0 || *sectnum < 0)
|
if ((xvect|yvect) == 0 || *sectnum < 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
uspritetype const * curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
uspriteptr_t curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
||||||
|
|
||||||
int32_t const dawalclipmask = (cliptype & 65535); // CLIPMASK0 = 0x00010001
|
int32_t const dawalclipmask = (cliptype & 65535); // CLIPMASK0 = 0x00010001
|
||||||
int32_t const dasprclipmask = (cliptype >> 16); // CLIPMASK1 = 0x01000040
|
int32_t const dasprclipmask = (cliptype >> 16); // CLIPMASK1 = 0x01000040
|
||||||
|
@ -1024,7 +1026,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
engineSetClipMap(&origmapinfo, &clipmapinfo);
|
engineSetClipMap(&origmapinfo, &clipmapinfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspriteptr_t)&sprite[clipspritelist[clipspritecnt]];
|
||||||
clipshapeidx = clipshape_idx_for_sprite(curspr, clipshapeidx);
|
clipshapeidx = clipshape_idx_for_sprite(curspr, clipshapeidx);
|
||||||
|
|
||||||
if (clipshapeidx < 0)
|
if (clipshapeidx < 0)
|
||||||
|
@ -1043,14 +1045,14 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
|
|
||||||
////////// Walls //////////
|
////////// Walls //////////
|
||||||
|
|
||||||
auto const sec = (usectortype *)§or[dasect];
|
auto const sec = (usectorptr_t)§or[dasect];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = startwall + sec->wallnum;
|
int const endwall = startwall + sec->wallnum;
|
||||||
auto wal = (uwalltype *)&wall[startwall];
|
auto wal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
for (native_t j=startwall; j<endwall; j++, wal++)
|
for (native_t j=startwall; j<endwall; j++, wal++)
|
||||||
{
|
{
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
if ((wal->x < clipMin.x && wal2->x < clipMin.x) || (wal->x > clipMax.x && wal2->x > clipMax.x) ||
|
if ((wal->x < clipMin.x && wal2->x < clipMin.x) || (wal->x > clipMax.x && wal2->x > clipMax.x) ||
|
||||||
(wal->y < clipMin.y && wal2->y < clipMin.y) || (wal->y > clipMax.y && wal2->y > clipMax.y))
|
(wal->y < clipMin.y && wal2->y < clipMin.y) || (wal->y > clipMax.y && wal2->y > clipMax.y))
|
||||||
|
@ -1076,7 +1078,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
{
|
{
|
||||||
if (wal->nextsector>=0)
|
if (wal->nextsector>=0)
|
||||||
{
|
{
|
||||||
auto const sec2 = (usectortype *)§or[wal->nextsector];
|
auto const sec2 = (usectorptr_t)§or[wal->nextsector];
|
||||||
|
|
||||||
clipmove_tweak_pos(pos, diff.x, diff.y, p1.x, p1.y, p2.x, p2.y, &v.x, &v.y);
|
clipmove_tweak_pos(pos, diff.x, diff.y, p1.x, p1.y, p2.x, p2.y, &v.x, &v.y);
|
||||||
|
|
||||||
|
@ -1129,7 +1131,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
|
|
||||||
if (clipyou == 0)
|
if (clipyou == 0)
|
||||||
{
|
{
|
||||||
auto const sec2 = (usectortype *)§or[wal->nextsector];
|
auto const sec2 = (usectorptr_t)§or[wal->nextsector];
|
||||||
int32_t daz2 = getceilzofslope(wal->nextsector, v.x, v.y);
|
int32_t daz2 = getceilzofslope(wal->nextsector, v.x, v.y);
|
||||||
|
|
||||||
clipyou = ((sec2->ceilingstat&1) == 0 &&
|
clipyou = ((sec2->ceilingstat&1) == 0 &&
|
||||||
|
@ -1181,7 +1183,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
#endif
|
#endif
|
||||||
for (int j=headspritesect[dasect]; j>=0; j=nextspritesect[j])
|
for (int j=headspritesect[dasect]; j>=0; j=nextspritesect[j])
|
||||||
{
|
{
|
||||||
auto const spr = (uspritetype *)&sprite[j];
|
auto const spr = (uspriteptr_t)&sprite[j];
|
||||||
const int32_t cstat = spr->cstat;
|
const int32_t cstat = spr->cstat;
|
||||||
|
|
||||||
if ((cstat&dasprclipmask) == 0)
|
if ((cstat&dasprclipmask) == 0)
|
||||||
|
@ -1257,7 +1259,7 @@ int32_t clipmove(vec3_t * const pos, int16_t * const sectnum, int32_t xvect, int
|
||||||
rxi[0] = p1.x;
|
rxi[0] = p1.x;
|
||||||
ryi[0] = p1.y;
|
ryi[0] = p1.y;
|
||||||
|
|
||||||
get_floorspr_points((uspritetype const *) spr, 0, 0, &rxi[0], &rxi[1], &rxi[2], &rxi[3],
|
get_floorspr_points((uspriteptr_t) spr, 0, 0, &rxi[0], &rxi[1], &rxi[2], &rxi[3],
|
||||||
&ryi[0], &ryi[1], &ryi[2], &ryi[3]);
|
&ryi[0], &ryi[1], &ryi[2], &ryi[3]);
|
||||||
|
|
||||||
vec2_t v = { mulscale14(sintable[(spr->ang-256+512)&2047], walldist),
|
vec2_t v = { mulscale14(sintable[(spr->ang-256+512)&2047], walldist),
|
||||||
|
@ -1398,8 +1400,8 @@ int32_t pushmove(vec3_t * const vect, int16_t * const sectnum,
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
const uwalltype *wal;
|
uwallptr_t wal;
|
||||||
const usectortype *sec;
|
usectorptr_t sec;
|
||||||
int32_t startwall, endwall;
|
int32_t startwall, endwall;
|
||||||
#if 0
|
#if 0
|
||||||
// Push FACE sprites
|
// Push FACE sprites
|
||||||
|
@ -1434,13 +1436,13 @@ int32_t pushmove(vec3_t * const vect, int16_t * const sectnum,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
sec = (usectortype *)§or[clipsectorlist[clipsectcnt]];
|
sec = (usectorptr_t)§or[clipsectorlist[clipsectcnt]];
|
||||||
if (dir > 0)
|
if (dir > 0)
|
||||||
startwall = sec->wallptr, endwall = startwall + sec->wallnum;
|
startwall = sec->wallptr, endwall = startwall + sec->wallnum;
|
||||||
else
|
else
|
||||||
endwall = sec->wallptr, startwall = endwall + sec->wallnum;
|
endwall = sec->wallptr, startwall = endwall + sec->wallnum;
|
||||||
|
|
||||||
for (i=startwall, wal=(uwalltype *)&wall[startwall]; i!=endwall; i+=dir, wal+=dir)
|
for (i=startwall, wal=(uwallptr_t)&wall[startwall]; i!=endwall; i+=dir, wal+=dir)
|
||||||
if (clipinsidebox((vec2_t *)vect, i, walldist-4) == 1)
|
if (clipinsidebox((vec2_t *)vect, i, walldist-4) == 1)
|
||||||
{
|
{
|
||||||
j = 0;
|
j = 0;
|
||||||
|
@ -1448,7 +1450,7 @@ int32_t pushmove(vec3_t * const vect, int16_t * const sectnum,
|
||||||
if (wal->cstat&dawalclipmask) j = 1;
|
if (wal->cstat&dawalclipmask) j = 1;
|
||||||
if (j == 0)
|
if (j == 0)
|
||||||
{
|
{
|
||||||
auto const sec2 = (usectortype *)§or[wal->nextsector];
|
auto const sec2 = (usectorptr_t)§or[wal->nextsector];
|
||||||
int32_t daz2;
|
int32_t daz2;
|
||||||
|
|
||||||
//Find closest point on wall (dax, day) to (vect->x, vect->y)
|
//Find closest point on wall (dax, day) to (vect->x, vect->y)
|
||||||
|
@ -1526,7 +1528,7 @@ void getzrange(const vec3_t *pos, int16_t sectnum,
|
||||||
int32_t mcf=-1;
|
int32_t mcf=-1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uspritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
uspriteptr_t curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
||||||
int32_t curidx=-1, clipspritecnt = 0;
|
int32_t curidx=-1, clipspritecnt = 0;
|
||||||
|
|
||||||
//Extra walldist for sprites on sector lines
|
//Extra walldist for sprites on sector lines
|
||||||
|
@ -1570,7 +1572,7 @@ restart_grand:
|
||||||
{
|
{
|
||||||
// one set of clip-sprite sectors completed, prepare the next
|
// one set of clip-sprite sectors completed, prepare the next
|
||||||
|
|
||||||
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspriteptr_t)&sprite[clipspritelist[clipspritecnt]];
|
||||||
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
||||||
|
|
||||||
if (curidx < 0)
|
if (curidx < 0)
|
||||||
|
@ -1610,7 +1612,7 @@ restart_grand:
|
||||||
#endif
|
#endif
|
||||||
////////// Walls //////////
|
////////// Walls //////////
|
||||||
|
|
||||||
auto const startsec = (usectortype *)§or[clipsectorlist[clipsectcnt]];
|
auto const startsec = (usectorptr_t)§or[clipsectorlist[clipsectcnt]];
|
||||||
const int startwall = startsec->wallptr;
|
const int startwall = startsec->wallptr;
|
||||||
const int endwall = startwall + startsec->wallnum;
|
const int endwall = startwall + startsec->wallnum;
|
||||||
|
|
||||||
|
@ -1637,7 +1639,7 @@ restart_grand:
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (wall[j].cstat&dawalclipmask) continue; // XXX?
|
if (wall[j].cstat&dawalclipmask) continue; // XXX?
|
||||||
auto const sec = (usectortype *)§or[k];
|
auto const sec = (usectorptr_t)§or[k];
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
if (curspr)
|
if (curspr)
|
||||||
|
@ -1741,7 +1743,7 @@ restart_grand:
|
||||||
int32_t clipyou = 0;
|
int32_t clipyou = 0;
|
||||||
|
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
if (clipsprite_try((uspritetype *)&sprite[j], xmin,ymin, xmax,ymax))
|
if (clipsprite_try((uspriteptr_t)&sprite[j], xmin,ymin, xmax,ymax))
|
||||||
continue;
|
continue;
|
||||||
#endif
|
#endif
|
||||||
vec2_t v1 = *(vec2_t *)&sprite[j];
|
vec2_t v1 = *(vec2_t *)&sprite[j];
|
||||||
|
@ -1763,7 +1765,7 @@ restart_grand:
|
||||||
case CSTAT_SPRITE_ALIGNMENT_WALL:
|
case CSTAT_SPRITE_ALIGNMENT_WALL:
|
||||||
{
|
{
|
||||||
vec2_t v2;
|
vec2_t v2;
|
||||||
get_wallspr_points((uspritetype *)&sprite[j], &v1.x, &v2.x, &v1.y, &v2.y);
|
get_wallspr_points((uspriteptr_t)&sprite[j], &v1.x, &v2.x, &v1.y, &v2.y);
|
||||||
|
|
||||||
if (clipinsideboxline(pos->x,pos->y,v1.x,v1.y,v2.x,v2.y,walldist+1) != 0)
|
if (clipinsideboxline(pos->x,pos->y,v1.x,v1.y,v2.x,v2.y,walldist+1) != 0)
|
||||||
{
|
{
|
||||||
|
@ -1783,7 +1785,7 @@ restart_grand:
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
vec2_t v2, v3, v4;
|
vec2_t v2, v3, v4;
|
||||||
get_floorspr_points((uspritetype const *) &sprite[j], pos->x, pos->y, &v1.x, &v2.x, &v3.x, &v4.x,
|
get_floorspr_points((uspriteptr_t) &sprite[j], pos->x, pos->y, &v1.x, &v2.x, &v3.x, &v4.x,
|
||||||
&v1.y, &v2.y, &v3.y, &v4.y);
|
&v1.y, &v2.y, &v3.y, &v4.y);
|
||||||
|
|
||||||
vec2_t const da = { mulscale14(sintable[(sprite[j].ang - 256 + 512) & 2047], walldist + 4),
|
vec2_t const da = { mulscale14(sintable[(sprite[j].ang - 256 + 512) & 2047], walldist + 4),
|
||||||
|
@ -1921,7 +1923,7 @@ restart_grand:
|
||||||
|
|
||||||
|
|
||||||
// intp: point of currently best (closest) intersection
|
// intp: point of currently best (closest) intersection
|
||||||
int32_t try_facespr_intersect(uspritetype const * const spr, const vec3_t *refpos,
|
int32_t try_facespr_intersect(uspriteptr_t const spr, const vec3_t *refpos,
|
||||||
int32_t vx, int32_t vy, int32_t vz,
|
int32_t vx, int32_t vy, int32_t vz,
|
||||||
vec3_t *intp, int32_t strictly_smaller_than_p)
|
vec3_t *intp, int32_t strictly_smaller_than_p)
|
||||||
{
|
{
|
||||||
|
@ -1983,7 +1985,7 @@ static int32_t hitscan_hitsectcf=-1;
|
||||||
|
|
||||||
// stat, heinum, z: either ceiling- or floor-
|
// stat, heinum, z: either ceiling- or floor-
|
||||||
// how: -1: behave like ceiling, 1: behave like floor
|
// how: -1: behave like ceiling, 1: behave like floor
|
||||||
static int32_t hitscan_trysector(const vec3_t *sv, const usectortype *sec, hitdata_t *hit,
|
static int32_t hitscan_trysector(const vec3_t *sv, usectorptr_t sec, hitdata_t *hit,
|
||||||
int32_t vx, int32_t vy, int32_t vz,
|
int32_t vx, int32_t vy, int32_t vz,
|
||||||
uint16_t stat, int16_t heinum, int32_t z, int32_t how, const intptr_t *tmp)
|
uint16_t stat, int16_t heinum, int32_t z, int32_t how, const intptr_t *tmp)
|
||||||
{
|
{
|
||||||
|
@ -1992,8 +1994,8 @@ static int32_t hitscan_trysector(const vec3_t *sv, const usectortype *sec, hitda
|
||||||
|
|
||||||
if (stat&2)
|
if (stat&2)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[sec->wallptr];
|
auto const wal = (uwallptr_t)&wall[sec->wallptr];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
int32_t j, dax=wal2->x-wal->x, day=wal2->y-wal->y;
|
int32_t j, dax=wal2->x-wal->x, day=wal2->y-wal->y;
|
||||||
|
|
||||||
i = nsqrtasm(uhypsq(dax,day)); if (i == 0) return 1; //continue;
|
i = nsqrtasm(uhypsq(dax,day)); if (i == 0) return 1; //continue;
|
||||||
|
@ -2074,7 +2076,7 @@ int32_t hitscan(const vec3_t *sv, int16_t sectnum, int32_t vx, int32_t vy, int32
|
||||||
int32_t i, k, daz;
|
int32_t i, k, daz;
|
||||||
int16_t tempshortcnt, tempshortnum;
|
int16_t tempshortcnt, tempshortnum;
|
||||||
|
|
||||||
uspritetype *curspr = NULL;
|
uspriteptr_t curspr = NULL;
|
||||||
int32_t clipspritecnt, curidx=-1;
|
int32_t clipspritecnt, curidx=-1;
|
||||||
// tmp: { (int32_t)curidx, (spritetype *)curspr, (!=0 if outer sector) }
|
// tmp: { (int32_t)curidx, (spritetype *)curspr, (!=0 if outer sector) }
|
||||||
intptr_t tmp[3], *tmpptr=NULL;
|
intptr_t tmp[3], *tmpptr=NULL;
|
||||||
|
@ -2110,7 +2112,7 @@ restart_grand:
|
||||||
if (!curspr)
|
if (!curspr)
|
||||||
engineSetClipMap(&origmapinfo, &clipmapinfo); // replace sector and wall with clip map
|
engineSetClipMap(&origmapinfo, &clipmapinfo); // replace sector and wall with clip map
|
||||||
|
|
||||||
curspr = (uspritetype *)&sprite[clipspritelist[clipspritecnt]];
|
curspr = (uspriteptr_t)&sprite[clipspritelist[clipspritecnt]];
|
||||||
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
curidx = clipshape_idx_for_sprite(curspr, curidx);
|
||||||
|
|
||||||
if (curidx < 0)
|
if (curidx < 0)
|
||||||
|
@ -2129,7 +2131,7 @@ restart_grand:
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
dasector = clipsectorlist[tempshortcnt];
|
dasector = clipsectorlist[tempshortcnt];
|
||||||
auto const sec = (usectortype *)§or[dasector];
|
auto const sec = (usectorptr_t)§or[dasector];
|
||||||
|
|
||||||
i = 1;
|
i = 1;
|
||||||
#ifdef HAVE_CLIPSHAPE_FEATURE
|
#ifdef HAVE_CLIPSHAPE_FEATURE
|
||||||
|
@ -2153,8 +2155,8 @@ restart_grand:
|
||||||
startwall = sec->wallptr; endwall = startwall + sec->wallnum;
|
startwall = sec->wallptr; endwall = startwall + sec->wallnum;
|
||||||
for (z=startwall; z<endwall; z++)
|
for (z=startwall; z<endwall; z++)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[z];
|
auto const wal = (uwallptr_t)&wall[z];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
int const nextsector = wal->nextsector;
|
int const nextsector = wal->nextsector;
|
||||||
|
|
||||||
|
@ -2221,7 +2223,7 @@ restart_grand:
|
||||||
#endif
|
#endif
|
||||||
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
||||||
{
|
{
|
||||||
auto const spr = (uspritetype *)&sprite[z];
|
auto const spr = (uspriteptr_t)&sprite[z];
|
||||||
const int32_t cstat = spr->cstat;
|
const int32_t cstat = spr->cstat;
|
||||||
#ifdef USE_OPENGL
|
#ifdef USE_OPENGL
|
||||||
if (!hitallsprites)
|
if (!hitallsprites)
|
||||||
|
@ -2325,7 +2327,7 @@ restart_grand:
|
||||||
if (klabs(intx-sv->x)+klabs(inty-sv->y) > klabs((hit->pos.x)-sv->x)+klabs((hit->pos.y)-sv->y))
|
if (klabs(intx-sv->x)+klabs(inty-sv->y) > klabs((hit->pos.x)-sv->x)+klabs((hit->pos.y)-sv->y))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
get_floorspr_points((uspritetype const *)spr, intx, inty, &x1, &x2, &x3, &x4,
|
get_floorspr_points((uspriteptr_t)spr, intx, inty, &x1, &x2, &x3, &x4,
|
||||||
&y1, &y2, &y3, &y4);
|
&y1, &y2, &y3, &y4);
|
||||||
|
|
||||||
if (get_floorspr_clipyou(x1, x2, x3, x4, y1, y2, y3, y4))
|
if (get_floorspr_clipyou(x1, x2, x3, x4, y1, y2, y3, y4))
|
||||||
|
|
|
@ -779,7 +779,7 @@ static void yax_copytsprites()
|
||||||
{
|
{
|
||||||
int32_t i, spritenum, gotthrough, sectnum;
|
int32_t i, spritenum, gotthrough, sectnum;
|
||||||
int32_t sortcnt = yax_spritesortcnt[yax_globallev];
|
int32_t sortcnt = yax_spritesortcnt[yax_globallev];
|
||||||
const uspritetype *spr;
|
uspriteptr_t spr;
|
||||||
|
|
||||||
for (i=0; i<sortcnt; i++)
|
for (i=0; i<sortcnt; i++)
|
||||||
{
|
{
|
||||||
|
@ -788,7 +788,7 @@ static void yax_copytsprites()
|
||||||
gotthrough = spritenum&(MAXSPRITES|(MAXSPRITES<<1));
|
gotthrough = spritenum&(MAXSPRITES|(MAXSPRITES<<1));
|
||||||
|
|
||||||
spritenum &= MAXSPRITES-1;
|
spritenum &= MAXSPRITES-1;
|
||||||
spr = (uspritetype *)&sprite[spritenum];
|
spr = (uspriteptr_t)&sprite[spritenum];
|
||||||
sectnum = spr->sectnum;
|
sectnum = spr->sectnum;
|
||||||
|
|
||||||
if (gotthrough == (MAXSPRITES|(MAXSPRITES<<1)))
|
if (gotthrough == (MAXSPRITES|(MAXSPRITES<<1)))
|
||||||
|
@ -1478,7 +1478,7 @@ char apptitle[256] = "Build Engine";
|
||||||
// 1=break out of sprite collecting;
|
// 1=break out of sprite collecting;
|
||||||
int32_t renderAddTsprite(int16_t z, int16_t sectnum)
|
int32_t renderAddTsprite(int16_t z, int16_t sectnum)
|
||||||
{
|
{
|
||||||
auto const spr = (uspritetype *)&sprite[z];
|
auto const spr = (uspriteptr_t)&sprite[z];
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
if (g_nodraw==0)
|
if (g_nodraw==0)
|
||||||
{
|
{
|
||||||
|
@ -1663,7 +1663,7 @@ static void classicScanSector(int16_t startsectnum)
|
||||||
#endif
|
#endif
|
||||||
for (bssize_t i=headspritesect[sectnum]; i>=0; i=nextspritesect[i])
|
for (bssize_t i=headspritesect[sectnum]; i>=0; i=nextspritesect[i])
|
||||||
{
|
{
|
||||||
auto const spr = (uspritetype *)&sprite[i];
|
auto const spr = (uspriteptr_t)&sprite[i];
|
||||||
|
|
||||||
if (((spr->cstat & 0x8000) && !showinvisibility) || spr->xrepeat == 0 || spr->yrepeat == 0)
|
if (((spr->cstat & 0x8000) && !showinvisibility) || spr->xrepeat == 0 || spr->yrepeat == 0)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1689,9 +1689,9 @@ static void classicScanSector(int16_t startsectnum)
|
||||||
|
|
||||||
for (bssize_t w=startwall; w<endwall; w++)
|
for (bssize_t w=startwall; w<endwall; w++)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[w];
|
auto const wal = (uwallptr_t)&wall[w];
|
||||||
const int32_t nextsectnum = wal->nextsector;
|
const int32_t nextsectnum = wal->nextsector;
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
const int32_t x1 = wal->x-globalposx, y1 = wal->y-globalposy;
|
const int32_t x1 = wal->x-globalposx, y1 = wal->y-globalposy;
|
||||||
const int32_t x2 = wal2->x-globalposx, y2 = wal2->y-globalposy;
|
const int32_t x2 = wal2->x-globalposx, y2 = wal2->y-globalposy;
|
||||||
|
@ -2077,10 +2077,10 @@ int32_t wallfront(int32_t l1, int32_t l2)
|
||||||
//
|
//
|
||||||
// spritewallfront (internal)
|
// spritewallfront (internal)
|
||||||
//
|
//
|
||||||
static inline int32_t spritewallfront(const uspritetype *s, int32_t w)
|
static inline int32_t spritewallfront(uspriteptr_t s, int32_t w)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[w];
|
auto const wal = (uwallptr_t)&wall[w];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
const vec2_t v = { wal->x, wal->y };
|
const vec2_t v = { wal->x, wal->y };
|
||||||
|
|
||||||
return dmulscale32(wal2->x - v.x, s->y - v.y, -(s->x - v.x), wal2->y - v.y) >= 0;
|
return dmulscale32(wal2->x - v.x, s->y - v.y, -(s->x - v.x), wal2->y - v.y) >= 0;
|
||||||
|
@ -2210,7 +2210,7 @@ static inline void slowhline(int32_t xr, int32_t yp)
|
||||||
//
|
//
|
||||||
// prepwall (internal)
|
// prepwall (internal)
|
||||||
//
|
//
|
||||||
static void prepwall(int32_t z, const uwalltype *wal)
|
static void prepwall(int32_t z, uwallptr_t wal)
|
||||||
{
|
{
|
||||||
int32_t l=0, ol=0, x;
|
int32_t l=0, ol=0, x;
|
||||||
|
|
||||||
|
@ -2487,7 +2487,7 @@ static int32_t wallmost(int16_t *mostbuf, int32_t w, int32_t sectnum, char dasta
|
||||||
if (wi == sector[sectnum].wallptr)
|
if (wi == sector[sectnum].wallptr)
|
||||||
return owallmost(mostbuf,w,z);
|
return owallmost(mostbuf,w,z);
|
||||||
|
|
||||||
auto const wal = (uwalltype *)&wall[wi];
|
auto const wal = (uwallptr_t)&wall[wi];
|
||||||
const int32_t x1 = wal->x, x2 = wall[wal->point2].x-x1;
|
const int32_t x1 = wal->x, x2 = wall[wal->point2].x-x1;
|
||||||
const int32_t y1 = wal->y, y2 = wall[wal->point2].y-y1;
|
const int32_t y1 = wal->y, y2 = wall[wal->point2].y-y1;
|
||||||
|
|
||||||
|
@ -2614,7 +2614,7 @@ static void calc_globalshifts(void)
|
||||||
if (globalyshift > 31) globalyshift=0;
|
if (globalyshift > 31) globalyshift=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t setup_globals_cf1(const usectortype *sec, int32_t pal, int32_t zd,
|
static int32_t setup_globals_cf1(usectorptr_t sec, int32_t pal, int32_t zd,
|
||||||
int32_t picnum, int32_t shade, int32_t stat,
|
int32_t picnum, int32_t shade, int32_t stat,
|
||||||
int32_t xpanning, int32_t ypanning, int32_t x1)
|
int32_t xpanning, int32_t ypanning, int32_t x1)
|
||||||
{
|
{
|
||||||
|
@ -2709,7 +2709,7 @@ static int32_t setup_globals_cf1(const usectortype *sec, int32_t pal, int32_t zd
|
||||||
static void ceilscan(int32_t x1, int32_t x2, int32_t sectnum)
|
static void ceilscan(int32_t x1, int32_t x2, int32_t sectnum)
|
||||||
{
|
{
|
||||||
int32_t x, y1, y2;
|
int32_t x, y1, y2;
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
|
|
||||||
if (setup_globals_cf1(sec, sec->ceilingpal, sec->ceilingz-globalposz,
|
if (setup_globals_cf1(sec, sec->ceilingpal, sec->ceilingz-globalposz,
|
||||||
sec->ceilingpicnum, sec->ceilingshade, sec->ceilingstat,
|
sec->ceilingpicnum, sec->ceilingshade, sec->ceilingstat,
|
||||||
|
@ -2807,7 +2807,7 @@ static void ceilscan(int32_t x1, int32_t x2, int32_t sectnum)
|
||||||
static void florscan(int32_t x1, int32_t x2, int32_t sectnum)
|
static void florscan(int32_t x1, int32_t x2, int32_t sectnum)
|
||||||
{
|
{
|
||||||
int32_t x, y1, y2;
|
int32_t x, y1, y2;
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
|
|
||||||
if (setup_globals_cf1(sec, sec->floorpal, globalposz-sec->floorz,
|
if (setup_globals_cf1(sec, sec->floorpal, globalposz-sec->floorz,
|
||||||
sec->floorpicnum, sec->floorshade, sec->floorstat,
|
sec->floorpicnum, sec->floorshade, sec->floorstat,
|
||||||
|
@ -3429,8 +3429,8 @@ static void grouscan(int32_t dax1, int32_t dax2, int32_t sectnum, char dastat)
|
||||||
// Er, yes, they're not global anymore:
|
// Er, yes, they're not global anymore:
|
||||||
int32_t globalx, globaly, globalz, globalzx;
|
int32_t globalx, globaly, globalz, globalzx;
|
||||||
|
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
const uwalltype *wal;
|
uwallptr_t wal;
|
||||||
|
|
||||||
if (dastat == 0)
|
if (dastat == 0)
|
||||||
{
|
{
|
||||||
|
@ -3460,7 +3460,7 @@ static void grouscan(int32_t dax1, int32_t dax2, int32_t sectnum, char dastat)
|
||||||
if ((tilesiz[globalpicnum].x <= 0) || (tilesiz[globalpicnum].y <= 0)) return;
|
if ((tilesiz[globalpicnum].x <= 0) || (tilesiz[globalpicnum].y <= 0)) return;
|
||||||
if (waloff[globalpicnum] == 0) tileLoad(globalpicnum);
|
if (waloff[globalpicnum] == 0) tileLoad(globalpicnum);
|
||||||
|
|
||||||
wal = (uwalltype *)&wall[sec->wallptr];
|
wal = (uwallptr_t)&wall[sec->wallptr];
|
||||||
wx = wall[wal->point2].x - wal->x;
|
wx = wall[wal->point2].x - wal->x;
|
||||||
wy = wall[wal->point2].y - wal->y;
|
wy = wall[wal->point2].y - wal->y;
|
||||||
dasqr = krecipasm(nsqrtasm(uhypsq(wx,wy)));
|
dasqr = krecipasm(nsqrtasm(uhypsq(wx,wy)));
|
||||||
|
@ -3614,7 +3614,7 @@ static void parascan(char dastat, int32_t bunch)
|
||||||
int32_t logtilesizy, tsizy;
|
int32_t logtilesizy, tsizy;
|
||||||
|
|
||||||
int32_t sectnum = thesector[bunchfirst[bunch]];
|
int32_t sectnum = thesector[bunchfirst[bunch]];
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
|
|
||||||
globalhorizbak = globalhoriz;
|
globalhorizbak = globalhoriz;
|
||||||
globvis = globalpisibility;
|
globvis = globalpisibility;
|
||||||
|
@ -3793,7 +3793,7 @@ static void parascan(char dastat, int32_t bunch)
|
||||||
|
|
||||||
|
|
||||||
// set orientation, panning, shade, pal; picnum
|
// set orientation, panning, shade, pal; picnum
|
||||||
static void setup_globals_wall1(const uwalltype *wal, int32_t dapicnum)
|
static void setup_globals_wall1(uwallptr_t wal, int32_t dapicnum)
|
||||||
{
|
{
|
||||||
globalorientation = wal->cstat;
|
globalorientation = wal->cstat;
|
||||||
|
|
||||||
|
@ -3809,7 +3809,7 @@ static void setup_globals_wall1(const uwalltype *wal, int32_t dapicnum)
|
||||||
if (palookup[globalpal] == NULL) globalpal = 0; // JBF: fixes crash
|
if (palookup[globalpal] == NULL) globalpal = 0; // JBF: fixes crash
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setup_globals_wall2(const uwalltype *wal, uint8_t secvisibility, int32_t topzref, int32_t botzref)
|
static void setup_globals_wall2(uwallptr_t wal, uint8_t secvisibility, int32_t topzref, int32_t botzref)
|
||||||
{
|
{
|
||||||
const int32_t logtilesizy = (picsiz[globalpicnum]>>4);
|
const int32_t logtilesizy = (picsiz[globalpicnum]>>4);
|
||||||
const int32_t tsizy = tilesiz[globalpicnum].y;
|
const int32_t tsizy = tilesiz[globalpicnum].y;
|
||||||
|
@ -3913,7 +3913,7 @@ static void classicDrawBunches(int32_t bunch)
|
||||||
int32_t z = bunchfirst[bunch];
|
int32_t z = bunchfirst[bunch];
|
||||||
|
|
||||||
const int32_t sectnum = thesector[z];
|
const int32_t sectnum = thesector[z];
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
|
|
||||||
uint8_t andwstat1 = 0xff, andwstat2 = 0xff;
|
uint8_t andwstat1 = 0xff, andwstat2 = 0xff;
|
||||||
|
|
||||||
|
@ -4040,10 +4040,10 @@ static void classicDrawBunches(int32_t bunch)
|
||||||
}
|
}
|
||||||
|
|
||||||
const int32_t wallnum = thewall[z];
|
const int32_t wallnum = thewall[z];
|
||||||
auto const wal = (uwalltype *)&wall[wallnum];
|
auto const wal = (uwallptr_t)&wall[wallnum];
|
||||||
|
|
||||||
const int32_t nextsectnum = wal->nextsector;
|
const int32_t nextsectnum = wal->nextsector;
|
||||||
auto const nextsec = nextsectnum>=0 ? (usectortype *)§or[nextsectnum] : NULL;
|
auto const nextsec = nextsectnum>=0 ? (usectorptr_t)§or[nextsectnum] : NULL;
|
||||||
|
|
||||||
int32_t gotswall = 0;
|
int32_t gotswall = 0;
|
||||||
|
|
||||||
|
@ -4214,7 +4214,7 @@ static void classicDrawBunches(int32_t bunch)
|
||||||
searchstat = 0; searchit = 1;
|
searchstat = 0; searchit = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto const twal = (wal->cstat&2) ? (uwalltype *)&wall[wal->nextwall] : wal;
|
auto const twal = (wal->cstat&2) ? (uwallptr_t)&wall[wal->nextwall] : wal;
|
||||||
setup_globals_wall1(twal, twal->picnum);
|
setup_globals_wall1(twal, twal->picnum);
|
||||||
|
|
||||||
setup_globals_wall2(wal, sec->visibility, nextsec->floorz, sec->ceilingz);
|
setup_globals_wall2(wal, sec->visibility, nextsec->floorz, sec->ceilingz);
|
||||||
|
@ -4694,7 +4694,7 @@ static void classicDrawVoxel(int32_t dasprx, int32_t daspry, int32_t dasprz, int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void setup_globals_sprite1(const uspritetype *tspr, const usectortype *sec,
|
static void setup_globals_sprite1(tspriteptr_t tspr, usectorptr_t sec,
|
||||||
int32_t yspan, int32_t yoff, int32_t tilenum,
|
int32_t yspan, int32_t yoff, int32_t tilenum,
|
||||||
int32_t cstat, int32_t *z1ptr, int32_t *z2ptr)
|
int32_t cstat, int32_t *z1ptr, int32_t *z2ptr)
|
||||||
{
|
{
|
||||||
|
@ -4808,7 +4808,7 @@ static void classicDrawSprite(int32_t snum)
|
||||||
const int32_t spritenum = tspr->owner;
|
const int32_t spritenum = tspr->owner;
|
||||||
const float alpha = spriteext[spritenum].alpha;
|
const float alpha = spriteext[spritenum].alpha;
|
||||||
|
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
|
|
||||||
int32_t cstat=tspr->cstat, tilenum;
|
int32_t cstat=tspr->cstat, tilenum;
|
||||||
|
|
||||||
|
@ -5880,10 +5880,10 @@ static void renderDrawMaskedWall(int16_t damaskwallcnt)
|
||||||
//============================================================================= //POLYMOST ENDS
|
//============================================================================= //POLYMOST ENDS
|
||||||
|
|
||||||
int32_t z = maskwall[damaskwallcnt];
|
int32_t z = maskwall[damaskwallcnt];
|
||||||
auto wal = (uwalltype *)&wall[thewall[z]];
|
auto wal = (uwallptr_t)&wall[thewall[z]];
|
||||||
int32_t sectnum = thesector[z];
|
int32_t sectnum = thesector[z];
|
||||||
auto sec = (usectortype *)§or[sectnum];
|
auto sec = (usectorptr_t)§or[sectnum];
|
||||||
auto nsec = (usectortype *)§or[wal->nextsector];
|
auto nsec = (usectorptr_t)§or[wal->nextsector];
|
||||||
int32_t z1 = max(nsec->ceilingz,sec->ceilingz);
|
int32_t z1 = max(nsec->ceilingz,sec->ceilingz);
|
||||||
int32_t z2 = min(nsec->floorz,sec->floorz);
|
int32_t z2 = min(nsec->floorz,sec->floorz);
|
||||||
|
|
||||||
|
@ -7669,7 +7669,7 @@ static walltype wall_s[MAXWALLS + M32_FIXME_WALLS];
|
||||||
static wallext_t wallext_s[MAXWALLS];
|
static wallext_t wallext_s[MAXWALLS];
|
||||||
#endif
|
#endif
|
||||||
static spritetype sprite_s[MAXSPRITES];
|
static spritetype sprite_s[MAXSPRITES];
|
||||||
static uspritetype tsprite_s[MAXSPRITESONSCREEN];
|
static tspritetype tsprite_s[MAXSPRITESONSCREEN];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int32_t enginePreInit(void)
|
int32_t enginePreInit(void)
|
||||||
|
@ -8306,8 +8306,8 @@ static inline _equation equation(float const x1, float const y1, float const x2,
|
||||||
int32_t wallvisible(int32_t const x, int32_t const y, int16_t const wallnum)
|
int32_t wallvisible(int32_t const x, int32_t const y, int16_t const wallnum)
|
||||||
{
|
{
|
||||||
// 1 if wall is in front of player 0 otherwise
|
// 1 if wall is in front of player 0 otherwise
|
||||||
auto w1 = (uwalltype *)&wall[wallnum];
|
auto w1 = (uwallptr_t)&wall[wallnum];
|
||||||
auto w2 = (uwalltype *)&wall[w1->point2];
|
auto w2 = (uwallptr_t)&wall[w1->point2];
|
||||||
|
|
||||||
int32_t const a1 = getangle(w1->x - x, w1->y - y);
|
int32_t const a1 = getangle(w1->x - x, w1->y - y);
|
||||||
int32_t const a2 = getangle(w2->x - x, w2->y - y);
|
int32_t const a2 = getangle(w2->x - x, w2->y - y);
|
||||||
|
@ -8634,7 +8634,7 @@ killsprite:
|
||||||
if ((tspr->cstat & 48) != 16)
|
if ((tspr->cstat & 48) != 16)
|
||||||
tspriteptr[i]->ang = globalang;
|
tspriteptr[i]->ang = globalang;
|
||||||
|
|
||||||
get_wallspr_points((const uspritetype *)tspr, &xx[0], &xx[1], &yy[0], &yy[1]);
|
get_wallspr_points((uspriteptr_t)tspr, &xx[0], &xx[1], &yy[0], &yy[1]);
|
||||||
|
|
||||||
if ((tspr->cstat & 48) == 0)
|
if ((tspr->cstat & 48) == 0)
|
||||||
tspriteptr[i]->ang = oang;
|
tspriteptr[i]->ang = oang;
|
||||||
|
@ -8779,9 +8779,9 @@ void renderDrawMapView(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
|
|
||||||
videoBeginDrawing(); //{{{
|
videoBeginDrawing(); //{{{
|
||||||
|
|
||||||
usectortype *sec;
|
usectorptr_t sec;
|
||||||
|
|
||||||
for (s=0,sec=(usectortype *)§or[s]; s<numsectors; s++,sec++)
|
for (s=0,sec=(usectorptr_t)§or[s]; s<numsectors; s++,sec++)
|
||||||
if (show2dsector[s>>3]&pow2char[s&7])
|
if (show2dsector[s>>3]&pow2char[s&7])
|
||||||
{
|
{
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
|
@ -8804,9 +8804,9 @@ void renderDrawMapView(int32_t dax, int32_t day, int32_t zoome, int16_t ang)
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
j = startwall; l = 0;
|
j = startwall; l = 0;
|
||||||
uwalltype *wal;
|
uwallptr_t wal;
|
||||||
int32_t w;
|
int32_t w;
|
||||||
for (w=sec->wallnum,wal=(uwalltype *)&wall[startwall]; w>0; w--,wal++,j++)
|
for (w=sec->wallnum,wal=(uwallptr_t)&wall[startwall]; w>0; w--,wal++,j++)
|
||||||
{
|
{
|
||||||
k = lastwall(j);
|
k = lastwall(j);
|
||||||
if ((k > j) && (npoints > 0)) { xb1[npoints-1] = l; l = npoints; } //overwrite point2
|
if ((k > j) && (npoints > 0)) { xb1[npoints-1] = l; l = npoints; } //overwrite point2
|
||||||
|
@ -10215,15 +10215,16 @@ int32_t inside(int32_t x, int32_t y, int16_t sectnum)
|
||||||
if ((unsigned)sectnum < (unsigned)numsectors)
|
if ((unsigned)sectnum < (unsigned)numsectors)
|
||||||
{
|
{
|
||||||
uint32_t cnt1 = 0, cnt2 = 0;
|
uint32_t cnt1 = 0, cnt2 = 0;
|
||||||
auto wal = (uwalltype *) &wall[sector[sectnum].wallptr];
|
|
||||||
int wallsleft = sector[sectnum].wallnum;
|
auto wal = (uwallptr_t)&wall[sector[sectnum].wallptr];
|
||||||
|
int wallsleft = sector[sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
// Get the x and y components of the [tested point]-->[wall
|
// Get the x and y components of the [tested point]-->[wall
|
||||||
// point{1,2}] vectors.
|
// point{1,2}] vectors.
|
||||||
vec2_t v1 = { wal->x - x, wal->y - y };
|
vec2_t v1 = { wal->x - x, wal->y - y };
|
||||||
auto const &wal2 = *(uwalltype *)&wall[wal->point2];
|
auto const &wal2 = *(uwallptr_t)&wall[wal->point2];
|
||||||
vec2_t v2 = { wal2.x - x, wal2.y - y };
|
vec2_t v2 = { wal2.x - x, wal2.y - y };
|
||||||
|
|
||||||
// First, test if the point is EXACTLY_ON_WALL_POINT.
|
// First, test if the point is EXACTLY_ON_WALL_POINT.
|
||||||
|
@ -10304,7 +10305,7 @@ int32_t Mulscale(int32_t a, int32_t b, int32_t sh)
|
||||||
|
|
||||||
// Gets the BUILD unit height and z offset of a sprite.
|
// Gets the BUILD unit height and z offset of a sprite.
|
||||||
// Returns the z offset, 'height' may be NULL.
|
// Returns the z offset, 'height' may be NULL.
|
||||||
int32_t spriteheightofsptr(const uspritetype *spr, int32_t *height, int32_t alsotileyofs)
|
int32_t spriteheightofsptr(uspriteptr_t spr, int32_t *height, int32_t alsotileyofs)
|
||||||
{
|
{
|
||||||
int32_t hei, zofs=0;
|
int32_t hei, zofs=0;
|
||||||
const int32_t picnum=spr->picnum, yrepeat=spr->yrepeat;
|
const int32_t picnum=spr->picnum, yrepeat=spr->yrepeat;
|
||||||
|
@ -10372,7 +10373,7 @@ int32_t nextsectorneighborz(int16_t sectnum, int32_t refz, int16_t topbottom, in
|
||||||
int32_t nextz = (direction==1) ? INT32_MAX : INT32_MIN;
|
int32_t nextz = (direction==1) ? INT32_MAX : INT32_MIN;
|
||||||
int32_t sectortouse = -1;
|
int32_t sectortouse = -1;
|
||||||
|
|
||||||
auto wal = (uwalltype *)&wall[sector[sectnum].wallptr];
|
auto wal = (uwallptr_t)&wall[sector[sectnum].wallptr];
|
||||||
int32_t i = sector[sectnum].wallnum;
|
int32_t i = sector[sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -10441,8 +10442,8 @@ restart_grand:
|
||||||
for (dacnt=0; dacnt<danum; dacnt++)
|
for (dacnt=0; dacnt<danum; dacnt++)
|
||||||
{
|
{
|
||||||
const int32_t dasectnum = clipsectorlist[dacnt];
|
const int32_t dasectnum = clipsectorlist[dacnt];
|
||||||
auto const sec = (usectortype *)§or[dasectnum];
|
auto const sec = (usectorptr_t)§or[dasectnum];
|
||||||
const uwalltype *wal;
|
uwallptr_t wal;
|
||||||
bssize_t cnt;
|
bssize_t cnt;
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
int32_t cfz1[2], cfz2[2]; // both wrt dasectnum
|
int32_t cfz1[2], cfz2[2]; // both wrt dasectnum
|
||||||
|
@ -10452,9 +10453,9 @@ restart_grand:
|
||||||
getzsofslope(dasectnum, x1,y1, &cfz1[0], &cfz1[1]);
|
getzsofslope(dasectnum, x1,y1, &cfz1[0], &cfz1[1]);
|
||||||
getzsofslope(dasectnum, x2,y2, &cfz2[0], &cfz2[1]);
|
getzsofslope(dasectnum, x2,y2, &cfz2[0], &cfz2[1]);
|
||||||
#endif
|
#endif
|
||||||
for (cnt=sec->wallnum,wal=(uwalltype *)&wall[sec->wallptr]; cnt>0; cnt--,wal++)
|
for (cnt=sec->wallnum,wal=(uwallptr_t)&wall[sec->wallptr]; cnt>0; cnt--,wal++)
|
||||||
{
|
{
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
const int32_t x31 = wal->x-x1, x34 = wal->x-wal2->x;
|
const int32_t x31 = wal->x-x1, x34 = wal->x-wal2->x;
|
||||||
const int32_t y31 = wal->y-y1, y34 = wal->y-wal2->y;
|
const int32_t y31 = wal->y-y1, y34 = wal->y-wal2->y;
|
||||||
|
|
||||||
|
@ -10587,7 +10588,7 @@ add_nextsector:
|
||||||
|
|
||||||
// x1, y1: in/out
|
// x1, y1: in/out
|
||||||
// rest x/y: out
|
// rest x/y: out
|
||||||
void get_wallspr_points(uspritetype const * const spr, int32_t *x1, int32_t *x2,
|
void get_wallspr_points(uspriteptr_t const spr, int32_t *x1, int32_t *x2,
|
||||||
int32_t *y1, int32_t *y2)
|
int32_t *y1, int32_t *y2)
|
||||||
{
|
{
|
||||||
//These lines get the 2 points of the rotated sprite
|
//These lines get the 2 points of the rotated sprite
|
||||||
|
@ -10616,7 +10617,7 @@ void get_wallspr_points(uspritetype const * const spr, int32_t *x1, int32_t *x2,
|
||||||
|
|
||||||
// x1, y1: in/out
|
// x1, y1: in/out
|
||||||
// rest x/y: out
|
// rest x/y: out
|
||||||
void get_floorspr_points(uspritetype const * const spr, int32_t px, int32_t py,
|
void get_floorspr_points(uspriteptr_t const spr, int32_t px, int32_t py,
|
||||||
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
||||||
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4)
|
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4)
|
||||||
{
|
{
|
||||||
|
@ -10679,12 +10680,12 @@ void neartag(int32_t xs, int32_t ys, int32_t zs, int16_t sectnum, int16_t ange,
|
||||||
|
|
||||||
const int32_t startwall = sector[dasector].wallptr;
|
const int32_t startwall = sector[dasector].wallptr;
|
||||||
const int32_t endwall = startwall + sector[dasector].wallnum - 1;
|
const int32_t endwall = startwall + sector[dasector].wallnum - 1;
|
||||||
const uwalltype *wal;
|
uwallptr_t wal;
|
||||||
int32_t z;
|
int32_t z;
|
||||||
|
|
||||||
for (z=startwall,wal=(uwalltype *)&wall[startwall]; z<=endwall; z++,wal++)
|
for (z=startwall,wal=(uwallptr_t)&wall[startwall]; z<=endwall; z++,wal++)
|
||||||
{
|
{
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
const int32_t nextsector = wal->nextsector;
|
const int32_t nextsector = wal->nextsector;
|
||||||
|
|
||||||
const int32_t x1=wal->x, y1=wal->y, x2=wal2->x, y2=wal2->y;
|
const int32_t x1=wal->x, y1=wal->y, x2=wal2->x, y2=wal2->y;
|
||||||
|
@ -10729,7 +10730,7 @@ void neartag(int32_t xs, int32_t ys, int32_t zs, int16_t sectnum, int16_t ange,
|
||||||
|
|
||||||
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
for (z=headspritesect[dasector]; z>=0; z=nextspritesect[z])
|
||||||
{
|
{
|
||||||
auto const spr = (uspritetype *)&sprite[z];
|
auto const spr = (uspriteptr_t)&sprite[z];
|
||||||
|
|
||||||
if (blacklist_sprite_func && blacklist_sprite_func(z))
|
if (blacklist_sprite_func && blacklist_sprite_func(z))
|
||||||
continue;
|
continue;
|
||||||
|
@ -10981,10 +10982,10 @@ int32_t getsectordist(vec2_t const &pos, int const sectnum)
|
||||||
|
|
||||||
int32_t distance = INT32_MAX;
|
int32_t distance = INT32_MAX;
|
||||||
|
|
||||||
auto const sec = (usectortype *)§or[sectnum];
|
auto const sec = (usectorptr_t)§or[sectnum];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = sec->wallptr + sec->wallnum;
|
int const endwall = sec->wallptr + sec->wallnum;
|
||||||
auto uwal = (uwalltype *)&wall[startwall];
|
auto uwal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
for (int j = startwall; j < endwall; j++, uwal++)
|
for (int j = startwall; j < endwall; j++, uwal++)
|
||||||
{
|
{
|
||||||
|
@ -11038,7 +11039,7 @@ void updatesector(int32_t const x, int32_t const y, int16_t * const sectnum)
|
||||||
auto const sec = §or[listsectnum];
|
auto const sec = §or[listsectnum];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = sec->wallptr + sec->wallnum;
|
int const endwall = sec->wallptr + sec->wallnum;
|
||||||
auto uwal = (uwalltype *)&wall[startwall];
|
auto uwal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
for (int j=startwall; j<endwall; j++, uwal++)
|
for (int j=startwall; j<endwall; j++, uwal++)
|
||||||
if (uwal->nextsector >= 0 && getsectordist({x, y}, uwal->nextsector) < MAXUPDATESECTORDIST)
|
if (uwal->nextsector >= 0 && getsectordist({x, y}, uwal->nextsector) < MAXUPDATESECTORDIST)
|
||||||
|
@ -11062,7 +11063,7 @@ void updatesectorexclude(int32_t const x, int32_t const y, int16_t * const sectn
|
||||||
|
|
||||||
if (*sectnum >= 0 && *sectnum < numsectors)
|
if (*sectnum >= 0 && *sectnum < numsectors)
|
||||||
{
|
{
|
||||||
auto wal = (uwalltype *)&wall[sector[*sectnum].wallptr];
|
auto wal = (uwallptr_t)&wall[sector[*sectnum].wallptr];
|
||||||
int wallsleft = sector[*sectnum].wallnum;
|
int wallsleft = sector[*sectnum].wallnum;
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -11140,7 +11141,7 @@ void updatesectorz(int32_t const x, int32_t const y, int32_t const z, int16_t *
|
||||||
auto const sec = §or[listsectnum];
|
auto const sec = §or[listsectnum];
|
||||||
int const startwall = sec->wallptr;
|
int const startwall = sec->wallptr;
|
||||||
int const endwall = sec->wallptr + sec->wallnum;
|
int const endwall = sec->wallptr + sec->wallnum;
|
||||||
auto uwal = (uwalltype *)&wall[startwall];
|
auto uwal = (uwallptr_t)&wall[startwall];
|
||||||
|
|
||||||
for (int j=startwall; j<endwall; j++, uwal++)
|
for (int j=startwall; j<endwall; j++, uwal++)
|
||||||
if (uwal->nextsector >= 0 && getsectordist({x, y}, uwal->nextsector) < MAXUPDATESECTORDIST)
|
if (uwal->nextsector >= 0 && getsectordist({x, y}, uwal->nextsector) < MAXUPDATESECTORDIST)
|
||||||
|
@ -11750,13 +11751,13 @@ int32_t sectorofwall_noquick(int16_t wallNum)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t getceilzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
int32_t getceilzofslopeptr(usectorptr_t sec, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
if (!(sec->ceilingstat&2))
|
if (!(sec->ceilingstat&2))
|
||||||
return sec->ceilingz;
|
return sec->ceilingz;
|
||||||
|
|
||||||
auto const wal = (uwalltype *)&wall[sec->wallptr];
|
auto const wal = (uwallptr_t)&wall[sec->wallptr];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
vec2_t const w = *(vec2_t const *)wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d = { wal2->x - w.x, wal2->y - w.y };
|
vec2_t const d = { wal2->x - w.x, wal2->y - w.y };
|
||||||
|
@ -11768,13 +11769,13 @@ int32_t getceilzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
||||||
return sec->ceilingz + (scale(sec->ceilingheinum,j>>1,i)<<1);
|
return sec->ceilingz + (scale(sec->ceilingheinum,j>>1,i)<<1);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t getflorzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
int32_t getflorzofslopeptr(usectorptr_t sec, int32_t dax, int32_t day)
|
||||||
{
|
{
|
||||||
if (!(sec->floorstat&2))
|
if (!(sec->floorstat&2))
|
||||||
return sec->floorz;
|
return sec->floorz;
|
||||||
|
|
||||||
auto const wal = (uwalltype *)&wall[sec->wallptr];
|
auto const wal = (uwallptr_t)&wall[sec->wallptr];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
vec2_t const w = *(vec2_t const *)wal;
|
vec2_t const w = *(vec2_t const *)wal;
|
||||||
vec2_t const d = { wal2->x - w.x, wal2->y - w.y };
|
vec2_t const d = { wal2->x - w.x, wal2->y - w.y };
|
||||||
|
@ -11786,15 +11787,15 @@ int32_t getflorzofslopeptr(const usectortype *sec, int32_t dax, int32_t day)
|
||||||
return sec->floorz + (scale(sec->floorheinum,j>>1,i)<<1);
|
return sec->floorz + (scale(sec->floorheinum,j>>1,i)<<1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void getzsofslopeptr(const usectortype *sec, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
void getzsofslopeptr(usectorptr_t sec, int32_t dax, int32_t day, int32_t *ceilz, int32_t *florz)
|
||||||
{
|
{
|
||||||
*ceilz = sec->ceilingz; *florz = sec->floorz;
|
*ceilz = sec->ceilingz; *florz = sec->floorz;
|
||||||
|
|
||||||
if (((sec->ceilingstat|sec->floorstat)&2) != 2)
|
if (((sec->ceilingstat|sec->floorstat)&2) != 2)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto const wal = (uwalltype *)&wall[sec->wallptr];
|
auto const wal = (uwallptr_t)&wall[sec->wallptr];
|
||||||
auto const wal2 = (uwalltype *)&wall[wal->point2];
|
auto const wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
|
|
||||||
vec2_t const d = { wal2->x - wal->x, wal2->y - wal->y };
|
vec2_t const d = { wal2->x - wal->x, wal2->y - wal->y };
|
||||||
|
|
||||||
|
@ -11814,7 +11815,7 @@ void getzsofslopeptr(const usectortype *sec, int32_t dax, int32_t day, int32_t *
|
||||||
//
|
//
|
||||||
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z)
|
void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[sector[dasect].wallptr];
|
auto const wal = (uwallptr_t)&wall[sector[dasect].wallptr];
|
||||||
const int32_t dax = wall[wal->point2].x-wal->x;
|
const int32_t dax = wall[wal->point2].x-wal->x;
|
||||||
const int32_t day = wall[wal->point2].y-wal->y;
|
const int32_t day = wall[wal->point2].y-wal->y;
|
||||||
|
|
||||||
|
@ -11835,7 +11836,7 @@ void alignceilslope(int16_t dasect, int32_t x, int32_t y, int32_t z)
|
||||||
//
|
//
|
||||||
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z)
|
void alignflorslope(int16_t dasect, int32_t x, int32_t y, int32_t z)
|
||||||
{
|
{
|
||||||
auto const wal = (uwalltype *)&wall[sector[dasect].wallptr];
|
auto const wal = (uwallptr_t)&wall[sector[dasect].wallptr];
|
||||||
const int32_t dax = wall[wal->point2].x-wal->x;
|
const int32_t dax = wall[wal->point2].x-wal->x;
|
||||||
const int32_t day = wall[wal->point2].y-wal->y;
|
const int32_t day = wall[wal->point2].y-wal->y;
|
||||||
|
|
||||||
|
|
|
@ -208,7 +208,7 @@ extern uint16_t ATTRIBUTE((used)) sqrtable[4096], ATTRIBUTE((used)) shlookup[409
|
||||||
extern int16_t thesector[MAXWALLSB], thewall[MAXWALLSB];
|
extern int16_t thesector[MAXWALLSB], thewall[MAXWALLSB];
|
||||||
extern int16_t bunchfirst[MAXWALLSB], bunchlast[MAXWALLSB];
|
extern int16_t bunchfirst[MAXWALLSB], bunchlast[MAXWALLSB];
|
||||||
extern int16_t maskwall[MAXWALLSB], maskwallcnt;
|
extern int16_t maskwall[MAXWALLSB], maskwallcnt;
|
||||||
extern uspritetype *tspriteptr[MAXSPRITESONSCREEN + 1];
|
extern tspriteptr_t tspriteptr[MAXSPRITESONSCREEN + 1];
|
||||||
extern int32_t xdimen, xdimenrecip, halfxdimen, xdimenscale, xdimscale, ydimen;
|
extern int32_t xdimen, xdimenrecip, halfxdimen, xdimenscale, xdimscale, ydimen;
|
||||||
extern float fxdimen;
|
extern float fxdimen;
|
||||||
extern intptr_t frameoffset;
|
extern intptr_t frameoffset;
|
||||||
|
@ -258,9 +258,9 @@ void calc_and_apply_fog(int32_t shade, int32_t vis, int32_t pal);
|
||||||
void calc_and_apply_fog_factor(int32_t shade, int32_t vis, int32_t pal, float factor);
|
void calc_and_apply_fog_factor(int32_t shade, int32_t vis, int32_t pal, float factor);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern void get_wallspr_points(uspritetype const * spr, int32_t *x1, int32_t *x2,
|
extern void get_wallspr_points(uspriteptr_t spr, int32_t *x1, int32_t *x2,
|
||||||
int32_t *y1, int32_t *y2);
|
int32_t *y1, int32_t *y2);
|
||||||
extern void get_floorspr_points(uspritetype const * spr, int32_t px, int32_t py,
|
extern void get_floorspr_points(uspriteptr_t spr, int32_t px, int32_t py,
|
||||||
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
int32_t *x1, int32_t *x2, int32_t *x3, int32_t *x4,
|
||||||
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4);
|
int32_t *y1, int32_t *y2, int32_t *y3, int32_t *y4);
|
||||||
|
|
||||||
|
@ -276,7 +276,7 @@ int32_t animateoffs(int tilenum);
|
||||||
if ((((Fakevar) & 16384) == 16384) && (globalorientation & CSTAT_WALL_ROTATE_90) && rottile[Picnum].newtile != -1) Picnum = rottile[Picnum].newtile; \
|
if ((((Fakevar) & 16384) == 16384) && (globalorientation & CSTAT_WALL_ROTATE_90) && rottile[Picnum].newtile != -1) Picnum = rottile[Picnum].newtile; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
static FORCE_INLINE int32_t bad_tspr(const uspritetype *tspr)
|
static FORCE_INLINE int32_t bad_tspr(tspriteptr_t tspr)
|
||||||
{
|
{
|
||||||
// NOTE: tspr->owner >= MAXSPRITES (could be model) has to be handled by
|
// NOTE: tspr->owner >= MAXSPRITES (could be model) has to be handled by
|
||||||
// caller.
|
// caller.
|
||||||
|
|
|
@ -913,7 +913,7 @@ FHardwareTexture *mdloadskin(md2model_t *m, int32_t number, int32_t pal, int32_t
|
||||||
}
|
}
|
||||||
|
|
||||||
//Note: even though it says md2model, it works for both md2model&md3model
|
//Note: even though it says md2model, it works for both md2model&md3model
|
||||||
void updateanimation(md2model_t *m, const uspritetype *tspr, uint8_t lpal)
|
void updateanimation(md2model_t *m, tspriteptr_t tspr, uint8_t lpal)
|
||||||
{
|
{
|
||||||
if (m->numframes < 2)
|
if (m->numframes < 2)
|
||||||
{
|
{
|
||||||
|
@ -1845,7 +1845,7 @@ int md3postload_polymer(md3model_t *m)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void md3_vox_calcmat_common(const uspritetype *tspr, const vec3f_t *a0, float f, float mat[16])
|
void md3_vox_calcmat_common(tspriteptr_t tspr, const vec3f_t *a0, float f, float mat[16])
|
||||||
{
|
{
|
||||||
float g;
|
float g;
|
||||||
float k0, k1, k2, k3, k4, k5, k6, k7;
|
float k0, k1, k2, k3, k4, k5, k6, k7;
|
||||||
|
@ -1899,7 +1899,7 @@ static void md3draw_handle_triangles(const md3surf_t *s, uint16_t *indexhandle,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t polymost_md3draw(md3model_t *m, const uspritetype *tspr)
|
static int32_t polymost_md3draw(md3model_t *m, tspriteptr_t tspr)
|
||||||
{
|
{
|
||||||
vec3f_t m0, m1, a0;
|
vec3f_t m0, m1, a0;
|
||||||
md3xyzn_t *v0, *v1;
|
md3xyzn_t *v0, *v1;
|
||||||
|
@ -2364,7 +2364,7 @@ mdmodel_t *mdload(const char *filnam)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int32_t polymost_mddraw(const uspritetype *tspr)
|
int32_t polymost_mddraw(tspriteptr_t tspr)
|
||||||
{
|
{
|
||||||
if (maxmodelverts > allocmodelverts)
|
if (maxmodelverts > allocmodelverts)
|
||||||
{
|
{
|
||||||
|
|
|
@ -897,7 +897,7 @@ voxmodel_t *voxload(const char *filnam)
|
||||||
|
|
||||||
//Draw voxel model as perfect cubes
|
//Draw voxel model as perfect cubes
|
||||||
// Note: This is a hopeless mess that totally forfeits any chance of using a vertex buffer with its messy coordinate adjustments. :(
|
// Note: This is a hopeless mess that totally forfeits any chance of using a vertex buffer with its messy coordinate adjustments. :(
|
||||||
int32_t polymost_voxdraw(voxmodel_t *m, const uspritetype *tspr)
|
int32_t polymost_voxdraw(voxmodel_t *m, tspriteptr_t const tspr)
|
||||||
{
|
{
|
||||||
// float clut[6] = {1.02,1.02,0.94,1.06,0.98,0.98};
|
// float clut[6] = {1.02,1.02,0.94,1.06,0.98,0.98};
|
||||||
float f, g, k0;
|
float f, g, k0;
|
||||||
|
|
|
@ -94,7 +94,7 @@ void G_ClearCameraView(DukePlayer_t *ps)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Manhattan distance between wall-point and sprite.
|
// Manhattan distance between wall-point and sprite.
|
||||||
static FORCE_INLINE int32_t G_WallSpriteDist(uwalltype const * const wal, uspritetype const * const spr)
|
static FORCE_INLINE int32_t G_WallSpriteDist(uwallptr_t const wal, uspriteptr_t const spr)
|
||||||
{
|
{
|
||||||
return klabs(wal->x - spr->x) + klabs(wal->y - spr->y);
|
return klabs(wal->x - spr->x) + klabs(wal->y - spr->y);
|
||||||
}
|
}
|
||||||
|
@ -107,7 +107,7 @@ void A_RadiusDamage(int spriteNum, int blastRadius, int dmg1, int dmg2, int dmg3
|
||||||
ud.returnvar[3] = dmg3;
|
ud.returnvar[3] = dmg3;
|
||||||
ud.returnvar[4] = dmg4;
|
ud.returnvar[4] = dmg4;
|
||||||
|
|
||||||
uspritetype const *const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
|
|
||||||
int32_t sectorCount = 0;
|
int32_t sectorCount = 0;
|
||||||
int32_t numSectors = 1;
|
int32_t numSectors = 1;
|
||||||
|
@ -127,8 +127,8 @@ void A_RadiusDamage(int spriteNum, int blastRadius, int dmg1, int dmg2, int dmg3
|
||||||
|
|
||||||
// Check if "hit" 1st or 3rd wall-point. This mainly makes sense
|
// Check if "hit" 1st or 3rd wall-point. This mainly makes sense
|
||||||
// for rectangular "ceiling light"-style sectors.
|
// for rectangular "ceiling light"-style sectors.
|
||||||
if (G_WallSpriteDist((uwalltype *)&wall[startWall], pSprite) < blastRadius ||
|
if (G_WallSpriteDist((uwallptr_t)&wall[startWall], pSprite) < blastRadius ||
|
||||||
G_WallSpriteDist((uwalltype *)&wall[wall[w2].point2], pSprite) < blastRadius)
|
G_WallSpriteDist((uwallptr_t)&wall[wall[w2].point2], pSprite) < blastRadius)
|
||||||
{
|
{
|
||||||
if (((sector[sectorNum].ceilingz-pSprite->z)>>8) < blastRadius)
|
if (((sector[sectorNum].ceilingz-pSprite->z)>>8) < blastRadius)
|
||||||
Sect_DamageCeiling_Internal(spriteNum, sectorNum);
|
Sect_DamageCeiling_Internal(spriteNum, sectorNum);
|
||||||
|
@ -138,7 +138,7 @@ void A_RadiusDamage(int spriteNum, int blastRadius, int dmg1, int dmg2, int dmg3
|
||||||
|
|
||||||
native_t w = startWall;
|
native_t w = startWall;
|
||||||
|
|
||||||
for (uwalltype const *pWall = (uwalltype *)&wall[startWall]; w < endWall; w++, pWall++)
|
for (auto pWall = (uwallptr_t)&wall[startWall]; w < endWall; w++, pWall++)
|
||||||
{
|
{
|
||||||
if (G_WallSpriteDist(pWall, pSprite) >= blastRadius)
|
if (G_WallSpriteDist(pWall, pSprite) >= blastRadius)
|
||||||
continue;
|
continue;
|
||||||
|
@ -324,14 +324,15 @@ next_sprite:
|
||||||
// <spritenum>: the projectile
|
// <spritenum>: the projectile
|
||||||
// <i>: the SE7
|
// <i>: the SE7
|
||||||
// <fromunderp>: below->above change?
|
// <fromunderp>: below->above change?
|
||||||
static int32_t Proj_MaybeDoTransport(int32_t spriteNum, const uspritetype * const pSEffector, int32_t fromunderp, int32_t daz)
|
static int32_t Proj_MaybeDoTransport(int32_t spriteNum, uspriteptr_t const pSEffector, int32_t fromunderp, int32_t daz)
|
||||||
{
|
{
|
||||||
if ((totalclock & UINT8_MAX) == actor[spriteNum].lasttransport)
|
if ((totalclock & UINT8_MAX) == actor[spriteNum].lasttransport)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
spritetype *const pSprite = &sprite[spriteNum];
|
auto const pSprite = &sprite[spriteNum];
|
||||||
const uspritetype *const otherse = (uspritetype *)&sprite[pSEffector->owner];
|
auto const otherse = (uspriteptr_t)&sprite[pSEffector->owner];
|
||||||
actor[spriteNum].lasttransport = (totalclock & UINT8_MAX);
|
|
||||||
|
actor[spriteNum].lasttransport = (totalclock & UINT8_MAX);
|
||||||
|
|
||||||
pSprite->x += (otherse->x - pSEffector->x);
|
pSprite->x += (otherse->x - pSEffector->x);
|
||||||
pSprite->y += (otherse->y - pSEffector->y);
|
pSprite->y += (otherse->y - pSEffector->y);
|
||||||
|
@ -349,7 +350,7 @@ static int32_t Proj_MaybeDoTransport(int32_t spriteNum, const uspritetype * cons
|
||||||
|
|
||||||
// Check whether sprite <s> is on/in a non-SE7 water sector.
|
// Check whether sprite <s> is on/in a non-SE7 water sector.
|
||||||
// <othersectptr>: if not NULL, the sector on the other side.
|
// <othersectptr>: if not NULL, the sector on the other side.
|
||||||
int A_CheckNoSE7Water(uspritetype const * const pSprite, int sectNum, int sectLotag, int32_t *pOther)
|
int A_CheckNoSE7Water(uspriteptr_t const pSprite, int sectNum, int sectLotag, int32_t *pOther)
|
||||||
{
|
{
|
||||||
if (sectLotag == ST_1_ABOVE_WATER || sectLotag == ST_2_UNDERWATER)
|
if (sectLotag == ST_1_ABOVE_WATER || sectLotag == ST_2_UNDERWATER)
|
||||||
{
|
{
|
||||||
|
@ -383,8 +384,8 @@ static int32_t A_CheckNeedZUpdate(int32_t spriteNum, int32_t zChange, int32_t *p
|
||||||
if (zChange == 0)
|
if (zChange == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
uspritetype const *const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
int const newZ = pSprite->z + (zChange >> 1);
|
int const newZ = pSprite->z + (zChange >> 1);
|
||||||
|
|
||||||
*pZcoord = newZ;
|
*pZcoord = newZ;
|
||||||
|
|
||||||
|
@ -598,11 +599,11 @@ int32_t A_MoveSpriteClipdist(int32_t spriteNum, vec3_t const * const change, uin
|
||||||
int const sectLotag = sector[newSectnum].lotag;
|
int const sectLotag = sector[newSectnum].lotag;
|
||||||
|
|
||||||
if (sectLotag == ST_1_ABOVE_WATER && newZ >= actor[spriteNum].floorz)
|
if (sectLotag == ST_1_ABOVE_WATER && newZ >= actor[spriteNum].floorz)
|
||||||
if (Proj_MaybeDoTransport(spriteNum, (uspritetype *)&sprite[otherSpriteNum], 0, newZ))
|
if (Proj_MaybeDoTransport(spriteNum, (uspriteptr_t)&sprite[otherSpriteNum], 0, newZ))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (sectLotag == ST_2_UNDERWATER && newZ <= actor[spriteNum].ceilingz)
|
if (sectLotag == ST_2_UNDERWATER && newZ <= actor[spriteNum].ceilingz)
|
||||||
if (Proj_MaybeDoTransport(spriteNum, (uspritetype *)&sprite[otherSpriteNum], 1, newZ))
|
if (Proj_MaybeDoTransport(spriteNum, (uspriteptr_t)&sprite[otherSpriteNum], 1, newZ))
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -697,8 +698,8 @@ void A_SpawnMultiple(int spriteNum, int tileNum, int spawnCnt)
|
||||||
#ifndef EDUKE32_STANDALONE
|
#ifndef EDUKE32_STANDALONE
|
||||||
void A_DoGuts(int spriteNum, int tileNum, int spawnCnt)
|
void A_DoGuts(int spriteNum, int tileNum, int spawnCnt)
|
||||||
{
|
{
|
||||||
uspritetype const *const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
vec2_t repeat = { 32, 32 };
|
vec2_t repeat = { 32, 32 };
|
||||||
|
|
||||||
if (A_CheckEnemySprite(pSprite) && pSprite->xrepeat < 16)
|
if (A_CheckEnemySprite(pSprite) && pSprite->xrepeat < 16)
|
||||||
repeat.x = repeat.y = 8;
|
repeat.x = repeat.y = 8;
|
||||||
|
@ -730,8 +731,8 @@ void A_DoGuts(int spriteNum, int tileNum, int spawnCnt)
|
||||||
|
|
||||||
void A_DoGutsDir(int spriteNum, int tileNum, int spawnCnt)
|
void A_DoGutsDir(int spriteNum, int tileNum, int spawnCnt)
|
||||||
{
|
{
|
||||||
uspritetype const * const s = (uspritetype *)&sprite[spriteNum];
|
auto const s = (uspriteptr_t)&sprite[spriteNum];
|
||||||
vec2_t repeat = { 32, 32 };
|
vec2_t repeat = { 32, 32 };
|
||||||
|
|
||||||
if (A_CheckEnemySprite(s) && s->xrepeat < 16)
|
if (A_CheckEnemySprite(s) && s->xrepeat < 16)
|
||||||
repeat.x = repeat.y = 8;
|
repeat.x = repeat.y = 8;
|
||||||
|
@ -917,7 +918,7 @@ ACTOR_STATIC void A_MaybeAwakenBadGuys(int const spriteNum)
|
||||||
|
|
||||||
if (A_CheckSpriteFlags(spriteNum, SFLAG_WAKEUPBADGUYS))
|
if (A_CheckSpriteFlags(spriteNum, SFLAG_WAKEUPBADGUYS))
|
||||||
{
|
{
|
||||||
uspritetype *const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
|
|
||||||
for (bssize_t nextSprite, SPRITES_OF_STAT_SAFE(STAT_ZOMBIEACTOR, spriteNum, nextSprite))
|
for (bssize_t nextSprite, SPRITES_OF_STAT_SAFE(STAT_ZOMBIEACTOR, spriteNum, nextSprite))
|
||||||
{
|
{
|
||||||
|
@ -1274,7 +1275,7 @@ ACTOR_STATIC void G_MovePlayers(void)
|
||||||
int const sectorLotag = sector[playerSectnum].lotag;
|
int const sectorLotag = sector[playerSectnum].lotag;
|
||||||
int32_t otherSector;
|
int32_t otherSector;
|
||||||
|
|
||||||
if (A_CheckNoSE7Water((uspritetype const *)pSprite, playerSectnum, sectorLotag, &otherSector))
|
if (A_CheckNoSE7Water((uspriteptr_t)pSprite, playerSectnum, sectorLotag, &otherSector))
|
||||||
{
|
{
|
||||||
// NOTE: Compare with G_MoveTransports().
|
// NOTE: Compare with G_MoveTransports().
|
||||||
pPlayer->on_warping_sector = 1;
|
pPlayer->on_warping_sector = 1;
|
||||||
|
@ -2775,7 +2776,7 @@ static void Proj_BounceOffWall(spritetype *s, int j)
|
||||||
// NOTE: Compare with Proj_MaybeDamageCF2() in sector.c
|
// NOTE: Compare with Proj_MaybeDamageCF2() in sector.c
|
||||||
static int Proj_MaybeDamageCF(int spriteNum)
|
static int Proj_MaybeDamageCF(int spriteNum)
|
||||||
{
|
{
|
||||||
uspritetype const * const s = (uspritetype const *)&sprite[spriteNum];
|
auto const s = (uspriteptr_t)&sprite[spriteNum];
|
||||||
|
|
||||||
if (s->zvel < 0)
|
if (s->zvel < 0)
|
||||||
{
|
{
|
||||||
|
@ -7886,7 +7887,7 @@ next_sprite:
|
||||||
|
|
||||||
if (s->lotag == SE_29_WAVES)
|
if (s->lotag == SE_29_WAVES)
|
||||||
{
|
{
|
||||||
usectortype const *const sc = (usectortype *)§or[s->sectnum];
|
auto const sc = (usectorptr_t)§or[s->sectnum];
|
||||||
|
|
||||||
if (sc->wallnum == 4)
|
if (sc->wallnum == 4)
|
||||||
{
|
{
|
||||||
|
|
|
@ -436,7 +436,7 @@ extern int32_t ticrandomseed;
|
||||||
extern projectile_t SpriteProjectile[MAXSPRITES];
|
extern projectile_t SpriteProjectile[MAXSPRITES];
|
||||||
|
|
||||||
|
|
||||||
int A_CheckNoSE7Water(uspritetype const *pSprite, int sectNum, int sectLotag, int32_t *pOther);
|
int A_CheckNoSE7Water(uspriteptr_t pSprite, int sectNum, int sectLotag, int32_t *pOther);
|
||||||
int A_CheckSwitchTile(int spriteNum);
|
int A_CheckSwitchTile(int spriteNum);
|
||||||
int A_IncurDamage(int spriteNum);
|
int A_IncurDamage(int spriteNum);
|
||||||
void A_AddToDeleteQueue(int spriteNum);
|
void A_AddToDeleteQueue(int spriteNum);
|
||||||
|
@ -536,7 +536,7 @@ EXTERN_INLINE int G_CheckForSpaceFloor(int const sectnum)
|
||||||
|
|
||||||
EXTERN_INLINE int A_CheckEnemySprite(void const * const pSprite)
|
EXTERN_INLINE int A_CheckEnemySprite(void const * const pSprite)
|
||||||
{
|
{
|
||||||
return A_CheckEnemyTile(((uspritetype const *) pSprite)->picnum);
|
return A_CheckEnemyTile(((uspriteptr_t) pSprite)->picnum);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -3414,7 +3414,7 @@ SPAWN_END:
|
||||||
return newSprite;
|
return newSprite;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int G_MaybeTakeOnFloorPal(uspritetype *pSprite, int sectNum)
|
static int G_MaybeTakeOnFloorPal(tspriteptr_t pSprite, int sectNum)
|
||||||
{
|
{
|
||||||
int const floorPal = sector[sectNum].floorpal;
|
int const floorPal = sector[sectNum].floorpal;
|
||||||
|
|
||||||
|
@ -3555,7 +3555,7 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
#endif
|
#endif
|
||||||
for (j=spritesortcnt-1; j>=0; j--)
|
for (j=spritesortcnt-1; j>=0; j--)
|
||||||
{
|
{
|
||||||
uspritetype *const t = &tsprite[j];
|
auto const t = &tsprite[j];
|
||||||
const int32_t i = t->owner;
|
const int32_t i = t->owner;
|
||||||
const spritetype *const s = &sprite[i];
|
const spritetype *const s = &sprite[i];
|
||||||
|
|
||||||
|
@ -3584,9 +3584,9 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
|
|
||||||
for (j=spritesortcnt-1; j>=0; j--)
|
for (j=spritesortcnt-1; j>=0; j--)
|
||||||
{
|
{
|
||||||
uspritetype *const t = &tsprite[j];
|
auto const t = &tsprite[j];
|
||||||
const int32_t i = t->owner;
|
const int32_t i = t->owner;
|
||||||
const spritetype *const s = &sprite[i];
|
auto const s = (uspriteptr_t)&sprite[i];
|
||||||
|
|
||||||
if (t->picnum < GREENSLIME || t->picnum > GREENSLIME+7)
|
if (t->picnum < GREENSLIME || t->picnum > GREENSLIME+7)
|
||||||
switch (DYNAMICTILEMAP(t->picnum))
|
switch (DYNAMICTILEMAP(t->picnum))
|
||||||
|
@ -3675,11 +3675,11 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
int32_t startframe, viewtype;
|
int32_t startframe, viewtype;
|
||||||
#endif
|
#endif
|
||||||
//is the perfect time to animate sprites
|
//is the perfect time to animate sprites
|
||||||
uspritetype *const t = &tsprite[j];
|
auto const t = &tsprite[j];
|
||||||
const int32_t i = t->owner;
|
const int32_t i = t->owner;
|
||||||
// XXX: what's up with the (i < 0) check?
|
// XXX: what's up with the (i < 0) check?
|
||||||
// NOTE: not const spritetype because set at SET_SPRITE_NOT_TSPRITE (see below).
|
// NOTE: not const spritetype because set at SET_SPRITE_NOT_TSPRITE (see below).
|
||||||
uspritetype *const pSprite = (i < 0) ? &tsprite[j] : (uspritetype *)&sprite[i];
|
auto const pSprite = (i < 0) ? (uspriteptr_t)&tsprite[j] : (uspriteptr_t)&sprite[i];
|
||||||
|
|
||||||
#ifndef EDUKE32_STANDALONE
|
#ifndef EDUKE32_STANDALONE
|
||||||
if (ud.lockout && G_CheckAdultTile(DYNAMICTILEMAP(pSprite->picnum)))
|
if (ud.lockout && G_CheckAdultTile(DYNAMICTILEMAP(pSprite->picnum)))
|
||||||
|
@ -3921,8 +3921,8 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
if (ud.showweapons && sprite[g_player[playerNum].ps->i].extra > 0 && g_player[playerNum].ps->curr_weapon > 0
|
if (ud.showweapons && sprite[g_player[playerNum].ps->i].extra > 0 && g_player[playerNum].ps->curr_weapon > 0
|
||||||
&& spritesortcnt < maxspritesonscreen)
|
&& spritesortcnt < maxspritesonscreen)
|
||||||
{
|
{
|
||||||
uspritetype *const newTspr = &tsprite[spritesortcnt];
|
auto const newTspr = &tsprite[spritesortcnt];
|
||||||
int const currentWeapon = g_player[playerNum].ps->curr_weapon;
|
int const currentWeapon = g_player[playerNum].ps->curr_weapon;
|
||||||
|
|
||||||
*newTspr = *t;
|
*newTspr = *t;
|
||||||
newTspr->statnum = TSPR_TEMP;
|
newTspr->statnum = TSPR_TEMP;
|
||||||
|
@ -3938,7 +3938,7 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
|
|
||||||
if (g_player[playerNum].inputBits->extbits & (1 << 7) && !ud.pause_on && spritesortcnt < maxspritesonscreen)
|
if (g_player[playerNum].inputBits->extbits & (1 << 7) && !ud.pause_on && spritesortcnt < maxspritesonscreen)
|
||||||
{
|
{
|
||||||
uspritetype *const playerTyping = t;
|
auto const playerTyping = t;
|
||||||
|
|
||||||
playerTyping->statnum = TSPR_TEMP;
|
playerTyping->statnum = TSPR_TEMP;
|
||||||
playerTyping->cstat = 0;
|
playerTyping->cstat = 0;
|
||||||
|
@ -3978,8 +3978,8 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
l = pSprite->z-actor[g_player[playerNum].ps->i].floorz+(3<<8);
|
l = pSprite->z-actor[g_player[playerNum].ps->i].floorz+(3<<8);
|
||||||
// SET_SPRITE_NOT_TSPRITE
|
// SET_SPRITE_NOT_TSPRITE
|
||||||
if (l > 1024 && pSprite->yrepeat > 32 && pSprite->extra > 0)
|
if (l > 1024 && pSprite->yrepeat > 32 && pSprite->extra > 0)
|
||||||
pSprite->yoffset = (int8_t)tabledivide32_noinline(l, pSprite->yrepeat<<2);
|
t->yoffset = (int8_t)tabledivide32_noinline(l, pSprite->yrepeat<<2);
|
||||||
else pSprite->yoffset=0;
|
else t->yoffset=0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_player[playerNum].ps->newowner > -1)
|
if (g_player[playerNum].ps->newowner > -1)
|
||||||
|
@ -4216,7 +4216,7 @@ skip:
|
||||||
|
|
||||||
if ((pSprite->z-shadowZ) < ZOFFSET3 && g_player[screenpeek].ps->pos.z < shadowZ)
|
if ((pSprite->z-shadowZ) < ZOFFSET3 && g_player[screenpeek].ps->pos.z < shadowZ)
|
||||||
{
|
{
|
||||||
uspritetype *const tsprShadow = &tsprite[spritesortcnt];
|
tspriteptr_t tsprShadow = &tsprite[spritesortcnt];
|
||||||
|
|
||||||
*tsprShadow = *t;
|
*tsprShadow = *t;
|
||||||
tsprShadow->statnum = TSPR_TEMP;
|
tsprShadow->statnum = TSPR_TEMP;
|
||||||
|
|
|
@ -549,14 +549,14 @@ static inline int G_GetMusicIdx(const char *str)
|
||||||
return (ep * MAXLEVELS) + lev;
|
return (ep * MAXLEVELS) + lev;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int G_GetViewscreenSizeShift(const uspritetype *tspr)
|
static inline int G_GetViewscreenSizeShift(uspriteptr_t const spr)
|
||||||
{
|
{
|
||||||
#if VIEWSCREENFACTOR == 0
|
#if VIEWSCREENFACTOR == 0
|
||||||
UNREFERENCED_PARAMETER(tspr);
|
UNREFERENCED_PARAMETER(spr);
|
||||||
return VIEWSCREENFACTOR;
|
return VIEWSCREENFACTOR;
|
||||||
#else
|
#else
|
||||||
static const int mask = (1<<VIEWSCREENFACTOR)-1;
|
static const int mask = (1<<VIEWSCREENFACTOR)-1;
|
||||||
const int rem = (tspr->xrepeat & mask) | (tspr->yrepeat & mask);
|
const int rem = (spr->xrepeat & mask) | (spr->yrepeat & mask);
|
||||||
|
|
||||||
for (int i=0; i < VIEWSCREENFACTOR; i++)
|
for (int i=0; i < VIEWSCREENFACTOR; i++)
|
||||||
if (rem & (1<<i))
|
if (rem & (1<<i))
|
||||||
|
|
|
@ -230,7 +230,7 @@ int32_t VM_OnEvent__(int const nEventID, int const spriteNum, int const playerNu
|
||||||
|
|
||||||
static bool VM_CheckSquished(void)
|
static bool VM_CheckSquished(void)
|
||||||
{
|
{
|
||||||
auto const pSector = (usectortype *)§or[vm.pSprite->sectnum];
|
auto const pSector = (usectorptr_t)§or[vm.pSprite->sectnum];
|
||||||
|
|
||||||
if (pSector->lotag == ST_23_SWINGING_DOOR || (vm.pSprite->picnum == APLAYER && ud.noclip) ||
|
if (pSector->lotag == ST_23_SWINGING_DOOR || (vm.pSprite->picnum == APLAYER && ud.noclip) ||
|
||||||
(pSector->lotag == ST_1_ABOVE_WATER && !A_CheckNoSE7Water(vm.pUSprite, vm.pSprite->sectnum, pSector->lotag, NULL)))
|
(pSector->lotag == ST_1_ABOVE_WATER && !A_CheckNoSE7Water(vm.pUSprite, vm.pSprite->sectnum, pSector->lotag, NULL)))
|
||||||
|
@ -316,7 +316,7 @@ bool A_Dodge(spritetype * const pSprite)
|
||||||
|
|
||||||
int A_GetFurthestAngle(int spriteNum, int angDiv)
|
int A_GetFurthestAngle(int spriteNum, int angDiv)
|
||||||
{
|
{
|
||||||
auto const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
|
|
||||||
if (pSprite->picnum != APLAYER && (AC_COUNT(actor[spriteNum].t_data)&63) > 2)
|
if (pSprite->picnum != APLAYER && (AC_COUNT(actor[spriteNum].t_data)&63) > 2)
|
||||||
return pSprite->ang + 1024;
|
return pSprite->ang + 1024;
|
||||||
|
@ -328,9 +328,9 @@ int A_GetFurthestAngle(int spriteNum, int angDiv)
|
||||||
|
|
||||||
for (native_t j = pSprite->ang; j < (2048 + pSprite->ang); j += angIncs)
|
for (native_t j = pSprite->ang; j < (2048 + pSprite->ang); j += angIncs)
|
||||||
{
|
{
|
||||||
pSprite->z -= ZOFFSET3;
|
vec3_t origin = *(const vec3_t *)pSprite;
|
||||||
hitscan((const vec3_t *)pSprite, pSprite->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 0, &hit, CLIPMASK1);
|
origin.z -= ZOFFSET3;
|
||||||
pSprite->z += ZOFFSET3;
|
hitscan(&origin, pSprite->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 0, &hit, CLIPMASK1);
|
||||||
|
|
||||||
int const hitDist = klabs(hit.pos.x-pSprite->x) + klabs(hit.pos.y-pSprite->y);
|
int const hitDist = klabs(hit.pos.x-pSprite->x) + klabs(hit.pos.y-pSprite->y);
|
||||||
|
|
||||||
|
@ -344,12 +344,12 @@ int A_GetFurthestAngle(int spriteNum, int angDiv)
|
||||||
return furthestAngle & 2047;
|
return furthestAngle & 2047;
|
||||||
}
|
}
|
||||||
|
|
||||||
int A_FurthestVisiblePoint(int const spriteNum, uspritetype * const ts, vec2_t * const vect)
|
int A_FurthestVisiblePoint(int const spriteNum, uspriteptr_t const ts, vec2_t * const vect)
|
||||||
{
|
{
|
||||||
if (AC_COUNT(actor[spriteNum].t_data)&63)
|
if (AC_COUNT(actor[spriteNum].t_data)&63)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
const uspritetype *const pnSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pnSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
|
|
||||||
hitdata_t hit;
|
hitdata_t hit;
|
||||||
int const angincs = 128;
|
int const angincs = 128;
|
||||||
|
@ -357,9 +357,9 @@ int A_FurthestVisiblePoint(int const spriteNum, uspritetype * const ts, vec2_t *
|
||||||
|
|
||||||
for (native_t j = ts->ang; j < (2048 + ts->ang); j += (angincs /*-(krand()&511)*/))
|
for (native_t j = ts->ang; j < (2048 + ts->ang); j += (angincs /*-(krand()&511)*/))
|
||||||
{
|
{
|
||||||
ts->z -= ZOFFSET2;
|
vec3_t origin = *(const vec3_t *)ts;
|
||||||
hitscan((const vec3_t *)ts, ts->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 16384 - (krand() & 32767), &hit, CLIPMASK1);
|
origin.z -= ZOFFSET2;
|
||||||
ts->z += ZOFFSET2;
|
hitscan(&origin, ts->sectnum, sintable[(j + 512) & 2047], sintable[j & 2047], 16384 - (krand() & 32767), &hit, CLIPMASK1);
|
||||||
|
|
||||||
if (hit.sect < 0)
|
if (hit.sect < 0)
|
||||||
continue;
|
continue;
|
||||||
|
@ -383,7 +383,7 @@ int A_FurthestVisiblePoint(int const spriteNum, uspritetype * const ts, vec2_t *
|
||||||
|
|
||||||
static void VM_GetZRange(int const spriteNum, int32_t * const ceilhit, int32_t * const florhit, int const wallDist)
|
static void VM_GetZRange(int const spriteNum, int32_t * const ceilhit, int32_t * const florhit, int const wallDist)
|
||||||
{
|
{
|
||||||
uspritetype *const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = &sprite[spriteNum];
|
||||||
int const ocstat = pSprite->cstat;
|
int const ocstat = pSprite->cstat;
|
||||||
|
|
||||||
pSprite->cstat = 0;
|
pSprite->cstat = 0;
|
||||||
|
@ -406,7 +406,7 @@ void A_GetZLimits(int const spriteNum)
|
||||||
|
|
||||||
if ((florhit&49152) == 49152 && (sprite[florhit&(MAXSPRITES-1)].cstat&48) == 0)
|
if ((florhit&49152) == 49152 && (sprite[florhit&(MAXSPRITES-1)].cstat&48) == 0)
|
||||||
{
|
{
|
||||||
auto const hitspr = (uspritetype *)&sprite[florhit&(MAXSPRITES-1)];
|
auto const hitspr = (uspriteptr_t)&sprite[florhit&(MAXSPRITES-1)];
|
||||||
|
|
||||||
florhit &= (MAXSPRITES-1);
|
florhit &= (MAXSPRITES-1);
|
||||||
|
|
||||||
|
@ -968,7 +968,7 @@ static int A_GetVerticalVel(actor_t const * const pActor)
|
||||||
|
|
||||||
static int32_t A_GetWaterZOffset(int const spriteNum)
|
static int32_t A_GetWaterZOffset(int const spriteNum)
|
||||||
{
|
{
|
||||||
auto const pSprite = (uspritetype *)&sprite[spriteNum];
|
auto const pSprite = (uspriteptr_t)&sprite[spriteNum];
|
||||||
auto const pActor = &actor[spriteNum];
|
auto const pActor = &actor[spriteNum];
|
||||||
|
|
||||||
if (sector[pSprite->sectnum].lotag == ST_1_ABOVE_WATER)
|
if (sector[pSprite->sectnum].lotag == ST_1_ABOVE_WATER)
|
||||||
|
@ -3063,7 +3063,7 @@ badindex:
|
||||||
|
|
||||||
vInstruction(CON_IFCANSEE):
|
vInstruction(CON_IFCANSEE):
|
||||||
{
|
{
|
||||||
auto pSprite = (uspritetype *)&sprite[vm.pPlayer->i];
|
auto pSprite = (uspriteptr_t)&sprite[vm.pPlayer->i];
|
||||||
|
|
||||||
// select sprite for monster to target
|
// select sprite for monster to target
|
||||||
// if holoduke is on, let them target holoduke first.
|
// if holoduke is on, let them target holoduke first.
|
||||||
|
@ -3071,7 +3071,7 @@ badindex:
|
||||||
#ifndef EDUKE32_STANDALONE
|
#ifndef EDUKE32_STANDALONE
|
||||||
if (vm.pPlayer->holoduke_on >= 0)
|
if (vm.pPlayer->holoduke_on >= 0)
|
||||||
{
|
{
|
||||||
pSprite = (uspritetype *)&sprite[vm.pPlayer->holoduke_on];
|
pSprite = (uspriteptr_t)&sprite[vm.pPlayer->holoduke_on];
|
||||||
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - (krand() & (ZOFFSET5 - 1)), vm.pSprite->sectnum, pSprite->x, pSprite->y,
|
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - (krand() & (ZOFFSET5 - 1)), vm.pSprite->sectnum, pSprite->x, pSprite->y,
|
||||||
pSprite->z, pSprite->sectnum);
|
pSprite->z, pSprite->sectnum);
|
||||||
|
|
||||||
|
@ -3079,7 +3079,7 @@ badindex:
|
||||||
{
|
{
|
||||||
// they can't see player's holoduke
|
// they can't see player's holoduke
|
||||||
// check for player...
|
// check for player...
|
||||||
pSprite = (uspritetype *)&sprite[vm.pPlayer->i];
|
pSprite = (uspriteptr_t)&sprite[vm.pPlayer->i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -104,7 +104,7 @@ int32_t __fastcall VM_GetSector(int const sectNum, int32_t labelNum)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto const &s = *(usectortype *)§or[sectNum];
|
auto const &s = *(usectorptr_t)§or[sectNum];
|
||||||
|
|
||||||
switch (labelNum)
|
switch (labelNum)
|
||||||
{
|
{
|
||||||
|
|
|
@ -113,7 +113,7 @@ typedef struct {
|
||||||
int32_t g_st;
|
int32_t g_st;
|
||||||
union {
|
union {
|
||||||
spritetype * pSprite;
|
spritetype * pSprite;
|
||||||
uspritetype *pUSprite;
|
uspritetype const * pUSprite;
|
||||||
};
|
};
|
||||||
uint32_t flags; // g_errorFlag, g_returnFlag;
|
uint32_t flags; // g_errorFlag, g_returnFlag;
|
||||||
|
|
||||||
|
|
|
@ -1327,7 +1327,7 @@ skip_check:
|
||||||
const int32_t parm2 = how<=ITER_DRAWNSPRITES ? 0 : Gv_GetVarX(*insptr++);
|
const int32_t parm2 = how<=ITER_DRAWNSPRITES ? 0 : Gv_GetVarX(*insptr++);
|
||||||
instype *const end = insptr + *insptr, *const beg = ++insptr;
|
instype *const end = insptr + *insptr, *const beg = ++insptr;
|
||||||
const int32_t vm_i_bak = vm.spriteNum;
|
const int32_t vm_i_bak = vm.spriteNum;
|
||||||
uspritetype *const vm_sp_bak = vm.pUSprite;
|
auto const vm_sp_bak = vm.pUSprite;
|
||||||
|
|
||||||
if (vm.flags&VMFLAG_ERROR)
|
if (vm.flags&VMFLAG_ERROR)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1416,7 +1416,7 @@ skip_check:
|
||||||
case ITER_DRAWNSPRITES:
|
case ITER_DRAWNSPRITES:
|
||||||
{
|
{
|
||||||
uspritetype lastSpriteBackup;
|
uspritetype lastSpriteBackup;
|
||||||
uspritetype *const lastSpritePtr = (uspritetype *)&sprite[MAXSPRITES-1];
|
auto const lastSpritePtr = (uspritetype *)&sprite[MAXSPRITES-1];
|
||||||
|
|
||||||
// Back up sprite MAXSPRITES-1.
|
// Back up sprite MAXSPRITES-1.
|
||||||
Bmemcpy(&lastSpriteBackup, lastSpritePtr, sizeof(uspritetype));
|
Bmemcpy(&lastSpriteBackup, lastSpritePtr, sizeof(uspritetype));
|
||||||
|
|
|
@ -373,8 +373,8 @@ static int GetAutoAimAng(int spriteNum, int playerNum, int projecTile, int zAdju
|
||||||
|
|
||||||
if (returnSprite >= 0)
|
if (returnSprite >= 0)
|
||||||
{
|
{
|
||||||
const uspritetype *const pSprite = (uspritetype *)&sprite[returnSprite];
|
auto const pSprite = (uspriteptr_t)&sprite[returnSprite];
|
||||||
int zCenter = 2 * (pSprite->yrepeat * tilesiz[pSprite->picnum].y) + zAdjust;
|
int zCenter = 2 * (pSprite->yrepeat * tilesiz[pSprite->picnum].y) + zAdjust;
|
||||||
|
|
||||||
#ifndef EDUKE32_STANDALONE
|
#ifndef EDUKE32_STANDALONE
|
||||||
if (!IONMAIDEN && aimFlags &&
|
if (!IONMAIDEN && aimFlags &&
|
||||||
|
@ -590,7 +590,7 @@ static int SectorContainsSE13(int const sectNum)
|
||||||
// (in that case walltype *hitwal may be stale)
|
// (in that case walltype *hitwal may be stale)
|
||||||
static inline void HandleHitWall(hitdata_t *hitData)
|
static inline void HandleHitWall(hitdata_t *hitData)
|
||||||
{
|
{
|
||||||
uwalltype const * const hitWall = (uwalltype *)&wall[hitData->wall];
|
auto const hitWall = (uwallptr_t)&wall[hitData->wall];
|
||||||
|
|
||||||
if ((hitWall->cstat & 2) && redwallp(hitWall) && (hitData->pos.z >= sector[hitWall->nextsector].floorz))
|
if ((hitWall->cstat & 2) && redwallp(hitWall) && (hitData->pos.z >= sector[hitWall->nextsector].floorz))
|
||||||
hitData->wall = hitWall->nextwall;
|
hitData->wall = hitWall->nextwall;
|
||||||
|
@ -684,7 +684,7 @@ static int P_PostFireHitscan(int playerNum, int const spriteNum, hitdata_t *cons
|
||||||
}
|
}
|
||||||
else if (hitData->wall >= 0)
|
else if (hitData->wall >= 0)
|
||||||
{
|
{
|
||||||
uwalltype const * const hitWall = (uwalltype *)&wall[hitData->wall];
|
auto const hitWall = (uwallptr_t)&wall[hitData->wall];
|
||||||
|
|
||||||
Proj_MaybeSpawn(spriteNum, spawnTile, hitData);
|
Proj_MaybeSpawn(spriteNum, spawnTile, hitData);
|
||||||
|
|
||||||
|
@ -790,7 +790,7 @@ static int Proj_CheckBlood(vec3_t const *const srcVect, hitdata_t const *const h
|
||||||
if (hitData->wall < 0 || hitData->sect < 0)
|
if (hitData->wall < 0 || hitData->sect < 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
uwalltype const *const hitWall = (uwalltype *)&wall[hitData->wall];
|
auto const hitWall = (uwallptr_t)&wall[hitData->wall];
|
||||||
|
|
||||||
if ((FindDistance2D(srcVect->x - hitData->pos.x, srcVect->y - hitData->pos.y) < bloodRange)
|
if ((FindDistance2D(srcVect->x - hitData->pos.x, srcVect->y - hitData->pos.y) < bloodRange)
|
||||||
&& (hitWall->overpicnum != BIGFORCE && (hitWall->cstat & 16) == 0)
|
&& (hitWall->overpicnum != BIGFORCE && (hitWall->cstat & 16) == 0)
|
||||||
|
@ -1042,7 +1042,7 @@ static int A_ShootCustom(int const spriteNum, int const projecTile, int shootAng
|
||||||
|
|
||||||
if (Proj_CheckBlood(startPos, &hitData, pProj->range, mulscale3(pProj->yrepeat, tilesiz[pProj->decal].y) << 8))
|
if (Proj_CheckBlood(startPos, &hitData, pProj->range, mulscale3(pProj->yrepeat, tilesiz[pProj->decal].y) << 8))
|
||||||
{
|
{
|
||||||
const uwalltype *const hitWall = (uwalltype *)&wall[hitData.wall];
|
uwallptr_t const hitWall = (uwallptr_t)&wall[hitData.wall];
|
||||||
|
|
||||||
if (FindDistance2D(hitWall->x - wall[hitWall->point2].x, hitWall->y - wall[hitWall->point2].y) >
|
if (FindDistance2D(hitWall->x - wall[hitWall->point2].x, hitWall->y - wall[hitWall->point2].y) >
|
||||||
(mulscale3(pProj->xrepeat + 8, tilesiz[pProj->decal].x)))
|
(mulscale3(pProj->xrepeat + 8, tilesiz[pProj->decal].x)))
|
||||||
|
@ -1139,7 +1139,7 @@ static int32_t A_ShootHardcoded(int spriteNum, int projecTile, int shootAng, vec
|
||||||
{
|
{
|
||||||
if (Proj_CheckBlood(&startPos, &hitData, 1024, 16 << 8))
|
if (Proj_CheckBlood(&startPos, &hitData, 1024, 16 << 8))
|
||||||
{
|
{
|
||||||
const uwalltype *const hitwal = (uwalltype *)&wall[hitData.wall];
|
uwallptr_t const hitwal = (uwallptr_t)&wall[hitData.wall];
|
||||||
|
|
||||||
if (SectorContainsSE13(hitwal->nextsector))
|
if (SectorContainsSE13(hitwal->nextsector))
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -4771,7 +4771,7 @@ void P_ProcessInput(int playerNum)
|
||||||
int spriteNum = lowZhit&(MAXSPRITES-1);
|
int spriteNum = lowZhit&(MAXSPRITES-1);
|
||||||
|
|
||||||
if ((sprite[spriteNum].cstat&33) == 33 || (sprite[spriteNum].cstat&17) == 17 ||
|
if ((sprite[spriteNum].cstat&33) == 33 || (sprite[spriteNum].cstat&17) == 17 ||
|
||||||
clipshape_idx_for_sprite((uspritetype *)&sprite[spriteNum], -1) >= 0)
|
clipshape_idx_for_sprite((uspriteptr_t)&sprite[spriteNum], -1) >= 0)
|
||||||
{
|
{
|
||||||
// EDuke32 extension: xvel of 1 makes a sprite be never regarded as a bridge.
|
// EDuke32 extension: xvel of 1 makes a sprite be never regarded as a bridge.
|
||||||
|
|
||||||
|
@ -5416,7 +5416,7 @@ HORIZONLY:;
|
||||||
// ST_2_UNDERWATER
|
// ST_2_UNDERWATER
|
||||||
if (pPlayer->cursectnum >= 0 && sectorLotag < 3)
|
if (pPlayer->cursectnum >= 0 && sectorLotag < 3)
|
||||||
{
|
{
|
||||||
usectortype const *pSector = (usectortype *)§or[pPlayer->cursectnum];
|
auto const pSector = (usectorptr_t)§or[pPlayer->cursectnum];
|
||||||
|
|
||||||
// TRAIN_SECTOR_TO_SE_INDEX
|
// TRAIN_SECTOR_TO_SE_INDEX
|
||||||
if ((!ud.noclip && pSector->lotag == ST_31_TWO_WAY_TRAIN) &&
|
if ((!ud.noclip && pSector->lotag == ST_31_TWO_WAY_TRAIN) &&
|
||||||
|
|
|
@ -397,10 +397,10 @@ static inline int P_GetP(const void *pSprite)
|
||||||
// NOTE: In the no-netcode build, there's no point to pass player indices
|
// NOTE: In the no-netcode build, there's no point to pass player indices
|
||||||
// at all since there is ever only one player. However, merely returning 0
|
// at all since there is ever only one player. However, merely returning 0
|
||||||
// would mean making this build less strict than the normal one.
|
// would mean making this build less strict than the normal one.
|
||||||
Bassert(((const uspritetype *)pSprite)->yvel == 0);
|
Bassert(((uspriteptr_t)pSprite)->yvel == 0);
|
||||||
return 0;
|
return 0;
|
||||||
#else
|
#else
|
||||||
int playerNum = ((const uspritetype *)pSprite)->yvel;
|
int playerNum = ((uspriteptr_t)pSprite)->yvel;
|
||||||
// [JM] Check against MAXPLAYERS as opposed to g_mostConcurrentPlayers
|
// [JM] Check against MAXPLAYERS as opposed to g_mostConcurrentPlayers
|
||||||
// to prevent CON for disconnected/fake players from executing as playernum 0.
|
// to prevent CON for disconnected/fake players from executing as playernum 0.
|
||||||
if ((unsigned)playerNum >= MAXPLAYERS)
|
if ((unsigned)playerNum >= MAXPLAYERS)
|
||||||
|
@ -410,7 +410,7 @@ static inline int P_GetP(const void *pSprite)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the player index given an APLAYER sprite index.
|
// Get the player index given an APLAYER sprite index.
|
||||||
static inline int P_Get(int32_t spriteNum) { return P_GetP((const uspritetype *)&sprite[spriteNum]); }
|
static inline int P_Get(int32_t spriteNum) { return P_GetP((uspriteptr_t)&sprite[spriteNum]); }
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -322,7 +322,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
int32_t xvect, yvect, xvect2, yvect2;
|
int32_t xvect, yvect, xvect2, yvect2;
|
||||||
int16_t p;
|
int16_t p;
|
||||||
char col;
|
char col;
|
||||||
uwalltype *wal, *wal2;
|
uwallptr_t wal, wal2;
|
||||||
spritetype *spr;
|
spritetype *spr;
|
||||||
|
|
||||||
int32_t tmpydim = (xdim*5)/8;
|
int32_t tmpydim = (xdim*5)/8;
|
||||||
|
@ -347,7 +347,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
z1 = sector[i].ceilingz;
|
z1 = sector[i].ceilingz;
|
||||||
z2 = sector[i].floorz;
|
z2 = sector[i].floorz;
|
||||||
|
|
||||||
for (j=startwall, wal=(uwalltype *)&wall[startwall]; j<endwall; j++, wal++)
|
for (j=startwall, wal=(uwallptr_t)&wall[startwall]; j<endwall; j++, wal++)
|
||||||
{
|
{
|
||||||
k = wal->nextwall;
|
k = wal->nextwall;
|
||||||
if (k < 0) continue;
|
if (k < 0) continue;
|
||||||
|
@ -364,7 +364,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
x1 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
x1 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
||||||
y1 = dmulscale16(oy, xvect2, ox, yvect2)+(ydim<<11);
|
y1 = dmulscale16(oy, xvect2, ox, yvect2)+(ydim<<11);
|
||||||
|
|
||||||
wal2 = (uwalltype *)&wall[wal->point2];
|
wal2 = (uwallptr_t)&wall[wal->point2];
|
||||||
ox = wal2->x-cposx;
|
ox = wal2->x-cposx;
|
||||||
oy = wal2->y-cposy;
|
oy = wal2->y-cposy;
|
||||||
x2 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
x2 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
||||||
|
@ -532,7 +532,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
endwall = sector[i].wallptr + sector[i].wallnum;
|
endwall = sector[i].wallptr + sector[i].wallnum;
|
||||||
|
|
||||||
k = -1;
|
k = -1;
|
||||||
for (j=startwall, wal=(uwalltype *)&wall[startwall]; j<endwall; j++, wal++)
|
for (j=startwall, wal=(uwallptr_t)&wall[startwall]; j<endwall; j++, wal++)
|
||||||
{
|
{
|
||||||
if (wal->nextwall >= 0) continue;
|
if (wal->nextwall >= 0) continue;
|
||||||
|
|
||||||
|
@ -553,7 +553,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
}
|
}
|
||||||
|
|
||||||
k = wal->point2;
|
k = wal->point2;
|
||||||
wal2 = (uwalltype *)&wall[k];
|
wal2 = (uwallptr_t)&wall[k];
|
||||||
ox = wal2->x-cposx;
|
ox = wal2->x-cposx;
|
||||||
oy = wal2->y-cposy;
|
oy = wal2->y-cposy;
|
||||||
x2 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
x2 = dmulscale16(ox, xvect, -oy, yvect)+(xdim<<11);
|
||||||
|
@ -572,7 +572,7 @@ static void G_DrawOverheadMap(int32_t cposx, int32_t cposy, int32_t czoom, int16
|
||||||
if (ud.scrollmode && p == screenpeek) continue;
|
if (ud.scrollmode && p == screenpeek) continue;
|
||||||
|
|
||||||
DukePlayer_t const * const pPlayer = g_player[p].ps;
|
DukePlayer_t const * const pPlayer = g_player[p].ps;
|
||||||
uspritetype const * const pSprite = (uspritetype const *)&sprite[pPlayer->i];
|
auto const pSprite = (uspriteptr_t)&sprite[pPlayer->i];
|
||||||
|
|
||||||
ox = pSprite->x - cposx;
|
ox = pSprite->x - cposx;
|
||||||
oy = pSprite->y - cposy;
|
oy = pSprite->y - cposy;
|
||||||
|
|
|
@ -427,7 +427,7 @@ void G_AnimateCamSprite(int smoothRatio)
|
||||||
|
|
||||||
if (OW(spriteNum) >= 0 && dist(&sprite[pPlayer->i], &sprite[spriteNum]) < VIEWSCREEN_ACTIVE_DISTANCE)
|
if (OW(spriteNum) >= 0 && dist(&sprite[pPlayer->i], &sprite[spriteNum]) < VIEWSCREEN_ACTIVE_DISTANCE)
|
||||||
{
|
{
|
||||||
int const viewscrShift = G_GetViewscreenSizeShift((const uspritetype *)&sprite[spriteNum]);
|
int const viewscrShift = G_GetViewscreenSizeShift((uspriteptr_t)&sprite[spriteNum]);
|
||||||
int const viewscrTile = TILE_VIEWSCR - viewscrShift;
|
int const viewscrTile = TILE_VIEWSCR - viewscrShift;
|
||||||
|
|
||||||
if (waloff[viewscrTile] == 0)
|
if (waloff[viewscrTile] == 0)
|
||||||
|
|
Loading…
Reference in a new issue