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:
terminx 2019-04-18 17:25:24 +00:00 committed by Christoph Oelckers
parent 5948513d76
commit 301ac48ccd
21 changed files with 227 additions and 223 deletions

View file

@ -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 *)&sector[sectnum], dax, day); return getceilzofslopeptr((usectorptr_t)&sector[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 *)&sector[sectnum], dax, day); return getflorzofslopeptr((usectorptr_t)&sector[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 *)&sector[sectnum], dax, day, ceilz, florz); getzsofslopeptr((usectorptr_t)&sector[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)));

View file

@ -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;

View file

@ -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);

View file

@ -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);
} }

View file

@ -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 *)&sector[j]; auto const sec = &sector[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 *)&sector[nextsect]; auto const sec2 = (usectorptr_t)&sector[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 = &sector[listsectnum]; auto const sec = &sector[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 = &sector[listsectnum]; auto const sec = &sector[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 *)&sector[dasect]; auto const sec = (usectorptr_t)&sector[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 *)&sector[wal->nextsector]; auto const sec2 = (usectorptr_t)&sector[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 *)&sector[wal->nextsector]; auto const sec2 = (usectorptr_t)&sector[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 *)&sector[clipsectorlist[clipsectcnt]]; sec = (usectorptr_t)&sector[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 *)&sector[wal->nextsector]; auto const sec2 = (usectorptr_t)&sector[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 *)&sector[clipsectorlist[clipsectcnt]]; auto const startsec = (usectorptr_t)&sector[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 *)&sector[k]; auto const sec = (usectorptr_t)&sector[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 *)&sector[dasector]; auto const sec = (usectorptr_t)&sector[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))

View file

@ -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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[nextsectnum] : NULL; auto const nextsec = nextsectnum>=0 ? (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto sec = (usectorptr_t)&sector[sectnum];
auto nsec = (usectortype *)&sector[wal->nextsector]; auto nsec = (usectorptr_t)&sector[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 *)&sector[s]; s<numsectors; s++,sec++) for (s=0,sec=(usectorptr_t)&sector[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 *)&sector[dasectnum]; auto const sec = (usectorptr_t)&sector[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 *)&sector[sectnum]; auto const sec = (usectorptr_t)&sector[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 = &sector[listsectnum]; auto const sec = &sector[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 = &sector[listsectnum]; auto const sec = &sector[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;

View file

@ -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.

View file

@ -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)
{ {

View file

@ -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;

View file

@ -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 *)&sector[s->sectnum]; auto const sc = (usectorptr_t)&sector[s->sectnum];
if (sc->wallnum == 4) if (sc->wallnum == 4)
{ {

View file

@ -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

View file

@ -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;

View file

@ -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))

View file

@ -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 *)&sector[vm.pSprite->sectnum]; auto const pSector = (usectorptr_t)&sector[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

View file

@ -104,7 +104,7 @@ int32_t __fastcall VM_GetSector(int const sectNum, int32_t labelNum)
return -1; return -1;
} }
auto const &s = *(usectortype *)&sector[sectNum]; auto const &s = *(usectorptr_t)&sector[sectNum];
switch (labelNum) switch (labelNum)
{ {

View file

@ -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;

View file

@ -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));

View file

@ -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 *)&sector[pPlayer->cursectnum]; auto const pSector = (usectorptr_t)&sector[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) &&

View file

@ -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
} }

View file

@ -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;

View file

@ -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)