mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-03 23:10:48 +00:00
- more instructions,
This commit is contained in:
parent
11255cbf6a
commit
72514b0a1d
2 changed files with 83 additions and 261 deletions
|
@ -218,7 +218,7 @@ int findlabel(const char* text)
|
||||||
{
|
{
|
||||||
if (strcmp(label + (j << 6), text) == 0)
|
if (strcmp(label + (j << 6), text) == 0)
|
||||||
{
|
{
|
||||||
return j;// labelcode[j];
|
return j;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -691,16 +691,6 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
appendscriptvalue(labelcode[lnum]);
|
appendscriptvalue(labelcode[lnum]);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#if 0
|
|
||||||
case concmd_sound:
|
|
||||||
case concmd_globalsound:
|
|
||||||
case concmd_soundonce:
|
|
||||||
case concmd_stopsound:
|
|
||||||
case concmd_lotsofglass:
|
|
||||||
transnum();
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
case concmd_ends:
|
case concmd_ends:
|
||||||
if (parsing_state == 0)
|
if (parsing_state == 0)
|
||||||
{
|
{
|
||||||
|
@ -986,6 +976,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case concmd_actor:
|
case concmd_actor:
|
||||||
|
case concmd_useractor: // merged with 'actor' because the code is identical except for the added type parameter.
|
||||||
{
|
{
|
||||||
if (parsing_state)
|
if (parsing_state)
|
||||||
{
|
{
|
||||||
|
@ -1003,12 +994,27 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
popscriptvalue();
|
popscriptvalue();
|
||||||
parsing_actor = scriptpos();
|
parsing_actor = scriptpos();
|
||||||
|
|
||||||
|
if (tw == concmd_useractor)
|
||||||
|
{
|
||||||
|
transnum();
|
||||||
|
j = popscriptvalue();
|
||||||
|
}
|
||||||
|
|
||||||
transnum();
|
transnum();
|
||||||
lnum = popscriptvalue();
|
lnum = popscriptvalue();
|
||||||
#if 1
|
#if 1
|
||||||
g_tile[lnum].execPtr = apScript + parsing_actor; // TRANSITIONAL should only store an index
|
g_tile[lnum].execPtr = apScript + parsing_actor; // TRANSITIONAL should only store an index
|
||||||
|
if (tw == concmd_useractor)
|
||||||
|
{
|
||||||
|
if (j & 1)
|
||||||
|
g_tile[lnum].flags |= SFLAG_BADGUY;
|
||||||
|
|
||||||
|
if (j & 2)
|
||||||
|
g_tile[lnum].flags |= (SFLAG_BADGUY | SFLAG_BADGUYSTAYPUT);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
//actorscrptr[lnum] = parsing_actor;
|
actorscrptr[lnum] = parsing_actor;
|
||||||
|
actortype[lnum] = j;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (j = 0; j < 4; j++)
|
for (j = 0; j < 4; j++)
|
||||||
|
@ -1034,8 +1040,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
transnum();
|
transnum();
|
||||||
setscriptvalue(parsing_actor + j, 0);
|
// This code was originally here but is a no-op, because both source and destination are the same here.
|
||||||
|
|
||||||
//*(parsing_actor + j) = *(scriptptr - 1);
|
//*(parsing_actor + j) = *(scriptptr - 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1078,71 +1083,41 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
checking_ifelse = 0;
|
checking_ifelse = 0;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
case concmd_useractor:
|
case concmd_cstat:
|
||||||
|
|
||||||
if (parsing_state)
|
|
||||||
{
|
|
||||||
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Found 'useractor' within 'state'.\n", fn, line_number);
|
|
||||||
errorcount++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parsing_actor)
|
|
||||||
{
|
|
||||||
Printf(TEXTCOLOR_RED " * ERROR!(%s, line %d) Found 'useractor' within 'actor'.\n", fn, line_number);
|
|
||||||
errorcount++;
|
|
||||||
}
|
|
||||||
|
|
||||||
num_squigilly_brackets = 0;
|
|
||||||
popscriptvalue();
|
|
||||||
parsing_actor = scriptptr;
|
|
||||||
|
|
||||||
transnum();
|
transnum();
|
||||||
popscriptvalue();
|
#if 0
|
||||||
j = *scriptptr;
|
// the following checks are being performed by EDuke32 and RedNukem - not sure if this really should be done.
|
||||||
|
// DukeGDX and RedneckGDX do not perform these checks. Code pasted here for making a decision later.
|
||||||
|
|
||||||
transnum();
|
i = popscriptvalue();
|
||||||
popscriptvalue();
|
if (i == 32767)
|
||||||
actorscrptr[*scriptptr] = parsing_actor;
|
|
||||||
actortype[*scriptptr] = j;
|
|
||||||
|
|
||||||
for (j = 0; j < 4; j++)
|
|
||||||
{
|
{
|
||||||
*(parsing_actor + j) = 0;
|
i = 32768;
|
||||||
if (j == 3)
|
Printf(TEXTCOLOR_RED " * WARNING!(%s, line %d) tried to set cstat 32767, using 32768 instead.\n", fn, line_number);
|
||||||
|
warningcount++;
|
||||||
|
}
|
||||||
|
else if ((i & 48) == 48)
|
||||||
{
|
{
|
||||||
j = 0;
|
Printf(TEXTCOLOR_RED " * WARNING!(%s, line %d) tried to set cstat %d, using %d instead.\n", fn, line_number, i, i ^ 48);
|
||||||
while (keyword() == -1)
|
i ^= 48;
|
||||||
{
|
warningcount++;
|
||||||
transnum();
|
|
||||||
popscriptvalue();
|
|
||||||
j |= *scriptptr;
|
|
||||||
}
|
}
|
||||||
appendscriptvalue(j);
|
appendscriptvalue(i);
|
||||||
break;
|
#endif
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (keyword() >= 0)
|
|
||||||
{
|
|
||||||
scriptptr += (4 - j);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
transnum();
|
|
||||||
|
|
||||||
*(parsing_actor + j) = *(scriptptr - 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
checking_ifelse = 0;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
||||||
|
case concmd_sound:
|
||||||
|
case concmd_globalsound:
|
||||||
|
case concmd_soundonce:
|
||||||
|
case concmd_stopsound:
|
||||||
|
case concmd_lotsofglass:
|
||||||
case concmd_strength:
|
case concmd_strength:
|
||||||
case concmd_shoot:
|
case concmd_shoot:
|
||||||
case concmd_addphealth:
|
case concmd_addphealth:
|
||||||
case concmd_spawn:
|
case concmd_spawn:
|
||||||
case concmd_cstat:
|
|
||||||
case concmd_count:
|
case concmd_count:
|
||||||
case concmd_endofgame:
|
case concmd_endofgame:
|
||||||
case concmd_spritepal:
|
case concmd_spritepal:
|
||||||
|
@ -1172,7 +1147,8 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
case concmd_guts:
|
case concmd_guts:
|
||||||
transnum();
|
transnum();
|
||||||
transnum();
|
transnum();
|
||||||
break;
|
return 0;
|
||||||
|
|
||||||
case concmd_hitradius:
|
case concmd_hitradius:
|
||||||
transnum();
|
transnum();
|
||||||
transnum();
|
transnum();
|
||||||
|
@ -1180,6 +1156,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
|
||||||
transnum();
|
transnum();
|
||||||
transnum();
|
transnum();
|
||||||
break;
|
break;
|
||||||
|
#if 0
|
||||||
case concmd_else:
|
case concmd_else:
|
||||||
if (checking_ifelse)
|
if (checking_ifelse)
|
||||||
{
|
{
|
||||||
|
|
|
@ -960,6 +960,43 @@ static int32_t C_ParseCommand(int32_t loop)
|
||||||
case concmd_music:
|
case concmd_music:
|
||||||
case concmd_ai:
|
case concmd_ai:
|
||||||
case concmd_action:
|
case concmd_action:
|
||||||
|
case concmd_actor:
|
||||||
|
case concmd_useractor:
|
||||||
|
case concmd_cstat:
|
||||||
|
case concmd_strength:
|
||||||
|
case concmd_shoot:
|
||||||
|
case concmd_addphealth:
|
||||||
|
case concmd_spawn:
|
||||||
|
case concmd_count:
|
||||||
|
case concmd_endofgame:
|
||||||
|
case concmd_spritepal:
|
||||||
|
case concmd_cactor:
|
||||||
|
case concmd_money:
|
||||||
|
case concmd_addkills:
|
||||||
|
case concmd_debug:
|
||||||
|
case concmd_addstrength:
|
||||||
|
case concmd_cstator:
|
||||||
|
case concmd_mail:
|
||||||
|
case concmd_paper:
|
||||||
|
case concmd_sleeptime:
|
||||||
|
case concmd_clipdist:
|
||||||
|
case concmd_isdrunk:
|
||||||
|
case concmd_iseat:
|
||||||
|
case concmd_newpic:
|
||||||
|
case concmd_hitradius:
|
||||||
|
case concmd_addammo:
|
||||||
|
case concmd_addweapon:
|
||||||
|
case concmd_sizeto:
|
||||||
|
case concmd_sizeat:
|
||||||
|
case concmd_debris:
|
||||||
|
case concmd_addinventory:
|
||||||
|
case concmd_guts:
|
||||||
|
case concmd_lotsofglass:
|
||||||
|
case concmd_quote:
|
||||||
|
case concmd_sound:
|
||||||
|
case concmd_globalsound:
|
||||||
|
case concmd_soundonce:
|
||||||
|
case concmd_stopsound:
|
||||||
parsecommand(g_lastKeyword);
|
parsecommand(g_lastKeyword);
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -1039,135 +1076,6 @@ static int32_t C_ParseCommand(int32_t loop)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
|
||||||
case concmd_actor:
|
|
||||||
case concmd_useractor:
|
|
||||||
if (EDUKE32_PREDICT_FALSE(parsing_state || parsing_actor))
|
|
||||||
{
|
|
||||||
C_ReportError(ERROR_FOUNDWITHIN);
|
|
||||||
errorcount++;
|
|
||||||
}
|
|
||||||
|
|
||||||
num_squigilly_brackets = 0;
|
|
||||||
scriptptr--;
|
|
||||||
parsing_actor = scriptptr - apScript;
|
|
||||||
|
|
||||||
if (tw == concmd_useractor)
|
|
||||||
{
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
scriptptr--;
|
|
||||||
}
|
|
||||||
|
|
||||||
// save the actor name w/o consuming it
|
|
||||||
C_SkipComments();
|
|
||||||
j = 0;
|
|
||||||
while (isaltok(*(textptr+j)))
|
|
||||||
{
|
|
||||||
g_szCurrentBlockName[j] = textptr[j];
|
|
||||||
j++;
|
|
||||||
}
|
|
||||||
g_szCurrentBlockName[j] = 0;
|
|
||||||
|
|
||||||
j = findlabel(g_szCurrentBlockName);
|
|
||||||
|
|
||||||
//if (j != -1)
|
|
||||||
// labeltype[j] |= LABEL_ACTOR;
|
|
||||||
|
|
||||||
if (tw == concmd_useractor)
|
|
||||||
{
|
|
||||||
j = *scriptptr;
|
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE(j >= 3))
|
|
||||||
{
|
|
||||||
C_ReportError(-1);
|
|
||||||
Printf("%s:%d: warning: invalid useractor type. Must be 0, 1, 2"
|
|
||||||
" (notenemy, enemy, enemystayput).\n",
|
|
||||||
g_scriptFileName,line_number);
|
|
||||||
warningcount++;
|
|
||||||
j = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
C_GetNextValue(LABEL_ACTOR);
|
|
||||||
scriptptr--;
|
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE((unsigned)*scriptptr >= MAXTILES))
|
|
||||||
{
|
|
||||||
C_ReportError(ERROR_EXCEEDSMAXTILES);
|
|
||||||
errorcount++;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
g_tile[*scriptptr].execPtr = apScript + parsing_actor;
|
|
||||||
|
|
||||||
if (tw == concmd_useractor)
|
|
||||||
{
|
|
||||||
if (j & 1)
|
|
||||||
g_tile[*scriptptr].flags |= SFLAG_BADGUY;
|
|
||||||
|
|
||||||
if (j & 2)
|
|
||||||
g_tile[*scriptptr].flags |= (SFLAG_BADGUY|SFLAG_BADGUYSTAYPUT);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (j=0; j<4; j++)
|
|
||||||
{
|
|
||||||
BITPTR_CLEAR(parsing_actor+j);
|
|
||||||
*((apScript+j)+parsing_actor) = 0;
|
|
||||||
if (j == 3)
|
|
||||||
{
|
|
||||||
j = 0;
|
|
||||||
while (C_GetKeyword() == -1)
|
|
||||||
C_BitOrNextValue(&j);
|
|
||||||
|
|
||||||
C_FinishBitOr(j);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (C_GetKeyword() != -1)
|
|
||||||
{
|
|
||||||
for (i=4-j; i; i--)
|
|
||||||
{
|
|
||||||
BITPTR_CLEAR(scriptptr-apScript);
|
|
||||||
*(scriptptr++) = 0;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
switch (j)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
C_GetNextValue(LABEL_ACTION);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
// XXX: LABEL_MOVE|LABEL_DEFINE, what is this shit? compatibility?
|
|
||||||
// yep, it sure is :(
|
|
||||||
C_GetNextValue(LABEL_MOVE | LABEL_DEFINE);
|
|
||||||
#if 0
|
|
||||||
if (EDUKE32_PREDICT_FALSE((C_GetNextValue(LABEL_MOVE|LABEL_DEFINE) == 0) && (*(scriptptr-1) != 0) && (*(scriptptr-1) != 1)))
|
|
||||||
{
|
|
||||||
C_ReportError(-1);
|
|
||||||
BITPTR_CLEAR(scriptptr-apScript-1);
|
|
||||||
*(scriptptr-1) = 0;
|
|
||||||
Printf("%s:%d: warning: expected a move, found a constant.\n",g_scriptFileName,line_number);
|
|
||||||
warningcount++;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (*(scriptptr - 1) >= (intptr_t)&apScript[0] && *(scriptptr - 1) < (intptr_t)&apScript[g_scriptSize])
|
|
||||||
{
|
|
||||||
int a = 0;
|
|
||||||
BITPTR_SET(parsing_actor + j);
|
|
||||||
}
|
|
||||||
else BITPTR_CLEAR(parsing_actor+j);
|
|
||||||
*((apScript+j)+parsing_actor) = *(scriptptr-1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_checkingIfElse = 0;
|
|
||||||
continue;
|
|
||||||
|
|
||||||
case concmd_onevent:
|
case concmd_onevent:
|
||||||
if (EDUKE32_PREDICT_FALSE(parsing_state || parsing_actor))
|
if (EDUKE32_PREDICT_FALSE(parsing_state || parsing_actor))
|
||||||
{
|
{
|
||||||
|
@ -1208,69 +1116,6 @@ static int32_t C_ParseCommand(int32_t loop)
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
case concmd_cstat:
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
|
|
||||||
if (EDUKE32_PREDICT_FALSE(*(scriptptr-1) == 32767))
|
|
||||||
{
|
|
||||||
*(scriptptr-1) = 32768;
|
|
||||||
C_ReportError(-1);
|
|
||||||
Printf("%s:%d: warning: tried to set cstat 32767, using 32768 instead.\n",g_scriptFileName,line_number);
|
|
||||||
warningcount++;
|
|
||||||
}
|
|
||||||
else if (EDUKE32_PREDICT_FALSE((*(scriptptr-1) & 48) == 48))
|
|
||||||
{
|
|
||||||
i = *(scriptptr-1);
|
|
||||||
*(scriptptr-1) ^= 48;
|
|
||||||
C_ReportError(-1);
|
|
||||||
Printf("%s:%d: warning: tried to set cstat %d, using %d instead.\n",g_scriptFileName,line_number,i,(int32_t)(*(scriptptr-1)));
|
|
||||||
warningcount++;
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
|
|
||||||
case concmd_hitradius:
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
fallthrough__;
|
|
||||||
case concmd_addammo:
|
|
||||||
case concmd_addweapon:
|
|
||||||
case concmd_sizeto:
|
|
||||||
case concmd_sizeat:
|
|
||||||
case concmd_debris:
|
|
||||||
case concmd_addinventory:
|
|
||||||
case concmd_guts:
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
fallthrough__;
|
|
||||||
case concmd_strength:
|
|
||||||
case concmd_shoot:
|
|
||||||
case concmd_addphealth:
|
|
||||||
case concmd_spawn:
|
|
||||||
case concmd_count:
|
|
||||||
case concmd_endofgame:
|
|
||||||
case concmd_spritepal:
|
|
||||||
case concmd_cactor:
|
|
||||||
case concmd_money:
|
|
||||||
case concmd_addkills:
|
|
||||||
case concmd_debug:
|
|
||||||
case concmd_addstrength:
|
|
||||||
case concmd_cstator:
|
|
||||||
case concmd_mail:
|
|
||||||
case concmd_paper:
|
|
||||||
case concmd_sleeptime:
|
|
||||||
case concmd_clipdist:
|
|
||||||
case concmd_isdrunk:
|
|
||||||
case concmd_iseat:
|
|
||||||
case concmd_newpic:
|
|
||||||
case concmd_lotsofglass:
|
|
||||||
case concmd_quote:
|
|
||||||
case concmd_sound:
|
|
||||||
case concmd_globalsound:
|
|
||||||
case concmd_soundonce:
|
|
||||||
case concmd_stopsound:
|
|
||||||
C_GetNextValue(LABEL_DEFINE);
|
|
||||||
continue;
|
|
||||||
|
|
||||||
case concmd_else:
|
case concmd_else:
|
||||||
{
|
{
|
||||||
if (EDUKE32_PREDICT_FALSE(!g_checkingIfElse))
|
if (EDUKE32_PREDICT_FALSE(!g_checkingIfElse))
|
||||||
|
|
Loading…
Reference in a new issue