- progress

# Conflicts:
#	source/games/duke/src/zz_gamedef.cpp
This commit is contained in:
Christoph Oelckers 2020-05-12 21:22:08 +02:00
parent 49e7fa20e8
commit 56975d3ee2
2 changed files with 87 additions and 279 deletions

View file

@ -37,6 +37,9 @@ into many sub-files.
#include "memarena.h" #include "memarena.h"
#include "printf.h" #include "printf.h"
#include "filesystem.h" #include "filesystem.h"
#include "mapinfo.h"
#include "menu.h"
#include "global.h"
BEGIN_DUKE_NS BEGIN_DUKE_NS
@ -100,6 +103,7 @@ void SortCommands()
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#if 0
enum enum
{ {
ERROR_ISAKEYWORD = 1, ERROR_ISAKEYWORD = 1,
@ -113,6 +117,12 @@ enum
ERROR_CLOSEBRACKET, ERROR_CLOSEBRACKET,
ERROR_NOENDSWITCH ERROR_NOENDSWITCH
}; };
#endif
enum
{
ERROR_PARMUNDEFINED = 20,
};
void ReportError(int iError) void ReportError(int iError)
{ {
@ -236,7 +246,7 @@ void skipwhitespace()
void skipblockcomment() void skipblockcomment()
{ {
while (*textptr != '*' && textptr[1] != '/') while (*textptr != '*' || textptr[1] != '/')
{ {
if (*textptr == '\n') line_number++; if (*textptr == '\n') line_number++;
if (*textptr == 0) return; // reached the end of the file if (*textptr == 0) return; // reached the end of the file
@ -291,6 +301,38 @@ bool isaltok(char c)
return c > 0 && (isalnum(c) || c == '{' || c == '}' || c == '/' || c == '*' || c == '-' || c == '_' || c == '.'); return c > 0 && (isalnum(c) || c == '{' || c == '}' || c == '/' || c == '*' || c == '-' || c == '_' || c == '.');
} }
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
int keyword(void)
{
int i;
const char* temptextptr;
skipcomments();
temptextptr = textptr;
while (isaltok(*temptextptr) == 0)
{
temptextptr++;
if (*temptextptr == 0)
return 0;
}
i = 0;
while (isaltok(*temptextptr))
{
tempbuf[i] = *(temptextptr++);
i++;
}
tempbuf[i] = 0;
return getkeyword(tempbuf);
}
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// //
// //
@ -301,6 +343,8 @@ void getlabel(void)
{ {
long i; long i;
skipcomments();
while (isalnum(*textptr & 0xff) == 0) while (isalnum(*textptr & 0xff) == 0)
{ {
if (*textptr == 0x0a) line_number++; if (*textptr == 0x0a) line_number++;
@ -340,9 +384,11 @@ static void appendscriptvalue(int value)
script.Push(value); script.Push(value);
} }
static void popscriptvalue() static int popscriptvalue()
{ {
script.Pop(); int p;
script.Pop(p);
return p;
} }
void pushlabeladdress() void pushlabeladdress()
@ -372,14 +418,20 @@ static void appendscriptvalue(int value)
scriptWriteValue(value); scriptWriteValue(value);
} }
static void popscriptvalue() static int popscriptvalue()
{ {
scriptptr--; return *--scriptptr;
} }
void pushlabeladdress() void appendlabeladdress(int offset = 0)
{ {
labelcode[labelcnt++] = int(scriptptr - apScript); labelcode[labelcnt++] = int(scriptptr - apScript) + offset;
labelcnt++;
}
void appendlabelvalue(int value)
{
labelcode[labelcnt++] = value;
labelcnt++; labelcnt++;
} }
@ -398,6 +450,8 @@ int transword(void) //Returns its code #
{ {
int i, l; int i, l;
skipcomments();
while (isaltok(*textptr) == 0) while (isaltok(*textptr) == 0)
{ {
if (*textptr == 0x0a) line_number++; if (*textptr == 0x0a) line_number++;
@ -591,7 +645,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
{ {
getlabel(); getlabel();
popscriptvalue(); popscriptvalue();
pushlabeladdress(); appendlabeladdress();
parsing_state = 1; parsing_state = 1;
@ -669,34 +723,25 @@ int parsecommand(int tw) // for now just run an externally parsed command.
); );
scriptptr -= 3; // no need to save in script... scriptptr -= 3; // no need to save in script...
return 0; return 0;
#endif
case concmd_define: case concmd_define:
getlabel(); getlabel();
// Check to see it's already defined checkforkeyword();
lnum = findlabel(label + (labelcnt << 6));
if (getkeyword(label + (labelcnt << 6)) >= 0) if (lnum >= 0)
{ {
errorcount++; warningcount++;
ReportError(ERROR_ISAKEYWORD); ReportError(WARNING_DUPLICATEDEFINITION);
return 0; break;
}
for (i = 0; i < labelcnt; i++)
{
if (strcmp(label + (labelcnt << 6), label + (i << 6)) == 0)
{
warningcount++;
ReportError(WARNING_DUPLICATEDEFINITION);
break;
}
} }
transnum(); transnum();
if (i == labelcnt) i = popscriptvalue();
if (lnum < 0)
{ {
labelcode[labelcnt++] = *(scriptptr - 1); appendlabelvalue(i);
} }
scriptptr -= 2; popscriptvalue();
return 0; return 0;
case concmd_palfrom: case concmd_palfrom:
@ -735,12 +780,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
getlabel(); getlabel();
// Check to see it's already defined // Check to see it's already defined
if (getkeyword(label + (labelcnt << 6)) >= 0) checkforkeyword();
{
errorcount++;
ReportError(ERROR_ISAKEYWORD);
return 0;
}
for (i = 0; i < labelcnt; i++) for (i = 0; i < labelcnt; i++)
if (strcmp(label + (labelcnt << 6), label + (i << 6)) == 0) if (strcmp(label + (labelcnt << 6), label + (i << 6)) == 0)
@ -750,7 +790,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
break; break;
} }
if (i == labelcnt) if (i == labelcnt)
labelcode[labelcnt++] = (intptr_t)scriptptr; appendlabeladdress();
for (j = 0; j < 2; j++) for (j = 0; j < 2; j++)
{ {
if (keyword() >= 0) break; if (keyword() >= 0) break;
@ -798,8 +838,9 @@ int parsecommand(int tw) // for now just run an externally parsed command.
i++; i++;
} }
} }
return 0;
} }
return 0; #if 0
case concmd_include: case concmd_include:
{ {
popscriptvalue(); popscriptvalue();
@ -848,6 +889,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
return 0; return 0;
} }
#endif
case concmd_ai: case concmd_ai:
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)
transnum(); transnum();
@ -855,13 +897,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
{ {
popscriptvalue(); popscriptvalue();
getlabel(); getlabel();
checkforkeyword();
if (getkeyword(label + (labelcnt << 6)) >= 0)
{
errorcount++;
ReportError(ERROR_ISAKEYWORD);
return 0;
}
for (i = 0; i < labelcnt; i++) for (i = 0; i < labelcnt; i++)
if (strcmp(label + (labelcnt << 6), label + (i << 6)) == 0) if (strcmp(label + (labelcnt << 6), label + (i << 6)) == 0)
@ -871,8 +907,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
break; break;
} }
if (i == labelcnt) if (i == labelcnt) appendlabeladdress();
labelcode[labelcnt++] = (intptr_t)scriptptr;
for (j = 0; j < 3; j++) for (j = 0; j < 3; j++)
{ {
@ -883,8 +918,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
while (keyword() == -1) while (keyword() == -1)
{ {
transnum(); transnum();
popscriptvalue(); k |= popscriptvalue();
k |= *scriptptr;
} }
appendscriptvalue(k); appendscriptvalue(k);
return 0; return 0;
@ -898,6 +932,7 @@ int parsecommand(int tw) // for now just run an externally parsed command.
} }
return 0; return 0;
#if 0
case concmd_action: case concmd_action:
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)
transnum(); transnum();

View file

@ -954,6 +954,11 @@ static int32_t C_ParseCommand(int32_t loop)
return 1; //End return 1; //End
case concmd_state: case concmd_state:
case concmd_ends: case concmd_ends:
case concmd_define:
case concmd_palfrom:
case concmd_move:
case concmd_music:
case concmd_ai:
parsecommand(g_lastKeyword); parsecommand(g_lastKeyword);
continue; continue;
@ -1011,168 +1016,6 @@ static int32_t C_ParseCommand(int32_t loop)
continue; continue;
} }
case concmd_define:
{
C_GetNextLabelName();
if (getkeyword(label + (labelcnt << 6)) >= 0)
{
errorcount++;
C_ReportError(ERROR_ISAKEYWORD);
continue;
}
C_GetNextValue(LABEL_DEFINE);
i = findlabel(label+(labelcnt<<6));
if (i>=0)
{
// if (i >= g_numDefaultLabels)
if (EDUKE32_PREDICT_FALSE(labelcode[i] != *(scriptptr-1)))
{
warningcount++;
Printf("%s:%d: warning: ignored redefinition of `%s' to %d (old: %d).\n",g_scriptFileName,
line_number,label+(labelcnt<<6), (int32_t)(*(scriptptr-1)), labelcode[i]);
}
}
else
{
//labeltype[labelcnt] = LABEL_DEFINE;
labelcode[labelcnt++] = *(scriptptr-1);
//if (*(scriptptr-1) >= 0 && *(scriptptr-1) < MAXTILES && g_dynamicTileMapping)
// G_ProcessDynamicTileMapping(label+((labelcnt-1)<<6),*(scriptptr-1));
}
scriptptr -= 2;
continue;
}
case concmd_palfrom:
for (j=3; j>=0; j--)
{
if (C_GetKeyword() == -1)
C_GetNextValue(LABEL_DEFINE);
else break;
}
while (j>-1)
{
BITPTR_CLEAR(scriptptr-apScript);
*scriptptr++ = 0;
j--;
}
continue;
case concmd_move:
if (parsing_actor || parsing_state)
{
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
j = 0;
while (C_GetKeyword() == -1)
C_BitOrNextValue(&j);
C_FinishBitOr(j);
}
else
{
scriptptr--;
C_GetNextLabelName();
// Check to see it's already defined
if (getkeyword(label + (labelcnt << 6)) >= 0)
{
errorcount++;
C_ReportError(ERROR_ISAKEYWORD);
continue;
}
if (EDUKE32_PREDICT_FALSE((i = findlabel(label+(labelcnt<<6))) >= 0))
{
warningcount++;
Printf("%s:%d: warning: duplicate move `%s' ignored.\n",g_scriptFileName,line_number,label+(labelcnt<<6));
}
else
{
//labeltype[labelcnt] = LABEL_MOVE;
labelcode[labelcnt++] = scriptptr-apScript;
}
for (j=1; j>=0; j--)
{
if (C_GetKeyword() != -1) break;
C_GetNextValue(LABEL_DEFINE);
}
for (k=j; k>=0; k--)
{
BITPTR_CLEAR(scriptptr-apScript);
*scriptptr = 0;
scriptptr++;
}
}
continue;
case concmd_music:
{
// NOTE: this doesn't get stored in the PCode...
// music 1 stalker.mid dethtoll.mid streets.mid watrwld1.mid snake1.mid
// thecall.mid ahgeez.mid dethtoll.mid streets.mid watrwld1.mid snake1.mid
scriptptr--;
C_GetNextValue(LABEL_DEFINE); // Volume Number (0/4)
scriptptr--;
k = *scriptptr-1; // 0-based volume number. -1 or MAXVOLUMES: "special"
if (k == -1)
k = MAXVOLUMES;
if (EDUKE32_PREDICT_FALSE((unsigned)k >= MAXVOLUMES+1)) // if it's not background or special music
{
errorcount++;
C_ReportError(-1);
Printf("%s:%d: error: volume number must be between 0 and MAXVOLUMES+1=%d.\n",
g_scriptFileName, line_number, MAXVOLUMES+1);
continue;
}
i = 0;
// get the file name...
while (C_GetKeyword() == -1)
{
C_SkipComments();
j = 0;
tempbuf[j] = '/';
while (isaltok(*(textptr+j)))
{
tempbuf[j+1] = textptr[j];
j++;
}
tempbuf[j+1] = '\0';
C_DefineMusic(k, i, tempbuf);
textptr += j;
if (i >= MAXLEVELS)
break;
i++;
}
}
continue;
case concmd_include: case concmd_include:
scriptptr--; scriptptr--;
@ -1194,76 +1037,6 @@ static int32_t C_ParseCommand(int32_t loop)
C_Include(tempbuf); C_Include(tempbuf);
continue; continue;
case concmd_ai:
if (parsing_actor || parsing_state)
{
C_GetNextValue(LABEL_AI);
}
else
{
scriptptr--;
C_GetNextLabelName();
if (getkeyword(label + (labelcnt << 6)) >= 0)
{
errorcount++;
C_ReportError(ERROR_ISAKEYWORD);
continue;
}
i = findlabel(label+(labelcnt<<6));
if (EDUKE32_PREDICT_FALSE(i>=0))
{
warningcount++;
Printf("%s:%d: warning: duplicate ai `%s' ignored.\n",g_scriptFileName,line_number,label+(labelcnt<<6));
}
else
{
//labeltype[labelcnt] = LABEL_AI;
labelcode[labelcnt++] = scriptptr-apScript;
}
for (j=0; j<3; j++)
{
if (C_GetKeyword() != -1) break;
if (j == 1)
C_GetNextValue(LABEL_ACTION);
else if (j == 2)
{
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
k = 0;
while (C_GetKeyword() == -1)
C_BitOrNextValue(&k);
C_FinishBitOr(k);
j = 666;
break;
}
}
if (j == 666)
continue;
for (k=j; k<3; k++)
{
BITPTR_CLEAR(scriptptr-apScript);
*scriptptr = 0;
scriptptr++;
}
}
continue;
case concmd_action: case concmd_action:
if (parsing_actor || parsing_state) if (parsing_actor || parsing_state)