- step 1.

This commit is contained in:
Christoph Oelckers 2020-05-14 19:23:36 +02:00
parent 18d6a8e65d
commit 1b135ecb0b
11 changed files with 693 additions and 886 deletions

View file

@ -4181,4 +4181,61 @@ void fall_d(int g_i, int g_p)
fall_common(g_i, g_p, JIBS6, DRONE, BLOODPOOL, SHOTSPARK1, SQUISHED, THUD, nullptr, falladjustz); fall_common(g_i, g_p, JIBS6, DRONE, BLOODPOOL, SHOTSPARK1, SQUISHED, THUD, nullptr, falladjustz);
} }
bool spawnweapondebris_d(int picnum, int dnum)
{
return picnum == BLIMP && dnum == SCRAP1;
}
void respawnhitag_d(spritetype* g_sp)
{
switch (g_sp->picnum)
{
case FEM1:
case FEM2:
case FEM3:
case FEM4:
case FEM5:
case FEM6:
case FEM7:
case FEM8:
case FEM9:
case FEM10:
case PODFEM1:
case NAKED1:
case STATUE:
if (g_sp->yvel) fi.operaterespawns(g_sp->yvel);
break;
default:
if (g_sp->hitag >= 0) fi.operaterespawns(g_sp->hitag);
break;
}
}
void checktimetosleep_d(int g_i)
{
auto g_sp = &sprite[g_i];
if (g_sp->statnum == 6)
{
switch (g_sp->picnum)
{
case RUBBERCAN:
case EXPLODINGBARREL:
case WOODENHORSE:
case HORSEONSIDE:
case CANWITHSOMETHING:
case FIREBARREL:
case NUKEBARREL:
case NUKEBARRELDENTED:
case NUKEBARRELLEAKED:
case TRIPBOMB:
case EGG:
if (hittype[g_i].timetosleep > 1)
hittype[g_i].timetosleep--;
else if (hittype[g_i].timetosleep == 1)
changespritestat(g_i, 2);
break;
}
}
}
END_DUKE_NS END_DUKE_NS

View file

@ -4614,4 +4614,53 @@ void mamaspawn(int g_i)
spawn(g_i, RABBIT); spawn(g_i, RABBIT);
} }
} }
bool spawnweapondebris_r(int picnum, int dnum)
{
return dnum == SCRAP1;
}
void respawnhitag_r(spritetype* g_sp)
{
switch (g_sp->picnum)
{
case FEM10:
case NAKED1:
case STATUE:
if (g_sp->yvel) fi.operaterespawns(g_sp->yvel);
break;
default:
if (g_sp->hitag >= 0) fi.operaterespawns(g_sp->hitag);
break;
}
}
void checktimetosleep_r(int g_i)
{
auto g_sp = &sprite[g_i];
if (g_sp->statnum == 6)
{
switch (g_sp->picnum)
{
case RUBBERCAN:
case EXPLODINGBARREL:
case WOODENHORSE:
case HORSEONSIDE:
case CANWITHSOMETHING:
case FIREBARREL:
case NUKEBARREL:
case NUKEBARRELDENTED:
case NUKEBARRELLEAKED:
case TRIPBOMB:
case EGG:
if (hittype[g_i].timetosleep > 1)
hittype[g_i].timetosleep--;
else if (hittype[g_i].timetosleep == 1)
changespritestat(g_i, 2);
break;
}
}
}
END_DUKE_NS END_DUKE_NS

View file

@ -78,6 +78,14 @@ int ifhitbyweapon_r(int sn);
int ifhitbyweapon_d(int sn); int ifhitbyweapon_d(int sn);
void fall_d(int g_i, int g_p); void fall_d(int g_i, int g_p);
void fall_r(int g_i, int g_p); void fall_r(int g_i, int g_p);
bool spawnweapondebris_d(int picnum, int dnum);
bool spawnweapondebris_r(int picnum, int dnum);
void respawnhitag_d(spritetype* g_sp);
void respawnhitag_r(spritetype* g_sp);
void checktimetosleep_d(int g_i);
void checktimetosleep_r(int g_i);
void move_d(int g_i, int g_p, int g_x);
void move_r(int g_i, int g_p, int g_x);
Dispatcher fi; Dispatcher fi;
@ -110,7 +118,11 @@ void SetDispatcher()
gutsdir_d, gutsdir_d,
ifhitsectors_d, ifhitsectors_d,
ifhitbyweapon_d, ifhitbyweapon_d,
fall_d fall_d,
spawnweapondebris_d,
respawnhitag_d,
checktimetosleep_d,
move_d
}; };
} }
else else
@ -140,7 +152,11 @@ void SetDispatcher()
gutsdir_r, gutsdir_r,
ifhitsectors_r, ifhitsectors_r,
ifhitbyweapon_r, ifhitbyweapon_r,
fall_r fall_r,
spawnweapondebris_r,
respawnhitag_r,
checktimetosleep_r,
move_r,
}; };
} }
} }

View file

@ -224,6 +224,10 @@ extern int32_t voting;
//extern int8_t cheatbuf[MAXCHEATLEN],cheatbuflen; //extern int8_t cheatbuf[MAXCHEATLEN],cheatbuflen;
int32_t A_CheckInventorySprite(spritetype *s); int32_t A_CheckInventorySprite(spritetype *s);
inline int inventory(spritetype* S)
{
return A_CheckInventorySprite(S);
}
int32_t A_InsertSprite(int16_t whatsect, int32_t s_x, int32_t s_y, int32_t s_z, int16_t s_pn, int8_t s_s, uint8_t s_xr, int32_t A_InsertSprite(int16_t whatsect, int32_t s_x, int32_t s_y, int32_t s_z, int16_t s_pn, int8_t s_s, uint8_t s_xr,
uint8_t s_yr, int16_t s_a, int16_t s_ve, int16_t s_zv, int16_t s_ow, int16_t s_ss); uint8_t s_yr, int16_t s_a, int16_t s_ve, int16_t s_zv, int16_t s_ow, int16_t s_ss);
#define EGS A_InsertSprite #define EGS A_InsertSprite
@ -473,6 +477,12 @@ struct Dispatcher
int (*ifhitsectors)(int sectnum); int (*ifhitsectors)(int sectnum);
int (*ifhitbyweapon)(int sectnum); int (*ifhitbyweapon)(int sectnum);
void (*fall)(int g_i, int g_p); void (*fall)(int g_i, int g_p);
bool (*spawnweapondebris)(int picnum, int dnum);
void (*respawnhitag)(spritetype* g_sp);
void (*checktimetosleep)(int g_i);
void (*move)(int g_i, int g_p, int g_x);
}; };
extern Dispatcher fi; extern Dispatcher fi;

File diff suppressed because it is too large Load diff

View file

@ -216,7 +216,7 @@ struct msy_
G_EXTERN msx_ msx; G_EXTERN msx_ msx;
G_EXTERN msy_ msy; G_EXTERN msy_ msy;
G_EXTERN int32_t g_windTime, WindDir; G_EXTERN int32_t WindTime, WindDir;
G_EXTERN int16_t fakebubba_spawn, mamaspawn_count, banjosound, g_bellTime, g_bellSprite; G_EXTERN int16_t fakebubba_spawn, mamaspawn_count, banjosound, g_bellTime, g_bellSprite;
#define BellTime g_bellTime #define BellTime g_bellTime
#define word_119BE0 g_bellSprite #define word_119BE0 g_bellSprite

View file

@ -278,6 +278,7 @@ typedef struct player_struct {
#define heat_amount inv_amount[GET_HEATS] #define heat_amount inv_amount[GET_HEATS]
#define scuba_amount inv_amount[GET_SCUBA] #define scuba_amount inv_amount[GET_SCUBA]
#define boot_amount inv_amount[GET_BOOTS] #define boot_amount inv_amount[GET_BOOTS]
#define shield_amount inv_amount[GET_SHIELD]
#define raat609 MamaEnd #define raat609 MamaEnd
#define raat5dd sea_sick_stat #define raat5dd sea_sick_stat

View file

@ -74,7 +74,8 @@ int32_t g_aimAngleVarID = -1; // var ID of "AUTOAIMANGLE"
uint32_t g_actorCalls[MAXTILES]; uint32_t g_actorCalls[MAXTILES];
double g_actorTotalMs[MAXTILES], g_actorMinMs[MAXTILES], g_actorMaxMs[MAXTILES]; double g_actorTotalMs[MAXTILES], g_actorMinMs[MAXTILES], g_actorMaxMs[MAXTILES];
GAMEEXEC_STATIC void VM_Execute(native_t loop); void VM_Execute(native_t loop);
int parse();
#define VM_CONDITIONAL(xxx) \ #define VM_CONDITIONAL(xxx) \
{ \ { \
@ -191,7 +192,7 @@ static int32_t VM_CheckSquished(void)
return ifsquished(vm.spriteNum, vm.playerNum); return ifsquished(vm.spriteNum, vm.playerNum);
} }
GAMEEXEC_STATIC GAMEEXEC_INLINE void P_ForceAngle(DukePlayer_t *pPlayer) void forceplayerangle(DukePlayer_t *pPlayer)
{ {
int const nAngle = 128-(krand2()&255); int const nAngle = 128-(krand2()&255);
@ -268,12 +269,10 @@ static int32_t VM_GetFlorZOfSlope(void)
//////////////////// ////////////////////
static int32_t A_GetWaterZOffset(int spritenum); static int32_t A_GetWaterZOffset(int spritenum);
void move_d(int g_i, int g_p, int g_x);
void move_r(int g_i, int g_p, int g_x);
GAMEEXEC_STATIC void VM_Move(void) GAMEEXEC_STATIC void VM_Move(void)
{ {
if (isRR()) move_r(vm.spriteNum, vm.playerNum, vm.playerDist); else move_d(vm.spriteNum, vm.playerNum, vm.playerDist); fi.move(vm.spriteNum, vm.playerNum, vm.playerDist);
} }
static void VM_AddWeapon(DukePlayer_t * const pPlayer, int const weaponNum, int const nAmount) static void VM_AddWeapon(DukePlayer_t * const pPlayer, int const weaponNum, int const nAmount)
@ -337,8 +336,8 @@ static void VM_AddInventory(DukePlayer_t * const pPlayer, int const itemNum, int
case GET_SHIELD: case GET_SHIELD:
{ {
int16_t & shield_amount = pPlayer->inv_amount[GET_SHIELD]; int16_t & shieldamount = pPlayer->inv_amount[GET_SHIELD];
shield_amount = min(shield_amount + nAmount, max_player_health); shieldamount = min(shieldamount + nAmount, max_player_health);
break; break;
} }
@ -628,7 +627,9 @@ void Screen_Play(void)
} while (running); } while (running);
} }
GAMEEXEC_STATIC void VM_Execute(native_t loop) extern uint8_t killit_flag;
void VM_Execute(native_t loop)
{ {
native_t tw = *insptr; native_t tw = *insptr;
DukePlayer_t *const pPlayer = vm.pPlayer; DukePlayer_t *const pPlayer = vm.pPlayer;
@ -650,192 +651,10 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
g_errorLineNum = tw >> 12; g_errorLineNum = tw >> 12;
g_tw = tw &= VM_INSTMASK; g_tw = tw &= VM_INSTMASK;
if (tw == concmd_leftbrace)
{
insptr++, loop++;
continue;
}
else if (tw == concmd_rightbrace)
{
insptr++, loop--;
continue;
}
else if (tw == concmd_else)
{
insptr = apScript + *(insptr + 1);
continue;
}
else if (tw == concmd_state)
{
intptr_t const *const tempscrptr = insptr + 2;
insptr = apScript + *(insptr + 1);
VM_Execute(1);
insptr = tempscrptr;
continue;
}
switch (tw) switch (tw)
{ {
case concmd_enda:
case concmd_break:
case concmd_ends:
case concmd_endevent: return;
case concmd_ifrnd: VM_CONDITIONAL(rnd(*(++insptr))); continue;
case concmd_ifcanshoottarget:
{
if (vm.playerDist > 1024)
{
int16_t temphit;
if ((tw = hitasprite(vm.spriteNum, &temphit)) == (1 << 30))
{
VM_CONDITIONAL(1);
continue;
}
int dist = 768;
int angDiff = 16;
if (A_CheckEnemySprite(vm.pSprite) && vm.pSprite->xrepeat > 56)
{
dist = 3084;
angDiff = 48;
}
#define CHECK(x) \
if (x >= 0 && sprite[x].picnum == vm.pSprite->picnum) \
{ \
VM_CONDITIONAL(0); \
continue; \
}
#define CHECK2(x) \
do \
{ \
vm.pSprite->ang += x; \
tw = hitasprite(vm.spriteNum, &temphit); \
vm.pSprite->ang -= x; \
} while (0)
if (tw > dist)
{
CHECK(temphit);
CHECK2(angDiff);
if (tw > dist)
{
CHECK(temphit);
CHECK2(-angDiff);
if (tw > 768)
{
CHECK(temphit);
VM_CONDITIONAL(1);
continue;
}
}
}
VM_CONDITIONAL(0);
continue;
}
VM_CONDITIONAL(1);
}
continue;
case concmd_ifcanseetarget:
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - ((krand2() & 41) << 8), vm.pSprite->sectnum, pPlayer->pos.x, pPlayer->pos.y,
pPlayer->pos.z /*-((krand2()&41)<<8)*/, sprite[pPlayer->i].sectnum);
VM_CONDITIONAL(tw);
if (tw)
vm.pActor->timetosleep = SLEEPTIME;
continue;
case concmd_ifnocover:
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z, vm.pSprite->sectnum, pPlayer->pos.x, pPlayer->pos.y,
pPlayer->pos.z, sprite[pPlayer->i].sectnum);
VM_CONDITIONAL(tw);
if (tw)
vm.pActor->timetosleep = SLEEPTIME;
continue;
case concmd_ifactornotstayput: VM_CONDITIONAL(vm.pActor->actorstayput == -1); continue;
case concmd_ifcansee:
{
uspritetype *pSprite = (uspritetype *)&sprite[pPlayer->i];
if (DEER)
{
if (sintable[vm.pSprite->ang&2047] * (pSprite->y - vm.pSprite->y) + sintable[(vm.pSprite->ang+512)&2047] * (pSprite->x - vm.pSprite->x) >= 0)
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - (krand2() % 13312), vm.pSprite->sectnum,
pSprite->x, pSprite->y, pPlayer->opos.z-(krand2() % 8192), pPlayer->cursectnum);
else
tw = 0;
VM_CONDITIONAL(tw);
continue;
}
// select sprite for monster to target
// if holoduke is on, let them target holoduke first.
//
if (!RR && pPlayer->holoduke_on >= 0)
{
pSprite = (uspritetype *)&sprite[pPlayer->holoduke_on];
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - (krand2() & (ZOFFSET5 - 1)), vm.pSprite->sectnum, pSprite->x, pSprite->y,
pSprite->z, pSprite->sectnum);
if (tw == 0)
{
// they can't see player's holoduke
// check for player...
pSprite = (uspritetype *)&sprite[pPlayer->i];
}
}
// can they see player, (or player's holoduke)
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - (krand2() & ((47 << 8))), vm.pSprite->sectnum, pSprite->x, pSprite->y,
pSprite->z - (RR ? (28 << 8) : (24 << 8)), pSprite->sectnum);
if (tw == 0)
{
// search around for target player
// also modifies 'target' x&y if found..
tw = 1;
if (furthestcanseepoint(vm.spriteNum, (spritetype*)pSprite, &vm.pActor->lastv.x, &vm.pActor->lastv.y) == -1)
tw = 0;
}
else
{
// else, they did see it.
// save where we were looking...
vm.pActor->lastv.x = pSprite->x;
vm.pActor->lastv.y = pSprite->y;
}
if (tw && (vm.pSprite->statnum == STAT_ACTOR || vm.pSprite->statnum == STAT_STANDABLE))
vm.pActor->timetosleep = SLEEPTIME;
VM_CONDITIONAL(tw);
continue;
}
case concmd_ifhitweapon:
if (DEER)
{
VM_CONDITIONAL(ghtrophy_isakill(vm.spriteNum));
}
else
{
VM_CONDITIONAL(fi.ifhitbyweapon(vm.spriteNum) >= 0);
}
continue;
case concmd_ifsquished: VM_CONDITIONAL(VM_CheckSquished()); continue;
case concmd_ifdead: VM_CONDITIONAL(vm.pSprite->extra - (vm.pSprite->picnum == TILE_APLAYER) < 0); continue;
case concmd_ai: case concmd_ai:
insptr++; insptr++;
@ -874,15 +693,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
vm.pActor->timetosleep = SLEEPTIME; vm.pActor->timetosleep = SLEEPTIME;
continue; continue;
case concmd_addstrength:
insptr++;
vm.pSprite->extra += *insptr++;
continue;
case concmd_strength:
insptr++;
vm.pSprite->extra = *insptr++;
continue;
case concmd_smacksprite: case concmd_smacksprite:
insptr++; insptr++;
@ -912,12 +722,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
} }
continue; continue;
case concmd_rndmove:
insptr++;
vm.pSprite->ang = krand2()&2047;
vm.pSprite->xvel = 25;
continue;
case concmd_mamatrigger: case concmd_mamatrigger:
insptr++; insptr++;
operateactivators(667, vm.playerNum); operateactivators(667, vm.playerNum);
@ -1181,11 +985,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
A_PlaySound(*insptr++, vm.spriteNum); A_PlaySound(*insptr++, vm.spriteNum);
continue; continue;
case concmd_tip:
insptr++;
pPlayer->tipincs = GAMETICSPERSEC;
continue;
case concmd_iftipcow: case concmd_iftipcow:
if (g_spriteExtra[vm.spriteNum] == 1) if (g_spriteExtra[vm.spriteNum] == 1)
{ {
@ -1206,16 +1005,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
VM_CONDITIONAL(0); VM_CONDITIONAL(0);
continue; continue;
#if 0 // RRDH only
case concmd_iffindnewspot:
VM_CONDITIONAL(ghcons_findnewspot(vm.spriteNum));
continue;
case concmd_leavedroppings:
insptr++;
ghtrax_leavedroppings(vm.spriteNum);
continue;
#endif
case concmd_tearitup: case concmd_tearitup:
insptr++; insptr++;
@ -1234,8 +1023,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
VM_Fall(vm.spriteNum, vm.pSprite); VM_Fall(vm.spriteNum, vm.pSprite);
continue; continue;
case concmd_nullop: insptr++; continue;
case concmd_addammo: case concmd_addammo:
insptr++; insptr++;
{ {
@ -1247,26 +1034,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
continue; continue;
} }
case concmd_money:
insptr++;
A_SpawnMultiple(vm.spriteNum, TILE_MONEY, *insptr++);
continue;
case concmd_mail:
insptr++;
A_SpawnMultiple(vm.spriteNum, RR ? TILE_MONEY : TILE_MAIL, *insptr++);
continue;
case concmd_sleeptime:
insptr++;
vm.pActor->timetosleep = (int16_t)*insptr++;
continue;
case concmd_paper:
insptr++;
A_SpawnMultiple(vm.spriteNum, RR ? TILE_MONEY : TILE_PAPER, *insptr++);
continue;
case concmd_addkills: case concmd_addkills:
if (DEER) if (DEER)
{ {
@ -1288,15 +1055,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
vm.pActor->actorstayput = -1; vm.pActor->actorstayput = -1;
continue; continue;
case concmd_lotsofglass:
insptr++;
spriteglass(vm.spriteNum, *insptr++);
continue;
case concmd_killit:
insptr++;
vm.flags |= VM_KILL;
return;
case concmd_addweapon: case concmd_addweapon:
insptr++; insptr++;
@ -1377,12 +1135,6 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
sprite[pPlayer->i].z = pPlayer->pos.z; sprite[pPlayer->i].z = pPlayer->pos.z;
continue; continue;
#if 0 // RRDH only
case concmd_leavetrax:
insptr++;
ghtrax_leavetrax(vm.spriteNum);
continue;
#endif
case concmd_destroyit: case concmd_destroyit:
insptr++; insptr++;
@ -1725,7 +1477,7 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
continue; continue;
case concmd_ifwind: case concmd_ifwind:
VM_CONDITIONAL(g_windTime > 0); VM_CONDITIONAL(WindTime > 0);
continue; continue;
#if 0 // RRDH only #if 0 // RRDH only
case concmd_ifpupwind: case concmd_ifpupwind:
@ -1823,7 +1575,7 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
case concmd_slapplayer: case concmd_slapplayer:
insptr++; insptr++;
P_ForceAngle(pPlayer); forceplayerangle(pPlayer);
pPlayer->vel.x -= sintable[(fix16_to_int(pPlayer->q16ang)+512)&2047]<<7; pPlayer->vel.x -= sintable[(fix16_to_int(pPlayer->q16ang)+512)&2047]<<7;
pPlayer->vel.y -= sintable[fix16_to_int(pPlayer->q16ang)&2047]<<7; pPlayer->vel.y -= sintable[fix16_to_int(pPlayer->q16ang)&2047]<<7;
continue; continue;
@ -1838,7 +1590,7 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
pPlayer->jumping_toggle = 1; pPlayer->jumping_toggle = 1;
} }
else else
P_ForceAngle(pPlayer); forceplayerangle(pPlayer);
continue; continue;
case concmd_ifgapzl: case concmd_ifgapzl:
@ -1846,7 +1598,8 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
VM_CONDITIONAL(((vm.pActor->floorz - vm.pActor->ceilingz) >> 8) < *insptr); VM_CONDITIONAL(((vm.pActor->floorz - vm.pActor->ceilingz) >> 8) < *insptr);
continue; continue;
case concmd_ifhitspace: VM_CONDITIONAL(TEST_SYNC_KEY(g_player[vm.playerNum].input->bits, SK_OPEN)); continue; case concmd_ifhitspace:
VM_CONDITIONAL(TEST_SYNC_KEY(g_player[vm.playerNum].input->bits, SK_OPEN)); continue;
case concmd_ifoutside: case concmd_ifoutside:
if (DEER) if (DEER)
@ -1857,7 +1610,8 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
VM_CONDITIONAL(sector[vm.pSprite->sectnum].ceilingstat & 1); VM_CONDITIONAL(sector[vm.pSprite->sectnum].ceilingstat & 1);
continue; continue;
case concmd_ifmultiplayer: VM_CONDITIONAL((g_netServer || g_netClient || ud.multimode > 1)); continue; case concmd_ifmultiplayer:
VM_CONDITIONAL((g_netServer || g_netClient || ud.multimode > 1)); continue;
case concmd_operate: case concmd_operate:
insptr++; insptr++;
@ -1885,7 +1639,8 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
} }
continue; continue;
case concmd_ifinspace: VM_CONDITIONAL(fi.ceilingspace(vm.pSprite->sectnum)); continue; case concmd_ifinspace:
VM_CONDITIONAL(fi.ceilingspace(vm.pSprite->sectnum)); continue;
case concmd_spritepal: case concmd_spritepal:
insptr++; insptr++;
@ -1899,7 +1654,8 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
vm.pSprite->picnum = *insptr++; vm.pSprite->picnum = *insptr++;
continue; continue;
case concmd_ifbulletnear: VM_CONDITIONAL(dodge(vm.pSprite) == 1); continue; case concmd_ifbulletnear:
VM_CONDITIONAL(dodge(vm.pSprite) == 1); continue;
case concmd_ifrespawn: case concmd_ifrespawn:
if (A_CheckEnemySprite(vm.pSprite)) if (A_CheckEnemySprite(vm.pSprite))
@ -2045,9 +1801,11 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
P_DoQuote(*(insptr++) | MAXQUOTES, pPlayer); P_DoQuote(*(insptr++) | MAXQUOTES, pPlayer);
continue; continue;
case concmd_ifinouterspace: VM_CONDITIONAL(fi.floorspace(vm.pSprite->sectnum)); continue; case concmd_ifinouterspace:
VM_CONDITIONAL(fi.floorspace(vm.pSprite->sectnum)); continue;
case concmd_ifnotmoving: VM_CONDITIONAL((vm.pActor->movflag & 49152) > 16384); continue; case concmd_ifnotmoving:
VM_CONDITIONAL((vm.pActor->movflag & 49152) > 16384); continue;
case concmd_respawnhitag: case concmd_respawnhitag:
insptr++; insptr++;
@ -2163,6 +1921,41 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
VM_CONDITIONAL(tw); VM_CONDITIONAL(tw);
continue; continue;
case concmd_enda:
case concmd_break:
case concmd_ends:
case concmd_endevent:
case concmd_ifrnd:
case concmd_ifactornotstayput:
case concmd_ifsquished:
case concmd_ifdead:
case concmd_ifhitweapon:
case concmd_addstrength:
case concmd_strength:
case concmd_rndmove:
case concmd_tip:
case concmd_nullop:
case concmd_money:
case concmd_mail:
case concmd_sleeptime:
case concmd_paper:
case concmd_lotsofglass:
case concmd_killit:
case concmd_leftbrace:
case concmd_rightbrace:
case concmd_else:
case concmd_state:
case concmd_ifcanshoottarget:
case concmd_ifcanseetarget:
case concmd_ifnocover:
case concmd_ifcansee:
if (parse()) goto out;
if (killit_flag & 1) vm.flags |= VM_KILL;
if (killit_flag & 2) vm.flags |= VM_NOEXECUTE;
killit_flag = 0;
continue;
default: // you aren't supposed to be here! default: // you aren't supposed to be here!
if (RR && ud.recstat == 2) if (RR && ud.recstat == 2)
{ {
@ -2175,6 +1968,10 @@ GAMEEXEC_STATIC void VM_Execute(native_t loop)
break; break;
} }
} }
out:
if (killit_flag & 1) vm.flags |= VM_KILL;
if (killit_flag & 2) vm.flags |= VM_NOEXECUTE;
killit_flag = 0;
} }
void VM_UpdateAnim(int spriteNum, int32_t *pData) void VM_UpdateAnim(int spriteNum, int32_t *pData)
@ -2202,6 +1999,12 @@ void VM_UpdateAnim(int spriteNum, int32_t *pData)
} }
} }
extern int g_i, g_p;
extern int g_x;
extern int* g_t;
extern uint8_t killit_flag;
extern spritetype* g_sp;
// NORECURSE // NORECURSE
void A_Execute(int spriteNum, int playerNum, int playerDist) void A_Execute(int spriteNum, int playerNum, int playerDist)
{ {
@ -2211,6 +2014,13 @@ void A_Execute(int spriteNum, int playerNum, int playerDist)
= { spriteNum, playerNum, playerDist, 0, &sprite[spriteNum], &actor[spriteNum].t_data[0], g_player[playerNum].ps, &actor[spriteNum] }; = { spriteNum, playerNum, playerDist, 0, &sprite[spriteNum], &actor[spriteNum].t_data[0], g_player[playerNum].ps, &actor[spriteNum] };
vm = tempvm; vm = tempvm;
g_i = spriteNum;
g_p = playerNum;
g_x = playerDist;
g_sp = &sprite[spriteNum];
g_t = &actor[spriteNum].t_data[0];
killit_flag = 0;
/* /*
if (g_netClient && A_CheckSpriteFlags(spriteNum, SFLAG_NULL)) if (g_netClient && A_CheckSpriteFlags(spriteNum, SFLAG_NULL))
{ {

View file

@ -4202,11 +4202,11 @@ static int32_t P_DoCounters(int playerNum)
if (RRRA) if (RRRA)
{ {
if (g_windTime > 0) if (WindTime > 0)
g_windTime--; WindTime--;
else if ((krand2() & 127) == 8) else if ((krand2() & 127) == 8)
{ {
g_windTime = 120+((krand2()&63)<<2); WindTime = 120+((krand2()&63)<<2);
WindDir = krand2()&2047; WindDir = krand2()&2047;
} }

View file

@ -1163,7 +1163,7 @@ static void resetprestat(int playerNum, int gameMode)
if (RRRA) if (RRRA)
{ {
g_windTime = 0; WindTime = 0;
WindDir = 0; WindDir = 0;
fakebubba_spawn = 0; fakebubba_spawn = 0;
RRRA_ExitedLevel = 0; RRRA_ExitedLevel = 0;
@ -1322,7 +1322,7 @@ static void prelevel(char g)
g_chickenPlant = 0; g_chickenPlant = 0;
if (RRRA) if (RRRA)
{ {
g_windTime = 0; WindTime = 0;
WindDir = 0; WindDir = 0;
fakebubba_spawn = 0; fakebubba_spawn = 0;
RRRA_ExitedLevel = 0; RRRA_ExitedLevel = 0;

View file

@ -894,7 +894,7 @@ static const dataspec_t svgm_anmisc[] =
{ 0, &g_geoSectorY2[0], sizeof(g_geoSectorY2[0]), ARRAY_SIZE(g_geoSectorY2) }, { 0, &g_geoSectorY2[0], sizeof(g_geoSectorY2[0]), ARRAY_SIZE(g_geoSectorY2) },
{ 0, &g_geoSectorCnt, sizeof(g_geoSectorCnt), 1 }, { 0, &g_geoSectorCnt, sizeof(g_geoSectorCnt), 1 },
{ 0, &g_windTime, sizeof(g_windTime), 1 }, { 0, &WindTime, sizeof(WindTime), 1 },
{ 0, &WindDir, sizeof(WindDir), 1 }, { 0, &WindDir, sizeof(WindDir), 1 },
{ 0, &fakebubba_spawn, sizeof(fakebubba_spawn), 1 }, { 0, &fakebubba_spawn, sizeof(fakebubba_spawn), 1 },
{ 0, &mamaspawn_count, sizeof(mamaspawn_count), 1 }, { 0, &mamaspawn_count, sizeof(mamaspawn_count), 1 },