mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Selective auto-correction option for the corruption checker. 'corruptcheck now' will print numbered tags for each warning, which can then be used like this: 'corruptcheck tryfix 20 34-64'. General cleanup; make mapster32 not depend on enet objects.
git-svn-id: https://svn.eduke32.com/eduke32@1799 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
177e506e01
commit
71d5dc5e59
21 changed files with 230 additions and 123 deletions
|
@ -205,7 +205,7 @@ ifeq (1,$(RELEASE))
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
mapster32$(EXESUFFIX): $(EDITOROBJS) $(EOBJ)/$(EDITORLIB) $(EOBJ)/$(ENGINELIB) $(JAUDIOLIBDIR)/$(JAUDIOLIB) $(ENETDIR)/$(ENETLIB)
|
mapster32$(EXESUFFIX): $(EDITOROBJS) $(EOBJ)/$(EDITORLIB) $(EOBJ)/$(ENGINELIB) $(JAUDIOLIBDIR)/$(JAUDIOLIB)
|
||||||
$(LINK_STATUS)
|
$(LINK_STATUS)
|
||||||
if $(CC) $(CFLAGS) $(OURCFLAGS) -o $@ $^ $(LIBS) $(STDCPPLIB) $(MISCLINKOPTS); then $(LINK_OK); else $(LINK_FAILED); fi
|
if $(CC) $(CFLAGS) $(OURCFLAGS) -o $@ $^ $(LIBS) $(STDCPPLIB) $(MISCLINKOPTS); then $(LINK_OK); else $(LINK_FAILED); fi
|
||||||
ifeq (1,$(RELEASE))
|
ifeq (1,$(RELEASE))
|
||||||
|
|
|
@ -303,7 +303,7 @@ extern int32_t rendmode;
|
||||||
EXTERN int32_t h_xsize[MAXTILES], h_ysize[MAXTILES];
|
EXTERN int32_t h_xsize[MAXTILES], h_ysize[MAXTILES];
|
||||||
EXTERN int8_t h_xoffs[MAXTILES], h_yoffs[MAXTILES];
|
EXTERN int8_t h_xoffs[MAXTILES], h_yoffs[MAXTILES];
|
||||||
|
|
||||||
extern char *engineerrstr;
|
extern const char *engineerrstr;
|
||||||
extern char noclip;
|
extern char noclip;
|
||||||
|
|
||||||
EXTERN int32_t editorzrange[2];
|
EXTERN int32_t editorzrange[2];
|
||||||
|
|
|
@ -549,7 +549,7 @@ int32_t Bcorrectfilename(char *filename, int32_t removefn);
|
||||||
int32_t Bcanonicalisefilename(char *filename, int32_t removefn);
|
int32_t Bcanonicalisefilename(char *filename, int32_t removefn);
|
||||||
char *Bgetsystemdrives(void);
|
char *Bgetsystemdrives(void);
|
||||||
int32_t Bfilelength(int32_t fd);
|
int32_t Bfilelength(int32_t fd);
|
||||||
char *Bstrtoken(char *s, char *delim, char **ptrptr, int32_t chop);
|
char *Bstrtoken(char *s, const char *delim, char **ptrptr, int32_t chop);
|
||||||
int32_t Bwildmatch (const char *i, const char *j);
|
int32_t Bwildmatch (const char *i, const char *j);
|
||||||
|
|
||||||
#if !defined(_WIN32)
|
#if !defined(_WIN32)
|
||||||
|
@ -566,5 +566,8 @@ char *Bstrupr(char *);
|
||||||
#define EDUKE32_TMRTIC t[ti++]=getticks()
|
#define EDUKE32_TMRTIC t[ti++]=getticks()
|
||||||
#define EDUKE32_TMRPRN do { int ii=0; fprintf(stderr,"%s: ",tmrstr); for (ii=1; ii<ti; ii++) fprintf(stderr,"%d ", t[ii]-t[ii-1]); fprintf(stderr,"\n"); } while (0)
|
#define EDUKE32_TMRPRN do { int ii=0; fprintf(stderr,"%s: ",tmrstr); for (ii=1; ii<ti; ii++) fprintf(stderr,"%d ", t[ii]-t[ii-1]); fprintf(stderr,"\n"); } while (0)
|
||||||
|
|
||||||
|
static inline int32_t ARBNDCHK(int32_t i) { return i<0 ? (*(int32_t *)123=234) : i; }
|
||||||
|
#define DOUBLEWALL(w) wall[ARBNDCHK(w)]
|
||||||
|
|
||||||
#endif // __compat_h__
|
#endif // __compat_h__
|
||||||
|
|
||||||
|
|
|
@ -116,7 +116,7 @@ extern const char *SaveBoard(const char *fn, uint32_t flags);
|
||||||
#define MAXCORRUPTTHINGS 64
|
#define MAXCORRUPTTHINGS 64
|
||||||
extern int32_t corruptlevel, numcorruptthings, corruptthings[MAXCORRUPTTHINGS];
|
extern int32_t corruptlevel, numcorruptthings, corruptthings[MAXCORRUPTTHINGS];
|
||||||
extern int32_t autocorruptcheck;
|
extern int32_t autocorruptcheck;
|
||||||
extern int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing);
|
extern int32_t CheckMapCorruption(int32_t printfromlev, uint64_t tryfixing);
|
||||||
|
|
||||||
extern void showsectordata(int16_t sectnum, int16_t small);
|
extern void showsectordata(int16_t sectnum, int16_t small);
|
||||||
extern void showwalldata(int16_t wallnum, int16_t small);
|
extern void showwalldata(int16_t wallnum, int16_t small);
|
||||||
|
|
|
@ -42,8 +42,8 @@ enum cvartype_t
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
char *name;
|
const char *name;
|
||||||
char *helpstr;
|
const char *helpstr;
|
||||||
void *var;
|
void *var;
|
||||||
int32_t type; // see cvartype_t
|
int32_t type; // see cvartype_t
|
||||||
int32_t min;
|
int32_t min;
|
||||||
|
|
|
@ -26,7 +26,7 @@ extern double gcosang, gsinang, gcosang2, gsinang2;
|
||||||
extern double gchang, gshang, gctang, gstang, gvisibility;
|
extern double gchang, gshang, gctang, gstang, gvisibility;
|
||||||
|
|
||||||
struct glfiltermodes {
|
struct glfiltermodes {
|
||||||
char *name;
|
const char *name;
|
||||||
int32_t min,mag;
|
int32_t min,mag;
|
||||||
};
|
};
|
||||||
#define numglfiltermodes 6
|
#define numglfiltermodes 6
|
||||||
|
|
|
@ -147,7 +147,7 @@ static int32_t osdfunc_setrendermode(const osdfuncparm_t *parm)
|
||||||
int32_t m;
|
int32_t m;
|
||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
char *modestrs[] =
|
const char *modestrs[] =
|
||||||
{
|
{
|
||||||
"classic software", "",
|
"classic software", "",
|
||||||
"", "polygonal OpenGL", "great justice (Polymer)"
|
"", "polygonal OpenGL", "great justice (Polymer)"
|
||||||
|
|
|
@ -2077,7 +2077,8 @@ void overheadeditor(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Bsprintf(cbuf, "map corrupt (level %d): %d errors", corruptlevel, numcorruptthings);
|
Bsprintf(cbuf, "Map corrupt (level %d): %s%d errors", corruptlevel,
|
||||||
|
numcorruptthings>=MAXCORRUPTTHINGS ? ">=":"", numcorruptthings);
|
||||||
printext16(8,8, editorcolors[13],editorcolors[0],cbuf,0);
|
printext16(8,8, editorcolors[13],editorcolors[0],cbuf,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5274,7 +5275,11 @@ int32_t getpointhighlight(int32_t xplc, int32_t yplc, int32_t point)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dst <= dist)
|
if (dst <= dist)
|
||||||
dist = dst, closest = j;
|
{
|
||||||
|
// prefer white walls
|
||||||
|
if (dist<dist || closest==-1 || (wall[j].nextwall>=0)-(wall[closest].nextwall>=0) <= 0)
|
||||||
|
dist = dst, closest = j;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (zoom >= 256)
|
if (zoom >= 256)
|
||||||
|
|
|
@ -69,7 +69,7 @@ static int32_t lockrecip[200];
|
||||||
|
|
||||||
static char toupperlookup[256];
|
static char toupperlookup[256];
|
||||||
|
|
||||||
static void reportandexit(char *errormessage);
|
static void reportandexit(const char *errormessage);
|
||||||
|
|
||||||
extern char pow2char[8];
|
extern char pow2char[8];
|
||||||
|
|
||||||
|
@ -226,7 +226,7 @@ void agecache(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reportandexit(char *errormessage)
|
static void reportandexit(const char *errormessage)
|
||||||
{
|
{
|
||||||
int32_t i, j;
|
int32_t i, j;
|
||||||
|
|
||||||
|
@ -841,7 +841,7 @@ void kclose(int32_t handle)
|
||||||
filehan[handle] = -1;
|
filehan[handle] = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t klistaddentry(CACHE1D_FIND_REC **rec, char *name, int32_t type, int32_t source)
|
static int32_t klistaddentry(CACHE1D_FIND_REC **rec, const char *name, int32_t type, int32_t source)
|
||||||
{
|
{
|
||||||
CACHE1D_FIND_REC *r = NULL, *attach = NULL;
|
CACHE1D_FIND_REC *r = NULL, *attach = NULL;
|
||||||
|
|
||||||
|
|
|
@ -707,7 +707,7 @@ int32_t Bclosedir(BDIR *dir)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
char *Bstrtoken(char *s, char *delim, char **ptrptr, int32_t chop)
|
char *Bstrtoken(char *s, const char *delim, char **ptrptr, int32_t chop)
|
||||||
{
|
{
|
||||||
char *p, *start;
|
char *p, *start;
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ enum scripttoken_t
|
||||||
T_TILEFROMTEXTURE, T_XOFFSET, T_YOFFSET
|
T_TILEFROMTEXTURE, T_XOFFSET, T_YOFFSET
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct { char *text; int32_t tokenid; } tokenlist;
|
typedef struct { const char *text; int32_t tokenid; } tokenlist;
|
||||||
|
|
||||||
static int32_t getatoken(scriptfile *sf, const tokenlist *tl, int32_t ntokens)
|
static int32_t getatoken(scriptfile *sf, const tokenlist *tl, int32_t ntokens)
|
||||||
{
|
{
|
||||||
|
|
|
@ -155,7 +155,7 @@ char britable[16][256]; // JBF 20040207: full 8bit precision
|
||||||
extern char textfont[2048], smalltextfont[2048];
|
extern char textfont[2048], smalltextfont[2048];
|
||||||
|
|
||||||
static char kensmessage[128];
|
static char kensmessage[128];
|
||||||
char *engineerrstr = "No error";
|
const char *engineerrstr = "No error";
|
||||||
|
|
||||||
int32_t showfirstwall=0;
|
int32_t showfirstwall=0;
|
||||||
int32_t showheightindicators=2;
|
int32_t showheightindicators=2;
|
||||||
|
@ -7912,7 +7912,7 @@ int32_t loadmaphack(const char *filename)
|
||||||
T_LIGHT,
|
T_LIGHT,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct { char *text; int32_t tokenid; } legaltokens[] =
|
static struct { const char *text; int32_t tokenid; } legaltokens[] =
|
||||||
{
|
{
|
||||||
{ "sprite", T_SPRITE },
|
{ "sprite", T_SPRITE },
|
||||||
{ "angleoff", T_ANGOFF },
|
{ "angleoff", T_ANGOFF },
|
||||||
|
@ -9696,7 +9696,9 @@ int32_t lastwall(int16_t point)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//////////
|
////////// CLIPMOVE //////////
|
||||||
|
|
||||||
|
int32_t clipmoveboxtracenum = 3;
|
||||||
|
|
||||||
static int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
static int32_t clipsprite_try(const spritetype *spr, int32_t xmin, int32_t ymin, int32_t xmax, int32_t ymax)
|
||||||
{
|
{
|
||||||
|
@ -9821,17 +9823,24 @@ static int32_t clipsprite_initindex(int32_t curidx, spritetype *curspr, int32_t
|
||||||
return flipmul;
|
return flipmul;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define addclipline(dax1, day1, dax2, day2, daoval) \
|
|
||||||
{ \
|
static int32_t clipmove_warned=0;
|
||||||
if (clipnum < MAXCLIPNUM) { \
|
|
||||||
clipit[clipnum].x1 = dax1; clipit[clipnum].y1 = day1; \
|
static void addclipline(int32_t dax1, int32_t day1, int32_t dax2, int32_t day2, int32_t daoval)
|
||||||
clipit[clipnum].x2 = dax2; clipit[clipnum].y2 = day2; \
|
{
|
||||||
clipobjectval[clipnum] = daoval; \
|
if (clipnum < MAXCLIPNUM)
|
||||||
clipnum++; \
|
{
|
||||||
} else if (!warned) { initprintf("!!clipnum\n"); warned=1; } \
|
clipit[clipnum].x1 = dax1; clipit[clipnum].y1 = day1;
|
||||||
} \
|
clipit[clipnum].x2 = dax2; clipit[clipnum].y2 = day2;
|
||||||
|
clipobjectval[clipnum] = daoval;
|
||||||
int32_t clipmoveboxtracenum = 3;
|
clipnum++;
|
||||||
|
}
|
||||||
|
else if (!clipmove_warned)
|
||||||
|
{
|
||||||
|
initprintf("!!clipnum\n");
|
||||||
|
clipmove_warned = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// clipmove
|
// clipmove
|
||||||
|
@ -9852,11 +9861,13 @@ int32_t clipmove(vec3_t *vect, int16_t *sectnum,
|
||||||
int32_t hitwall, cnt, clipyou;
|
int32_t hitwall, cnt, clipyou;
|
||||||
|
|
||||||
spritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
spritetype *curspr=NULL; // non-NULL when handling sprite with sector-like clipping
|
||||||
int32_t curidx=-1, warned=0, clipspritecnt;
|
int32_t curidx=-1, clipspritecnt;
|
||||||
|
|
||||||
if (((xvect|yvect) == 0) || (*sectnum < 0)) return(0);
|
if (((xvect|yvect) == 0) || (*sectnum < 0)) return(0);
|
||||||
retval = 0;
|
retval = 0;
|
||||||
|
|
||||||
|
clipmove_warned = 0;
|
||||||
|
|
||||||
oxvect = xvect;
|
oxvect = xvect;
|
||||||
oyvect = yvect;
|
oyvect = yvect;
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,9 @@ defstate arraytest
|
||||||
ends
|
ends
|
||||||
|
|
||||||
defstate itertest
|
defstate itertest
|
||||||
// iteration and break test
|
var gi gj gk
|
||||||
|
// iteration and break test
|
||||||
|
|
||||||
for i range 10
|
for i range 10
|
||||||
{
|
{
|
||||||
addlogvar i
|
addlogvar i
|
||||||
|
@ -82,70 +84,70 @@ define MIN_CONSTANT -2147483648
|
||||||
defstate consttest
|
defstate consttest
|
||||||
quote " --- Constants test ---", quote " "
|
quote " --- Constants test ---", quote " "
|
||||||
|
|
||||||
quote "Shoud be 0:"
|
quote "Should be 0:"
|
||||||
set i 0, set j TEST_ZERO
|
set i 0, set j TEST_ZERO
|
||||||
qsprintf TQUOTE "%d %d %d %d" 0 TEST_ZERO i j
|
qsprintf TQUOTE "%d %d %d %d" 0 TEST_ZERO i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be 1:"
|
quote "Should be 1:"
|
||||||
set i 1, set j TEST_PLUS_ONE
|
set i 1, set j TEST_PLUS_ONE
|
||||||
qsprintf TQUOTE "%d %d %d %d" 1 TEST_PLUS_ONE i j
|
qsprintf TQUOTE "%d %d %d %d" 1 TEST_PLUS_ONE i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -1:"
|
quote "Should be -1:"
|
||||||
set i -1, set j TEST_MINUS_ONE
|
set i -1, set j TEST_MINUS_ONE
|
||||||
qsprintf TQUOTE "%d %d %d %d" -1 TEST_MINUS_ONE i j
|
qsprintf TQUOTE "%d %d %d %d" -1 TEST_MINUS_ONE i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
|
|
||||||
quote "Shoud be 32767:"
|
quote "Should be 32767:"
|
||||||
set i 32767, set j MOST_POSITIVE_DIRECT
|
set i 32767, set j MOST_POSITIVE_DIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 32767 MOST_POSITIVE_DIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 32767 MOST_POSITIVE_DIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -32768:"
|
quote "Should be -32768:"
|
||||||
set i -32768, set j MOST_NEGATIVE_DIRECT
|
set i -32768, set j MOST_NEGATIVE_DIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" -32768 MOST_NEGATIVE_DIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" -32768 MOST_NEGATIVE_DIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be 32768:"
|
quote "Should be 32768:"
|
||||||
set i 32768, set j LEAST_POSITIVE_INDIRECT
|
set i 32768, set j LEAST_POSITIVE_INDIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 32768 LEAST_POSITIVE_INDIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 32768 LEAST_POSITIVE_INDIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -32769:"
|
quote "Should be -32769:"
|
||||||
set i -32769, set j LEAST_NEGATIVE_INDIRECT
|
set i -32769, set j LEAST_NEGATIVE_INDIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" -32769 LEAST_NEGATIVE_INDIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" -32769 LEAST_NEGATIVE_INDIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Hex tests:"
|
quote "Hex tests:"
|
||||||
quote "Shoud be 32767:"
|
quote "Should be 32767:"
|
||||||
set i 0x7fff, set j HEX_MOST_POSITIVE_DIRECT
|
set i 0x7fff, set j HEX_MOST_POSITIVE_DIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 0x7fff HEX_MOST_POSITIVE_DIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 0x7fff HEX_MOST_POSITIVE_DIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -32768:"
|
quote "Should be -32768:"
|
||||||
set i 0xffff8000, set j HEX_MOST_NEGATIVE_DIRECT
|
set i 0xffff8000, set j HEX_MOST_NEGATIVE_DIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 0xffff8000 HEX_MOST_NEGATIVE_DIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 0xffff8000 HEX_MOST_NEGATIVE_DIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be 32768:"
|
quote "Should be 32768:"
|
||||||
set i 0x8000, set j HEX_LEAST_POSITIVE_INDIRECT
|
set i 0x8000, set j HEX_LEAST_POSITIVE_INDIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 0x8000 HEX_LEAST_POSITIVE_INDIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 0x8000 HEX_LEAST_POSITIVE_INDIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -32769:"
|
quote "Should be -32769:"
|
||||||
set i 0xffff7fff, set j HEX_LEAST_NEGATIVE_INDIRECT
|
set i 0xffff7fff, set j HEX_LEAST_NEGATIVE_INDIRECT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 0xffff7fff HEX_LEAST_NEGATIVE_INDIRECT i j
|
qsprintf TQUOTE "%d %d %d %d" 0xffff7fff HEX_LEAST_NEGATIVE_INDIRECT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "min/max tests:"
|
quote "min/max tests:"
|
||||||
quote "Shoud be 2147483647:"
|
quote "Should be 2147483647:"
|
||||||
set i 2147483647, set j MAX_CONSTANT
|
set i 2147483647, set j MAX_CONSTANT
|
||||||
qsprintf TQUOTE "%d %d %d %d" 2147483647 MAX_CONSTANT i j
|
qsprintf TQUOTE "%d %d %d %d" 2147483647 MAX_CONSTANT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
||||||
quote "Shoud be -2147483648:"
|
quote "Should be -2147483648:"
|
||||||
set i -2147483648, set j MIN_CONSTANT
|
set i -2147483648, set j MIN_CONSTANT
|
||||||
qsprintf TQUOTE "%d %d %d %d" -2147483648 MIN_CONSTANT i j
|
qsprintf TQUOTE "%d %d %d %d" -2147483648 MIN_CONSTANT i j
|
||||||
quote TQUOTE, quote " "
|
quote TQUOTE, quote " "
|
||||||
|
|
|
@ -3,8 +3,6 @@
|
||||||
|
|
||||||
#include "names.h"
|
#include "names.h"
|
||||||
|
|
||||||
// tilegroup "All named" with the hotkey "Y" is constructed automatically
|
|
||||||
|
|
||||||
tilegroup "Actors"
|
tilegroup "Actors"
|
||||||
{
|
{
|
||||||
hotkey "A"
|
hotkey "A"
|
||||||
|
|
|
@ -3788,7 +3788,7 @@ static inline void getnumber_doint64(int64_t *ptr, int32_t num)
|
||||||
*ptr = (int64_t) num;
|
*ptr = (int64_t) num;
|
||||||
}
|
}
|
||||||
|
|
||||||
void getnumberptr256(char *namestart, void *num, int32_t bytes, int32_t maxnumber, char sign, void *(func)(int32_t))
|
static void getnumberptr256(const char *namestart, void *num, int32_t bytes, int32_t maxnumber, char sign, void *(func)(int32_t))
|
||||||
{
|
{
|
||||||
char buffer[80], ch;
|
char buffer[80], ch;
|
||||||
int32_t n, danum = 0, oldnum;
|
int32_t n, danum = 0, oldnum;
|
||||||
|
@ -7090,8 +7090,8 @@ static void Keys2d(void)
|
||||||
}
|
}
|
||||||
else x=editorgridextent+1;
|
else x=editorgridextent+1;
|
||||||
|
|
||||||
printmessage16("%s Corrupt %s %d%s", tsign<0?"<":">", secwalspr[j], i,
|
printmessage16("#%d: %s Corrupt %s %d%s", curcorruptthing+1, tsign<0?"<":">", secwalspr[j],
|
||||||
(x==editorgridextent+1) ? " (outside grid)" : (wrap ? " (wrap)" : ""));
|
i, (x==editorgridextent+1) ? " (outside grid)" : (wrap ? " (wrap)" : ""));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (wallsprite==0)
|
else if (wallsprite==0)
|
||||||
|
@ -7346,7 +7346,7 @@ void ExtPreSaveMap(void)
|
||||||
|
|
||||||
static void G_ShowParameterHelp(void)
|
static void G_ShowParameterHelp(void)
|
||||||
{
|
{
|
||||||
char *s = "Usage: mapster32 [OPTIONS] [FILE]\n\n"
|
const char *s = "Usage: mapster32 [OPTIONS] [FILE]\n\n"
|
||||||
"-gFILE, -grp FILE\tUse extra group file FILE\n"
|
"-gFILE, -grp FILE\tUse extra group file FILE\n"
|
||||||
"-hFILE\t\tUse definitions file FILE\n"
|
"-hFILE\t\tUse definitions file FILE\n"
|
||||||
"-jDIR, -game_dir DIR\n\t\tAdds DIR to the file path stack\n"
|
"-jDIR, -game_dir DIR\n\t\tAdds DIR to the file path stack\n"
|
||||||
|
@ -7655,6 +7655,11 @@ int32_t ExtPreInit(int32_t argc,const char **argv)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t atoi_safe(const char *str)
|
||||||
|
{
|
||||||
|
return (int32_t)strtol(str, NULL, 10);
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t osdcmd_quit(const osdfuncparm_t *parm)
|
static int32_t osdcmd_quit(const osdfuncparm_t *parm)
|
||||||
{
|
{
|
||||||
UNREFERENCED_PARAMETER(parm);
|
UNREFERENCED_PARAMETER(parm);
|
||||||
|
@ -7784,7 +7789,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
OSD_Printf("Turning acceleration+declaration is %d\n", pk_turnaccel);
|
OSD_Printf("Turning acceleration+declaration is %d\n", pk_turnaccel);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pk_turnaccel = atoi(parm->parms[0]);
|
pk_turnaccel = atoi_safe(parm->parms[0]);
|
||||||
pk_turnaccel = pk_turnaccel<=pk_turndecel ? (pk_turndecel+1):pk_turnaccel;
|
pk_turnaccel = pk_turnaccel<=pk_turndecel ? (pk_turndecel+1):pk_turnaccel;
|
||||||
pk_turnaccel = pk_turnaccel>256 ? 256:pk_turnaccel;
|
pk_turnaccel = pk_turnaccel>256 ? 256:pk_turnaccel;
|
||||||
}
|
}
|
||||||
|
@ -7795,7 +7800,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
OSD_Printf("Turning deceleration is %d\n", pk_turndecel);
|
OSD_Printf("Turning deceleration is %d\n", pk_turndecel);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pk_turndecel = atoi(parm->parms[0]);
|
pk_turndecel = atoi_safe(parm->parms[0]);
|
||||||
pk_turndecel = pk_turndecel<=0 ? 1:pk_turndecel;
|
pk_turndecel = pk_turndecel<=0 ? 1:pk_turndecel;
|
||||||
pk_turndecel = pk_turndecel>=pk_turnaccel ? (pk_turnaccel-1):pk_turndecel;
|
pk_turndecel = pk_turndecel>=pk_turnaccel ? (pk_turnaccel-1):pk_turndecel;
|
||||||
pk_turndecel = pk_turndecel>128 ? 128:pk_turndecel;
|
pk_turndecel = pk_turndecel>128 ? 128:pk_turndecel;
|
||||||
|
@ -7810,7 +7815,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
{
|
{
|
||||||
if (parm->numparms==1)
|
if (parm->numparms==1)
|
||||||
{
|
{
|
||||||
pk_uedaccel = atoi(parm->parms[0]);
|
pk_uedaccel = atoi_safe(parm->parms[0]);
|
||||||
pk_uedaccel = pk_uedaccel<0 ? 0:pk_uedaccel;
|
pk_uedaccel = pk_uedaccel<0 ? 0:pk_uedaccel;
|
||||||
pk_uedaccel = pk_uedaccel>5 ? 5:pk_uedaccel;
|
pk_uedaccel = pk_uedaccel>5 ? 5:pk_uedaccel;
|
||||||
}
|
}
|
||||||
|
@ -7843,7 +7848,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
static const char *how[3] = {"none", "two-sided walls only", "all"};
|
static const char *how[3] = {"none", "two-sided walls only", "all"};
|
||||||
|
|
||||||
if (parm->numparms == 1)
|
if (parm->numparms == 1)
|
||||||
showheightindicators = clamp(atoi(parm->parms[0]), 0, 2);
|
showheightindicators = clamp(atoi_safe(parm->parms[0]), 0, 2);
|
||||||
|
|
||||||
if (parm->numparms <= 1)
|
if (parm->numparms <= 1)
|
||||||
OSD_Printf("height indicators: %s\n", how[showheightindicators]);
|
OSD_Printf("height indicators: %s\n", how[showheightindicators]);
|
||||||
|
@ -7855,7 +7860,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
static const char *how[3] = {"none", "current sector only", "all"};
|
static const char *how[3] = {"none", "current sector only", "all"};
|
||||||
|
|
||||||
if (parm->numparms == 1)
|
if (parm->numparms == 1)
|
||||||
showambiencesounds = clamp(atoi(parm->parms[0]), 0, 2);
|
showambiencesounds = clamp(atoi_safe(parm->parms[0]), 0, 2);
|
||||||
|
|
||||||
if (parm->numparms <= 1)
|
if (parm->numparms <= 1)
|
||||||
OSD_Printf("ambience sound circles: %s\n", how[showambiencesounds]);
|
OSD_Printf("ambience sound circles: %s\n", how[showambiencesounds]);
|
||||||
|
@ -7864,7 +7869,9 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
}
|
}
|
||||||
else if (!Bstrcasecmp(parm->name, "corruptcheck"))
|
else if (!Bstrcasecmp(parm->name, "corruptcheck"))
|
||||||
{
|
{
|
||||||
if (parm->numparms == 1)
|
int32_t tryfix = parm->numparms>=1 && !Bstrcasecmp(parm->parms[0], "tryfix");
|
||||||
|
|
||||||
|
if (parm->numparms == 1 || tryfix)
|
||||||
{
|
{
|
||||||
if (!Bstrcasecmp(parm->parms[0], "now"))
|
if (!Bstrcasecmp(parm->parms[0], "now"))
|
||||||
{
|
{
|
||||||
|
@ -7872,14 +7879,47 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
OSD_Printf("All OK.\n");
|
OSD_Printf("All OK.\n");
|
||||||
return OSDCMD_OK;
|
return OSDCMD_OK;
|
||||||
}
|
}
|
||||||
else if (!Bstrcasecmp(parm->parms[0], "tryfix"))
|
else if (tryfix)
|
||||||
{
|
{
|
||||||
CheckMapCorruption(3, 1);
|
uint64_t whicherrs = parm->numparms==1 ? ULONG_LONG_MAX : 0;
|
||||||
|
|
||||||
|
if (whicherrs==0)
|
||||||
|
{
|
||||||
|
int32_t i, n, m;
|
||||||
|
char *endptr;
|
||||||
|
for (i=1; i<parm->numparms; i++)
|
||||||
|
{
|
||||||
|
n = (int32_t)Bstrtol(parm->parms[i], &endptr, 10);
|
||||||
|
if (endptr != parm->parms[i])
|
||||||
|
{
|
||||||
|
if (*endptr=='-')
|
||||||
|
{
|
||||||
|
m = (int32_t)Bstrtol(endptr+1, NULL, 10);
|
||||||
|
if (n>=1 && n<=m && m<=MAXCORRUPTTHINGS)
|
||||||
|
{
|
||||||
|
uint64_t mask = ULONG_LONG_MAX;
|
||||||
|
m = m-n+1;
|
||||||
|
mask >>= (MAXCORRUPTTHINGS-m);
|
||||||
|
mask <<= (n-1);
|
||||||
|
|
||||||
|
whicherrs |= mask;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (n>=1 && n<=MAXCORRUPTTHINGS)
|
||||||
|
whicherrs |= (1ull<<(n-1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CheckMapCorruption(3, whicherrs);
|
||||||
return OSDCMD_OK;
|
return OSDCMD_OK;
|
||||||
}
|
}
|
||||||
else if (isdigit(parm->parms[0][0]))
|
else if (isdigit(parm->parms[0][0]))
|
||||||
{
|
{
|
||||||
autocorruptcheck = clamp(atoi(parm->parms[0]), 0, 3600);
|
autocorruptcheck = clamp(atoi_safe(parm->parms[0]), 0, 3600);
|
||||||
corruptchecktimer = totalclock + 120*autocorruptcheck;
|
corruptchecktimer = totalclock + 120*autocorruptcheck;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7891,7 +7931,7 @@ static int32_t osdcmd_vars_pk(const osdfuncparm_t *parm)
|
||||||
else
|
else
|
||||||
OSD_Printf("auto corruption check: off\n");
|
OSD_Printf("auto corruption check: off\n");
|
||||||
}
|
}
|
||||||
else
|
else if (!tryfix)
|
||||||
return OSDCMD_SHOWHELP;
|
return OSDCMD_SHOWHELP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7906,7 +7946,7 @@ static int32_t osdcmd_tint(const osdfuncparm_t *parm)
|
||||||
|
|
||||||
if (parm->numparms==1)
|
if (parm->numparms==1)
|
||||||
{
|
{
|
||||||
i = atoi(parm->parms[0]);
|
i = atoi_safe(parm->parms[0]);
|
||||||
if (i>=0 && i<MAXPALOOKUPS-RESERVEDPALS)
|
if (i>=0 && i<MAXPALOOKUPS-RESERVEDPALS)
|
||||||
{
|
{
|
||||||
p = &hictinting[i];
|
p = &hictinting[i];
|
||||||
|
@ -7922,15 +7962,15 @@ static int32_t osdcmd_tint(const osdfuncparm_t *parm)
|
||||||
}
|
}
|
||||||
else if (parm->numparms>=2)
|
else if (parm->numparms>=2)
|
||||||
{
|
{
|
||||||
i = atoi(parm->parms[0]);
|
i = atoi_safe(parm->parms[0]);
|
||||||
if (i<0 || i>=MAXPALOOKUPS-RESERVEDPALS)
|
if (i<0 || i>=MAXPALOOKUPS-RESERVEDPALS)
|
||||||
return OSDCMD_SHOWHELP;
|
return OSDCMD_SHOWHELP;
|
||||||
|
|
||||||
p = &hictinting[i];
|
p = &hictinting[i];
|
||||||
p->r = atoi(parm->parms[1]);
|
p->r = atoi_safe(parm->parms[1]);
|
||||||
p->g = (parm->numparms>=3) ? atoi(parm->parms[2]) : 255;
|
p->g = (parm->numparms>=3) ? atoi_safe(parm->parms[2]) : 255;
|
||||||
p->b = (parm->numparms>=4) ? atoi(parm->parms[3]) : 255;
|
p->b = (parm->numparms>=4) ? atoi_safe(parm->parms[3]) : 255;
|
||||||
p->f = (parm->numparms>=5) ? atoi(parm->parms[4])&HICEFFECTMASK : 0;
|
p->f = (parm->numparms>=5) ? atoi_safe(parm->parms[4])&HICEFFECTMASK : 0;
|
||||||
}
|
}
|
||||||
return OSDCMD_OK;
|
return OSDCMD_OK;
|
||||||
}
|
}
|
||||||
|
@ -7965,7 +8005,7 @@ static int32_t osdcmd_disasm(const osdfuncparm_t *parm)
|
||||||
if (!isdigit(parm->parms[1][0]))
|
if (!isdigit(parm->parms[1][0]))
|
||||||
return OSDCMD_SHOWHELP;
|
return OSDCMD_SHOWHELP;
|
||||||
|
|
||||||
i=atoi(parm->parms[1]);
|
i=atoi_safe(parm->parms[1]);
|
||||||
|
|
||||||
if (parm->parms[0][0]=='s')
|
if (parm->parms[0][0]=='s')
|
||||||
{
|
{
|
||||||
|
@ -8122,7 +8162,7 @@ static int32_t osdcmd_endisableevent(const osdfuncparm_t *parm)
|
||||||
|
|
||||||
if (isdigit(parm->parms[i][0]))
|
if (isdigit(parm->parms[i][0]))
|
||||||
{
|
{
|
||||||
j = atoi(parm->parms[i]);
|
j = atoi_safe(parm->parms[i]);
|
||||||
Bsprintf(buf2, "event %d", j);
|
Bsprintf(buf2, "event %d", j);
|
||||||
}
|
}
|
||||||
else if (!Bstrncmp(parm->parms[i], "EVENT_", 6))
|
else if (!Bstrncmp(parm->parms[i], "EVENT_", 6))
|
||||||
|
@ -8349,12 +8389,12 @@ enum
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
char *text;
|
const char *text;
|
||||||
int32_t tokenid;
|
int32_t tokenid;
|
||||||
}
|
}
|
||||||
tokenlist;
|
tokenlist;
|
||||||
|
|
||||||
static int32_t getatoken(scriptfile *sf, tokenlist *tl, int32_t ntokens)
|
static int32_t getatoken(scriptfile *sf, const tokenlist *tl, int32_t ntokens)
|
||||||
{
|
{
|
||||||
char *tok;
|
char *tok;
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
@ -8466,7 +8506,7 @@ int32_t parsegroupfiles(scriptfile *script)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t loadgroupfiles(char *fn)
|
int32_t loadgroupfiles(const char *fn)
|
||||||
{
|
{
|
||||||
scriptfile *script;
|
scriptfile *script;
|
||||||
|
|
||||||
|
@ -10038,48 +10078,57 @@ void ExtCheckKeys(void)
|
||||||
//// port of a.m32's corruptchk ////
|
//// port of a.m32's corruptchk ////
|
||||||
// returns value from 0 (all OK) to 5 (panic!)
|
// returns value from 0 (all OK) to 5 (panic!)
|
||||||
#define CCHK_PANIC OSDTEXT_DARKRED "PANIC!!!^O "
|
#define CCHK_PANIC OSDTEXT_DARKRED "PANIC!!!^O "
|
||||||
#define CCHKPREF OSDTEXT_RED "* ^O"
|
//#define CCHKPREF OSDTEXT_RED "^O"
|
||||||
#define CCHK_CORRECTED OSDTEXT_GREEN " -> "
|
#define CCHK_CORRECTED OSDTEXT_GREEN " -> "
|
||||||
|
|
||||||
#define CORRUPTCHK_PRINT(errlev, what, fmt, ...) do \
|
#define CORRUPTCHK_PRINT(errlev, what, fmt, ...) do \
|
||||||
{ \
|
{ \
|
||||||
bad = max(bad, errlev); \
|
bad = max(bad, errlev); \
|
||||||
if (numcorruptthings<MAXCORRUPTTHINGS) \
|
if (numcorruptthings>=MAXCORRUPTTHINGS) \
|
||||||
corruptthings[numcorruptthings++] = what; \
|
goto too_many_errors; \
|
||||||
|
corruptthings[numcorruptthings++] = what; \
|
||||||
if (errlev >= printfromlev) \
|
if (errlev >= printfromlev) \
|
||||||
OSD_Printf(CCHKPREF fmt "\n", ## __VA_ARGS__); \
|
OSD_Printf("#%d: " fmt "\n", numcorruptthings, ## __VA_ARGS__); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
static int32_t walls_are_consistent(int32_t nw, int32_t j)
|
||||||
|
{
|
||||||
|
return (wall[j].x==POINT2(nw).x && wall[j].y==POINT2(nw).y
|
||||||
|
&& POINT2(j).x==wall[nw].x && POINT2(j).y==wall[nw].y);
|
||||||
|
}
|
||||||
|
|
||||||
static void suggest_nextsector_correction(int32_t nw, int32_t j)
|
static void suggest_nextsector_correction(int32_t nw, int32_t j)
|
||||||
{
|
{
|
||||||
if (nw>=0 && nw<numwalls)
|
if (nw>=0 && nw<numwalls)
|
||||||
{
|
{
|
||||||
// maybe nextwall is right?
|
// maybe nextwall is right?
|
||||||
if (wall[nw].nextwall==j && wall[j].x==POINT2(nw).x && wall[j].y==POINT2(nw).y)
|
if (wall[nw].nextwall==j && walls_are_consistent(nw, j))
|
||||||
OSD_Printf(" suggest setting wall[%d].nextsector to %d\n", j, sectorofwall_noquick(nw));
|
OSD_Printf(" suggest setting wall[%d].nextsector to %d\n",
|
||||||
|
j, sectorofwall_noquick(nw));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_nextsector_correction(int32_t nw, int32_t j)
|
static void do_nextsector_correction(int32_t nw, int32_t j)
|
||||||
{
|
{
|
||||||
if (nw>=0 && nw<numwalls)
|
if (nw>=0 && nw<numwalls)
|
||||||
if (wall[nw].nextwall==j && wall[j].x==POINT2(nw).x && wall[j].y==POINT2(nw).y)
|
if (wall[nw].nextwall==j && walls_are_consistent(nw, j))
|
||||||
{
|
{
|
||||||
int32_t newns = sectorofwall_noquick(nw);
|
int32_t newns = sectorofwall_noquick(nw);
|
||||||
wall[j].nextsector = newns;
|
wall[j].nextsector = newns;
|
||||||
OSD_Printf(CCHK_CORRECTED "auto-correction: set wall[%d].nextsector=%d\n", j, newns);
|
OSD_Printf(CCHK_CORRECTED "auto-correction: set wall[%d].nextsector=%d\n",
|
||||||
|
j, newns);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
int32_t CheckMapCorruption(int32_t printfromlev, uint64_t tryfixing)
|
||||||
{
|
{
|
||||||
int32_t i, j, w0, numw, endwall, ns, nw;
|
int32_t i, j, w0, numw, endwall, ns, nw;
|
||||||
int32_t ewall=0; // expected wall index
|
int32_t ewall=0; // expected wall index
|
||||||
|
|
||||||
int32_t errlevel=0, bad=0;
|
int32_t errlevel=0, bad=0;
|
||||||
|
|
||||||
uint8_t *seen_nextwalls;
|
uint8_t *seen_nextwalls = NULL;
|
||||||
int16_t *lastnextwallsource;
|
int16_t *lastnextwallsource = NULL;
|
||||||
|
|
||||||
numcorruptthings = 0;
|
numcorruptthings = 0;
|
||||||
|
|
||||||
|
@ -10124,9 +10173,9 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
if (endwall > numwalls)
|
if (endwall > numwalls)
|
||||||
CORRUPTCHK_PRINT(4, CORRUPT_SECTOR|i, "SECTOR[%d]: wallptr+wallnum=%d out of range: numwalls=%d", i, endwall, numwalls);
|
CORRUPTCHK_PRINT(4, CORRUPT_SECTOR|i, "SECTOR[%d]: wallptr+wallnum=%d out of range: numwalls=%d", i, endwall, numwalls);
|
||||||
|
|
||||||
if (bad)
|
errlevel = max(errlevel, bad);
|
||||||
errlevel = max(errlevel, bad);
|
|
||||||
else
|
if (bad<4)
|
||||||
{
|
{
|
||||||
endwall--;
|
endwall--;
|
||||||
|
|
||||||
|
@ -10162,11 +10211,15 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
{
|
{
|
||||||
if (!bad)
|
if (!bad)
|
||||||
{
|
{
|
||||||
|
int32_t onumct = numcorruptthings;
|
||||||
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTSECTOR is its own sector", j);
|
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTSECTOR is its own sector", j);
|
||||||
if (tryfixing)
|
if (onumct < MAXCORRUPTTHINGS)
|
||||||
do_nextsector_correction(nw, j);
|
{
|
||||||
else if (4>=printfromlev)
|
if (tryfixing & (1ull<<onumct))
|
||||||
suggest_nextsector_correction(nw, j);
|
do_nextsector_correction(nw, j);
|
||||||
|
else if (4>=printfromlev)
|
||||||
|
suggest_nextsector_correction(nw, j);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10175,15 +10228,16 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
if (seen_nextwalls[nw>>3]&(1<<(nw&7)))
|
if (seen_nextwalls[nw>>3]&(1<<(nw&7)))
|
||||||
{
|
{
|
||||||
int16_t nwnw, lnws;
|
int16_t nwnw, lnws;
|
||||||
|
int32_t onumct = numcorruptthings;
|
||||||
|
|
||||||
lnws = lastnextwallsource[nw];
|
lnws = lastnextwallsource[nw];
|
||||||
CORRUPTCHK_PRINT(3, CORRUPT_WALL|j, "WALL[%d].NEXTWALL=%d already referenced from wall %d",
|
CORRUPTCHK_PRINT(3, CORRUPT_WALL|j, "WALL[%d].NEXTWALL=%d already referenced from wall %d",
|
||||||
j, nw, lnws);
|
j, nw, lnws);
|
||||||
nwnw = wall[nw].nextwall;
|
nwnw = wall[nw].nextwall;
|
||||||
if (nwnw==j || nwnw==lnws)
|
if (onumct < MAXCORRUPTTHINGS && (nwnw==j || nwnw==lnws))
|
||||||
{
|
{
|
||||||
int32_t walltoclear = nwnw==j ? lnws : j;
|
int32_t walltoclear = nwnw==j ? lnws : j;
|
||||||
if (tryfixing)
|
if (tryfixing & (1ull<<onumct))
|
||||||
{
|
{
|
||||||
wall[walltoclear].nextsector = wall[walltoclear].nextwall = -1;
|
wall[walltoclear].nextsector = wall[walltoclear].nextwall = -1;
|
||||||
OSD_Printf(CCHK_CORRECTED "auto-correction: cleared wall %d's nextwall and nextsector tags to -1\n",
|
OSD_Printf(CCHK_CORRECTED "auto-correction: cleared wall %d's nextwall and nextsector tags to -1\n",
|
||||||
|
@ -10203,14 +10257,18 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
|
|
||||||
if (bad<4)
|
if (bad<4)
|
||||||
{
|
{
|
||||||
|
int32_t onumct = numcorruptthings;
|
||||||
if ((ns^nw)<0)
|
if ((ns^nw)<0)
|
||||||
{
|
{
|
||||||
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTSECTOR=%d and .NEXTWALL=%d inconsistent:"
|
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTSECTOR=%d and .NEXTWALL=%d inconsistent:"
|
||||||
" missing one next pointer", j, ns, nw);
|
" missing one next pointer", j, ns, nw);
|
||||||
if (tryfixing)
|
if (onumct < MAXCORRUPTTHINGS)
|
||||||
do_nextsector_correction(nw, j);
|
{
|
||||||
else if (4>=printfromlev)
|
if (tryfixing & (1ull<<onumct))
|
||||||
suggest_nextsector_correction(nw, j);
|
do_nextsector_correction(nw, j);
|
||||||
|
else if (4>=printfromlev)
|
||||||
|
suggest_nextsector_correction(nw, j);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (ns>=0)
|
else if (ns>=0)
|
||||||
{
|
{
|
||||||
|
@ -10218,13 +10276,16 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
{
|
{
|
||||||
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTWALL=%d out of .NEXTSECTOR=%d's bounds",
|
CORRUPTCHK_PRINT(4, CORRUPT_WALL|j, "WALL[%d].NEXTWALL=%d out of .NEXTSECTOR=%d's bounds",
|
||||||
j, nw, ns);
|
j, nw, ns);
|
||||||
if (tryfixing)
|
if (onumct < MAXCORRUPTTHINGS)
|
||||||
do_nextsector_correction(nw, j);
|
|
||||||
else if (4 >= printfromlev)
|
|
||||||
{
|
{
|
||||||
OSD_Printf(" sector %d's walls: [%d .. %d]\n", ns, sector[ns].wallptr,
|
if (tryfixing & (1ull<<onumct))
|
||||||
sector[ns].wallptr+sector[ns].wallnum-1);
|
do_nextsector_correction(nw, j);
|
||||||
suggest_nextsector_correction(nw, j);
|
else if (4 >= printfromlev)
|
||||||
|
{
|
||||||
|
OSD_Printf(" sector %d's walls: [%d .. %d]\n", ns,
|
||||||
|
sector[ns].wallptr, sector[ns].wallptr+sector[ns].wallnum-1);
|
||||||
|
suggest_nextsector_correction(nw, j);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10251,6 +10312,13 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (0)
|
||||||
|
{
|
||||||
|
too_many_errors:
|
||||||
|
if (printfromlev<=errlevel)
|
||||||
|
OSD_Printf("!! too many errors, stopping. !!\n");
|
||||||
|
}
|
||||||
|
|
||||||
errlevel = max(errlevel, bad);
|
errlevel = max(errlevel, bad);
|
||||||
|
|
||||||
if (errlevel)
|
if (errlevel)
|
||||||
|
@ -10259,8 +10327,11 @@ int32_t CheckMapCorruption(int32_t printfromlev, int32_t tryfixing)
|
||||||
OSD_Printf("-- corruption level: %d\n", errlevel);
|
OSD_Printf("-- corruption level: %d\n", errlevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
Bfree(seen_nextwalls);
|
if (seen_nextwalls)
|
||||||
Bfree(lastnextwallsource);
|
{
|
||||||
|
Bfree(seen_nextwalls);
|
||||||
|
Bfree(lastnextwallsource);
|
||||||
|
}
|
||||||
|
|
||||||
corruptlevel = errlevel;
|
corruptlevel = errlevel;
|
||||||
|
|
||||||
|
@ -10506,7 +10577,7 @@ static void EditSectorData(int16_t sectnum)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (col == 2)
|
else if (col == 2)
|
||||||
{
|
{
|
||||||
switch (row)
|
switch (row)
|
||||||
{
|
{
|
||||||
|
@ -10606,10 +10677,10 @@ static void EditWallData(int16_t wallnum)
|
||||||
{
|
{
|
||||||
Bsprintf(med_edittext,"Wall %d X Repeat: ",wallnum);
|
Bsprintf(med_edittext,"Wall %d X Repeat: ",wallnum);
|
||||||
printmessage16("%s", med_edittext);
|
printmessage16("%s", med_edittext);
|
||||||
wall[wallnum].xrepeat = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].xrepeat,256L,0);
|
wall[wallnum].xrepeat = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].xrepeat,255,0);
|
||||||
Bsprintf(med_edittext,"Wall %d Y Repeat: ",wallnum);
|
Bsprintf(med_edittext,"Wall %d Y Repeat: ",wallnum);
|
||||||
printmessage16("%s", med_edittext);
|
printmessage16("%s", med_edittext);
|
||||||
wall[wallnum].yrepeat = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].yrepeat,256L,0);
|
wall[wallnum].yrepeat = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].yrepeat,255,0);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
|
@ -10618,10 +10689,10 @@ static void EditWallData(int16_t wallnum)
|
||||||
{
|
{
|
||||||
Bsprintf(med_edittext,"Wall %d X Pan: ",wallnum);
|
Bsprintf(med_edittext,"Wall %d X Pan: ",wallnum);
|
||||||
printmessage16("%s", med_edittext);
|
printmessage16("%s", med_edittext);
|
||||||
wall[wallnum].xpanning = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].xpanning,256L,0);
|
wall[wallnum].xpanning = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].xpanning,255,0);
|
||||||
Bsprintf(med_edittext,"Wall %d Y Pan: ",wallnum);
|
Bsprintf(med_edittext,"Wall %d Y Pan: ",wallnum);
|
||||||
printmessage16("%s", med_edittext);
|
printmessage16("%s", med_edittext);
|
||||||
wall[wallnum].ypanning = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].ypanning,256L,0);
|
wall[wallnum].ypanning = (char)getnumber16(med_edittext,(int32_t)wall[wallnum].ypanning,255,0);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
|
@ -10889,7 +10960,7 @@ static void GenericSpriteSearch()
|
||||||
int32_t rowmax[3]= {6,5,6}, dispwidth[3] = {24,24,28};
|
int32_t rowmax[3]= {6,5,6}, dispwidth[3] = {24,24,28};
|
||||||
int32_t xpos[3] = {8,200,400}, ypos = ydim-STATUS2DSIZ+48;
|
int32_t xpos[3] = {8,200,400}, ypos = ydim-STATUS2DSIZ+48;
|
||||||
|
|
||||||
static char *labels[7][3] =
|
static const char *labels[7][3] =
|
||||||
{
|
{
|
||||||
{"X-coordinate", "Flags (hex)", "Angle (2048 degrees)"},
|
{"X-coordinate", "Flags (hex)", "Angle (2048 degrees)"},
|
||||||
{"Y-coordinate", "Shade", "X-Velocity"},
|
{"Y-coordinate", "Shade", "X-Velocity"},
|
||||||
|
|
|
@ -909,6 +909,26 @@ static int32_t GetGamearrayID(const char *szGameLabel, int32_t searchlocals)
|
||||||
#define GV_WRITABLE GAMEVAR_READONLY
|
#define GV_WRITABLE GAMEVAR_READONLY
|
||||||
#define GV_SIMPLE GAMEVAR_SPECIAL
|
#define GV_SIMPLE GAMEVAR_SPECIAL
|
||||||
|
|
||||||
|
static int32_t parse_integer_literal(int32_t *num)
|
||||||
|
{
|
||||||
|
if (tolower(textptr[1])=='x')
|
||||||
|
sscanf(textptr+2, "%" SCNx32, num);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
long lnum;
|
||||||
|
errno = 0;
|
||||||
|
lnum = strtol(textptr, NULL, 10);
|
||||||
|
if (errno || (sizeof(long)>4 && (lnum<INT_MIN || lnum>INT_MAX)))
|
||||||
|
{
|
||||||
|
C_CUSTOMERROR("integer literal exceeds bitwidth.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
*num = (int32_t)lnum;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void C_GetNextVarType(int32_t type)
|
static void C_GetNextVarType(int32_t type)
|
||||||
{
|
{
|
||||||
int32_t i, id=0, flags=0, num, indirect=0; //, thenum;
|
int32_t i, id=0, flags=0, num, indirect=0; //, thenum;
|
||||||
|
@ -940,13 +960,10 @@ static void C_GetNextVarType(int32_t type)
|
||||||
// if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug)
|
// if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug)
|
||||||
// initprintf("%s:%d: debug: accepted constant %d in place of gamevar.\n",g_szScriptFileName,g_lineNumber,atol(textptr));
|
// initprintf("%s:%d: debug: accepted constant %d in place of gamevar.\n",g_szScriptFileName,g_lineNumber,atol(textptr));
|
||||||
|
|
||||||
if (tolower(textptr[1])=='x')
|
parse_integer_literal(&num);
|
||||||
sscanf(textptr+2, "%" SCNx32, &num);
|
|
||||||
else
|
|
||||||
num = atoi(textptr);
|
|
||||||
//thenum=num;
|
//thenum=num;
|
||||||
if (type==GV_SIMPLE && (num<0 || num>=65536))
|
if (type==GV_SIMPLE && (num<0 || num>=65536))
|
||||||
C_CUSTOMERROR("array index %d out of bounds. (max: 65535)", num);
|
C_CUSTOMERROR("array index %d out of bounds. (max: 65535)", num);
|
||||||
|
|
||||||
if (g_numCompilerErrors==0 && type!=GV_SIMPLE && num != (int16_t)num)
|
if (g_numCompilerErrors==0 && type!=GV_SIMPLE && num != (int16_t)num)
|
||||||
{
|
{
|
||||||
|
@ -1442,10 +1459,7 @@ static int32_t C_GetNextValue(int32_t type)
|
||||||
// if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug > 1)
|
// if (!(g_numCompilerErrors || g_numCompilerWarnings) && g_scriptDebug > 1)
|
||||||
// initprintf("%s:%d: debug: accepted constant %d.\n",g_szScriptFileName,g_lineNumber,atol(textptr));
|
// initprintf("%s:%d: debug: accepted constant %d.\n",g_szScriptFileName,g_lineNumber,atol(textptr));
|
||||||
|
|
||||||
if (tolower(textptr[1])=='x')
|
parse_integer_literal(g_scriptPtr);
|
||||||
sscanf(textptr+2,"%" SCNx32 "",g_scriptPtr);
|
|
||||||
else
|
|
||||||
*g_scriptPtr = atol(textptr);
|
|
||||||
|
|
||||||
g_scriptPtr++;
|
g_scriptPtr++;
|
||||||
|
|
||||||
|
|
|
@ -70,7 +70,7 @@ extern int32_t g_stateCount;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
char *name;
|
const char *name;
|
||||||
int16_t lId;
|
int16_t lId;
|
||||||
int16_t flags; // 1: read-only
|
int16_t flags; // 1: read-only
|
||||||
int32_t min, max;
|
int32_t min, max;
|
||||||
|
@ -82,7 +82,8 @@ extern const memberlabel_t SpriteLabels[];
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
char* token; int32_t val;
|
const char* token;
|
||||||
|
int32_t val;
|
||||||
} tokenmap_t;
|
} tokenmap_t;
|
||||||
|
|
||||||
extern const tokenmap_t iter_tokens[];
|
extern const tokenmap_t iter_tokens[];
|
||||||
|
|
|
@ -440,9 +440,11 @@ skip_check:
|
||||||
//AddLog("Done Executing Case");
|
//AddLog("Done Executing Case");
|
||||||
bMatched=1;
|
bMatched=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (right-left < 0)
|
if (right-left < 0)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!bMatched)
|
if (!bMatched)
|
||||||
{
|
{
|
||||||
if (*lpDefault >= 0)
|
if (*lpDefault >= 0)
|
||||||
|
|
|
@ -26,7 +26,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
// #define VULGARITY
|
// #define VULGARITY
|
||||||
|
|
||||||
char *defsfilename = "duke3d.def";
|
const char *defsfilename = "duke3d.def";
|
||||||
|
|
||||||
extern char keystatus[];
|
extern char keystatus[];
|
||||||
extern int16_t defaultspritecstat;
|
extern int16_t defaultspritecstat;
|
||||||
|
|
|
@ -937,7 +937,7 @@ static uint8_t savegame_comprthres;
|
||||||
// 64
|
// 64
|
||||||
#define DS_LOADFN 128 // .ptr is function that is run when loading
|
#define DS_LOADFN 128 // .ptr is function that is run when loading
|
||||||
#define DS_SAVEFN 256 // .ptr is function that is run when saving
|
#define DS_SAVEFN 256 // .ptr is function that is run when saving
|
||||||
#define DS_NOCHK 1024 // don't check for diffs (and don't write out in dump) since assumend constant throughout demo
|
#define DS_NOCHK 1024 // don't check for diffs (and don't write out in dump) since assumed constant throughout demo
|
||||||
#define DS_END (0x70000000)
|
#define DS_END (0x70000000)
|
||||||
|
|
||||||
static int32_t ds_getcnt(const dataspec_t *sp)
|
static int32_t ds_getcnt(const dataspec_t *sp)
|
||||||
|
|
|
@ -226,7 +226,7 @@ fallback:
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
static char *s[] = { "/etc/timidity.cfg", "/etc/timidity/timidity.cfg", "/etc/timidity/freepats.cfg" };
|
static const char *s[] = { "/etc/timidity.cfg", "/etc/timidity/timidity.cfg", "/etc/timidity/freepats.cfg" };
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue