- more instructions,

This commit is contained in:
Christoph Oelckers 2020-05-12 23:55:33 +02:00
parent 11255cbf6a
commit 72514b0a1d
2 changed files with 83 additions and 261 deletions

View file

@ -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)
{ {

View file

@ -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))