mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-03 23:10:48 +00:00
- step 1.
This commit is contained in:
parent
18d6a8e65d
commit
1b135ecb0b
11 changed files with 693 additions and 886 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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))
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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 },
|
||||||
|
|
Loading…
Reference in a new issue