mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
crude demo fast-forward/rewind; more m32script goodness
git-svn-id: https://svn.eduke32.com/eduke32@1536 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
9a39896b82
commit
d6f525b44b
9 changed files with 302 additions and 73 deletions
|
@ -3,10 +3,14 @@
|
||||||
|
|
||||||
include names.h
|
include names.h
|
||||||
|
|
||||||
gamevar i 0 1 // per-block (top-level, event, or state) variable
|
// flag 1: per-block (top-level, event, or state) variable
|
||||||
|
gamevar i 0 1
|
||||||
gamevar j 0 1
|
gamevar j 0 1
|
||||||
gamevar k 0 1
|
gamevar k 0 1
|
||||||
gamevar l 0 1
|
gamevar l 0 1
|
||||||
|
gamevar m 0 1
|
||||||
|
gamevar p 0 1
|
||||||
|
gamevar q 0 1
|
||||||
|
|
||||||
gamevar tmp 0 0
|
gamevar tmp 0 0
|
||||||
|
|
||||||
|
@ -243,18 +247,6 @@ onevent EVENT_ENTER3DMODE
|
||||||
state setas
|
state setas
|
||||||
endevent
|
endevent
|
||||||
|
|
||||||
onevent EVENT_ANALYZESPRITES
|
|
||||||
for i drawnsprites
|
|
||||||
{
|
|
||||||
set j tsprite[i].owner
|
|
||||||
switch sprite[j].picnum
|
|
||||||
case LIZTROOP spritepal 1 break
|
|
||||||
case PIGCOP spritepal 2 break
|
|
||||||
case BOSS1 spritepal 6 break
|
|
||||||
endswitch
|
|
||||||
}
|
|
||||||
endevent
|
|
||||||
|
|
||||||
defstate cmp_by_lotag
|
defstate cmp_by_lotag
|
||||||
set RETURN sprite[SV2].lotag
|
set RETURN sprite[SV2].lotag
|
||||||
sub RETURN sprite[SV1].lotag
|
sub RETURN sprite[SV1].lotag
|
||||||
|
@ -290,7 +282,7 @@ onevent EVENT_DRAW2DSCREEN
|
||||||
set drawlinepat -1
|
set drawlinepat -1
|
||||||
for i allsprites
|
for i allsprites
|
||||||
ifactor LIZTROOP
|
ifactor LIZTROOP
|
||||||
drawcircle16b sprite[i].x sprite[i].y 256 9
|
drawcircle16b sprite[i].x sprite[i].y 256 drawcol
|
||||||
*/
|
*/
|
||||||
endevent
|
endevent
|
||||||
|
|
||||||
|
@ -310,6 +302,73 @@ onevent EVENT_INSERTSPRITE2D
|
||||||
}
|
}
|
||||||
endevent
|
endevent
|
||||||
|
|
||||||
|
// rotates and duplicates selected sprites around
|
||||||
|
// pivot sprite (extra=123, ang:dang, yrepeat<<5:dz (pos. if pal!=0), lo:cnt)
|
||||||
|
defstate duprot
|
||||||
|
ifn searchstat 3 return
|
||||||
|
ifn sprite[searchwall].extra 123 return
|
||||||
|
ifl sprite[searchwall].shade 1 return
|
||||||
|
set k searchwall
|
||||||
|
|
||||||
|
for i range sprite[k].shade
|
||||||
|
{
|
||||||
|
for j selsprites, ifn j k
|
||||||
|
{
|
||||||
|
dupsprite j
|
||||||
|
set tmp i, add tmp 1, mul tmp sprite[k].ang
|
||||||
|
rotatepoint sprite[k].x sprite[k].y .x .y tmp (l m)
|
||||||
|
add .ang tmp
|
||||||
|
set tmp i, add tmp 1, mul tmp sprite[k].yrepeat, shiftl tmp 5
|
||||||
|
ife sprite[k].pal 0 inv tmp
|
||||||
|
add tmp .z
|
||||||
|
bsetsprite I l m tmp
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ends
|
||||||
|
|
||||||
|
// same as above but with tsprite[], as a kind of preview
|
||||||
|
defstate tduprot
|
||||||
|
ifn searchstat 3 return
|
||||||
|
ifn sprite[searchwall].extra 123 return
|
||||||
|
ifl sprite[searchwall].shade 1 return
|
||||||
|
set k searchwall
|
||||||
|
|
||||||
|
for i range sprite[k].shade
|
||||||
|
{
|
||||||
|
for j selsprites, ifn j k
|
||||||
|
{
|
||||||
|
set p spritesortcnt
|
||||||
|
tdupsprite j
|
||||||
|
set tmp i, add tmp 1, mul tmp sprite[k].ang
|
||||||
|
rotatepoint sprite[k].x sprite[k].y tsprite[p].x tsprite[p].y tmp (l m)
|
||||||
|
add tsprite[p].ang tmp
|
||||||
|
set tmp i, add tmp 1, mul tmp sprite[k].yrepeat, shiftl tmp 5
|
||||||
|
ife sprite[k].pal 0 inv tmp
|
||||||
|
add tmp tsprite[p].z
|
||||||
|
set tsprite[p].x l
|
||||||
|
set tsprite[p].y m
|
||||||
|
set tsprite[p].z tmp
|
||||||
|
or tsprite[p].cstat 514
|
||||||
|
// bsetsprite I l m tmp
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ends
|
||||||
|
|
||||||
|
onevent EVENT_ANALYZESPRITES
|
||||||
|
state tduprot
|
||||||
|
/*
|
||||||
|
for i drawnsprites
|
||||||
|
{
|
||||||
|
set j tsprite[i].owner
|
||||||
|
switch sprite[j].picnum
|
||||||
|
case LIZTROOP spritepal 1 break
|
||||||
|
case PIGCOP spritepal 2 break
|
||||||
|
case BOSS1 spritepal 6 break
|
||||||
|
endswitch
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
endevent
|
||||||
|
|
||||||
onevent EVENT_KEYS3D
|
onevent EVENT_KEYS3D
|
||||||
// swinging doors tester -- hit space on a door wall
|
// swinging doors tester -- hit space on a door wall
|
||||||
ife searchstat 0
|
ife searchstat 0
|
||||||
|
@ -371,26 +430,33 @@ onevent EVENT_KEYS3D
|
||||||
ife searchstat 3
|
ife searchstat 3
|
||||||
ifhitkey KEY_SPACE
|
ifhitkey KEY_SPACE
|
||||||
{
|
{
|
||||||
ifn sprite[searchwall].picnum SECTOREFFECTOR return
|
ife sprite[searchwall].picnum SECTOREFFECTOR
|
||||||
set tmp 0
|
|
||||||
ife sprite[searchwall].lotag 7 set tmp 1
|
|
||||||
ife sprite[searchwall].lotag 17 set tmp 1
|
|
||||||
ife tmp 0 return
|
|
||||||
|
|
||||||
for i allsprites
|
|
||||||
{
|
{
|
||||||
ifn i searchwall, ifactor SECTOREFFECTOR, ife sprite[i].lotag sprite[searchwall].lotag
|
set tmp 0
|
||||||
ife sprite[i].hitag sprite[searchwall].hitag
|
ife sprite[searchwall].lotag 7 set tmp 1
|
||||||
|
ife sprite[searchwall].lotag 17 set tmp 1
|
||||||
|
ife tmp 0 return
|
||||||
|
|
||||||
|
for i allsprites
|
||||||
{
|
{
|
||||||
add posx sprite[i].x, sub posx sprite[searchwall].x
|
ifn i searchwall, ifactor SECTOREFFECTOR, ife sprite[i].lotag sprite[searchwall].lotag
|
||||||
add posy sprite[i].y, sub posy sprite[searchwall].y
|
ife sprite[i].hitag sprite[searchwall].hitag
|
||||||
add posz sprite[i].z, sub posz sprite[searchwall].z
|
{
|
||||||
|
add posx sprite[i].x, sub posx sprite[searchwall].x
|
||||||
|
add posy sprite[i].y, sub posy sprite[searchwall].y
|
||||||
|
add posz sprite[i].z, sub posz sprite[searchwall].z
|
||||||
|
|
||||||
updatecursectnum
|
updatecursectnum
|
||||||
|
|
||||||
return
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else ife sprite[searchwall].extra 123
|
||||||
|
{
|
||||||
|
state duprot
|
||||||
|
add sprite[searchwall].extra 1
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ifholdkey KEY_0
|
ifholdkey KEY_0
|
||||||
|
|
|
@ -1380,6 +1380,8 @@ void OSD_Draw(void)
|
||||||
// and write it to the log file
|
// and write it to the log file
|
||||||
//
|
//
|
||||||
|
|
||||||
|
extern int32_t premap_quickenterlevel;
|
||||||
|
|
||||||
static inline void linefeed(void)
|
static inline void linefeed(void)
|
||||||
{
|
{
|
||||||
Bmemmove(osdtext+osdcols, osdtext, TEXTSIZE-osdcols);
|
Bmemmove(osdtext+osdcols, osdtext, TEXTSIZE-osdcols);
|
||||||
|
@ -1397,6 +1399,8 @@ void OSD_Printf(const char *fmt, ...)
|
||||||
|
|
||||||
if (!osdinited) OSD_Init();
|
if (!osdinited) OSD_Init();
|
||||||
|
|
||||||
|
if (premap_quickenterlevel) return;
|
||||||
|
|
||||||
va_start(va, fmt);
|
va_start(va, fmt);
|
||||||
Bvsnprintf(tmpstr, 8192, fmt, va);
|
Bvsnprintf(tmpstr, 8192, fmt, va);
|
||||||
va_end(va);
|
va_end(va);
|
||||||
|
|
BIN
polymer/eduke32/m32script_ex.map
Executable file
BIN
polymer/eduke32/m32script_ex.map
Executable file
Binary file not shown.
|
@ -78,6 +78,8 @@ static int16_t g_definedsndnum[MAXSOUNDS]; // maps parse order index to g_sound
|
||||||
static int16_t g_sndnum[MAXSOUNDS]; // maps current order index to g_sounds index
|
static int16_t g_sndnum[MAXSOUNDS]; // maps current order index to g_sounds index
|
||||||
int32_t g_numsounds = 0;
|
int32_t g_numsounds = 0;
|
||||||
|
|
||||||
|
int32_t premap_quickenterlevel=0;
|
||||||
|
|
||||||
#if !defined(_WIN32)
|
#if !defined(_WIN32)
|
||||||
static int32_t usecwd = 0;
|
static int32_t usecwd = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -8116,6 +8116,8 @@ static void G_ShowScores(void)
|
||||||
|
|
||||||
#undef SCORESHEETOFFSET
|
#undef SCORESHEETOFFSET
|
||||||
|
|
||||||
|
static int32_t demo_goalreccnt=0, demo_startreccnt=0, demo_oldsoundtoggle, demo_showstats=1;
|
||||||
|
|
||||||
static void G_HandleLocalKeys(void)
|
static void G_HandleLocalKeys(void)
|
||||||
{
|
{
|
||||||
int32_t i,ch;
|
int32_t i,ch;
|
||||||
|
@ -8235,6 +8237,78 @@ static void G_HandleLocalKeys(void)
|
||||||
P_DoQuote(83+ud.scrollmode,g_player[myconnectindex].ps);
|
P_DoQuote(83+ud.scrollmode,g_player[myconnectindex].ps);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ud.recstat == 2)
|
||||||
|
{
|
||||||
|
if (KB_KeyPressed(sc_Tab))
|
||||||
|
{
|
||||||
|
KB_ClearKeyDown(sc_Tab);
|
||||||
|
demo_showstats = !demo_showstats;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (KB_KeyPressed(sc_kpad_Plus))
|
||||||
|
{
|
||||||
|
if (g_timerTicsPerSecond != 240)
|
||||||
|
{
|
||||||
|
uninittimer();
|
||||||
|
inittimer(240);
|
||||||
|
g_timerTicsPerSecond = 240;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (KB_KeyPressed(sc_kpad_Minus))
|
||||||
|
{
|
||||||
|
if (g_timerTicsPerSecond != 60)
|
||||||
|
{
|
||||||
|
uninittimer();
|
||||||
|
inittimer(60);
|
||||||
|
g_timerTicsPerSecond = 60;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (g_timerTicsPerSecond != 120)
|
||||||
|
{
|
||||||
|
uninittimer();
|
||||||
|
inittimer(120);
|
||||||
|
g_timerTicsPerSecond = 120;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (KB_KeyPressed(sc_kpad_6))
|
||||||
|
{
|
||||||
|
KB_ClearKeyDown(sc_kpad_6);
|
||||||
|
j = ALT_IS_PRESSED ? 30 : 10;
|
||||||
|
demo_goalreccnt = ud.reccnt-(TICRATE/TICSPERFRAME)*ud.multimode*j;
|
||||||
|
demo_oldsoundtoggle = ud.config.SoundToggle;
|
||||||
|
|
||||||
|
j=(demo_startreccnt-ud.reccnt)/(ud.multimode*(TICRATE/TICSPERFRAME));
|
||||||
|
OSD_Printf(" FF %d s from %02d:%02d\n", ALT_IS_PRESSED ? 30 : 10, j/60, j%60);
|
||||||
|
|
||||||
|
if (demo_goalreccnt <= 0)
|
||||||
|
demo_goalreccnt = 0;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ud.config.SoundToggle = 0;
|
||||||
|
FX_StopAllSounds();
|
||||||
|
S_ClearSoundLocks();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (KB_KeyPressed(sc_kpad_4))
|
||||||
|
{
|
||||||
|
KB_ClearKeyDown(sc_kpad_4);
|
||||||
|
j = ALT_IS_PRESSED ? 30 : 10;
|
||||||
|
demo_goalreccnt = ud.reccnt+(TICRATE/(TICRATE/GAMETICSPERSEC))*ud.multimode*j;
|
||||||
|
demo_oldsoundtoggle = ud.config.SoundToggle;
|
||||||
|
|
||||||
|
j=(demo_startreccnt-ud.reccnt)/(ud.multimode*TICRATE/(TICRATE/GAMETICSPERSEC));
|
||||||
|
OSD_Printf(" RW %d s from %02d:%02d\n", ALT_IS_PRESSED ? 30 : 10, j/60, j%60);
|
||||||
|
|
||||||
|
if (demo_goalreccnt > demo_startreccnt)
|
||||||
|
demo_goalreccnt = demo_startreccnt;
|
||||||
|
|
||||||
|
demo_goalreccnt = -demo_goalreccnt;
|
||||||
|
ud.config.SoundToggle = 0;
|
||||||
|
FX_StopAllSounds();
|
||||||
|
S_ClearSoundLocks();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (SHIFTS_IS_PRESSED || ALT_IS_PRESSED)
|
if (SHIFTS_IS_PRESSED || ALT_IS_PRESSED)
|
||||||
{
|
{
|
||||||
i = 0;
|
i = 0;
|
||||||
|
@ -11384,6 +11458,7 @@ static int32_t G_OpenDemoRead(int32_t g_whichDemo) // 0 = mine
|
||||||
}
|
}
|
||||||
i = ud.reccnt/((TICRATE/TICSPERFRAME)*ud.multimode);
|
i = ud.reccnt/((TICRATE/TICSPERFRAME)*ud.multimode);
|
||||||
OSD_Printf("demo duration: %d min %d sec\n", i/60, i%60);
|
OSD_Printf("demo duration: %d min %d sec\n", i/60, i%60);
|
||||||
|
demo_startreccnt = ud.reccnt;
|
||||||
|
|
||||||
ud.god = ud.cashman = ud.eog = ud.showallmap = 0;
|
ud.god = ud.cashman = ud.eog = ud.showallmap = 0;
|
||||||
ud.clipping = ud.scrollmode = ud.overhead_on = ud.pause_on = 0;
|
ud.clipping = ud.scrollmode = ud.overhead_on = ud.pause_on = 0;
|
||||||
|
@ -11483,6 +11558,7 @@ void G_CloseDemoWrite(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t g_whichDemo = 1;
|
static int32_t g_whichDemo = 1;
|
||||||
|
extern int32_t premap_quickenterlevel;
|
||||||
|
|
||||||
// extern int32_t syncs[];
|
// extern int32_t syncs[];
|
||||||
static int32_t G_PlaybackDemo(void)
|
static int32_t G_PlaybackDemo(void)
|
||||||
|
@ -11501,14 +11577,13 @@ RECHECK:
|
||||||
pus = NUMPAGES;
|
pus = NUMPAGES;
|
||||||
|
|
||||||
flushperms();
|
flushperms();
|
||||||
|
|
||||||
if (ud.multimode < 2) foundemo = G_OpenDemoRead(g_whichDemo);
|
if (ud.multimode < 2) foundemo = G_OpenDemoRead(g_whichDemo);
|
||||||
|
|
||||||
if (foundemo == 0)
|
if (foundemo == 0)
|
||||||
{
|
{
|
||||||
if (g_whichDemo > 1)
|
if (g_whichDemo > 1)
|
||||||
{
|
{
|
||||||
g_whichDemo = 1;
|
g_whichDemo = 1;
|
||||||
|
premap_quickenterlevel=0;
|
||||||
goto RECHECK;
|
goto RECHECK;
|
||||||
}
|
}
|
||||||
fadepal(0,0,0, 0,63,7);
|
fadepal(0,0,0, 0,63,7);
|
||||||
|
@ -11525,14 +11600,18 @@ RECHECK:
|
||||||
ud.recstat = 2;
|
ud.recstat = 2;
|
||||||
g_whichDemo++;
|
g_whichDemo++;
|
||||||
if (g_whichDemo == 10) g_whichDemo = 1;
|
if (g_whichDemo == 10) g_whichDemo = 1;
|
||||||
|
|
||||||
if (G_EnterLevel(MODE_DEMO)) ud.recstat = foundemo = 0;
|
if (G_EnterLevel(MODE_DEMO)) ud.recstat = foundemo = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (foundemo == 0 || in_menu || KB_KeyWaiting() || numplayers > 1)
|
if (!premap_quickenterlevel)
|
||||||
{
|
{
|
||||||
FX_StopAllSounds();
|
if (foundemo == 0 || in_menu || KB_KeyWaiting() || numplayers > 1)
|
||||||
S_ClearSoundLocks();
|
{
|
||||||
g_player[myconnectindex].ps->gm |= MODE_MENU;
|
FX_StopAllSounds();
|
||||||
|
S_ClearSoundLocks();
|
||||||
|
g_player[myconnectindex].ps->gm |= MODE_MENU;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ready2send = 0;
|
ready2send = 0;
|
||||||
|
@ -11545,7 +11624,9 @@ RECHECK:
|
||||||
while (ud.reccnt > 0 || foundemo == 0)
|
while (ud.reccnt > 0 || foundemo == 0)
|
||||||
{
|
{
|
||||||
if (foundemo)
|
if (foundemo)
|
||||||
while (totalclock >= (lockclock+TICSPERFRAME))
|
{
|
||||||
|
while (totalclock >= (lockclock+TICSPERFRAME) ||
|
||||||
|
(demo_goalreccnt>0 && demo_goalreccnt<ud.reccnt))
|
||||||
{
|
{
|
||||||
if ((i == 0) || (i >= RECSYNCBUFSIZ))
|
if ((i == 0) || (i >= RECSYNCBUFSIZ))
|
||||||
{
|
{
|
||||||
|
@ -11571,8 +11652,35 @@ RECHECK:
|
||||||
}
|
}
|
||||||
G_DoMoveThings();
|
G_DoMoveThings();
|
||||||
ototalclock += TICSPERFRAME;
|
ototalclock += TICSPERFRAME;
|
||||||
|
|
||||||
|
if (demo_goalreccnt > 0)
|
||||||
|
{
|
||||||
|
if (demo_goalreccnt<ud.reccnt)
|
||||||
|
totalclock += TICSPERFRAME;
|
||||||
|
}
|
||||||
|
else if (demo_goalreccnt < 0)
|
||||||
|
{
|
||||||
|
demo_goalreccnt = -demo_goalreccnt;
|
||||||
|
|
||||||
|
if (g_whichDemo > 1) // load the same demo again and FF from beginning... yay!
|
||||||
|
g_whichDemo--;
|
||||||
|
foundemo = 0;
|
||||||
|
ud.reccnt = 0;
|
||||||
|
kclose(recfilep);
|
||||||
|
premap_quickenterlevel=1;
|
||||||
|
goto RECHECK;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (demo_goalreccnt > 0 && ud.reccnt<=demo_goalreccnt)
|
||||||
|
{
|
||||||
|
demo_goalreccnt = 0;
|
||||||
|
ud.config.SoundToggle = demo_oldsoundtoggle;
|
||||||
|
premap_quickenterlevel = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (foundemo == 0)
|
if (foundemo == 0)
|
||||||
G_DrawBackground();
|
G_DrawBackground();
|
||||||
else
|
else
|
||||||
|
@ -11584,6 +11692,13 @@ RECHECK:
|
||||||
G_DrawRooms(screenpeek,j);
|
G_DrawRooms(screenpeek,j);
|
||||||
G_DisplayRest(j);
|
G_DisplayRest(j);
|
||||||
|
|
||||||
|
if (demo_showstats && (g_player[myconnectindex].ps->gm&MODE_MENU) == 0)
|
||||||
|
{
|
||||||
|
j=(demo_startreccnt-ud.reccnt)/(TICRATE/TICSPERFRAME);
|
||||||
|
Bsprintf(buf, "%02d:%02d", j/60, j%60);
|
||||||
|
gametext(18,16,buf,0,2+8+16);
|
||||||
|
}
|
||||||
|
|
||||||
if (ud.multimode > 1 && g_player[myconnectindex].ps->gm)
|
if (ud.multimode > 1 && g_player[myconnectindex].ps->gm)
|
||||||
Net_GetPackets();
|
Net_GetPackets();
|
||||||
|
|
||||||
|
|
|
@ -310,6 +310,7 @@ const char *keyw[] =
|
||||||
"resetkey",
|
"resetkey",
|
||||||
"insertsprite",
|
"insertsprite",
|
||||||
"dupsprite",
|
"dupsprite",
|
||||||
|
"tdupsprite",
|
||||||
"deletesprite",
|
"deletesprite",
|
||||||
"lastwall",
|
"lastwall",
|
||||||
"updatecursectnum",
|
"updatecursectnum",
|
||||||
|
@ -2183,8 +2184,7 @@ repeatcase:
|
||||||
|
|
||||||
if ((tw==CON_GETTSPR || tw==CON_SETTSPR) && cs.currentEvent != EVENT_ANALYZESPRITES)
|
if ((tw==CON_GETTSPR || tw==CON_SETTSPR) && cs.currentEvent != EVENT_ANALYZESPRITES)
|
||||||
{
|
{
|
||||||
C_ReportError(-1);
|
C_ReportError(WARNING_OUTSIDEDRAWSPRITE);
|
||||||
initprintf("%s:%d: warning: found `%s' outside of EVENT_ANALYZESPRITES\n",g_szScriptFileName,g_lineNumber,tempbuf);
|
|
||||||
g_numCompilerWarnings++;
|
g_numCompilerWarnings++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2733,6 +2733,12 @@ repeatcase:
|
||||||
}
|
}
|
||||||
|
|
||||||
// *** BUILD functions
|
// *** BUILD functions
|
||||||
|
case CON_TDUPSPRITE:
|
||||||
|
if (cs.currentEvent>=0 && cs.currentEvent != EVENT_ANALYZESPRITES)
|
||||||
|
{
|
||||||
|
C_ReportError(WARNING_OUTSIDEDRAWSPRITE);
|
||||||
|
g_numCompilerWarnings++;
|
||||||
|
}
|
||||||
case CON_RESETKEY:
|
case CON_RESETKEY:
|
||||||
case CON_INSERTSPRITE:
|
case CON_INSERTSPRITE:
|
||||||
case CON_DUPSPRITE:
|
case CON_DUPSPRITE:
|
||||||
|
@ -3568,5 +3574,9 @@ void C_ReportError(int32_t iError)
|
||||||
initprintf("%s:%d: warning: constants where gamevars are expected save only 16 bits.\n",
|
initprintf("%s:%d: warning: constants where gamevars are expected save only 16 bits.\n",
|
||||||
g_szScriptFileName,g_lineNumber);
|
g_szScriptFileName,g_lineNumber);
|
||||||
break;
|
break;
|
||||||
|
case WARNING_OUTSIDEDRAWSPRITE:
|
||||||
|
initprintf("%s:%d: warning: found `%s' outside of EVENT_ANALYZESPRITES\n",
|
||||||
|
g_szScriptFileName,g_lineNumber,tempbuf);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -137,6 +137,7 @@ enum ScriptError_t
|
||||||
WARNING_LABELSONLY,
|
WARNING_LABELSONLY,
|
||||||
WARNING_NAMEMATCHESVAR,
|
WARNING_NAMEMATCHESVAR,
|
||||||
WARNING_CONSTANTBITSIZE,
|
WARNING_CONSTANTBITSIZE,
|
||||||
|
WARNING_OUTSIDEDRAWSPRITE,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -390,6 +391,7 @@ enum ScriptKeywords_t
|
||||||
CON_RESETKEY,
|
CON_RESETKEY,
|
||||||
CON_INSERTSPRITE,
|
CON_INSERTSPRITE,
|
||||||
CON_DUPSPRITE,
|
CON_DUPSPRITE,
|
||||||
|
CON_TDUPSPRITE,
|
||||||
CON_DELETESPRITE,
|
CON_DELETESPRITE,
|
||||||
CON_LASTWALL,
|
CON_LASTWALL,
|
||||||
CON_UPDATECURSECTNUM,
|
CON_UPDATECURSECTNUM,
|
||||||
|
|
|
@ -1524,6 +1524,7 @@ badindex:
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case CON_DUPSPRITE:
|
case CON_DUPSPRITE:
|
||||||
|
case CON_TDUPSPRITE:
|
||||||
insptr++;
|
insptr++;
|
||||||
{
|
{
|
||||||
int32_t ospritenum = Gv_GetVarX(*insptr++), nspritenum;
|
int32_t ospritenum = Gv_GetVarX(*insptr++), nspritenum;
|
||||||
|
@ -1533,26 +1534,38 @@ badindex:
|
||||||
OSD_Printf(CON_ERROR "Tried to duplicate nonexistent sprite %d\n",g_errorLineNum,keyw[g_tw],ospritenum);
|
OSD_Printf(CON_ERROR "Tried to duplicate nonexistent sprite %d\n",g_errorLineNum,keyw[g_tw],ospritenum);
|
||||||
vm.flags |= VMFLAG_ERROR;
|
vm.flags |= VMFLAG_ERROR;
|
||||||
}
|
}
|
||||||
if (numsprites >= MAXSPRITES)
|
if ((tw==CON_DUPSPRITE && numsprites >= MAXSPRITES) ||
|
||||||
|
(tw==CON_DUPSPRITE && spritesortcnt >= MAXSPRITESONSCREEN))
|
||||||
{
|
{
|
||||||
OSD_Printf(CON_ERROR "Maximum number of sprites reached.\n",g_errorLineNum,keyw[g_tw]);
|
OSD_Printf(CON_ERROR "Maximum number of sprites reached.\n",g_errorLineNum,keyw[g_tw]);
|
||||||
vm.flags |= VMFLAG_ERROR;
|
vm.flags |= VMFLAG_ERROR;
|
||||||
}
|
}
|
||||||
if (vm.flags&VMFLAG_ERROR) continue;
|
if (vm.flags&VMFLAG_ERROR) continue;
|
||||||
|
|
||||||
nspritenum = insertsprite(sprite[ospritenum].sectnum, sprite[ospritenum].statnum);
|
if (tw==CON_DUPSPRITE)
|
||||||
|
|
||||||
if (nspritenum < 0)
|
|
||||||
{
|
{
|
||||||
OSD_Printf(CON_ERROR "Internal error.\n",g_errorLineNum,keyw[g_tw]);
|
nspritenum = insertsprite(sprite[ospritenum].sectnum, sprite[ospritenum].statnum);
|
||||||
vm.flags |= VMFLAG_ERROR;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
Bmemcpy(&sprite[nspritenum], &sprite[ospritenum], sizeof(spritetype));
|
if (nspritenum < 0)
|
||||||
vm.g_i = nspritenum;
|
{
|
||||||
vm.g_sp = &sprite[nspritenum];
|
OSD_Printf(CON_ERROR "Internal error.\n",g_errorLineNum,keyw[g_tw]);
|
||||||
numsprites++;
|
vm.flags |= VMFLAG_ERROR;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
Bmemcpy(&sprite[nspritenum], &sprite[ospritenum], sizeof(spritetype));
|
||||||
|
vm.g_i = nspritenum;
|
||||||
|
vm.g_sp = &sprite[nspritenum];
|
||||||
|
numsprites++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Bmemcpy(&tsprite[spritesortcnt], &sprite[ospritenum], sizeof(spritetype));
|
||||||
|
tsprite[spritesortcnt].owner = ospritenum;
|
||||||
|
vm.g_i = -1;
|
||||||
|
vm.g_sp = &tsprite[spritesortcnt];
|
||||||
|
spritesortcnt++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
|
|
@ -1204,11 +1204,16 @@ static inline void prelevel(char g)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t premap_quickenterlevel=0;
|
||||||
|
|
||||||
void G_NewGame(int32_t vn,int32_t ln,int32_t sk)
|
void G_NewGame(int32_t vn,int32_t ln,int32_t sk)
|
||||||
{
|
{
|
||||||
DukePlayer_t *p = g_player[0].ps;
|
DukePlayer_t *p = g_player[0].ps;
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
|
if (!premap_quickenterlevel)
|
||||||
|
goto quick;
|
||||||
|
|
||||||
handleevents();
|
handleevents();
|
||||||
Net_GetPackets();
|
Net_GetPackets();
|
||||||
|
|
||||||
|
@ -1250,6 +1255,7 @@ void G_NewGame(int32_t vn,int32_t ln,int32_t sk)
|
||||||
FX_StopAllSounds();
|
FX_StopAllSounds();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
quick:
|
||||||
g_showShareware = GAMETICSPERSEC*34;
|
g_showShareware = GAMETICSPERSEC*34;
|
||||||
|
|
||||||
ud.level_number = ln;
|
ud.level_number = ln;
|
||||||
|
@ -1653,7 +1659,6 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
|
|
||||||
// flushpackets();
|
// flushpackets();
|
||||||
// waitforeverybody();
|
// waitforeverybody();
|
||||||
|
|
||||||
vote_map = vote_episode = voting = -1;
|
vote_map = vote_episode = voting = -1;
|
||||||
|
|
||||||
if ((g&MODE_DEMO) != MODE_DEMO) ud.recstat = ud.m_recstat;
|
if ((g&MODE_DEMO) != MODE_DEMO) ud.recstat = ud.m_recstat;
|
||||||
|
@ -1674,7 +1679,6 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
FX_SetReverb(0);
|
FX_SetReverb(0);
|
||||||
|
|
||||||
setgamemode(ud.config.ScreenMode,ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP);
|
setgamemode(ud.config.ScreenMode,ud.config.ScreenWidth,ud.config.ScreenHeight,ud.config.ScreenBPP);
|
||||||
|
|
||||||
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
||||||
{
|
{
|
||||||
int32_t volume, level;
|
int32_t volume, level;
|
||||||
|
@ -1713,11 +1717,15 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
i = ud.screen_size;
|
if (!premap_quickenterlevel)
|
||||||
ud.screen_size = 0;
|
{
|
||||||
G_DoLoadScreen(NULL, -1);
|
i = ud.screen_size;
|
||||||
G_UpdateScreenArea();
|
ud.screen_size = 0;
|
||||||
ud.screen_size = i;
|
|
||||||
|
G_DoLoadScreen(NULL, -1);
|
||||||
|
G_UpdateScreenArea();
|
||||||
|
ud.screen_size = i;
|
||||||
|
}
|
||||||
|
|
||||||
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
||||||
{
|
{
|
||||||
|
@ -1728,7 +1736,6 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
|
|
||||||
Bstrcpy(tempbuf,apptitle);
|
Bstrcpy(tempbuf,apptitle);
|
||||||
wm_setapptitle(tempbuf);
|
wm_setapptitle(tempbuf);
|
||||||
|
|
||||||
if (!VOLUMEONE)
|
if (!VOLUMEONE)
|
||||||
{
|
{
|
||||||
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
if (boardfilename[0] != 0 && ud.m_level_number == 7 && ud.m_volume_number == 0)
|
||||||
|
@ -1856,9 +1863,12 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_precacheCount = 0;
|
if (!premap_quickenterlevel)
|
||||||
clearbufbyte(gotpic,sizeof(gotpic),0L);
|
{
|
||||||
clearbufbyte(precachehightile, sizeof(precachehightile), 0l);
|
g_precacheCount = 0;
|
||||||
|
clearbufbyte(gotpic,sizeof(gotpic),0L);
|
||||||
|
clearbufbyte(precachehightile, sizeof(precachehightile), 0l);
|
||||||
|
}
|
||||||
//clearbufbyte(ActorExtra,sizeof(ActorExtra),0l); // JBF 20040531: yes? no?
|
//clearbufbyte(ActorExtra,sizeof(ActorExtra),0l); // JBF 20040531: yes? no?
|
||||||
|
|
||||||
prelevel(g);
|
prelevel(g);
|
||||||
|
@ -1869,7 +1879,8 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
cachedebug = 0;
|
cachedebug = 0;
|
||||||
automapping = 0;
|
automapping = 0;
|
||||||
|
|
||||||
G_CacheMapData();
|
if (!premap_quickenterlevel)
|
||||||
|
G_CacheMapData();
|
||||||
|
|
||||||
if (ud.recstat != 2)
|
if (ud.recstat != 2)
|
||||||
{
|
{
|
||||||
|
@ -1919,10 +1930,13 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
|
|
||||||
//g_player[myconnectindex].ps->palette = palette;
|
//g_player[myconnectindex].ps->palette = palette;
|
||||||
//G_FadePalette(0,0,0,0);
|
//G_FadePalette(0,0,0,0);
|
||||||
P_SetGamePalette(g_player[myconnectindex].ps, palette, 0); // JBF 20040308
|
if (!premap_quickenterlevel)
|
||||||
|
{
|
||||||
|
P_SetGamePalette(g_player[myconnectindex].ps, palette, 0); // JBF 20040308
|
||||||
|
|
||||||
P_UpdateScreenPal(g_player[myconnectindex].ps);
|
P_UpdateScreenPal(g_player[myconnectindex].ps);
|
||||||
flushperms();
|
flushperms();
|
||||||
|
}
|
||||||
|
|
||||||
everyothertime = 0;
|
everyothertime = 0;
|
||||||
g_globalRandom = 0;
|
g_globalRandom = 0;
|
||||||
|
@ -1935,14 +1949,17 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
|
|
||||||
g_restorePalette = 1;
|
g_restorePalette = 1;
|
||||||
|
|
||||||
Net_WaitForEverybody();
|
if (!premap_quickenterlevel)
|
||||||
mmulti_flushpackets();
|
{
|
||||||
|
Net_WaitForEverybody();
|
||||||
|
mmulti_flushpackets();
|
||||||
|
|
||||||
G_FadePalette(0,0,0,0);
|
G_FadePalette(0,0,0,0);
|
||||||
G_UpdateScreenArea();
|
G_UpdateScreenArea();
|
||||||
clearview(0L);
|
clearview(0L);
|
||||||
G_DrawBackground();
|
G_DrawBackground();
|
||||||
G_DrawRooms(myconnectindex,65536);
|
G_DrawRooms(myconnectindex,65536);
|
||||||
|
}
|
||||||
|
|
||||||
for (i=0; i<ud.multimode; i++)
|
for (i=0; i<ud.multimode; i++)
|
||||||
clearbufbyte(&g_player[i].playerquitflag,1,0x01010101);
|
clearbufbyte(&g_player[i].playerquitflag,1,0x01010101);
|
||||||
|
@ -1957,9 +1974,9 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
// variables are set by pointer...
|
// variables are set by pointer...
|
||||||
|
|
||||||
Bmemcpy(¤tboardfilename[0],&boardfilename[0],BMAX_PATH);
|
Bmemcpy(¤tboardfilename[0],&boardfilename[0],BMAX_PATH);
|
||||||
|
|
||||||
X_OnEvent(EVENT_ENTERLEVEL, -1, -1, -1);
|
X_OnEvent(EVENT_ENTERLEVEL, -1, -1, -1);
|
||||||
OSD_Printf(OSDTEXT_YELLOW "E%dL%d: %s\n",ud.volume_number+1,ud.level_number+1,MapInfo[(ud.volume_number*MAXLEVELS)+ud.level_number].name);
|
if (!premap_quickenterlevel)
|
||||||
|
OSD_Printf(OSDTEXT_YELLOW "E%dL%d: %s\n",ud.volume_number+1,ud.level_number+1,MapInfo[(ud.volume_number*MAXLEVELS)+ud.level_number].name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue