mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
git-svn-id: https://svn.eduke32.com/eduke32@1228 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
dec76c4907
commit
4ff6023244
14 changed files with 243 additions and 219 deletions
|
@ -300,6 +300,15 @@ extern char noclip;
|
||||||
|
|
||||||
EXTERN int32_t editorzrange[2];
|
EXTERN int32_t editorzrange[2];
|
||||||
|
|
||||||
|
static inline int32_t getrendermode(void)
|
||||||
|
{
|
||||||
|
#ifndef POLYMOST
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
return rendmode;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
POSITION VARIABLES:
|
POSITION VARIABLES:
|
||||||
|
|
||||||
|
@ -498,8 +507,6 @@ typedef struct s_equation {
|
||||||
typedef struct s_point2d {
|
typedef struct s_point2d {
|
||||||
float x, y;
|
float x, y;
|
||||||
} _point2d;
|
} _point2d;
|
||||||
_equation equation(float x1, float y1, float x2, float y2);
|
|
||||||
int32_t sameside(_equation* eq, _point2d* p1, _point2d* p2);
|
|
||||||
int32_t wallvisible(int16_t wallnum);
|
int32_t wallvisible(int16_t wallnum);
|
||||||
|
|
||||||
#define STATUS2DSIZ 144
|
#define STATUS2DSIZ 144
|
||||||
|
|
|
@ -5043,7 +5043,7 @@ static void dorotatesprite(int32_t sx, int32_t sy, int32_t z, int16_t a, int16_t
|
||||||
//
|
//
|
||||||
// initksqrt (internal)
|
// initksqrt (internal)
|
||||||
//
|
//
|
||||||
static void initksqrt(void)
|
static inline void initksqrt(void)
|
||||||
{
|
{
|
||||||
int32_t i, j, k;
|
int32_t i, j, k;
|
||||||
|
|
||||||
|
@ -5101,7 +5101,7 @@ static void dosetaspect(void)
|
||||||
//
|
//
|
||||||
// loadtables (internal)
|
// loadtables (internal)
|
||||||
//
|
//
|
||||||
static void calcbritable(void)
|
static inline void calcbritable(void)
|
||||||
{
|
{
|
||||||
int32_t i,j;
|
int32_t i,j;
|
||||||
double a,b;
|
double a,b;
|
||||||
|
@ -5382,7 +5382,7 @@ static int32_t deletespritestat(int16_t deleteme)
|
||||||
//
|
//
|
||||||
// lintersect (internal)
|
// lintersect (internal)
|
||||||
//
|
//
|
||||||
static int32_t lintersect(int32_t x1, int32_t y1, int32_t z1, int32_t x2, int32_t y2, int32_t z2, int32_t x3,
|
static inline int32_t lintersect(int32_t x1, int32_t y1, int32_t z1, int32_t x2, int32_t y2, int32_t z2, int32_t x3,
|
||||||
int32_t y3, int32_t x4, int32_t y4, int32_t *intx, int32_t *inty, int32_t *intz)
|
int32_t y3, int32_t x4, int32_t y4, int32_t *intx, int32_t *inty, int32_t *intz)
|
||||||
{
|
{
|
||||||
//p1 to p2 is a line segment
|
//p1 to p2 is a line segment
|
||||||
|
@ -5415,7 +5415,7 @@ static int32_t lintersect(int32_t x1, int32_t y1, int32_t z1, int32_t x2, int32_
|
||||||
//
|
//
|
||||||
// rintersect (internal)
|
// rintersect (internal)
|
||||||
//
|
//
|
||||||
static int32_t rintersect(int32_t x1, int32_t y1, int32_t z1, int32_t vx, int32_t vy, int32_t vz, int32_t x3,
|
static inline int32_t rintersect(int32_t x1, int32_t y1, int32_t z1, int32_t vx, int32_t vy, int32_t vz, int32_t x3,
|
||||||
int32_t y3, int32_t x4, int32_t y4, int32_t *intx, int32_t *inty, int32_t *intz)
|
int32_t y3, int32_t x4, int32_t y4, int32_t *intx, int32_t *inty, int32_t *intz)
|
||||||
{
|
{
|
||||||
//p1 towards p2 is a ray
|
//p1 towards p2 is a ray
|
||||||
|
@ -5447,7 +5447,7 @@ static int32_t rintersect(int32_t x1, int32_t y1, int32_t z1, int32_t vx, int32_
|
||||||
//
|
//
|
||||||
// keepaway (internal)
|
// keepaway (internal)
|
||||||
//
|
//
|
||||||
static void keepaway(int32_t *x, int32_t *y, int32_t w)
|
static inline void keepaway(int32_t *x, int32_t *y, int32_t w)
|
||||||
{
|
{
|
||||||
int32_t dx, dy, ox, oy, x1, y1;
|
int32_t dx, dy, ox, oy, x1, y1;
|
||||||
char first;
|
char first;
|
||||||
|
@ -5468,7 +5468,7 @@ static void keepaway(int32_t *x, int32_t *y, int32_t w)
|
||||||
//
|
//
|
||||||
// raytrace (internal)
|
// raytrace (internal)
|
||||||
//
|
//
|
||||||
static int32_t raytrace(int32_t x3, int32_t y3, int32_t *x4, int32_t *y4)
|
static inline int32_t raytrace(int32_t x3, int32_t y3, int32_t *x4, int32_t *y4)
|
||||||
{
|
{
|
||||||
int32_t x1, y1, x2, y2, bot, topu, nintx, ninty, cnt, z, hitwall;
|
int32_t x1, y1, x2, y2, bot, topu, nintx, ninty, cnt, z, hitwall;
|
||||||
int32_t x21, y21, x43, y43;
|
int32_t x21, y21, x43, y43;
|
||||||
|
@ -5950,7 +5950,7 @@ typedef struct s_maskleaf
|
||||||
_maskleaf maskleaves[MAXWALLSB];
|
_maskleaf maskleaves[MAXWALLSB];
|
||||||
|
|
||||||
// returns equation of a line given two points
|
// returns equation of a line given two points
|
||||||
_equation equation(float x1, float y1, float x2, float y2)
|
static inline _equation equation(float x1, float y1, float x2, float y2)
|
||||||
{
|
{
|
||||||
_equation ret;
|
_equation ret;
|
||||||
|
|
||||||
|
@ -5990,7 +5990,7 @@ int32_t wallvisible(int16_t wallnum)
|
||||||
else
|
else
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
// returns the intersection point between two lines
|
// returns the intersection point between two lines
|
||||||
_point2d intersection(_equation eq1, _equation eq2)
|
_point2d intersection(_equation eq1, _equation eq2)
|
||||||
{
|
{
|
||||||
|
@ -6037,7 +6037,7 @@ int32_t wallobstructswall(_maskleaf* wall1, _maskleaf* wall2)
|
||||||
}
|
}
|
||||||
|
|
||||||
// recursive mask drawing function
|
// recursive mask drawing function
|
||||||
void drawmaskleaf(_maskleaf* wall)
|
static inline void drawmaskleaf(_maskleaf* wall)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
|
@ -6056,8 +6056,9 @@ void drawmaskleaf(_maskleaf* wall)
|
||||||
//OSD_Printf("Drawing mask %i\n", wall->index);
|
//OSD_Printf("Drawing mask %i\n", wall->index);
|
||||||
drawmaskwall(wall->index);
|
drawmaskwall(wall->index);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
int32_t sameside(_equation* eq, _point2d* p1, _point2d* p2)
|
static inline int32_t sameside(_equation* eq, _point2d* p1, _point2d* p2)
|
||||||
{
|
{
|
||||||
float sign1, sign2;
|
float sign1, sign2;
|
||||||
|
|
||||||
|
@ -7121,7 +7122,7 @@ static void convertv6sprv7(struct spritetypev6 *from, spritetype *to)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Powerslave uses v6
|
// Powerslave uses v6
|
||||||
// Witchaven 1 and TekWar use v5
|
// Witchaven 1 and TekWar and LameDuke use v5
|
||||||
int32_t loadoldboard(char *filename, char fromwhere, int32_t *daposx, int32_t *daposy, int32_t *daposz,
|
int32_t loadoldboard(char *filename, char fromwhere, int32_t *daposx, int32_t *daposy, int32_t *daposz,
|
||||||
int16_t *daang, int16_t *dacursectnum)
|
int16_t *daang, int16_t *dacursectnum)
|
||||||
{
|
{
|
||||||
|
@ -12029,19 +12030,6 @@ int32_t setrendermode(int32_t renderer)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// getrendermode
|
|
||||||
//
|
|
||||||
int32_t getrendermode(void)
|
|
||||||
{
|
|
||||||
#ifndef POLYMOST
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
return rendmode;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// setrollangle
|
// setrollangle
|
||||||
//
|
//
|
||||||
|
|
|
@ -2236,6 +2236,44 @@ static void G_MoveWeapons(void)
|
||||||
// if( g_sounds[WIERDSHOT_FLY].num == 0 )
|
// if( g_sounds[WIERDSHOT_FLY].num == 0 )
|
||||||
// A_PlaySound(WIERDSHOT_FLY,i);
|
// A_PlaySound(WIERDSHOT_FLY,i);
|
||||||
|
|
||||||
|
if (ActorExtra[i].projectile.workslike & PROJECTILE_BOUNCESOFFWALLS)
|
||||||
|
{
|
||||||
|
/* if(s->yvel < 1 || s->extra < 2 || (s->xvel|s->zvel) == 0)
|
||||||
|
Did this cause the bug with prematurely exploding projectiles? */
|
||||||
|
if (s->yvel < 1)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (ActorExtra[i].projectile.spawns >= 0)
|
||||||
|
{
|
||||||
|
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
||||||
|
|
||||||
|
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
||||||
|
/*
|
||||||
|
sprite[k].x = dax;
|
||||||
|
sprite[k].y = day;
|
||||||
|
sprite[k].z = daz;
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (ActorExtra[i].projectile.sxrepeat > 4)
|
||||||
|
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
||||||
|
if (ActorExtra[i].projectile.syrepeat > 4)
|
||||||
|
sprite[k].yrepeat=ActorExtra[i].projectile.syrepeat;
|
||||||
|
}
|
||||||
|
if (ActorExtra[i].projectile.isound >= 0)
|
||||||
|
A_PlaySound(ActorExtra[i].projectile.isound,i);
|
||||||
|
|
||||||
|
s->extra=ActorExtra[i].projectile.extra;
|
||||||
|
|
||||||
|
if (ActorExtra[i].projectile.extra_rand > 0)
|
||||||
|
s->extra += (krand()&ActorExtra[i].projectile.extra_rand);
|
||||||
|
|
||||||
|
x = s->extra;
|
||||||
|
A_RadiusDamage(i,ActorExtra[i].projectile.hitradius, x>>2,x>>1,x-(x>>2),x);
|
||||||
|
|
||||||
|
KILLIT(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
p = -1;
|
p = -1;
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.workslike & PROJECTILE_COOLEXPLOSION1)
|
if (ActorExtra[i].projectile.workslike & PROJECTILE_COOLEXPLOSION1)
|
||||||
|
@ -2261,11 +2299,6 @@ static void G_MoveWeapons(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
Bmemcpy(&davect,s,sizeof(vec3_t));
|
Bmemcpy(&davect,s,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
dax = s->x;
|
|
||||||
day = s->y;
|
|
||||||
daz = s->z;
|
|
||||||
*/
|
|
||||||
|
|
||||||
A_GetZLimits(i);
|
A_GetZLimits(i);
|
||||||
qq = CLIPMASK1;
|
qq = CLIPMASK1;
|
||||||
|
@ -2326,11 +2359,6 @@ static void G_MoveWeapons(void)
|
||||||
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
||||||
|
|
||||||
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
sprite[k].x = dax;
|
|
||||||
sprite[k].y = day;
|
|
||||||
sprite[k].z = daz;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.sxrepeat > 4)
|
if (ActorExtra[i].projectile.sxrepeat > 4)
|
||||||
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
||||||
|
@ -2352,45 +2380,6 @@ static void G_MoveWeapons(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.workslike & PROJECTILE_BOUNCESOFFWALLS)
|
|
||||||
{
|
|
||||||
/* if(s->yvel < 1 || s->extra < 2 || (s->xvel|s->zvel) == 0)
|
|
||||||
Did this cause the bug with prematurely exploding projectiles? */
|
|
||||||
if (s->yvel < 1)
|
|
||||||
{
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.spawns >= 0)
|
|
||||||
{
|
|
||||||
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
|
||||||
|
|
||||||
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
|
||||||
/*
|
|
||||||
sprite[k].x = dax;
|
|
||||||
sprite[k].y = day;
|
|
||||||
sprite[k].z = daz;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.sxrepeat > 4)
|
|
||||||
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
|
||||||
if (ActorExtra[i].projectile.syrepeat > 4)
|
|
||||||
sprite[k].yrepeat=ActorExtra[i].projectile.syrepeat;
|
|
||||||
}
|
|
||||||
if (ActorExtra[i].projectile.isound >= 0)
|
|
||||||
A_PlaySound(ActorExtra[i].projectile.isound,i);
|
|
||||||
|
|
||||||
s->extra=ActorExtra[i].projectile.extra;
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.extra_rand > 0)
|
|
||||||
s->extra += (krand()&ActorExtra[i].projectile.extra_rand);
|
|
||||||
|
|
||||||
x = s->extra;
|
|
||||||
A_RadiusDamage(i,ActorExtra[i].projectile.hitradius, x>>2,x>>1,x-(x>>2),x);
|
|
||||||
|
|
||||||
KILLIT(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((j&49152) != 49152)
|
if ((j&49152) != 49152)
|
||||||
if (!(ActorExtra[i].projectile.workslike & PROJECTILE_BOUNCESOFFWALLS))
|
if (!(ActorExtra[i].projectile.workslike & PROJECTILE_BOUNCESOFFWALLS))
|
||||||
{
|
{
|
||||||
|
@ -2483,11 +2472,6 @@ static void G_MoveWeapons(void)
|
||||||
{
|
{
|
||||||
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
||||||
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
sprite[k].x = dax;
|
|
||||||
sprite[k].y = day;
|
|
||||||
sprite[k].z = daz;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.sxrepeat > 4)
|
if (ActorExtra[i].projectile.sxrepeat > 4)
|
||||||
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
||||||
|
@ -2582,11 +2566,6 @@ static void G_MoveWeapons(void)
|
||||||
{
|
{
|
||||||
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
k = A_Spawn(i,ActorExtra[i].projectile.spawns);
|
||||||
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
sprite[k].x = dax;
|
|
||||||
sprite[k].y = day;
|
|
||||||
sprite[k].z = daz;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (ActorExtra[i].projectile.sxrepeat > 4)
|
if (ActorExtra[i].projectile.sxrepeat > 4)
|
||||||
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
sprite[k].xrepeat=ActorExtra[i].projectile.sxrepeat;
|
||||||
|
@ -2696,11 +2675,6 @@ static void G_MoveWeapons(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
Bmemcpy(&davect,s,sizeof(vec3_t));
|
Bmemcpy(&davect,s,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
dax = s->x;
|
|
||||||
day = s->y;
|
|
||||||
daz = s->z;
|
|
||||||
*/
|
|
||||||
|
|
||||||
A_GetZLimits(i);
|
A_GetZLimits(i);
|
||||||
qq = CLIPMASK1;
|
qq = CLIPMASK1;
|
||||||
|
@ -2892,11 +2866,6 @@ static void G_MoveWeapons(void)
|
||||||
{
|
{
|
||||||
k = A_Spawn(i,EXPLOSION2);
|
k = A_Spawn(i,EXPLOSION2);
|
||||||
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
Bmemcpy(&sprite[k],&davect,sizeof(vec3_t));
|
||||||
/*
|
|
||||||
sprite[k].x = dax;
|
|
||||||
sprite[k].y = day;
|
|
||||||
sprite[k].z = daz;
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (s->xrepeat < 10)
|
if (s->xrepeat < 10)
|
||||||
{
|
{
|
||||||
|
|
|
@ -8628,9 +8628,9 @@ int32_t ExtInit(void)
|
||||||
{
|
{
|
||||||
int32_t i;
|
int32_t i;
|
||||||
#if 1
|
#if 1
|
||||||
i=wm_ynbox("Texture Caching",
|
i=wm_ynbox("Texture Cache",
|
||||||
"Would you like to enable the on-disk texture cache?\n\n"
|
"Would you like to enable the on-disk texture cache?\n\n"
|
||||||
"You will generally want to say 'yes' here, especially if using the HRP.");
|
"You generally want to say 'yes' here, especially if using the HRP.");
|
||||||
#else
|
#else
|
||||||
i = 1;
|
i = 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -4577,6 +4577,8 @@ static void G_DumpDebugInfo(void)
|
||||||
{
|
{
|
||||||
int32_t i,j,x;
|
int32_t i,j,x;
|
||||||
// FILE * fp=fopen("condebug.log","w");
|
// FILE * fp=fopen("condebug.log","w");
|
||||||
|
|
||||||
|
OSD_Printf("Current gamevar values:\n");
|
||||||
for (i=0;i<MAX_WEAPONS;i++)
|
for (i=0;i<MAX_WEAPONS;i++)
|
||||||
{
|
{
|
||||||
for (j=0;j<numplayers;j++)
|
for (j=0;j<numplayers;j++)
|
||||||
|
@ -6953,12 +6955,14 @@ void G_DoSpriteAnimations(int32_t x,int32_t y,int32_t a,int32_t smoothratio)
|
||||||
case RPG__STATIC:
|
case RPG__STATIC:
|
||||||
|
|
||||||
#if defined(POLYMOST) && defined(USE_OPENGL)
|
#if defined(POLYMOST) && defined(USE_OPENGL)
|
||||||
if (getrendermode() >= 3 && usemodels && md_tilehasmodel(t->picnum,t->pal) >= 0 && !(spriteext[i].flags&SPREXT_NOTMD))
|
if (getrendermode() >= 3 && usemodels && md_tilehasmodel(t->picnum,t->pal) >= 0 &&
|
||||||
|
!(spriteext[i].flags & SPREXT_NOTMD))
|
||||||
{
|
{
|
||||||
int32_t v=getangle(t->xvel,t->zvel>>4);
|
int32_t v = getangle(t->xvel, t->zvel>>4);
|
||||||
if (v>1023)v-=2048;
|
|
||||||
spriteext[i].pitch=v;
|
|
||||||
|
|
||||||
|
if (v > 1023)
|
||||||
|
v -= 2048;
|
||||||
|
spriteext[i].pitch = v;
|
||||||
t->cstat &= ~4;
|
t->cstat &= ~4;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -9759,7 +9763,7 @@ static void G_CheckCommandLine(int32_t argc, const char **argv)
|
||||||
g_noMusic = 1;
|
g_noMusic = 1;
|
||||||
initprintf("Music off.\n");
|
initprintf("Music off.\n");
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
else if (*c == 'd' || *c == 'D')
|
else if (*c == 'd' || *c == 'D')
|
||||||
{
|
{
|
||||||
FILE * fp=fopen("gamevars.txt","w");
|
FILE * fp=fopen("gamevars.txt","w");
|
||||||
|
@ -9768,7 +9772,7 @@ static void G_CheckCommandLine(int32_t argc, const char **argv)
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
initprintf("Game variables saved to gamevars.txt.\n");
|
initprintf("Game variables saved to gamevars.txt.\n");
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
G_ShowParameterHelp();
|
G_ShowParameterHelp();
|
||||||
|
@ -10891,9 +10895,9 @@ void app_main(int32_t argc,const char **argv)
|
||||||
#if defined(POLYMOST) && defined(USE_OPENGL)
|
#if defined(POLYMOST) && defined(USE_OPENGL)
|
||||||
if (glusetexcache == -1 || glusetexcachecompression == -1)
|
if (glusetexcache == -1 || glusetexcachecompression == -1)
|
||||||
{
|
{
|
||||||
i=wm_ynbox("Texture Caching",
|
i=wm_ynbox("Texture Cache",
|
||||||
"Would you like to enable the on-disk texture cache?\n\n"
|
"Would you like to enable the on-disk texture cache?\n\n"
|
||||||
"You will generally want to say 'yes' here, especially if using the HRP.");
|
"You generally want to say 'yes' here, especially if using the HRP.");
|
||||||
if (i) ud.config.useprecache = glusetexcompr = glusetexcache = glusetexcachecompression = 1;
|
if (i) ud.config.useprecache = glusetexcompr = glusetexcache = glusetexcachecompression = 1;
|
||||||
else glusetexcache = glusetexcachecompression = 0;
|
else glusetexcache = glusetexcachecompression = 0;
|
||||||
}
|
}
|
||||||
|
@ -10938,12 +10942,6 @@ void app_main(int32_t argc,const char **argv)
|
||||||
|
|
||||||
if (!ShellExecuteExA(&sinfo))
|
if (!ShellExecuteExA(&sinfo))
|
||||||
initprintf("update: error launching browser!\n");
|
initprintf("update: error launching browser!\n");
|
||||||
/*
|
|
||||||
CONFIG_SetupMouse();
|
|
||||||
CONFIG_SetupJoystick();
|
|
||||||
CONFIG_WriteSetup();
|
|
||||||
G_GameExit(" ");
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else initprintf("... no updates available\n");
|
else initprintf("... no updates available\n");
|
||||||
|
|
|
@ -38,6 +38,7 @@ char g_szBuf[1024];
|
||||||
|
|
||||||
intptr_t *g_caseScriptPtr=NULL; // the pointer to the start of the case table in a switch statement
|
intptr_t *g_caseScriptPtr=NULL; // the pointer to the start of the case table in a switch statement
|
||||||
// first entry is 'default' code.
|
// first entry is 'default' code.
|
||||||
|
static intptr_t *previous_event=NULL;
|
||||||
static int32_t g_numCases = 0;
|
static int32_t g_numCases = 0;
|
||||||
static int32_t g_checkingSwitch = 0, g_currentEvent = -1;
|
static int32_t g_checkingSwitch = 0, g_currentEvent = -1;
|
||||||
static int32_t g_labelsOnly = 0, g_skipKeywordCheck = 0, g_dynamicTileMapping = 0;
|
static int32_t g_labelsOnly = 0, g_skipKeywordCheck = 0, g_dynamicTileMapping = 0;
|
||||||
|
@ -486,6 +487,7 @@ const char *keyw[] =
|
||||||
"ifvarvareither", // 342
|
"ifvarvareither", // 342
|
||||||
"getarraysize", // 343
|
"getarraysize", // 343
|
||||||
"savenn", // 344
|
"savenn", // 344
|
||||||
|
"copy", // 345
|
||||||
"<null>"
|
"<null>"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -2773,17 +2775,12 @@ static int32_t C_ParseCommand(void)
|
||||||
g_numCompilerErrors++;
|
g_numCompilerErrors++;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
// if event has already been declared then store previous script location
|
||||||
if (apScriptGameEvent[j])
|
if (apScriptGameEvent[j])
|
||||||
{
|
{
|
||||||
tempscrptr = g_parsingEventPtr;
|
previous_event =apScriptGameEvent[j];
|
||||||
g_parsingEventPtr = g_parsingActorPtr = 0;
|
|
||||||
C_ReportError(-1);
|
|
||||||
g_parsingEventPtr = g_parsingActorPtr = tempscrptr;
|
|
||||||
initprintf("%s:%d: warning: duplicate event `%s'.\n",g_szScriptFileName,g_lineNumber,g_szCurrentBlockName);
|
|
||||||
g_numCompilerWarnings++;
|
|
||||||
}
|
}
|
||||||
else apScriptGameEvent[j]=g_parsingEventPtr;
|
apScriptGameEvent[j]=g_parsingEventPtr;
|
||||||
|
|
||||||
g_checkingIfElse = 0;
|
g_checkingIfElse = 0;
|
||||||
|
|
||||||
|
@ -3863,6 +3860,46 @@ static int32_t C_ParseCommand(void)
|
||||||
|
|
||||||
C_GetNextValue(LABEL_DEFINE); // the number to check against...
|
C_GetNextValue(LABEL_DEFINE); // the number to check against...
|
||||||
return 0;
|
return 0;
|
||||||
|
case CON_WRITEARRAYTOFILE:
|
||||||
|
case CON_READARRAYFROMFILE:
|
||||||
|
C_GetNextLabelName();
|
||||||
|
i=GetADefID(label+(g_numLabels<<6));
|
||||||
|
if (i > (-1))
|
||||||
|
{
|
||||||
|
bitptr[(g_scriptPtr-script)>>3] &= ~(1<<((g_scriptPtr-script)&7));
|
||||||
|
*g_scriptPtr++=i;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
C_ReportError(ERROR_NOTAGAMEARRAY);
|
||||||
|
C_GetNextValue(LABEL_DEFINE);
|
||||||
|
return 0;
|
||||||
|
case CON_COPY:
|
||||||
|
C_GetNextLabelName();
|
||||||
|
i=GetADefID(label+(g_numLabels<<6));
|
||||||
|
if (i > (-1))
|
||||||
|
{
|
||||||
|
bitptr[(g_scriptPtr-script)>>3] &= ~(1<<((g_scriptPtr-script)&7));
|
||||||
|
*g_scriptPtr++=i;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
C_ReportError(ERROR_NOTAGAMEARRAY);
|
||||||
|
C_SkipComments();// skip comments and whitespace
|
||||||
|
if (*textptr != '[')
|
||||||
|
{
|
||||||
|
g_numCompilerErrors++;
|
||||||
|
C_ReportError(ERROR_GAMEARRAYBNO);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
textptr++;
|
||||||
|
C_GetNextVar();
|
||||||
|
C_SkipComments();// skip comments and whitespace
|
||||||
|
if (*textptr != ']')
|
||||||
|
{
|
||||||
|
g_numCompilerErrors++;
|
||||||
|
C_ReportError(ERROR_GAMEARRAYBNC);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
textptr++;
|
||||||
case CON_SETARRAY:
|
case CON_SETARRAY:
|
||||||
C_GetNextLabelName();
|
C_GetNextLabelName();
|
||||||
i=GetADefID(label+(g_numLabels<<6));
|
i=GetADefID(label+(g_numLabels<<6));
|
||||||
|
@ -3906,6 +3943,7 @@ static int32_t C_ParseCommand(void)
|
||||||
C_SkipComments();
|
C_SkipComments();
|
||||||
C_GetNextVar();
|
C_GetNextVar();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case CON_RANDVARVAR:
|
case CON_RANDVARVAR:
|
||||||
if (!C_CheckEventSync(g_currentEvent))
|
if (!C_CheckEventSync(g_currentEvent))
|
||||||
{
|
{
|
||||||
|
@ -5440,6 +5478,16 @@ repeatcase:
|
||||||
C_ReportError(ERROR_CLOSEBRACKET);
|
C_ReportError(ERROR_CLOSEBRACKET);
|
||||||
g_numCompilerErrors++;
|
g_numCompilerErrors++;
|
||||||
}
|
}
|
||||||
|
// if event has already been declared then put a jump in instead
|
||||||
|
if (previous_event)
|
||||||
|
{
|
||||||
|
g_scriptPtr--;
|
||||||
|
*(g_scriptPtr++) = CON_JUMP;
|
||||||
|
*(g_scriptPtr++) = MAXGAMEVARS;
|
||||||
|
*(g_scriptPtr++) = previous_event-script;
|
||||||
|
*(g_scriptPtr++) = CON_ENDEVENT;
|
||||||
|
previous_event = NULL;
|
||||||
|
}
|
||||||
g_parsingEventPtr = 0;
|
g_parsingEventPtr = 0;
|
||||||
g_parsingActorPtr = 0;
|
g_parsingActorPtr = 0;
|
||||||
g_currentEvent = -1;
|
g_currentEvent = -1;
|
||||||
|
@ -5622,45 +5670,6 @@ repeatcase:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
#define NUM_DEFAULT_CONS 4
|
|
||||||
static const char *defaultcons[NUM_DEFAULT_CONS] =
|
|
||||||
{
|
|
||||||
"EDUKE.CON",
|
|
||||||
"GAME.CON",
|
|
||||||
"USER.CON",
|
|
||||||
"DEFS.CON"
|
|
||||||
};
|
|
||||||
|
|
||||||
void copydefaultcons(void)
|
|
||||||
{
|
|
||||||
int32_t i, fs, fpi;
|
|
||||||
FILE *fpo;
|
|
||||||
|
|
||||||
for (i=0;i<NUM_DEFAULT_CONS;i++)
|
|
||||||
{
|
|
||||||
fpi = kopen4loadfrommod((char *)defaultcons[i] , 1);
|
|
||||||
if (fpi < 0) continue;
|
|
||||||
|
|
||||||
fpo = fopenfrompath((char *)defaultcons[i],"wb");
|
|
||||||
|
|
||||||
if (fpo == NULL)
|
|
||||||
{
|
|
||||||
kclose(fpi);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
fs = kfilelength(fpi);
|
|
||||||
|
|
||||||
kread(fpi,&ActorExtra[0],fs);
|
|
||||||
if (fwrite(&ActorExtra[0],fs,1,fpo)==0)initprintf("Failed to restore default CONs.\n");
|
|
||||||
|
|
||||||
kclose(fpi);
|
|
||||||
fclose(fpo);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Anything added with C_AddDefinition() cannot be overwritten in the CONs */
|
/* Anything added with C_AddDefinition() cannot be overwritten in the CONs */
|
||||||
|
|
||||||
static void C_AddDefinition(const char *lLabel,int32_t lValue,int32_t lType)
|
static void C_AddDefinition(const char *lLabel,int32_t lValue,int32_t lType)
|
||||||
|
@ -5843,23 +5852,6 @@ void C_Compile(const char *filenam)
|
||||||
Gv_Init();
|
Gv_Init();
|
||||||
C_InitProjectiles();
|
C_InitProjectiles();
|
||||||
|
|
||||||
/* JBF 20040109: Don't prompt to extract CONs from GRP if they're missing.
|
|
||||||
* If someone really wants them they can Kextract them.
|
|
||||||
if(!SafeFileExists(filenam) && g_loadFromGroupOnly == 0)
|
|
||||||
{
|
|
||||||
initprintf("Missing external CON file(s).\n");
|
|
||||||
initprintf("COPY INTERNAL DEFAULTS TO DIRECTORY(Y/n)?\n");
|
|
||||||
|
|
||||||
i=wm_ynbox("Missing CON file(s)", "Missing external CON file(s). "
|
|
||||||
"Copy internal defaults to directory?");
|
|
||||||
if (i) i = 'y';
|
|
||||||
if(i == 'y' || i == 'Y')
|
|
||||||
{
|
|
||||||
initprintf(" Yes\n");
|
|
||||||
copydefaultcons();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
fp = kopen4loadfrommod((char *)filenam,g_loadFromGroupOnly);
|
fp = kopen4loadfrommod((char *)filenam,g_loadFromGroupOnly);
|
||||||
if (fp == -1) // JBF: was 0
|
if (fp == -1) // JBF: was 0
|
||||||
{
|
{
|
||||||
|
|
|
@ -900,6 +900,7 @@ enum ScriptKeywords_t
|
||||||
CON_IFVARVAREITHER, // 342
|
CON_IFVARVAREITHER, // 342
|
||||||
CON_GETARRAYSIZE, // 343
|
CON_GETARRAYSIZE, // 343
|
||||||
CON_SAVENN, // 344
|
CON_SAVENN, // 344
|
||||||
|
CON_COPY, // 345
|
||||||
CON_END
|
CON_END
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2977,10 +2977,10 @@ static int32_t X_DoExecute(void)
|
||||||
case CON_IFGAPZL:
|
case CON_IFGAPZL:
|
||||||
insptr++;
|
insptr++;
|
||||||
X_DoConditional(((ActorExtra[vm.g_i].floorz - ActorExtra[vm.g_i].ceilingz) >> 8) < *insptr);
|
X_DoConditional(((ActorExtra[vm.g_i].floorz - ActorExtra[vm.g_i].ceilingz) >> 8) < *insptr);
|
||||||
/*
|
/*
|
||||||
if (sprite[vm.g_i].sectnum == g_player[vm.g_p].ps->cursectnum)
|
if (sprite[vm.g_i].sectnum == g_player[vm.g_p].ps->cursectnum)
|
||||||
OSD_Printf("%d %d\n",ActorExtra[vm.g_i].floorz,ActorExtra[vm.g_i].ceilingz);
|
OSD_Printf("%d %d\n",ActorExtra[vm.g_i].floorz,ActorExtra[vm.g_i].ceilingz);
|
||||||
*/
|
*/
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CON_IFHITSPACE:
|
case CON_IFHITSPACE:
|
||||||
|
@ -3671,6 +3671,56 @@ static int32_t X_DoExecute(void)
|
||||||
aGameArrays[j].plValues[index]=value;
|
aGameArrays[j].plValues[index]=value;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case CON_WRITEARRAYTOFILE:
|
||||||
|
case CON_READARRAYFROMFILE:
|
||||||
|
insptr++;
|
||||||
|
{
|
||||||
|
int32_t j=*insptr++;
|
||||||
|
{
|
||||||
|
int q = *insptr++;
|
||||||
|
|
||||||
|
if (ScriptQuotes[q] == NULL)
|
||||||
|
{
|
||||||
|
OSD_Printf(CON_ERROR "null quote %d\n",g_errorLineNum,keyw[g_tw],q);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tw == CON_READARRAYFROMFILE)
|
||||||
|
{
|
||||||
|
int32_t fil = kopen4loadfrommod(ScriptQuotes[q], 0);
|
||||||
|
int32_t asize;
|
||||||
|
|
||||||
|
if (fil < 0)
|
||||||
|
break;
|
||||||
|
|
||||||
|
asize = kfilelength(fil);
|
||||||
|
|
||||||
|
if (asize > 0)
|
||||||
|
{
|
||||||
|
OSD_Printf(OSDTEXT_GREEN "CON_RESIZEARRAY: resizing array %s from %d to %d\n", aGameArrays[j].szLabel, aGameArrays[j].size, asize);
|
||||||
|
aGameArrays[j].plValues=Brealloc(aGameArrays[j].plValues, sizeof(int) * asize);
|
||||||
|
aGameArrays[j].size = asize;
|
||||||
|
}
|
||||||
|
|
||||||
|
kread(fil,aGameArrays[j].plValues,sizeof(int) * asize);
|
||||||
|
kclose(fil);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FILE *fil;
|
||||||
|
char temp[BMAX_PATH];
|
||||||
|
if (mod_dir[0] != '/')
|
||||||
|
Bsprintf(temp,"%s/%s",mod_dir,ScriptQuotes[q]);
|
||||||
|
else Bsprintf(temp,"%s",ScriptQuotes[q]);
|
||||||
|
if ((fil = fopen(temp,"wb")) == 0) break;
|
||||||
|
|
||||||
|
fwrite(aGameArrays[j].plValues,1,sizeof(int) * aGameArrays[j].size,fil);
|
||||||
|
fclose(fil);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
case CON_GETARRAYSIZE:
|
case CON_GETARRAYSIZE:
|
||||||
insptr++;
|
insptr++;
|
||||||
{
|
{
|
||||||
|
@ -3693,6 +3743,24 @@ static int32_t X_DoExecute(void)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case CON_COPY:
|
||||||
|
insptr++;
|
||||||
|
{
|
||||||
|
int32_t j=*insptr++;
|
||||||
|
{
|
||||||
|
int32_t index = Gv_GetVar(*insptr++, vm.g_i, vm.g_p);
|
||||||
|
int32_t j1=*insptr++;
|
||||||
|
int32_t index1 = Gv_GetVar(*insptr++, vm.g_i, vm.g_p);
|
||||||
|
int32_t value = Gv_GetVar(*insptr++, vm.g_i, vm.g_p);
|
||||||
|
if (index>aGameArrays[j].size) break;
|
||||||
|
if (index1>aGameArrays[j1].size) break;
|
||||||
|
if ((index+value)>aGameArrays[j].size) value=aGameArrays[j].size-index;
|
||||||
|
if ((index1+value)>aGameArrays[j1].size) value=aGameArrays[j1].size-index1;
|
||||||
|
memcpy(aGameArrays[j1].plValues+index1,aGameArrays[j].plValues+index,value*sizeof(int));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
case CON_RANDVAR:
|
case CON_RANDVAR:
|
||||||
insptr++;
|
insptr++;
|
||||||
Gv_SetVarX(*insptr, mulscale16(krand(), *(insptr+1)+1));
|
Gv_SetVarX(*insptr, mulscale16(krand(), *(insptr+1)+1));
|
||||||
|
|
|
@ -565,6 +565,7 @@ int32_t __fastcall Gv_GetVar(int32_t id, int32_t iActor, int32_t iPlayer)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
label = Gv_GetVar(*insptr++, index, iPlayer);
|
label = Gv_GetVar(*insptr++, index, iPlayer);
|
||||||
|
// OSD_Printf("actorvar returned %d\n",label);
|
||||||
}
|
}
|
||||||
else label = *insptr++;
|
else label = *insptr++;
|
||||||
|
|
||||||
|
@ -777,7 +778,7 @@ int32_t __fastcall Gv_GetVarX(int32_t id)
|
||||||
OSD_Printf(CON_ERROR "Gv_GetVar(): invalid array index\n",g_errorLineNum,keyw[g_tw]);
|
OSD_Printf(CON_ERROR "Gv_GetVar(): invalid array index\n",g_errorLineNum,keyw[g_tw]);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
label = Gv_GetVarX(*insptr++);
|
label = Gv_GetVar(*insptr++, index, vm.g_p);
|
||||||
}
|
}
|
||||||
else label = *insptr++;
|
else label = *insptr++;
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ Modifications for JonoF's port by Jonathon Fowler (jonof@edgenetwk.com)
|
||||||
#define NumberOfBuffers 16
|
#define NumberOfBuffers 16
|
||||||
#define TotalBufferSize ( MixBufferSize * NumberOfBuffers )
|
#define TotalBufferSize ( MixBufferSize * NumberOfBuffers )
|
||||||
|
|
||||||
#define PI 3.1415926536
|
#define PI 3.14159265358979323
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
|
|
|
@ -57,7 +57,7 @@ LONG MiniDumper::TopLevelFilter( struct _EXCEPTION_POINTERS *pExceptionInfo )
|
||||||
/*if (!GetTempPath( _MAX_PATH, szDumpPath ))
|
/*if (!GetTempPath( _MAX_PATH, szDumpPath ))
|
||||||
_tcscpy( szDumpPath, "c:\\temp\\" );
|
_tcscpy( szDumpPath, "c:\\temp\\" );
|
||||||
*/
|
*/
|
||||||
Bsprintf(szDumpPath,"%s_%u",m_szAppName,timeGetTime());
|
sprintf(szDumpPath,"%s_%u",m_szAppName,timeGetTime());
|
||||||
_tcscat( szDumpPath, ".dmp" );
|
_tcscat( szDumpPath, ".dmp" );
|
||||||
|
|
||||||
// ask the user if they want to save a dump file
|
// ask the user if they want to save a dump file
|
||||||
|
@ -79,20 +79,20 @@ LONG MiniDumper::TopLevelFilter( struct _EXCEPTION_POINTERS *pExceptionInfo )
|
||||||
BOOL bOK = pDump( GetCurrentProcess(), GetCurrentProcessId(), hFile, MiniDumpNormal, &ExInfo, NULL, NULL );
|
BOOL bOK = pDump( GetCurrentProcess(), GetCurrentProcessId(), hFile, MiniDumpNormal, &ExInfo, NULL, NULL );
|
||||||
if (bOK)
|
if (bOK)
|
||||||
{
|
{
|
||||||
Bsprintf( szScratch, "Saved dump file to '%s'", szDumpPath );
|
sprintf( szScratch, "Saved dump file to '%s'", szDumpPath );
|
||||||
szResult = szScratch;
|
szResult = szScratch;
|
||||||
retval = EXCEPTION_EXECUTE_HANDLER;
|
retval = EXCEPTION_EXECUTE_HANDLER;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Bsprintf( szScratch, "Failed to save dump file to '%s' (error %d)", szDumpPath, GetLastError() );
|
sprintf( szScratch, "Failed to save dump file to '%s' (error %d)", szDumpPath, GetLastError() );
|
||||||
szResult = szScratch;
|
szResult = szScratch;
|
||||||
}
|
}
|
||||||
::CloseHandle(hFile);
|
::CloseHandle(hFile);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Bsprintf( szScratch, "Failed to create dump file '%s' (error %d)", szDumpPath, GetLastError() );
|
sprintf( szScratch, "Failed to create dump file '%s' (error %d)", szDumpPath, GetLastError() );
|
||||||
szResult = szScratch;
|
szResult = szScratch;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ static int32_t g_whichPalForPlayer = 9;
|
||||||
int32_t g_numRealPalettes;
|
int32_t g_numRealPalettes;
|
||||||
int16_t SpriteCacheList[MAXTILES][3];
|
int16_t SpriteCacheList[MAXTILES][3];
|
||||||
|
|
||||||
static char precachehightile[2][MAXTILES>>3];
|
static uint8_t precachehightile[2][MAXTILES>>3];
|
||||||
static int32_t g_precacheCount;
|
static int32_t g_precacheCount;
|
||||||
|
|
||||||
extern char *duke3dgrpstring;
|
extern char *duke3dgrpstring;
|
||||||
|
@ -378,17 +378,17 @@ static void G_DoLoadScreen(char *statustext, int32_t percent)
|
||||||
{
|
{
|
||||||
int32_t ii = scale(288,percent,100);
|
int32_t ii = scale(288,percent,100);
|
||||||
int32_t x = 32;
|
int32_t x = 32;
|
||||||
/*
|
/*
|
||||||
j = usehightile;
|
j = usehightile;
|
||||||
usehightile = 0;
|
usehightile = 0;
|
||||||
*/
|
*/
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
rotatesprite(x<<16,140<<16,49152,0,NOTCHON,0,2,2+8+16,0,0,xdim-1,ydim-1);
|
rotatesprite(x<<16,140<<16,49152,0,NOTCHON,0,2,2+8+16,0,0,xdim-1,ydim-1);
|
||||||
x++;
|
x++;
|
||||||
}
|
}
|
||||||
while (x < ii);
|
while (x < ii);
|
||||||
/* usehightile = j;*/
|
/* usehightile = j;*/
|
||||||
}
|
}
|
||||||
X_OnEvent(EVENT_DISPLAYLOADINGSCREEN, g_player[screenpeek].ps->i, screenpeek, -1);
|
X_OnEvent(EVENT_DISPLAYLOADINGSCREEN, g_player[screenpeek].ps->i, screenpeek, -1);
|
||||||
nextpage();
|
nextpage();
|
||||||
|
|
Loading…
Reference in a new issue