Duke3d: replace VM_CONDITIONAL macro with a lambda

# Conflicts:
#	source/duke3d/src/gameexec.cpp
This commit is contained in:
Richard C. Gobeille 2020-05-06 05:13:01 -07:00 committed by Christoph Oelckers
parent c0160065e4
commit 1f82cfa3bf

View file

@ -1393,19 +1393,17 @@ static void ResizeArray(int const arrayNum, int const newSize)
} \ } \
} while (0) } while (0)
// be careful when changing this--the assignment used as a condition doubles as a null pointer check
#define VM_CONDITIONAL(xxx) \
do \
{ \
if ((xxx) || ((insptr = (intptr_t *)insptr[1]) && (VM_DECODE_INST(*insptr) == CON_ELSE))) \
{ \
insptr += 2; \
VM_Execute(); \
} \
} while (0)
GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/) GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
// be careful when changing this--the assignment used as a condition doubles as the nullptr check!
auto branch = [&](int x) {
if (x || ((insptr = (intptr_t *)insptr[1]) && (VM_DECODE_INST(*insptr) == CON_ELSE)))
{
insptr += 2;
VM_Execute();
}
};
int vm_execution_depth = loop; int vm_execution_depth = loop;
#ifdef CON_USE_COMPUTED_GOTO #ifdef CON_USE_COMPUTED_GOTO
static void *const jumpTable[] = JUMP_TABLE_ARRAY_LITERAL; static void *const jumpTable[] = JUMP_TABLE_ARRAY_LITERAL;
@ -1449,77 +1447,77 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
vInstruction(CON_IFVARE_GLOBAL): vInstruction(CON_IFVARE_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw == *insptr); branch(tw == *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARN_GLOBAL): vInstruction(CON_IFVARN_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw != *insptr); branch(tw != *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAND_GLOBAL): vInstruction(CON_IFVARAND_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw & *insptr); branch(tw & *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAROR_GLOBAL): vInstruction(CON_IFVAROR_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw | *insptr); branch(tw | *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARXOR_GLOBAL): vInstruction(CON_IFVARXOR_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw ^ *insptr); branch(tw ^ *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAREITHER_GLOBAL): vInstruction(CON_IFVAREITHER_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw || *insptr); branch(tw || *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBOTH_GLOBAL): vInstruction(CON_IFVARBOTH_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw && *insptr); branch(tw && *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARG_GLOBAL): vInstruction(CON_IFVARG_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw > *insptr); branch(tw > *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARGE_GLOBAL): vInstruction(CON_IFVARGE_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw >= *insptr); branch(tw >= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARL_GLOBAL): vInstruction(CON_IFVARL_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw < *insptr); branch(tw < *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARLE_GLOBAL): vInstruction(CON_IFVARLE_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL(tw <= *insptr); branch(tw <= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARA_GLOBAL): vInstruction(CON_IFVARA_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL((uint32_t)tw > (uint32_t)*insptr); branch((uint32_t)tw > (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAE_GLOBAL): vInstruction(CON_IFVARAE_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL((uint32_t)tw >= (uint32_t)*insptr); branch((uint32_t)tw >= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARB_GLOBAL): vInstruction(CON_IFVARB_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL((uint32_t)tw < (uint32_t)*insptr); branch((uint32_t)tw < (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBE_GLOBAL): vInstruction(CON_IFVARBE_GLOBAL):
insptr++; insptr++;
tw = aGameVars[*insptr++].global; tw = aGameVars[*insptr++].global;
VM_CONDITIONAL((uint32_t)tw <= (uint32_t)*insptr); branch((uint32_t)tw <= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_SETVAR_GLOBAL): vInstruction(CON_SETVAR_GLOBAL):
@ -1571,77 +1569,77 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
vInstruction(CON_IFVARE_ACTOR): vInstruction(CON_IFVARE_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw == *insptr); branch(tw == *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARN_ACTOR): vInstruction(CON_IFVARN_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw != *insptr); branch(tw != *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAND_ACTOR): vInstruction(CON_IFVARAND_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw & *insptr); branch(tw & *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAROR_ACTOR): vInstruction(CON_IFVAROR_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw | *insptr); branch(tw | *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARXOR_ACTOR): vInstruction(CON_IFVARXOR_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw ^ *insptr); branch(tw ^ *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAREITHER_ACTOR): vInstruction(CON_IFVAREITHER_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw || *insptr); branch(tw || *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBOTH_ACTOR): vInstruction(CON_IFVARBOTH_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw && *insptr); branch(tw && *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARG_ACTOR): vInstruction(CON_IFVARG_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw > *insptr); branch(tw > *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARGE_ACTOR): vInstruction(CON_IFVARGE_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw >= *insptr); branch(tw >= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARL_ACTOR): vInstruction(CON_IFVARL_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw < *insptr); branch(tw < *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARLE_ACTOR): vInstruction(CON_IFVARLE_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL(tw <= *insptr); branch(tw <= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARA_ACTOR): vInstruction(CON_IFVARA_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL((uint32_t)tw > (uint32_t)*insptr); branch((uint32_t)tw > (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAE_ACTOR): vInstruction(CON_IFVARAE_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL((uint32_t)tw >= (uint32_t)*insptr); branch((uint32_t)tw >= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARB_ACTOR): vInstruction(CON_IFVARB_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL((uint32_t)tw < (uint32_t)*insptr); branch((uint32_t)tw < (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBE_ACTOR): vInstruction(CON_IFVARBE_ACTOR):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)]; tw = aGameVars[*insptr++].pValues[vm.spriteNum & (MAXSPRITES-1)];
VM_CONDITIONAL((uint32_t)tw <= (uint32_t)*insptr); branch((uint32_t)tw <= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_SETVAR_ACTOR): vInstruction(CON_SETVAR_ACTOR):
@ -1693,77 +1691,77 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
vInstruction(CON_IFVARE_PLAYER): vInstruction(CON_IFVARE_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw == *insptr); branch(tw == *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARN_PLAYER): vInstruction(CON_IFVARN_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw != *insptr); branch(tw != *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAND_PLAYER): vInstruction(CON_IFVARAND_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw & *insptr); branch(tw & *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAROR_PLAYER): vInstruction(CON_IFVAROR_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw | *insptr); branch(tw | *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARXOR_PLAYER): vInstruction(CON_IFVARXOR_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw ^ *insptr); branch(tw ^ *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAREITHER_PLAYER): vInstruction(CON_IFVAREITHER_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw || *insptr); branch(tw || *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBOTH_PLAYER): vInstruction(CON_IFVARBOTH_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw && *insptr); branch(tw && *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARG_PLAYER): vInstruction(CON_IFVARG_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw > *insptr); branch(tw > *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARGE_PLAYER): vInstruction(CON_IFVARGE_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw >= *insptr); branch(tw >= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARL_PLAYER): vInstruction(CON_IFVARL_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw < *insptr); branch(tw < *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARLE_PLAYER): vInstruction(CON_IFVARLE_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL(tw <= *insptr); branch(tw <= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARA_PLAYER): vInstruction(CON_IFVARA_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL((uint32_t)tw > (uint32_t)*insptr); branch((uint32_t)tw > (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAE_PLAYER): vInstruction(CON_IFVARAE_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL((uint32_t)tw >= (uint32_t)*insptr); branch((uint32_t)tw >= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARB_PLAYER): vInstruction(CON_IFVARB_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL((uint32_t)tw < (uint32_t)*insptr); branch((uint32_t)tw < (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBE_PLAYER): vInstruction(CON_IFVARBE_PLAYER):
insptr++; insptr++;
tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)]; tw = aGameVars[*insptr++].pValues[vm.playerNum & (MAXPLAYERS-1)];
VM_CONDITIONAL((uint32_t)tw <= (uint32_t)*insptr); branch((uint32_t)tw <= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_SETVAR_PLAYER): vInstruction(CON_SETVAR_PLAYER):
@ -1819,7 +1817,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (aGameVars[insptr[-1]].global != *insptr); tw = (aGameVars[insptr[-1]].global != *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -1831,7 +1829,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (aGameVars[insptr[-1]].global < *insptr); tw = (aGameVars[insptr[-1]].global < *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -1844,7 +1842,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (v != *insptr); tw = (v != *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
@ -1858,7 +1856,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (v < *insptr); tw = (v < *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
@ -1872,7 +1870,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (v != *insptr); tw = (v != *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
@ -1886,7 +1884,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (v < *insptr); tw = (v < *insptr);
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
@ -1912,83 +1910,83 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
vInstruction(CON_IFVARAND): vInstruction(CON_IFVARAND):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw & *insptr); branch(tw & *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAROR): vInstruction(CON_IFVAROR):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw | *insptr); branch(tw | *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARXOR): vInstruction(CON_IFVARXOR):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw ^ *insptr); branch(tw ^ *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVAREITHER): vInstruction(CON_IFVAREITHER):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw || *insptr); branch(tw || *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBOTH): vInstruction(CON_IFVARBOTH):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw && *insptr); branch(tw && *insptr);
dispatch(); dispatch();
vInstruction(CON_IFRND): vInstruction(CON_IFRND):
VM_CONDITIONAL(rnd(*(++insptr))); branch(rnd(*(++insptr)));
dispatch(); dispatch();
vInstruction(CON_IFVARG): vInstruction(CON_IFVARG):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw > *insptr); branch(tw > *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARGE): vInstruction(CON_IFVARGE):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw >= *insptr); branch(tw >= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARL): vInstruction(CON_IFVARL):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw < *insptr); branch(tw < *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARLE): vInstruction(CON_IFVARLE):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw <= *insptr); branch(tw <= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARA): vInstruction(CON_IFVARA):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL((uint32_t)tw > (uint32_t)*insptr); branch((uint32_t)tw > (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARAE): vInstruction(CON_IFVARAE):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL((uint32_t)tw >= (uint32_t)*insptr); branch((uint32_t)tw >= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARB): vInstruction(CON_IFVARB):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL((uint32_t)tw < (uint32_t)*insptr); branch((uint32_t)tw < (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARBE): vInstruction(CON_IFVARBE):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL((uint32_t)tw <= (uint32_t)*insptr); branch((uint32_t)tw <= (uint32_t)*insptr);
dispatch(); dispatch();
vInstruction(CON_SETVARVAR): vInstruction(CON_SETVARVAR):
@ -2096,13 +2094,13 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
vInstruction(CON_IFVARE): vInstruction(CON_IFVARE):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw == *insptr); branch(tw == *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARN): vInstruction(CON_IFVARN):
insptr++; insptr++;
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
VM_CONDITIONAL(tw != *insptr); branch(tw != *insptr);
dispatch(); dispatch();
vInstruction(CON_IFVARVARE): vInstruction(CON_IFVARVARE):
@ -2110,7 +2108,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw == Gv_GetVar(*insptr++)); tw = (tw == Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARN): vInstruction(CON_IFVARVARN):
@ -2118,7 +2116,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw != Gv_GetVar(*insptr++)); tw = (tw != Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARG): vInstruction(CON_IFVARVARG):
@ -2126,7 +2124,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw > Gv_GetVar(*insptr++)); tw = (tw > Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARGE): vInstruction(CON_IFVARVARGE):
@ -2134,7 +2132,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw >= Gv_GetVar(*insptr++)); tw = (tw >= Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARL): vInstruction(CON_IFVARVARL):
@ -2142,7 +2140,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw < Gv_GetVar(*insptr++)); tw = (tw < Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARLE): vInstruction(CON_IFVARVARLE):
@ -2150,7 +2148,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (tw <= Gv_GetVar(*insptr++)); tw = (tw <= Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARA): vInstruction(CON_IFVARVARA):
@ -2158,7 +2156,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = ((uint32_t)tw > (uint32_t)Gv_GetVar(*insptr++)); tw = ((uint32_t)tw > (uint32_t)Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARAE): vInstruction(CON_IFVARVARAE):
@ -2166,7 +2164,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = ((uint32_t)tw >= (uint32_t)Gv_GetVar(*insptr++)); tw = ((uint32_t)tw >= (uint32_t)Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARB): vInstruction(CON_IFVARVARB):
@ -2174,7 +2172,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = ((uint32_t)tw < (uint32_t)Gv_GetVar(*insptr++)); tw = ((uint32_t)tw < (uint32_t)Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARBE): vInstruction(CON_IFVARVARBE):
@ -2182,7 +2180,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = ((uint32_t)tw <= (uint32_t)Gv_GetVar(*insptr++)); tw = ((uint32_t)tw <= (uint32_t)Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARAND): vInstruction(CON_IFVARVARAND):
@ -2190,7 +2188,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw &= Gv_GetVar(*insptr++); tw &= Gv_GetVar(*insptr++);
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVAROR): vInstruction(CON_IFVARVAROR):
@ -2198,7 +2196,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw |= Gv_GetVar(*insptr++); tw |= Gv_GetVar(*insptr++);
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARXOR): vInstruction(CON_IFVARVARXOR):
@ -2206,7 +2204,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw ^= Gv_GetVar(*insptr++); tw ^= Gv_GetVar(*insptr++);
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVAREITHER): vInstruction(CON_IFVARVAREITHER):
@ -2214,7 +2212,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (Gv_GetVar(*insptr++) || tw); tw = (Gv_GetVar(*insptr++) || tw);
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_IFVARVARBOTH): vInstruction(CON_IFVARVARBOTH):
@ -2222,7 +2220,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(*insptr++); tw = Gv_GetVar(*insptr++);
tw = (Gv_GetVar(*insptr++) && tw); tw = (Gv_GetVar(*insptr++) && tw);
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_WHILEVARN): vInstruction(CON_WHILEVARN):
@ -2231,8 +2229,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
do do
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (Gv_GetVar(insptr[-1]) != *insptr); branch((tw = (Gv_GetVar(insptr[-1]) != *insptr)));
VM_CONDITIONAL(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -2246,7 +2243,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(insptr[-1]); tw = Gv_GetVar(insptr[-1]);
tw = (tw != Gv_GetVar(*insptr++)); tw = (tw != Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -2257,8 +2254,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
do do
{ {
insptr = savedinsptr; insptr = savedinsptr;
tw = (Gv_GetVar(insptr[-1]) < *insptr); branch((tw = (Gv_GetVar(insptr[-1]) < *insptr)));
VM_CONDITIONAL(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -2272,7 +2268,7 @@ GAMEEXEC_STATIC void VM_Execute(int const loop /*= false*/)
tw = Gv_GetVar(insptr[-1]); tw = Gv_GetVar(insptr[-1]);
tw = (tw < Gv_GetVar(*insptr++)); tw = (tw < Gv_GetVar(*insptr++));
insptr--; insptr--;
VM_CONDITIONAL(tw); branch(tw);
} while (tw); } while (tw);
dispatch(); dispatch();
} }
@ -2900,22 +2896,22 @@ badindex:
#define CHECK_PICNUM(x) \ #define CHECK_PICNUM(x) \
if ((unsigned)x < MAXSPRITES && sprite[x].picnum == vm.pSprite->picnum) \ if ((unsigned)x < MAXSPRITES && sprite[x].picnum == vm.pSprite->picnum) \
{ \ { \
VM_CONDITIONAL(0); \ branch(false); \
dispatch(); \ dispatch(); \
} }
#define CHECK_HIT_SPRITE(x) \
vm.pSprite->ang += x; \
tw = A_CheckHitSprite(vm.spriteNum, &temphit); \
vm.pSprite->ang -= x;
if (vm.playerDist > 1024) if (vm.playerDist > 1024)
{ {
int16_t temphit; int16_t temphit;
auto checkHitSprite = [&](int x) {
vm.pSprite->ang += x;
tw = A_CheckHitSprite(vm.spriteNum, &temphit);
vm.pSprite->ang -= x;
};
if ((tw = A_CheckHitSprite(vm.spriteNum, &temphit)) == (1 << 30)) if ((tw = A_CheckHitSprite(vm.spriteNum, &temphit)) == (1 << 30))
{ {
VM_CONDITIONAL(1); branch(true);
dispatch(); dispatch();
} }
@ -2931,171 +2927,170 @@ badindex:
if (tw > dist) if (tw > dist)
{ {
CHECK_PICNUM(temphit); CHECK_PICNUM(temphit);
CHECK_HIT_SPRITE(angDiff); checkHitSprite(angDiff);
if (tw > dist) if (tw > dist)
{ {
CHECK_PICNUM(temphit); CHECK_PICNUM(temphit);
CHECK_HIT_SPRITE(-angDiff); checkHitSprite(-angDiff);
if (tw > 768) if (tw > 768)
{ {
CHECK_PICNUM(temphit); CHECK_PICNUM(temphit);
VM_CONDITIONAL(1); branch(true);
dispatch(); dispatch();
} }
} }
} }
VM_CONDITIONAL(0); branch(false);
dispatch(); dispatch();
} }
VM_CONDITIONAL(1); branch(true);
#undef CHECK_PICNUM #undef CHECK_PICNUM
#undef CHECK_HIT_SPRITE
} }
dispatch(); dispatch();
vInstruction(CON_IFCANSEETARGET): vInstruction(CON_IFCANSEETARGET):
tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - ((krand() & 41) << 8), vm.pSprite->sectnum, vm.pPlayer->pos.x, vm.pPlayer->pos.y, tw = cansee(vm.pSprite->x, vm.pSprite->y, vm.pSprite->z - ((krand() & 41) << 8), vm.pSprite->sectnum, vm.pPlayer->pos.x, vm.pPlayer->pos.y,
vm.pPlayer->pos.z /*-((krand()&41)<<8)*/, sprite[vm.pPlayer->i].sectnum); vm.pPlayer->pos.z /*-((krand()&41)<<8)*/, sprite[vm.pPlayer->i].sectnum);
VM_CONDITIONAL(tw); branch(tw);
if (tw) if (tw)
vm.pActor->timetosleep = SLEEPTIME; vm.pActor->timetosleep = SLEEPTIME;
dispatch(); dispatch();
vInstruction(CON_IFACTION): vInstruction(CON_IFACTION):
VM_CONDITIONAL(AC_ACTION_ID(vm.pData) == *(++insptr)); branch(AC_ACTION_ID(vm.pData) == *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFACTIONCOUNT): vInstruction(CON_IFACTIONCOUNT):
VM_CONDITIONAL(AC_ACTION_COUNT(vm.pData) >= *(++insptr)); branch(AC_ACTION_COUNT(vm.pData) >= *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFACTOR): vInstruction(CON_IFACTOR):
VM_CONDITIONAL(vm.pSprite->picnum == *(++insptr)); branch(vm.pSprite->picnum == *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFACTORNOTSTAYPUT): vInstruction(CON_IFACTORNOTSTAYPUT):
VM_CONDITIONAL(vm.pActor->stayput == -1); branch(vm.pActor->stayput == -1);
dispatch(); dispatch();
vInstruction(CON_IFAI): vInstruction(CON_IFAI):
VM_CONDITIONAL(AC_AI_ID(vm.pData) == *(++insptr)); branch(AC_AI_ID(vm.pData) == *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFBULLETNEAR): vInstruction(CON_IFBULLETNEAR):
VM_CONDITIONAL(A_Dodge(vm.pSprite) == 1); branch(A_Dodge(vm.pSprite) == 1);
dispatch(); dispatch();
vInstruction(CON_IFCEILINGDISTL): vInstruction(CON_IFCEILINGDISTL):
VM_CONDITIONAL((vm.pSprite->z - vm.pActor->ceilingz) <= (*(++insptr) << 8)); branch((vm.pSprite->z - vm.pActor->ceilingz) <= (*(++insptr) << 8));
dispatch(); dispatch();
vInstruction(CON_IFCLIENT): vInstruction(CON_IFCLIENT):
VM_CONDITIONAL(g_netClient != NULL); branch(g_netClient != NULL);
dispatch(); dispatch();
vInstruction(CON_IFCOUNT): vInstruction(CON_IFCOUNT):
VM_CONDITIONAL(AC_COUNT(vm.pData) >= *(++insptr)); branch(AC_COUNT(vm.pData) >= *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFDEAD): vInstruction(CON_IFDEAD):
VM_CONDITIONAL(vm.pSprite->extra <= 0); branch(vm.pSprite->extra <= 0);
dispatch(); dispatch();
vInstruction(CON_IFFLOORDISTL): vInstruction(CON_IFFLOORDISTL):
VM_CONDITIONAL((vm.pActor->floorz - vm.pSprite->z) <= (*(++insptr) << 8)); branch((vm.pActor->floorz - vm.pSprite->z) <= (*(++insptr) << 8));
dispatch(); dispatch();
vInstruction(CON_IFGAPZL): vInstruction(CON_IFGAPZL):
VM_CONDITIONAL(((vm.pActor->floorz - vm.pActor->ceilingz) >> 8) < *(++insptr)); branch(((vm.pActor->floorz - vm.pActor->ceilingz) >> 8) < *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFHITSPACE): vInstruction(CON_IFHITSPACE):
VM_CONDITIONAL(TEST_SYNC_KEY(g_player[vm.playerNum].input->bits, SK_OPEN)); branch(TEST_SYNC_KEY(g_player[vm.playerNum].input->bits, SK_OPEN));
dispatch(); dispatch();
vInstruction(CON_IFHITWEAPON): vInstruction(CON_IFHITWEAPON):
VM_CONDITIONAL(A_IncurDamage(vm.spriteNum) >= 0); branch(A_IncurDamage(vm.spriteNum) >= 0);
dispatch(); dispatch();
vInstruction(CON_IFINSPACE): vInstruction(CON_IFINSPACE):
VM_CONDITIONAL(G_CheckForSpaceCeiling(vm.pSprite->sectnum)); branch(G_CheckForSpaceCeiling(vm.pSprite->sectnum));
dispatch(); dispatch();
vInstruction(CON_IFINWATER): vInstruction(CON_IFINWATER):
VM_CONDITIONAL(sector[vm.pSprite->sectnum].lotag == ST_2_UNDERWATER); branch(sector[vm.pSprite->sectnum].lotag == ST_2_UNDERWATER);
dispatch(); dispatch();
vInstruction(CON_IFONWATER): vInstruction(CON_IFONWATER):
VM_CONDITIONAL(sector[vm.pSprite->sectnum].lotag == ST_1_ABOVE_WATER branch(sector[vm.pSprite->sectnum].lotag == ST_1_ABOVE_WATER
&& klabs(vm.pSprite->z - sector[vm.pSprite->sectnum].floorz) < ZOFFSET5); && klabs(vm.pSprite->z - sector[vm.pSprite->sectnum].floorz) < ZOFFSET5);
dispatch(); dispatch();
vInstruction(CON_IFMOVE): vInstruction(CON_IFMOVE):
VM_CONDITIONAL(AC_MOVE_ID(vm.pData) == *(++insptr)); branch(AC_MOVE_ID(vm.pData) == *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFMULTIPLAYER): vInstruction(CON_IFMULTIPLAYER):
VM_CONDITIONAL((g_netServer || g_netClient || ud.multimode > 1)); branch((g_netServer || g_netClient || ud.multimode > 1));
dispatch(); dispatch();
vInstruction(CON_IFOUTSIDE): vInstruction(CON_IFOUTSIDE):
VM_CONDITIONAL(sector[vm.pSprite->sectnum].ceilingstat & 1); branch(sector[vm.pSprite->sectnum].ceilingstat & 1);
dispatch(); dispatch();
vInstruction(CON_IFPLAYBACKON): vInstruction(CON_IFPLAYBACKON):
VM_CONDITIONAL(0); branch(false);
dispatch(); dispatch();
vInstruction(CON_IFPLAYERSL): vInstruction(CON_IFPLAYERSL):
VM_CONDITIONAL(numplayers < *(++insptr)); branch(numplayers < *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFSERVER): vInstruction(CON_IFSERVER):
VM_CONDITIONAL(g_netServer != NULL); branch(g_netServer != NULL);
dispatch(); dispatch();
vInstruction(CON_IFSQUISHED): vInstruction(CON_IFSQUISHED):
VM_CONDITIONAL(VM_CheckSquished()); branch(VM_CheckSquished());
dispatch(); dispatch();
vInstruction(CON_IFSTRENGTH): vInstruction(CON_IFSTRENGTH):
VM_CONDITIONAL(vm.pSprite->extra <= *(++insptr)); branch(vm.pSprite->extra <= *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFSPAWNEDBY): vInstruction(CON_IFSPAWNEDBY):
vInstruction(CON_IFWASWEAPON): vInstruction(CON_IFWASWEAPON):
VM_CONDITIONAL(vm.pActor->picnum == *(++insptr)); branch(vm.pActor->picnum == *(++insptr));
dispatch(); dispatch();
vInstruction(CON_IFPDISTL): vInstruction(CON_IFPDISTL):
VM_CONDITIONAL(vm.playerDist < *(++insptr)); branch(vm.playerDist < *(++insptr));
if (vm.playerDist > MAXSLEEPDIST && vm.pActor->timetosleep == 0) if (vm.playerDist > MAXSLEEPDIST && vm.pActor->timetosleep == 0)
vm.pActor->timetosleep = SLEEPTIME; vm.pActor->timetosleep = SLEEPTIME;
dispatch(); dispatch();
vInstruction(CON_IFPDISTG): vInstruction(CON_IFPDISTG):
VM_CONDITIONAL(vm.playerDist > *(++insptr)); branch(vm.playerDist > *(++insptr));
if (vm.playerDist > MAXSLEEPDIST && vm.pActor->timetosleep == 0) if (vm.playerDist > MAXSLEEPDIST && vm.pActor->timetosleep == 0)
vm.pActor->timetosleep = SLEEPTIME; vm.pActor->timetosleep = SLEEPTIME;
dispatch(); dispatch();
vInstruction(CON_IFRESPAWN): vInstruction(CON_IFRESPAWN):
if (A_CheckEnemySprite(vm.pSprite)) if (A_CheckEnemySprite(vm.pSprite))
VM_CONDITIONAL(ud.respawn_monsters); branch(ud.respawn_monsters);
else if (A_CheckInventorySprite(vm.pSprite)) else if (A_CheckInventorySprite(vm.pSprite))
VM_CONDITIONAL(ud.respawn_inventory); branch(ud.respawn_inventory);
else else
VM_CONDITIONAL(ud.respawn_items); branch(ud.respawn_items);
dispatch(); dispatch();
vInstruction(CON_IFINOUTERSPACE): vInstruction(CON_IFINOUTERSPACE):
VM_CONDITIONAL(G_CheckForSpaceFloor(vm.pSprite->sectnum)); branch(G_CheckForSpaceFloor(vm.pSprite->sectnum));
dispatch(); dispatch();
vInstruction(CON_IFNOTMOVING): vInstruction(CON_IFNOTMOVING):
VM_CONDITIONAL((vm.pActor->movflag & 49152) > 16384); branch((vm.pActor->movflag & 49152) > 16384);
dispatch(); dispatch();
vInstruction(CON_IFCANSEE): vInstruction(CON_IFCANSEE):
@ -3142,7 +3137,7 @@ badindex:
if (tw && (vm.pSprite->statnum == STAT_ACTOR || vm.pSprite->statnum == STAT_STANDABLE)) if (tw && (vm.pSprite->statnum == STAT_ACTOR || vm.pSprite->statnum == STAT_STANDABLE))
vm.pActor->timetosleep = SLEEPTIME; vm.pActor->timetosleep = SLEEPTIME;
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
} }
@ -3196,17 +3191,17 @@ badindex:
if (vm.pPlayer->weaprecs[j] == vm.pSprite->picnum) if (vm.pPlayer->weaprecs[j] == vm.pSprite->picnum)
break; break;
VM_CONDITIONAL(j < vm.pPlayer->weapreccnt && vm.pSprite->owner == vm.spriteNum); branch(j < vm.pPlayer->weapreccnt && vm.pSprite->owner == vm.spriteNum);
dispatch(); dispatch();
} }
else if (vm.pPlayer->weapreccnt < MAX_WEAPONS) else if (vm.pPlayer->weapreccnt < MAX_WEAPONS)
{ {
vm.pPlayer->weaprecs[vm.pPlayer->weapreccnt++] = vm.pSprite->picnum; vm.pPlayer->weaprecs[vm.pPlayer->weapreccnt++] = vm.pSprite->picnum;
VM_CONDITIONAL(vm.pSprite->owner == vm.spriteNum); branch(vm.pSprite->owner == vm.spriteNum);
dispatch(); dispatch();
} }
} }
VM_CONDITIONAL(0); branch(false);
dispatch(); dispatch();
vInstruction(CON_GETLASTPAL): vInstruction(CON_GETLASTPAL):
@ -3284,7 +3279,7 @@ badindex:
VM_ASSERT((unsigned)soundNum < MAXSOUNDS, "invalid sound %d\n", soundNum); VM_ASSERT((unsigned)soundNum < MAXSOUNDS, "invalid sound %d\n", soundNum);
insptr--; insptr--;
VM_CONDITIONAL(A_CheckSoundPlaying(spriteNum, soundNum)); branch(A_CheckSoundPlaying(spriteNum, soundNum));
} }
dispatch(); dispatch();
@ -3294,7 +3289,7 @@ badindex:
CON_ERRPRINTF("invalid sound %d\n", (int32_t)*insptr); CON_ERRPRINTF("invalid sound %d\n", (int32_t)*insptr);
abort_after_error(); abort_after_error();
} }
VM_CONDITIONAL(S_CheckSoundPlaying(*insptr)); branch(S_CheckSoundPlaying(*insptr));
// VM_DoConditional(SoundOwner[*insptr][0].ow == vm.spriteNum); // VM_DoConditional(SoundOwner[*insptr][0].ow == vm.spriteNum);
dispatch(); dispatch();
@ -4266,7 +4261,7 @@ badindex:
if (VM_DECODE_INST(tw) == CON_IFCUTSCENE) if (VM_DECODE_INST(tw) == CON_IFCUTSCENE)
{ {
insptr--; insptr--;
VM_CONDITIONAL(g_animPtr == Anim_Find(quoteMgr.GetQuote(nQuote))); branch(g_animPtr == Anim_Find(quoteMgr.GetQuote(nQuote)));
dispatch(); dispatch();
} }
@ -5053,7 +5048,7 @@ badindex:
nResult = (nResult > -128 && nResult < 128); nResult = (nResult > -128 && nResult < 128);
} }
VM_CONDITIONAL(nResult); branch(nResult);
} }
dispatch(); dispatch();
@ -6147,7 +6142,7 @@ badindex:
vInstruction(CON_IFPHEALTHL): vInstruction(CON_IFPHEALTHL):
insptr++; insptr++;
VM_CONDITIONAL(sprite[vm.pPlayer->i].extra < *insptr); branch(sprite[vm.pPlayer->i].extra < *insptr);
dispatch(); dispatch();
vInstruction(CON_IFPINVENTORY): vInstruction(CON_IFPINVENTORY):
@ -6176,7 +6171,7 @@ badindex:
dispatch(); dispatch();
} }
VM_CONDITIONAL(tw); branch(tw);
dispatch(); dispatch();
vInstruction(CON_PSTOMP): vInstruction(CON_PSTOMP):
@ -6227,7 +6222,7 @@ badindex:
} }
} }
VM_CONDITIONAL(tw); branch(tw);
#undef IFAWAYDIST #undef IFAWAYDIST
} }
@ -6294,16 +6289,16 @@ badindex:
vInstruction(CON_IFSPRITEPAL): vInstruction(CON_IFSPRITEPAL):
insptr++; insptr++;
VM_CONDITIONAL(vm.pSprite->pal == *insptr); branch(vm.pSprite->pal == *insptr);
dispatch(); dispatch();
vInstruction(CON_IFANGDIFFL): vInstruction(CON_IFANGDIFFL):
insptr++; insptr++;
tw = klabs(G_GetAngleDelta(fix16_to_int(vm.pPlayer->q16ang), vm.pSprite->ang)); tw = klabs(G_GetAngleDelta(fix16_to_int(vm.pPlayer->q16ang), vm.pSprite->ang));
VM_CONDITIONAL(tw <= *insptr); branch(tw <= *insptr);
dispatch(); dispatch();
vInstruction(CON_IFNOSOUNDS): VM_CONDITIONAL(!A_CheckAnySoundPlaying(vm.spriteNum)); dispatch(); vInstruction(CON_IFNOSOUNDS): branch(!A_CheckAnySoundPlaying(vm.spriteNum)); dispatch();
vInstruction(CON_SPRITEFLAGS): vInstruction(CON_SPRITEFLAGS):
insptr++; insptr++;