some more functions for m32-script

git-svn-id: https://svn.eduke32.com/eduke32@1499 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2009-09-17 22:08:37 +00:00
parent d7951477f5
commit e7acafc9e7
7 changed files with 296 additions and 46 deletions

View file

@ -5,10 +5,16 @@ include names.h
gamevar i 0 1 // per-block (top-level, event, or state) variable gamevar i 0 1 // per-block (top-level, event, or state) variable
gamevar j 0 1 gamevar j 0 1
gamevar k 0 1
gamevar l 0 1
gamevar tmp 0 0
gamevar davr 65536 0 gamevar davr 65536 0
gamevar dayx 65536 0 gamevar dayx 65536 0
gamevar drawcol 9 0
define TQUOTE 3 define TQUOTE 3
definequote 0 OK definequote 0 OK
@ -20,16 +26,27 @@ definequote TQUOTE write on me!
definequote 4 ASPECT: VR=%d, YX=%d definequote 4 ASPECT: VR=%d, YX=%d
definequote 5 KEY:%d definequote 5 KEY:%d
definequote 6 time: %d ms
definequote 7 SPRITES:
gamearray ar 128 gamearray ar 128
gamearray parm 8 gamearray parm 8
defstate artest defstate artest
for j range 128 getarraysize ar tmp
resizearray ar 65536
getticks parm[2]
for j range 65536
set ar[j] j set ar[j] j
set i 0 set i 0
for j range 128 for j range 65536
add i ar[j] add i ar[j]
ife i 8128 quote 0 else quote 1 getticks parm[3]
resizearray ar tmp
ife i 2147450880 quote 0 else quote 1
sub parm[3] parm[2]
qsprintf TQUOTE 6 parm[3]
quote TQUOTE
ends ends
defstate setas defstate setas
@ -39,44 +56,92 @@ defstate setas
setaspect davr j setaspect davr j
ends ends
onevent EVENT_ANALYZESPRITES
for i drawnsprites
ifactor LIZTROOP spritepal 6
endevent
onevent EVENT_ENTER3DMODE onevent EVENT_ENTER3DMODE
state setas state setas
endevent endevent
onevent EVENT_ANALYZESPRITES
for i drawnsprites
{
switch tsprite[i].picnum
case LIZTROOP spritepal 1 break
case PIGCOP spritepal 2 break
case BOSS1 spritepal 6 break
endswitch
}
/*
for i drawnsprites
{
ife tsprite[i].picnum LIZTROOP spritepal 1 else
ife tsprite[i].picnum PIGCOP spritepal 2 else
ife tsprite[i].picnum BOSS1 spritepal 6
}
*/
endevent
defstate cmp_by_lotag
set RETURN sprite[SV2].lotag
sub RETURN sprite[SV1].lotag
ends
onevent EVENT_DRAW2DSCREEN onevent EVENT_DRAW2DSCREEN
ifl cursectnum 0 return
getarraysize ar tmp
set j 0
for i spritesofsector cursectnum
{
ifge j tmp nullop else
ifactor LOCATORS
{
set ar[j] i
add j 1
}
}
set tmp j
sort ar tmp cmp_by_lotag
sub tmp 1
for i range tmp
{
set j ar[i]
set k i, add k 1, set k ar[k]
drawline16b sprite[j].x sprite[j].y sprite[k].x sprite[k].y drawcol
}
/*
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 9
// set i totalclock */
// shiftr i 6
// drawcircle16b posx posy 256 i /*
// set j i set i totalclock
// add j 8 shiftr i 6
// drawcircle16 halfxdim16 midydim16 12 j drawcircle16b posx posy 256 i
// qsprintf 3 2 i j set j i
// printmessage16 3 add j 8
drawcircle16 halfxdim16 midydim16 12 j
qsprintf 3 2 i j
printmessage16 3
*/
endevent endevent
onevent EVENT_OVERHEADEDITOR onevent EVENT_OVERHEADEDITOR
for i range 27 for i range 27
{ {
ifkey alphakeys[i] ifholdkey alphakeys[i]
{ {
qsprintf TQUOTE 5 i qsprintf TQUOTE 5 i
quote TQUOTE quote TQUOTE
} }
} }
for i range 10 for i range 10
// ife 0 1
{ {
ifkey numberkeys[i] ifholdkey numberkeys[i]
{ {
qsprintf TQUOTE 5 i qsprintf TQUOTE 5 i
quote TQUOTE quote TQUOTE
@ -88,14 +153,39 @@ onevent EVENT_KEYS3D
for i range 10 for i range 10
// ife 0 1 // ife 0 1
{ {
ifkey numberkeys[i] ifholdkey numberkeys[i]
{ {
qsprintf TQUOTE 5 i qsprintf TQUOTE 5 i
quote TQUOTE quote TQUOTE
} }
} }
ifkey KEY_SPACE ifhitkey KEY_SPACE
{
ifn searchstat 3 break
ifn sprite[searchwall].picnum SECTOREFFECTOR break
set tmp 0
ife sprite[searchwall].lotag 7 set tmp 1
ife sprite[searchwall].lotag 17 set tmp 1
ife tmp 0 break
for i allsprites
{
ifn i searchwall, ifactor SECTOREFFECTOR, ife sprite[i].lotag sprite[searchwall].lotag
ife sprite[i].hitag sprite[searchwall].hitag
{
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
break
}
}
}
ifholdkey KEY_0
// ife 0 1 // ife 0 1
{ {
ifeithershift sub davr 512 else add davr 512 ifeithershift sub davr 512 else add davr 512

View file

@ -89,8 +89,8 @@ enum GameEvent_t {
EVENT_ANALYZESPRITES, EVENT_ANALYZESPRITES,
EVENT_INSERTSPRITE2D, EVENT_INSERTSPRITE2D,
EVENT_INSERTSPRITE3D, EVENT_INSERTSPRITE3D,
EVENT_DRAW2DSCREEN, // must be 4 EVENT_DRAW2DSCREEN,
// EVENT_KEYS2D, EVENT_KEYS2D,
EVENT_KEYS3D, EVENT_KEYS3D,
EVENT_OVERHEADEDITOR, EVENT_OVERHEADEDITOR,
MAXEVENTS MAXEVENTS
@ -163,6 +163,8 @@ extern int32_t g_gameArrayCount, g_systemArrayCount;
extern uint32_t m32_drawlinepat; extern uint32_t m32_drawlinepat;
extern int32_t g_iReturnVar;
extern int32_t m32_sortvar1, m32_sortvar2;
extern int32_t g_iReturnVarID; extern int32_t g_iReturnVarID;
extern int32_t g_iLoTagID; // var ID of "LOTAG" extern int32_t g_iLoTagID; // var ID of "LOTAG"
extern int32_t g_iHiTagID; // var ID of "HITAG" extern int32_t g_iHiTagID; // var ID of "HITAG"

View file

@ -8198,7 +8198,7 @@ static void Keys2d(void)
keystatus[KEYSC_J]=0; keystatus[KEYSC_J]=0;
} }
// X_OnEvent(EVENT_KEYS2D, -1); X_OnEvent(EVENT_KEYS2D, -1);
}// end key2d }// end key2d

View file

@ -81,6 +81,8 @@ static int32_t statesinfo_allocsize = 512;
static char tempbuf[2048]; static char tempbuf[2048];
static char tlabel[MAXLABELLEN]; static char tlabel[MAXLABELLEN];
int32_t g_iReturnVar=0;
int32_t m32_sortvar1, m32_sortvar2;
int32_t g_iReturnVarID=-1; // var ID of "RETURN" int32_t g_iReturnVarID=-1; // var ID of "RETURN"
int32_t g_iLoTagID=-1; // var ID of "LOTAG" int32_t g_iLoTagID=-1; // var ID of "LOTAG"
int32_t g_iHiTagID=-1; // var ID of "HITAG" int32_t g_iHiTagID=-1; // var ID of "HITAG"
@ -252,6 +254,7 @@ const char *keyw[] =
"getangle", "getangle",
"getincangle", "getincangle",
"sort",
"for", // * "for", // *
"ifvarl", "ifvarl",
@ -282,7 +285,8 @@ const char *keyw[] =
"whilevarvarn", "whilevarvarn",
"whilevarvarl", "whilevarvarl",
"ifkey", "ifhitkey",
"ifholdkey",
"ifrnd", "ifrnd",
"ifangdiffl", "ifangdiffl",
"ifspritepal", "ifspritepal",
@ -306,6 +310,7 @@ const char *keyw[] =
"dupsprite", "dupsprite",
"deletesprite", "deletesprite",
"lastwall", "lastwall",
"updatecursectnum",
"updatesector", "updatesector",
"updatesectorz", "updatesectorz",
"getzrange", "getzrange",
@ -318,6 +323,7 @@ const char *keyw[] =
"getceilzofslope", "getceilzofslope",
"getflorzofslope", "getflorzofslope",
"bsetsprite", // * "bsetsprite", // *
"setfirstwall",
"changespritestat", "changespritestat",
"changespritesect", "changespritesect",
"headspritestat", "headspritestat",
@ -642,7 +648,7 @@ static int32_t C_SkipComments(void)
static inline int32_t ispecial(const char c) static inline int32_t ispecial(const char c)
{ {
if (c == ' ' || c == 0x0d || c == '(' || c == ')' || if (c == ' ' || c == 0x0d || c == '(' || c == ')' ||
c == ',' || c == ';' || (c == 0x0a && ++g_lineNumber)) c == ',' || c == ';' || (c == 0x0a /*&& ++g_lineNumber*/))
return 1; return 1;
return 0; return 0;
@ -687,11 +693,9 @@ static void C_GetNextLabelName(void)
if (i < MAXLABELLEN-1) if (i < MAXLABELLEN-1)
tlabel[i++] = *(textptr++); tlabel[i++] = *(textptr++);
else else
i++, textptr++; textptr++;
} }
if (i >= MAXLABELLEN-1)
i = MAXLABELLEN-1;
tlabel[i] = 0; tlabel[i] = 0;
// if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug > 1) // if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug > 1)
// initprintf("%s:%d: debug: got label `%s'.\n",g_szScriptFileName,g_lineNumber,tlabel); // initprintf("%s:%d: debug: got label `%s'.\n",g_szScriptFileName,g_lineNumber,tlabel);
@ -919,6 +923,14 @@ static void C_GetNextVarType(int32_t type)
flags &= ~(MAXGAMEVARS<<2); // not an array flags &= ~(MAXGAMEVARS<<2); // not an array
flags |= (MAXGAMEVARS<<3); flags |= (MAXGAMEVARS<<3);
} }
else
{
if ((aGameArrays[id].dwFlags & GAMEARRAY_READONLY) && type&GAMEVAR_READONLY)
{
C_ReportError(ERROR_ARRAYREADONLY);
g_numCompilerErrors++;
}
}
C_GetNextVarType(GAMEVAR_SPECIAL); // _SPECIAL signifies that we want only simple vars or a constant C_GetNextVarType(GAMEVAR_SPECIAL); // _SPECIAL signifies that we want only simple vars or a constant
g_scriptPtr--; g_scriptPtr--;
@ -977,7 +989,7 @@ static void C_GetNextVarType(int32_t type)
else // simple gamevar else // simple gamevar
*g_scriptPtr++ = (aridx<<16 | id | (lLabelID<<2) | flags); *g_scriptPtr++ = (aridx<<16 | id | (lLabelID<<2) | flags);
} }
else else // if (flags & (MAXGAMEVARS<<2))
{ {
if ((aridx & 0x0000FFFF) == MAXGAMEVARS) // constant if ((aridx & 0x0000FFFF) == MAXGAMEVARS) // constant
*g_scriptPtr++ = (aridx | id | flags); *g_scriptPtr++ = (aridx | id | flags);
@ -1593,6 +1605,32 @@ static int32_t C_ParseCommand(void)
} }
return 0; return 0;
case CON_SORT:
C_GetNextLabelName();
i = GetGamearrayID(tlabel);
if (i >= 0)
{
*g_scriptPtr++ = i;
if (aGameArrays[i].dwFlags & GAMEARRAY_READONLY)
{
C_ReportError(ERROR_ARRAYREADONLY);
g_numCompilerErrors++;
}
}
else
{
C_ReportError(ERROR_NOTAGAMEARRAY);
g_numCompilerErrors++;
}
C_SkipComments();
C_GetNextVar(); // element count to sort
if (C_GetKeyword() >= 0)
{
*g_scriptPtr++ = -1;
return 0;
}
// fall-through
case CON_STATE: case CON_STATE:
C_GetNextLabelName(); C_GetNextLabelName();
@ -1602,7 +1640,6 @@ static int32_t C_ParseCommand(void)
C_ReportError(ERROR_ISAKEYWORD); C_ReportError(ERROR_ISAKEYWORD);
return 1; return 1;
} }
if (hash_find(&gamevarH, tlabel)>=0) if (hash_find(&gamevarH, tlabel)>=0)
{ {
g_numCompilerWarnings++; g_numCompilerWarnings++;
@ -2230,7 +2267,10 @@ repeatcase:
if (i >= 0) if (i >= 0)
*g_scriptPtr++ = i; *g_scriptPtr++ = i;
else else
{
C_ReportError(ERROR_NOTAGAMEARRAY); C_ReportError(ERROR_NOTAGAMEARRAY);
g_numCompilerErrors++;
}
C_SkipComments();// skip comments and whitespace C_SkipComments();// skip comments and whitespace
if (*textptr != '[') if (*textptr != '[')
@ -2254,9 +2294,20 @@ repeatcase:
i = GetGamearrayID(tlabel); i = GetGamearrayID(tlabel);
if (i >= 0) if (i >= 0)
{
*g_scriptPtr++ = i; *g_scriptPtr++ = i;
if (aGameArrays[i].dwFlags & GAMEARRAY_READONLY)
{
C_ReportError(ERROR_ARRAYREADONLY);
g_numCompilerErrors++;
}
}
else else
{
C_ReportError(ERROR_NOTAGAMEARRAY); C_ReportError(ERROR_NOTAGAMEARRAY);
g_numCompilerErrors++;
}
C_SkipComments();// skip comments and whitespace C_SkipComments();// skip comments and whitespace
if (*textptr != '[') if (*textptr != '[')
@ -2282,12 +2333,21 @@ repeatcase:
case CON_RESIZEARRAY: case CON_RESIZEARRAY:
C_GetNextLabelName(); C_GetNextLabelName();
i = GetGamearrayID(tlabel); i = GetGamearrayID(tlabel);
if (i > (-1)) if (i >= 0)
{ {
*g_scriptPtr++ = i; *g_scriptPtr++ = i;
if (tw==CON_RESIZEARRAY && (aGameArrays[i].dwFlags&(GAMEARRAY_TYPEMASK)))
{
C_ReportError(-1);
initprintf("%s:%d: error: can't resize system array `%s'.\n",g_szScriptFileName,g_lineNumber,tlabel);
g_numCompilerErrors++;
}
} }
else else
{
C_ReportError(ERROR_NOTAGAMEARRAY); C_ReportError(ERROR_NOTAGAMEARRAY);
g_numCompilerErrors++;
}
C_SkipComments(); C_SkipComments();
C_GetNextVar(); C_GetNextVar();
return 0; return 0;
@ -2302,7 +2362,10 @@ repeatcase:
*g_scriptPtr++ = i; *g_scriptPtr++ = i;
} }
else else
{
C_ReportError(ERROR_NOTAGAMEARRAY); C_ReportError(ERROR_NOTAGAMEARRAY);
g_numCompilerErrors++;
}
C_GetNextValue(LABEL_DEFINE); C_GetNextValue(LABEL_DEFINE);
return 0; return 0;
#endif #endif
@ -2503,7 +2566,8 @@ repeatcase:
case CON_WHILEVARVARN: case CON_WHILEVARVARN:
case CON_WHILEVARVARL: case CON_WHILEVARVARL:
// --- // ---
case CON_IFKEY: case CON_IFHITKEY:
case CON_IFHOLDKEY:
case CON_IFRND: case CON_IFRND:
// vvv if* using current sprite // vvv if* using current sprite
case CON_IFANGDIFFL: case CON_IFANGDIFFL:
@ -2607,6 +2671,9 @@ repeatcase:
C_GetNextVarType(GAMEVAR_READONLY); C_GetNextVarType(GAMEVAR_READONLY);
break; break;
case CON_UPDATECURSECTNUM:
return 0;
case CON_UPDATESECTOR: case CON_UPDATESECTOR:
case CON_UPDATESECTORZ: case CON_UPDATESECTORZ:
C_GetManyVars(2); C_GetManyVars(2);
@ -2657,6 +2724,7 @@ repeatcase:
C_GetManyVars(4); C_GetManyVars(4);
break; break;
case CON_SETFIRSTWALL:
case CON_CHANGESPRITESTAT: case CON_CHANGESPRITESTAT:
case CON_CHANGESPRITESECT: case CON_CHANGESPRITESECT:
case CON_HEADSPRITESTAT: case CON_HEADSPRITESTAT:
@ -2967,7 +3035,7 @@ static void C_AddDefaultDefinitions(void)
C_AddDefinition("EVENT_INSERTSPRITE2D", EVENT_INSERTSPRITE2D, LABEL_EVENT); C_AddDefinition("EVENT_INSERTSPRITE2D", EVENT_INSERTSPRITE2D, LABEL_EVENT);
C_AddDefinition("EVENT_INSERTSPRITE3D", EVENT_INSERTSPRITE3D, LABEL_EVENT); C_AddDefinition("EVENT_INSERTSPRITE3D", EVENT_INSERTSPRITE3D, LABEL_EVENT);
C_AddDefinition("EVENT_DRAW2DSCREEN", EVENT_DRAW2DSCREEN, LABEL_EVENT); C_AddDefinition("EVENT_DRAW2DSCREEN", EVENT_DRAW2DSCREEN, LABEL_EVENT);
// C_AddDefinition("EVENT_KEYS2D", EVENT_KEYS2D, LABEL_EVENT); C_AddDefinition("EVENT_KEYS2D", EVENT_KEYS2D, LABEL_EVENT);
C_AddDefinition("EVENT_KEYS3D", EVENT_KEYS3D, LABEL_EVENT); C_AddDefinition("EVENT_KEYS3D", EVENT_KEYS3D, LABEL_EVENT);
C_AddDefinition("EVENT_OVERHEADEDITOR", EVENT_OVERHEADEDITOR, LABEL_EVENT); C_AddDefinition("EVENT_OVERHEADEDITOR", EVENT_OVERHEADEDITOR, LABEL_EVENT);
@ -3371,6 +3439,10 @@ void C_ReportError(int32_t iError)
initprintf("%s:%d: error: variable `%s' is read-only.\n", initprintf("%s:%d: error: variable `%s' is read-only.\n",
g_szScriptFileName, g_lineNumber, tlabel); g_szScriptFileName, g_lineNumber, tlabel);
break; break;
case ERROR_ARRAYREADONLY:
initprintf("%s:%d: error: array `%s' is read-only.\n",
g_szScriptFileName, g_lineNumber, tlabel);
break;
case ERROR_VARTYPEMISMATCH: case ERROR_VARTYPEMISMATCH:
initprintf("%s:%d: error: variable `%s' is of the wrong type.\n", initprintf("%s:%d: error: variable `%s' is of the wrong type.\n",
g_szScriptFileName, g_lineNumber, tlabel); g_szScriptFileName, g_lineNumber, tlabel);

View file

@ -124,6 +124,7 @@ enum ScriptError_t
ERROR_SYMBOLNOTRECOGNIZED, ERROR_SYMBOLNOTRECOGNIZED,
ERROR_SYNTAXERROR, ERROR_SYNTAXERROR,
ERROR_VARREADONLY, ERROR_VARREADONLY,
ERROR_ARRAYREADONLY,
ERROR_VARTYPEMISMATCH, ERROR_VARTYPEMISMATCH,
ERROR_LABELINUSE, ERROR_LABELINUSE,
// WARNING_BADGAMEVAR, // WARNING_BADGAMEVAR,
@ -314,6 +315,7 @@ enum ScriptKeywords_t
CON_GETANGLE, CON_GETANGLE,
CON_GETINCANGLE, CON_GETINCANGLE,
CON_SORT,
CON_FOR, CON_FOR,
// if & while var // if & while var
@ -347,7 +349,8 @@ enum ScriptKeywords_t
CON_WHILEVARVARL, CON_WHILEVARVARL,
// other if* // other if*
CON_IFKEY, CON_IFHITKEY,
CON_IFHOLDKEY,
CON_IFRND, CON_IFRND,
// if* using current sprite // if* using current sprite
@ -382,6 +385,7 @@ enum ScriptKeywords_t
CON_DUPSPRITE, CON_DUPSPRITE,
CON_DELETESPRITE, CON_DELETESPRITE,
CON_LASTWALL, CON_LASTWALL,
CON_UPDATECURSECTNUM,
CON_UPDATESECTOR, CON_UPDATESECTOR,
CON_UPDATESECTORZ, CON_UPDATESECTORZ,
CON_GETZRANGE, CON_GETZRANGE,
@ -394,6 +398,7 @@ enum ScriptKeywords_t
CON_GETCEILZOFSLOPE, CON_GETCEILZOFSLOPE,
CON_GETFLORZOFSLOPE, CON_GETFLORZOFSLOPE,
CON_BSETSPRITE, // was CON_SETSPRITE CON_BSETSPRITE, // was CON_SETSPRITE
CON_SETFIRSTWALL,
CON_CHANGESPRITESTAT, CON_CHANGESPRITESTAT,
CON_CHANGESPRITESECT, CON_CHANGESPRITESECT,
CON_HEADSPRITESTAT, CON_HEADSPRITESTAT,

View file

@ -52,6 +52,7 @@ uint32_t m32_drawlinepat=0xffffffff;
instype *insptr; instype *insptr;
int32_t X_DoExecute(int32_t once); int32_t X_DoExecute(int32_t once);
static instype *x_sortingstateptr;
#include "m32structures.c" #include "m32structures.c"
@ -146,7 +147,10 @@ void X_OnEvent(register int32_t iEventID, register int32_t iActor)
X_DoExecute(0); X_DoExecute(0);
if (vm.g_errorFlag) if (vm.g_errorFlag)
{
aEventEnabled[iEventID] = 0; aEventEnabled[iEventID] = 0;
message("ERROR executing %s. Event disabled.", label+(iEventID*MAXLABELLEN));
}
// restore old values... // restore old values...
Bmemcpy(&vm, &vm_backup, sizeof(vmstate_t)); Bmemcpy(&vm, &vm_backup, sizeof(vmstate_t));
@ -195,6 +199,20 @@ static inline void __fastcall X_DoConditional(register int32_t condition)
} }
} }
static int32_t X_DoSortDefault(const int32_t *lv, const int32_t *rv)
{
return (*rv - *lv);
}
static int32_t X_DoSort(const int32_t *lv, const int32_t *rv)
{
m32_sortvar1 = *lv;
m32_sortvar2 = *rv;
insptr = x_sortingstateptr;
X_DoExecute(0);
return g_iReturnVar;
}
#define X_ERROR_INVALIDCI() \ #define X_ERROR_INVALIDCI() \
if ((vm.g_i < 0 || vm.g_i>=MAXSPRITES) && \ if ((vm.g_i < 0 || vm.g_i>=MAXSPRITES) && \
(vm.g_st!=0 || searchstat!=3 || (vm.g_i=searchwall, vm.g_sp=&sprite[vm.g_i], 0))) \ (vm.g_st!=0 || searchstat!=3 || (vm.g_i=searchwall, vm.g_sp=&sprite[vm.g_i], 0))) \
@ -273,12 +291,13 @@ skip_check:
case CON_STATE: case CON_STATE:
{ {
instype *tempscrptr = insptr+2; instype *tempscrptr = insptr+2;
int32_t stateidx = *(insptr+1), o_g_st = vm.g_st; int32_t stateidx = *(insptr+1), o_g_st = vm.g_st, oret=vm.g_returnFlag;
insptr = script + statesinfo[stateidx].ofs; insptr = script + statesinfo[stateidx].ofs;
vm.g_st = 1+MAXEVENTS+stateidx; vm.g_st = 1+MAXEVENTS+stateidx;
X_DoExecute(0); X_DoExecute(0);
vm.g_st = o_g_st; vm.g_st = o_g_st;
vm.g_returnFlag = oret;
insptr = tempscrptr; insptr = tempscrptr;
} }
continue; continue;
@ -356,7 +375,7 @@ skip_check:
// //AddLog("No Matching Case: No Default to use"); // //AddLog("No Matching Case: No Default to use");
// } // }
} }
insptr = (instype *)(script + lEnd); insptr = (instype *)(lCodeInsPtr + lEnd);
//Bsprintf(g_szBuf,"insptr=%d. ", (int32_t)insptr); AddLog(g_szBuf); //Bsprintf(g_szBuf,"insptr=%d. ", (int32_t)insptr); AddLog(g_szBuf);
//AddLog("Done Processing Switch"); //AddLog("Done Processing Switch");
continue; continue;
@ -489,7 +508,8 @@ skip_check:
insptr++; insptr++;
{ {
int32_t j=*insptr++; int32_t j=*insptr++;
Gv_SetVarX(*insptr++,aGameArrays[j].size); Gv_SetVarX(*insptr++, (aGameArrays[j].dwFlags&GAMEARRAY_VARSIZE) ?
Gv_GetVarN(aGameArrays[j].size) : aGameArrays[j].size);
} }
continue; continue;
@ -498,6 +518,7 @@ skip_check:
{ {
int32_t j=*insptr++; int32_t j=*insptr++;
int32_t asize = Gv_GetVarX(*insptr++); int32_t asize = Gv_GetVarX(*insptr++);
if (asize<=0 || asize>65536) if (asize<=0 || asize>65536)
{ {
OSD_Printf(CON_ERROR "Invalid array size %d (max: 65536)\n",g_errorLineNum,keyw[g_tw]); OSD_Printf(CON_ERROR "Invalid array size %d (max: 65536)\n",g_errorLineNum,keyw[g_tw]);
@ -1043,6 +1064,36 @@ skip_check:
continue; continue;
} }
case CON_SORT:
insptr++;
{
int32_t aridx=*insptr++, count=Gv_GetVarX(*insptr++), state=*insptr++;
int32_t o_g_st=vm.g_st;
instype *end=insptr;
if (count<=0) continue;
if (count > aGameArrays[aridx].size)
{
OSD_Printf(CON_ERROR "Count of elements to sort (%d) exceeds array size (%d)!\n",g_errorLineNum,keyw[g_tw],count,aGameArrays[aridx].size);
vm.g_errorFlag = 1;
continue;
}
if (state < 0)
{
qsort(aGameArrays[aridx].vals, count, sizeof(int32_t), (int32_t(*)(const void*,const void*))X_DoSortDefault);
}
else
{
x_sortingstateptr = script + statesinfo[state].ofs;
vm.g_st = 1+MAXEVENTS+state;
qsort(aGameArrays[aridx].vals, count, sizeof(int32_t), (int32_t(*)(const void*,const void*))X_DoSort);
vm.g_st = o_g_st;
insptr = end;
}
}
continue;
case CON_FOR: // special-purpose iteration case CON_FOR: // special-purpose iteration
insptr++; insptr++;
{ {
@ -1251,7 +1302,8 @@ badindex:
X_DoConditional(rnd(Gv_GetVarX(*(++insptr)))); X_DoConditional(rnd(Gv_GetVarX(*(++insptr))));
continue; continue;
case CON_IFKEY: case CON_IFHITKEY:
case CON_IFHOLDKEY:
insptr++; insptr++;
{ {
int32_t key=Gv_GetVarX(*insptr); int32_t key=Gv_GetVarX(*insptr);
@ -1263,10 +1315,14 @@ badindex:
} }
X_DoConditional(keystatus[key]); X_DoConditional(keystatus[key]);
if ((key>=KEYSC_1 && key<=KEYSC_ENTER) || (key>=KEYSC_A && key<=KEYSC_BQUOTE) if (tw==CON_IFHITKEY)
|| (key>=KEYSC_BSLASH && key<=KEYSC_SLASH)) {
if (!(key==0 || key==KEYSC_ESC || key==KEYSC_TILDE || key==KEYSC_gENTER ||
key==KEYSC_LALT || key==KEYSC_RALT || key==KEYSC_LCTRL || key==KEYSC_RCTRL ||
key==KEYSC_LSHIFT || key==KEYSC_RSHIFT))
keystatus[key] = 0; keystatus[key] = 0;
} }
}
continue; continue;
case CON_IFEITHERALT: case CON_IFEITHERALT:
@ -1623,6 +1679,21 @@ badindex:
} }
// CURSPR // CURSPR
case CON_SETFIRSTWALL:
insptr++;
{
int32_t sect=Gv_GetVarX(*insptr++), wal=Gv_GetVarX(*insptr++);
X_ERROR_INVALIDSECT(sect);
setfirstwall(sect, wal);
}
continue;
case CON_UPDATECURSECTNUM:
insptr++;
updatesectorz(pos.x, pos.y, pos.z, &cursectnum);
continue;
case CON_UPDATESECTOR: case CON_UPDATESECTOR:
case CON_UPDATESECTORZ: case CON_UPDATESECTORZ:
insptr++; insptr++;

View file

@ -76,7 +76,7 @@ int32_t Gv_NewArray(const char *pszLabel, void *arrayptr, intptr_t asize, uint32
{ {
g_numCompilerErrors++; g_numCompilerErrors++;
C_ReportError(-1); C_ReportError(-1);
initprintf("%s:%d: error: too many arrays!\n",g_szScriptFileName,g_lineNumber); initprintf("%s:%d: error: too many arrays! (max: %d)\n",g_szScriptFileName,g_lineNumber, MAXGAMEARRAYS);
return 0; return 0;
} }
@ -92,7 +92,13 @@ int32_t Gv_NewArray(const char *pszLabel, void *arrayptr, intptr_t asize, uint32
if (i>=0 && !(aGameArrays[i].dwFlags & GAMEARRAY_RESET)) if (i>=0 && !(aGameArrays[i].dwFlags & GAMEARRAY_RESET))
{ {
// found it it's a duplicate in error // found it it's a duplicate in error
// g_numCompilerWarnings++;
if (aGameArrays[i].dwFlags&GAMEARRAY_TYPEMASK)
{
g_numCompilerWarnings++;
C_ReportError(-1);
initprintf("%s:%d: warning: didn't redefine system array `%s'.\n",g_szScriptFileName,g_lineNumber,pszLabel);
}
// C_ReportError(WARNING_DUPLICATEDEFINITION); // C_ReportError(WARNING_DUPLICATEDEFINITION);
return 0; return 0;
} }
@ -508,7 +514,7 @@ static void Gv_AddSystemVars(void)
Gv_NewVar("tsprite", -1, GAMEVAR_READONLY | GAMEVAR_SYSTEM | GAMEVAR_SPECIAL); Gv_NewVar("tsprite", -1, GAMEVAR_READONLY | GAMEVAR_SYSTEM | GAMEVAR_SPECIAL);
g_iReturnVarID = g_gameVarCount; g_iReturnVarID = g_gameVarCount;
Gv_NewVar("RETURN", 0, GAMEVAR_SYSTEM); Gv_NewVar("RETURN", (intptr_t)&g_iReturnVar, GAMEVAR_INTPTR | GAMEVAR_SYSTEM);
g_iLoTagID = g_gameVarCount; g_iLoTagID = g_gameVarCount;
Gv_NewVar("LOTAG", 0, GAMEVAR_SYSTEM); Gv_NewVar("LOTAG", 0, GAMEVAR_SYSTEM);
g_iHiTagID = g_gameVarCount; g_iHiTagID = g_gameVarCount;
@ -593,6 +599,10 @@ static void Gv_AddSystemVars(void)
Gv_NewVar("midydim16", (intptr_t)&midydim16, GAMEVAR_READONLY | GAMEVAR_INTPTR | GAMEVAR_SYSTEM); Gv_NewVar("midydim16", (intptr_t)&midydim16, GAMEVAR_READONLY | GAMEVAR_INTPTR | GAMEVAR_SYSTEM);
Gv_NewVar("ydim16",(intptr_t)&ydim16, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY); Gv_NewVar("ydim16",(intptr_t)&ydim16, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
Gv_NewVar("SV1",(intptr_t)&m32_sortvar1, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
Gv_NewVar("SV2",(intptr_t)&m32_sortvar2, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
Gv_NewVar("spritesortcnt",(intptr_t)&spritesortcnt, GAMEVAR_INTPTR | GAMEVAR_SYSTEM | GAMEVAR_READONLY);
g_systemVarCount = g_gameVarCount; g_systemVarCount = g_gameVarCount;