mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 11:10:39 +00:00
mapster32: new command-line switch '-namesfile <filename>' for overriding NAMES.H; new 'drawlabel <quotenum> <x> <y> <z> <col> <backcol>' m32script command for drawing small labels, see end of a.m32 for an example; some special handling for sprites whose tile yoffset is greater or equal their pixel height.
git-svn-id: https://svn.eduke32.com/eduke32@1832 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
cdb153fd35
commit
148f3cadef
10 changed files with 214 additions and 187 deletions
|
@ -64,6 +64,7 @@ extern int16_t prefixtiles[16];
|
||||||
extern char program_origcwd[BMAX_PATH];
|
extern char program_origcwd[BMAX_PATH];
|
||||||
extern char *mapster32_fullpath;
|
extern char *mapster32_fullpath;
|
||||||
extern char *testplay_addparam;
|
extern char *testplay_addparam;
|
||||||
|
extern const char *g_namesFileName;
|
||||||
|
|
||||||
extern int32_t m32_osd_tryscript;
|
extern int32_t m32_osd_tryscript;
|
||||||
extern int32_t showheightindicators;
|
extern int32_t showheightindicators;
|
||||||
|
@ -126,6 +127,8 @@ 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);
|
||||||
extern void showspritedata(int16_t spritenum, int16_t small);
|
extern void showspritedata(int16_t spritenum, int16_t small);
|
||||||
|
|
||||||
|
extern void drawsmallabel(const char *text, char col, char backcol, int32_t dax, int32_t day, int32_t daz);
|
||||||
|
|
||||||
extern int32_t circlewall;
|
extern int32_t circlewall;
|
||||||
|
|
||||||
int32_t loadsetup(const char *fn); // from config.c
|
int32_t loadsetup(const char *fn); // from config.c
|
||||||
|
@ -162,6 +165,7 @@ void update_highlightsector();
|
||||||
|
|
||||||
int32_t inside_editor(const vec3_t *pos, int32_t searchx, int32_t searchy, int32_t zoom,
|
int32_t inside_editor(const vec3_t *pos, int32_t searchx, int32_t searchy, int32_t zoom,
|
||||||
int32_t x, int32_t y, int16_t sectnum);
|
int32_t x, int32_t y, int16_t sectnum);
|
||||||
|
void correct_sprite_yoffset(int32_t i);
|
||||||
|
|
||||||
extern uint8_t hlsectorbitmap[MAXSECTORS>>3];
|
extern uint8_t hlsectorbitmap[MAXSECTORS>>3];
|
||||||
|
|
||||||
|
|
|
@ -106,6 +106,7 @@ int16_t localartlookup[MAXTILES], localartlookupnum;
|
||||||
char tempbuf[4096];
|
char tempbuf[4096];
|
||||||
|
|
||||||
char names[MAXTILES][25];
|
char names[MAXTILES][25];
|
||||||
|
const char *g_namesFileName = "NAMES.H";
|
||||||
|
|
||||||
int16_t asksave = 0;
|
int16_t asksave = 0;
|
||||||
extern int16_t editstatus, searchit;
|
extern int16_t editstatus, searchit;
|
||||||
|
@ -229,7 +230,7 @@ void overheadeditor(void);
|
||||||
static int32_t getlinehighlight(int32_t xplc, int32_t yplc, int32_t line);
|
static int32_t getlinehighlight(int32_t xplc, int32_t yplc, int32_t line);
|
||||||
void fixspritesectors(void);
|
void fixspritesectors(void);
|
||||||
static int32_t movewalls(int32_t start, int32_t offs);
|
static int32_t movewalls(int32_t start, int32_t offs);
|
||||||
int32_t loadnames(void);
|
int32_t loadnames(const char *namesfile);
|
||||||
void updatenumsprites(void);
|
void updatenumsprites(void);
|
||||||
static void getclosestpointonwall(int32_t x, int32_t y, int32_t dawall, int32_t *nx, int32_t *ny);
|
static void getclosestpointonwall(int32_t x, int32_t y, int32_t dawall, int32_t *nx, int32_t *ny);
|
||||||
static void initcrc(void);
|
static void initcrc(void);
|
||||||
|
@ -446,7 +447,7 @@ int32_t app_main(int32_t argc, const char **argv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
loadnames();
|
loadnames(g_namesFileName);
|
||||||
|
|
||||||
if (initinput()) return -1;
|
if (initinput()) return -1;
|
||||||
// if (option[3] != 0) moustat =
|
// if (option[3] != 0) moustat =
|
||||||
|
@ -1132,6 +1133,8 @@ void editinput(void)
|
||||||
else
|
else
|
||||||
sprite[i].cstat |= (tilesizy[sprite[i].picnum]>=32);
|
sprite[i].cstat |= (tilesizy[sprite[i].picnum]>=32);
|
||||||
|
|
||||||
|
correct_sprite_yoffset(i);
|
||||||
|
|
||||||
updatenumsprites();
|
updatenumsprites();
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
|
|
||||||
|
@ -1285,10 +1288,14 @@ static inline void drawline16base(int32_t bx, int32_t by, int32_t x1, int32_t y1
|
||||||
drawline16(bx+x1, by+y1, bx+x2, by+y2, col);
|
drawline16(bx+x1, by+y1, bx+x2, by+y2, col);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void drawsmalllabel(const char *text, char col, char backcol, int32_t dax, int32_t day)
|
void drawsmallabel(const char *text, char col, char backcol, int32_t dax, int32_t day, int32_t daz)
|
||||||
{
|
{
|
||||||
int32_t x1, y1, x2, y2;
|
int32_t x1, y1, x2, y2;
|
||||||
|
|
||||||
|
screencoords(&dax,&day, dax-pos.x,day-pos.y, zoom);
|
||||||
|
if (m32_sideview)
|
||||||
|
day += getscreenvdisp(daz-pos.z, zoom);
|
||||||
|
|
||||||
x1 = halfxdim16+dax-(Bstrlen(text)<<1);
|
x1 = halfxdim16+dax-(Bstrlen(text)<<1);
|
||||||
y1 = midydim16+day-4;
|
y1 = midydim16+day-4;
|
||||||
x2 = x1 + (Bstrlen(text)<<2)+2;
|
x2 = x1 + (Bstrlen(text)<<2)+2;
|
||||||
|
@ -1781,6 +1788,22 @@ static int32_t insert_sprite_common(int32_t sucksect, int32_t dax, int32_t day)
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void correct_sprite_yoffset(int32_t i)
|
||||||
|
{
|
||||||
|
int32_t tileyofs = (int8_t)((picanm[sprite[i].picnum]>>16)&255);
|
||||||
|
int32_t tileysiz = tilesizy[sprite[i].picnum];
|
||||||
|
|
||||||
|
if (klabs(tileyofs) >= tileysiz)
|
||||||
|
{
|
||||||
|
tileyofs *= -1;
|
||||||
|
if (tileyofs == 128)
|
||||||
|
tileyofs = 127;
|
||||||
|
|
||||||
|
sprite[i].yoffset = tileyofs;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
sprite[i].yoffset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
static void fade_screen()
|
static void fade_screen()
|
||||||
{
|
{
|
||||||
|
@ -2186,7 +2209,6 @@ void overheadeditor(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
draw2dscreen(&pos,cursectnum,ang,zoom,grid);
|
draw2dscreen(&pos,cursectnum,ang,zoom,grid);
|
||||||
VM_OnEvent(EVENT_DRAW2DSCREEN, -1);
|
|
||||||
|
|
||||||
begindrawing(); //{{{
|
begindrawing(); //{{{
|
||||||
if (showtags == 1)
|
if (showtags == 1)
|
||||||
|
@ -2195,7 +2217,6 @@ void overheadeditor(void)
|
||||||
{
|
{
|
||||||
for (i=0; i<numsectors; i++)
|
for (i=0; i<numsectors; i++)
|
||||||
{
|
{
|
||||||
int32_t vdisp = 0;
|
|
||||||
int16_t secshort = i;
|
int16_t secshort = i;
|
||||||
|
|
||||||
dabuffer = (char *)ExtGetSectorCaption(i);
|
dabuffer = (char *)ExtGetSectorCaption(i);
|
||||||
|
@ -2204,13 +2225,8 @@ void overheadeditor(void)
|
||||||
|
|
||||||
get_sectors_center(&secshort, 1, &dax, &day);
|
get_sectors_center(&secshort, 1, &dax, &day);
|
||||||
|
|
||||||
if (m32_sideview)
|
drawsmallabel(dabuffer, editorcolors[0], editorcolors[7],
|
||||||
vdisp = getscreenvdisp(getflorzofslope(i,dax,day)-pos.z, zoom);
|
dax, day, getflorzofslope(i,dax,day));
|
||||||
screencoords(&dax,&day, dax-pos.x,day-pos.y, zoom);
|
|
||||||
if (m32_sideview)
|
|
||||||
day += vdisp;
|
|
||||||
|
|
||||||
drawsmalllabel(dabuffer, editorcolors[0], editorcolors[7], dax, day);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2239,14 +2255,11 @@ void overheadeditor(void)
|
||||||
if ((dax > x3) && (dax < x4) && (day > y3) && (day < y4))
|
if ((dax > x3) && (dax < x4) && (day > y3) && (day < y4))
|
||||||
{
|
{
|
||||||
dabuffer = (char *)ExtGetWallCaption(i);
|
dabuffer = (char *)ExtGetWallCaption(i);
|
||||||
if (dabuffer[0] != 0)
|
if (dabuffer[0] == 0)
|
||||||
{
|
continue;
|
||||||
screencoords(&dax,&day, dax-pos.x,day-pos.y, zoom);
|
|
||||||
if (m32_sideview)
|
|
||||||
day += getscreenvdisp(getflorzofslope(sectorofwall(i), dax,day)-pos.z, zoom);
|
|
||||||
|
|
||||||
drawsmalllabel(dabuffer, editorcolors[0], editorcolors[31], dax, day);
|
drawsmallabel(dabuffer, editorcolors[0], editorcolors[31],
|
||||||
}
|
dax, day, getflorzofslope(sectorofwall(i), dax,day));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2266,12 +2279,6 @@ void overheadeditor(void)
|
||||||
{
|
{
|
||||||
dabuffer = (char *)ExtGetSpriteCaption(i);
|
dabuffer = (char *)ExtGetSpriteCaption(i);
|
||||||
if (dabuffer[0] != 0)
|
if (dabuffer[0] != 0)
|
||||||
{
|
|
||||||
//Get average point of sprite
|
|
||||||
screencoords(&dax,&day, sprite[i].x-pos.x,sprite[i].y-pos.y, zoom);
|
|
||||||
if (m32_sideview)
|
|
||||||
day += getscreenvdisp(sprite[i].z-pos.z, zoom);
|
|
||||||
|
|
||||||
{
|
{
|
||||||
int32_t blocking = (sprite[i].cstat&1);
|
int32_t blocking = (sprite[i].cstat&1);
|
||||||
|
|
||||||
|
@ -2282,8 +2289,8 @@ void overheadeditor(void)
|
||||||
if ((i == pointhighlight-16384) && (totalclock & 32))
|
if ((i == pointhighlight-16384) && (totalclock & 32))
|
||||||
col += (2<<2);
|
col += (2<<2);
|
||||||
|
|
||||||
drawsmalllabel(dabuffer, editorcolors[0], editorcolors[col], dax, day);
|
drawsmallabel(dabuffer, editorcolors[0], editorcolors[col],
|
||||||
}
|
sprite[i].x, sprite[i].y, sprite[i].z);
|
||||||
}
|
}
|
||||||
j--;
|
j--;
|
||||||
}
|
}
|
||||||
|
@ -2291,14 +2298,23 @@ void overheadeditor(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// stick this event right between begin- end enddrawing()...
|
||||||
|
// also after the above label stuff so users can redefine them
|
||||||
|
VM_OnEvent(EVENT_DRAW2DSCREEN, -1);
|
||||||
|
|
||||||
printcoords16(pos.x,pos.y,ang);
|
printcoords16(pos.x,pos.y,ang);
|
||||||
|
|
||||||
numwalls = tempint;
|
numwalls = tempint;
|
||||||
|
|
||||||
if (highlightsectorcnt >= 0)
|
if (highlightsectorcnt >= 0)
|
||||||
|
{
|
||||||
|
int32_t oydim16 = ydim16;
|
||||||
|
ydim16 = ydim-STATUS2DSIZ2;
|
||||||
for (i=0; i<numsectors; i++)
|
for (i=0; i<numsectors; i++)
|
||||||
if (hlsectorbitmap[i>>3]&(1<<(i&7)))
|
if (hlsectorbitmap[i>>3]&(1<<(i&7)))
|
||||||
fillsector(i,2);
|
fillsector(i,2);
|
||||||
|
ydim16 = oydim16;
|
||||||
|
}
|
||||||
|
|
||||||
if (keystatus[0x2a]) // FIXME
|
if (keystatus[0x2a]) // FIXME
|
||||||
{
|
{
|
||||||
|
@ -2375,7 +2391,7 @@ void overheadeditor(void)
|
||||||
////// Draw the white pixel closest to mouse cursor on linehighlight
|
////// Draw the white pixel closest to mouse cursor on linehighlight
|
||||||
if (linehighlight>=0 && !m32_sideview)
|
if (linehighlight>=0 && !m32_sideview)
|
||||||
{
|
{
|
||||||
getclosestpointonwall(mousxplc,mousyplc,(int32_t)linehighlight,&dax,&day);
|
getclosestpointonwall(mousxplc,mousyplc, linehighlight, &dax,&day);
|
||||||
x2 = mulscale14(dax-pos.x,zoom);
|
x2 = mulscale14(dax-pos.x,zoom);
|
||||||
y2 = mulscale14(day-pos.y,zoom);
|
y2 = mulscale14(day-pos.y,zoom);
|
||||||
|
|
||||||
|
@ -2660,7 +2676,7 @@ void overheadeditor(void)
|
||||||
keystatus[0x46] = 0;
|
keystatus[0x46] = 0;
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
}
|
}
|
||||||
|
#if 1
|
||||||
if (keystatus[0x3f]) //F5
|
if (keystatus[0x3f]) //F5
|
||||||
{
|
{
|
||||||
// keystatus[0x3f] = 0;
|
// keystatus[0x3f] = 0;
|
||||||
|
@ -2730,6 +2746,7 @@ void overheadeditor(void)
|
||||||
ydim16 = ydim-STATUS2DSIZ2;
|
ydim16 = ydim-STATUS2DSIZ2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if (keystatus[0x23]) //H (Hi 16 bits of tag)
|
if (keystatus[0x23]) //H (Hi 16 bits of tag)
|
||||||
{
|
{
|
||||||
|
@ -4052,6 +4069,8 @@ end_join_sectors:
|
||||||
if (tilesizy[sprite[i].picnum] >= 32)
|
if (tilesizy[sprite[i].picnum] >= 32)
|
||||||
sprite[i].cstat |= 1;
|
sprite[i].cstat |= 1;
|
||||||
|
|
||||||
|
correct_sprite_yoffset(i);
|
||||||
|
|
||||||
printmessage16("Sprite inserted.");
|
printmessage16("Sprite inserted.");
|
||||||
updatenumsprites();
|
updatenumsprites();
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
|
@ -6788,18 +6807,35 @@ static int16_t whitelinescan(int16_t dalinehighlight)
|
||||||
return(tnewnumwalls);
|
return(tnewnumwalls);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t loadnames(void)
|
int32_t loadnames(const char *namesfile)
|
||||||
{
|
{
|
||||||
char buffer[1024], *p, *name, *number, *endptr;
|
char buffer[1024], *p, *name, *number, *endptr;
|
||||||
int32_t num, syms=0, line=0, a, comment=0;
|
int32_t num, syms=0, line=0, a, comment=0;
|
||||||
BFILE *fp;
|
BFILE *fp;
|
||||||
|
|
||||||
fp = fopenfrompath("NAMES.H","r");
|
Bstrncpy(buffer, namesfile, sizeof(buffer));
|
||||||
|
buffer[sizeof(buffer)-1] = 0;
|
||||||
|
|
||||||
|
p = buffer;
|
||||||
|
while (*p)
|
||||||
|
{
|
||||||
|
*p = Btoupper(*p);
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
|
||||||
|
fp = fopenfrompath(buffer,"r");
|
||||||
if (!fp)
|
if (!fp)
|
||||||
{
|
{
|
||||||
if ((fp = fopenfrompath("names.h","r")) == NULL)
|
p = buffer;
|
||||||
|
while (*p)
|
||||||
{
|
{
|
||||||
initprintf("Failed to open NAMES.H\n");
|
*p = Btolower(*p);
|
||||||
|
p++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((fp = fopenfrompath(buffer,"r")) == NULL)
|
||||||
|
{
|
||||||
|
initprintf("Failed to open %s\n", buffer);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6807,7 +6843,7 @@ int32_t loadnames(void)
|
||||||
//clearbufbyte(names, sizeof(names), 0);
|
//clearbufbyte(names, sizeof(names), 0);
|
||||||
Bmemset(names,0,sizeof(names));
|
Bmemset(names,0,sizeof(names));
|
||||||
|
|
||||||
initprintf("Loading NAMES.H\n");
|
initprintf("Loading %s\n", buffer);
|
||||||
|
|
||||||
while (Bfgets(buffer, 1024, fp))
|
while (Bfgets(buffer, 1024, fp))
|
||||||
{
|
{
|
||||||
|
|
|
@ -24,16 +24,15 @@ define SFACTORSTEPS 100
|
||||||
define PREVIEW_DRAW_COLOR 11
|
define PREVIEW_DRAW_COLOR 11
|
||||||
gamevar showpal 0 0
|
gamevar showpal 0 0
|
||||||
|
|
||||||
// 2d mode corruption checker interval, 120 = 1 second
|
|
||||||
gamevar checkinterval 1200 0
|
|
||||||
|
|
||||||
// whether to use overridden aspect/range values when entering 3d mode (software/Polymost).
|
// whether to use overridden aspect/range values when entering 3d mode (software/Polymost).
|
||||||
// tweak with keys 7,8,9,0 on the top row
|
// tweak with keys 7,8,9,0 on the top row
|
||||||
gamevar use_custom_aspect 0 0 // this is now the same as r_usenewaspect
|
gamevar use_custom_aspect 0 0 // this is now the same as r_usenewaspect
|
||||||
gamevar davr 65536 0
|
gamevar davr 65536 0
|
||||||
gamevar dayx 65536 0
|
gamevar dayx 65536 0
|
||||||
|
|
||||||
// see end of file for user key defs
|
|
||||||
|
// see end of file for more user settings and examples
|
||||||
|
|
||||||
////////// END USER SETTINGS //////////
|
////////// END USER SETTINGS //////////
|
||||||
|
|
||||||
|
|
||||||
|
@ -72,18 +71,6 @@ definequote LIGHTQUOTE light %d %d %d %d %d %d %d %d %d %d %d %d %d %d
|
||||||
// sec range radius fade ang horiz prio tile
|
// sec range radius fade ang horiz prio tile
|
||||||
|
|
||||||
|
|
||||||
// Corruption checker
|
|
||||||
definequote 19 PANIC!!! SECTOR OR WALL LIMIT EXCEEDED!!!
|
|
||||||
definequote 20 SECTOR[%d].WALLPTR=%d out of range: numwalls=%d
|
|
||||||
definequote 21 SECTOR[%d].WALLPTR=%d inconsistent, expected %d
|
|
||||||
definequote 22 SECTOR[%d]: wallptr+wallnum=%d out of range: numwalls=%d
|
|
||||||
definequote 23 WALL[%d].POINT2=%d out of range [%d, %d]
|
|
||||||
definequote 24 WALL[%d].NEXTWALL=%d out of range: numwalls=%d
|
|
||||||
definequote 25 WALL[%d].NEXTSECTOR=%d out of range: numsectors=%d
|
|
||||||
definequote 26 SPRITE[%d].SECTNUM=%d. Expect problems!
|
|
||||||
definequote 27 SPRITE[%d].PICNUM=%d out of range, resetting to 0
|
|
||||||
definequote 28 WALL[%d] has nextsector but no nextwall or vice versa!
|
|
||||||
|
|
||||||
define PRSCALE 1000
|
define PRSCALE 1000
|
||||||
define MAXSPECULAR 100000
|
define MAXSPECULAR 100000
|
||||||
|
|
||||||
|
@ -393,7 +380,9 @@ defstate fiddlewithlights
|
||||||
}
|
}
|
||||||
ends
|
ends
|
||||||
|
|
||||||
defstate userkeys_3d ends // forward-ref
|
// forward refs
|
||||||
|
defstate userkeys_3d ends
|
||||||
|
defstate userdrawlabel ends
|
||||||
|
|
||||||
onevent EVENT_PREKEYS3D
|
onevent EVENT_PREKEYS3D
|
||||||
// state testkeyavail
|
// state testkeyavail
|
||||||
|
@ -1017,116 +1006,13 @@ defstate jumptosec // (tmp)
|
||||||
updatecursectnum
|
updatecursectnum
|
||||||
ends
|
ends
|
||||||
|
|
||||||
// Map corruption checker
|
|
||||||
// now included in Mapster32 natively
|
|
||||||
|
|
||||||
/*
|
|
||||||
defstate corruptchk
|
|
||||||
var ewall
|
|
||||||
var endwall
|
|
||||||
var ok
|
|
||||||
|
|
||||||
ifle numsectors MAXSECTORS ifle numwalls MAXWALLS nullop else
|
|
||||||
{ quote 19 printmessage16 19 return }
|
|
||||||
|
|
||||||
set ok 1
|
|
||||||
|
|
||||||
set ewall 0 // expected wall index
|
|
||||||
for i allsectors
|
|
||||||
{
|
|
||||||
set k 1
|
|
||||||
ifge sector[i].wallptr 0 ifl sector[i].wallptr numwalls nullop else
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 20 i sector[i].wallptr numwalls
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set k 0
|
|
||||||
}
|
|
||||||
ifn ewall sector[i].wallptr
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 21 i sector[i].wallptr ewall
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ewall sector[i].wallptr
|
|
||||||
}
|
|
||||||
add ewall sector[i].wallnum
|
|
||||||
|
|
||||||
set endwall sector[i].wallptr add endwall sector[i].wallnum
|
|
||||||
ifg endwall numwalls
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 22 i endwall numwalls
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set k 0
|
|
||||||
}
|
|
||||||
|
|
||||||
and ok k
|
|
||||||
|
|
||||||
ifn k 0
|
|
||||||
{
|
|
||||||
sub endwall 1
|
|
||||||
for j wallsofsector i
|
|
||||||
{
|
|
||||||
ifge wall[j].point2 sector[i].wallptr ifle wall[i].point2 endwall nullop else
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 23 j wall[j].point2 sector[i].wallptr endwall
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
|
|
||||||
ifge wall[j].nextwall numwalls
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 24 j wall[j].nextwall numwalls
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
|
|
||||||
ifge wall[j].nextsector numsectors
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 25 j wall[j].nextsector numsectors
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
|
|
||||||
set k 0
|
|
||||||
ifge wall[j].nextsector 0, xor k 1
|
|
||||||
ifge wall[j].nextwall 0, xor k 1
|
|
||||||
|
|
||||||
ife k 1
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 28 j
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for i allsprites
|
|
||||||
{
|
|
||||||
ifl .sectnum 0
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 26 i .sectnum
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
|
|
||||||
ifge .picnum 0 ifl .picnum MAXTILES nullop else
|
|
||||||
{
|
|
||||||
qsprintf TQUOTE 27 i .picnum
|
|
||||||
quote TQUOTE printmessage16 TQUOTE
|
|
||||||
set .picnum 0
|
|
||||||
set ok 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ife ok 0
|
|
||||||
print "--"
|
|
||||||
ends
|
|
||||||
*/
|
|
||||||
|
|
||||||
gamevar d2d_lastcheck 0 0
|
|
||||||
onevent EVENT_DRAW2DSCREEN
|
onevent EVENT_DRAW2DSCREEN
|
||||||
var tmp
|
var tmp
|
||||||
var xx
|
var xx
|
||||||
|
|
||||||
|
state userdrawlabel
|
||||||
|
|
||||||
ifge cursectnum 0
|
ifge cursectnum 0
|
||||||
{
|
{
|
||||||
state connectlocators
|
state connectlocators
|
||||||
|
@ -1135,14 +1021,6 @@ onevent EVENT_DRAW2DSCREEN
|
||||||
|
|
||||||
state previewdoors2d
|
state previewdoors2d
|
||||||
|
|
||||||
ifl checkinterval 120, set checkinterval 120
|
|
||||||
set tmp totalclock, sub tmp checkinterval
|
|
||||||
ifl d2d_lastcheck tmp
|
|
||||||
{
|
|
||||||
set d2d_lastcheck totalclock
|
|
||||||
// state corruptchk
|
|
||||||
}
|
|
||||||
|
|
||||||
ifn showpal 0
|
ifn showpal 0
|
||||||
{
|
{
|
||||||
set xx 100
|
set xx 100
|
||||||
|
@ -1237,7 +1115,23 @@ defstate chselshade
|
||||||
ends
|
ends
|
||||||
|
|
||||||
|
|
||||||
////////// USER KEY SETTINGS //////////
|
////////// USER AREA //////////
|
||||||
|
|
||||||
|
// key settings
|
||||||
defstate userkeys_3d
|
defstate userkeys_3d
|
||||||
ifholdkey KEY_SEMI ifhitkey KEY_C state chselshade
|
ifholdkey KEY_SEMI ifhitkey KEY_C state chselshade
|
||||||
ends
|
ends
|
||||||
|
|
||||||
|
/*
|
||||||
|
// example for custom labels
|
||||||
|
defstate userdrawlabel
|
||||||
|
for i allsprites
|
||||||
|
{
|
||||||
|
ifactor 2978
|
||||||
|
{
|
||||||
|
qsprintf TQUOTE "MOVABLE EX:%d OW:%d", sprite[i].owner, sprite[i].extra
|
||||||
|
drawlabel TQUOTE .x .y .z 0 31
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ends
|
||||||
|
*/
|
||||||
|
|
|
@ -152,3 +152,26 @@ defstate consttest
|
||||||
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 " "
|
||||||
ends
|
ends
|
||||||
|
|
||||||
|
defstate anmtest
|
||||||
|
var yo
|
||||||
|
|
||||||
|
for i range MAXTILES
|
||||||
|
{
|
||||||
|
set j tilesizx[i], or j tilesizy[i]
|
||||||
|
|
||||||
|
ifn j 0
|
||||||
|
{
|
||||||
|
set yo picanm[i]
|
||||||
|
shiftl yo 8, shiftr yo 24 // sign-extend
|
||||||
|
|
||||||
|
ifl yo 0, inv yo
|
||||||
|
|
||||||
|
ifge yo tilesizy[i]
|
||||||
|
{
|
||||||
|
qsprintf TQUOTE "Tile %d's y offset >= y size" i
|
||||||
|
quote TQUOTE
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ends
|
||||||
|
|
|
@ -400,6 +400,8 @@ void create_map_snapshot(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CheckMapCorruption(6, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void map_undoredo_free(void)
|
void map_undoredo_free(void)
|
||||||
|
@ -3211,7 +3213,6 @@ static int32_t m32gettile(int32_t idInitialTile)
|
||||||
keystatus[KEYSC_ENTER] = 0;
|
keystatus[KEYSC_ENTER] = 0;
|
||||||
|
|
||||||
return idSelectedTile;
|
return idSelectedTile;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Dir = 0 (zoom out) or 1 (zoom in)
|
// Dir = 0 (zoom out) or 1 (zoom in)
|
||||||
|
@ -3671,10 +3672,19 @@ static int32_t DrawTiles(int32_t iTopLeft, int32_t iSelected, int32_t nXTiles, i
|
||||||
Bsprintf(szT,"%dx%d",tilesizx[idTile],tilesizy[idTile]);
|
Bsprintf(szT,"%dx%d",tilesizx[idTile],tilesizy[idTile]);
|
||||||
printext256(xdim>>2,ydim-10,whitecol,-1,szT,0);
|
printext256(xdim>>2,ydim-10,whitecol,-1,szT,0);
|
||||||
|
|
||||||
// EditArt animation flags.
|
// EditArt offset flags.
|
||||||
Bsprintf(szT,"%d, %d",(picanm[idTile]>>8)&0xFF,(picanm[idTile]>>16)&0xFF);
|
Bsprintf(szT,"%d, %d", (int8_t)((picanm[idTile]>>8)&0xFF), (int8_t)((picanm[idTile]>>16)&0xFF));
|
||||||
printext256((xdim>>2)+100,ydim-10,whitecol,-1,szT,0);
|
printext256((xdim>>2)+100,ydim-10,whitecol,-1,szT,0);
|
||||||
|
|
||||||
|
// EditArt animation flags.
|
||||||
|
if (picanm[idTile]&0xc0)
|
||||||
|
{
|
||||||
|
static const char *anmtype[] = {"", "Osc", "Fwd", "Bck"};
|
||||||
|
|
||||||
|
Bsprintf(szT,"%s %d", anmtype[(picanm[idTile]&0xc0)>>6], picanm[idTile]&0x3f);
|
||||||
|
printext256((xdim>>2)+100+14*8,ydim-10,whitecol,-1,szT,0);
|
||||||
|
}
|
||||||
|
|
||||||
if (showmsg)
|
if (showmsg)
|
||||||
TMPERRMSG_SHOW(0);
|
TMPERRMSG_SHOW(0);
|
||||||
|
|
||||||
|
@ -4420,7 +4430,8 @@ static void Keys3d(void)
|
||||||
sprite[searchwall].hitag, sprite[searchwall].extra);
|
sprite[searchwall].hitag, sprite[searchwall].extra);
|
||||||
|
|
||||||
Bsprintf(lines[num++], "Repeat: %d,%d", sprite[searchwall].xrepeat, sprite[searchwall].yrepeat);
|
Bsprintf(lines[num++], "Repeat: %d,%d", sprite[searchwall].xrepeat, sprite[searchwall].yrepeat);
|
||||||
Bsprintf(lines[num++], "PosXY: %d,%d", sprite[searchwall].x, sprite[searchwall].y);
|
Bsprintf(lines[num++], "PosXY: %d,%d%s", sprite[searchwall].x, sprite[searchwall].y,
|
||||||
|
sprite[searchwall].xoffset|sprite[searchwall].yoffset ? " ^251*":"");
|
||||||
Bsprintf(lines[num++], "PosZ: "" %d", sprite[searchwall].z);// prevents tab character
|
Bsprintf(lines[num++], "PosZ: "" %d", sprite[searchwall].z);// prevents tab character
|
||||||
lines[num++][0]=0;
|
lines[num++][0]=0;
|
||||||
|
|
||||||
|
@ -4511,6 +4522,9 @@ static void Keys3d(void)
|
||||||
if (AIMING_AT_MASKWALL && wall[searchwall].nextwall >= 0)
|
if (AIMING_AT_MASKWALL && wall[searchwall].nextwall >= 0)
|
||||||
NEXTWALL(searchwall).overpicnum = tempint;
|
NEXTWALL(searchwall).overpicnum = tempint;
|
||||||
|
|
||||||
|
if (AIMING_AT_SPRITE)
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
|
|
||||||
if (oldtile != tempint)
|
if (oldtile != tempint)
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
}
|
}
|
||||||
|
@ -5023,6 +5037,9 @@ static void Keys3d(void)
|
||||||
j = 0;
|
j = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (AIMING_AT_SPRITE)
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
|
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
}
|
}
|
||||||
keystatus[KEYSC_DASH] = keystatus[KEYSC_EQUAL] = 0;
|
keystatus[KEYSC_DASH] = keystatus[KEYSC_EQUAL] = 0;
|
||||||
|
@ -5661,11 +5678,14 @@ static void Keys3d(void)
|
||||||
{
|
{
|
||||||
if (ASSERT_AIMING)
|
if (ASSERT_AIMING)
|
||||||
{
|
{
|
||||||
int16_t opicnum = AIMED_CF_SEL(picnum);
|
int16_t opicnum = AIMED_CF_SEL(picnum), aimspr=AIMING_AT_SPRITE;
|
||||||
static const char *Typestr_tmp[5] = { "Wall", "Sector ceiling", "Sector floor", "Sprite", "Masked wall" };
|
static const char *Typestr_tmp[5] = { "Wall", "Sector ceiling", "Sector floor", "Sprite", "Masked wall" };
|
||||||
Bsprintf(tempbuf, "%s picnum: ", Typestr_tmp[searchstat]);
|
Bsprintf(tempbuf, "%s picnum: ", Typestr_tmp[searchstat]);
|
||||||
getnumberptr256(tempbuf, &AIMED_CF_SEL(picnum), sizeof(int16_t), MAXTILES-1, 0, NULL);
|
getnumberptr256(tempbuf, &AIMED_CF_SEL(picnum), sizeof(int16_t), MAXTILES-1, 0, NULL);
|
||||||
asksave |= (opicnum != AIMED_CF_SEL(picnum));
|
asksave |= (opicnum != AIMED_CF_SEL(picnum));
|
||||||
|
|
||||||
|
if (aimspr)
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5765,6 +5785,9 @@ static void Keys3d(void)
|
||||||
{
|
{
|
||||||
AIMED_SELOVR_PICNUM = temppicnum;
|
AIMED_SELOVR_PICNUM = temppicnum;
|
||||||
message("Pasted picnum only");
|
message("Pasted picnum only");
|
||||||
|
|
||||||
|
if (AIMING_AT_SPRITE)
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
}
|
}
|
||||||
|
|
||||||
i = 512;
|
i = 512;
|
||||||
|
@ -6410,6 +6433,8 @@ static void Keys3d(void)
|
||||||
sprite[searchwall].yvel = tempyvel;
|
sprite[searchwall].yvel = tempyvel;
|
||||||
sprite[searchwall].zvel = tempzvel;
|
sprite[searchwall].zvel = tempzvel;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
}
|
}
|
||||||
message("Pasted clipboard");
|
message("Pasted clipboard");
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
|
@ -6442,7 +6467,10 @@ static void Keys3d(void)
|
||||||
for (i=0; i<MAXSPRITES; i++)
|
for (i=0; i<MAXSPRITES; i++)
|
||||||
if (sprite[i].statnum < MAXSTATUS)
|
if (sprite[i].statnum < MAXSTATUS)
|
||||||
if (sprite[i].picnum == j)
|
if (sprite[i].picnum == j)
|
||||||
|
{
|
||||||
sprite[i].picnum = temppicnum;
|
sprite[i].picnum = temppicnum;
|
||||||
|
correct_sprite_yoffset(i);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case SEARCH_MASKWALL:
|
case SEARCH_MASKWALL:
|
||||||
j = wall[searchwall].overpicnum;
|
j = wall[searchwall].overpicnum;
|
||||||
|
@ -6494,6 +6522,8 @@ static void Keys3d(void)
|
||||||
sprite[searchwall].xrepeat = 64;
|
sprite[searchwall].xrepeat = 64;
|
||||||
sprite[searchwall].yrepeat = 64;
|
sprite[searchwall].yrepeat = 64;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
correct_sprite_yoffset(searchwall);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ASSERT_AIMING)
|
if (ASSERT_AIMING)
|
||||||
|
@ -7465,6 +7495,12 @@ static void G_CheckCommandLine(int32_t argc, const char **argv)
|
||||||
i++;
|
i++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (!Bstrcasecmp(c+1,"namesfile"))
|
||||||
|
{
|
||||||
|
g_namesFileName = argv[i+1];
|
||||||
|
i++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (!Bstrcasecmp(c+1,"ww2gi"))
|
if (!Bstrcasecmp(c+1,"ww2gi"))
|
||||||
{
|
{
|
||||||
Bstrcpy(g_grpNamePtr, "ww2gi.grp");
|
Bstrcpy(g_grpNamePtr, "ww2gi.grp");
|
||||||
|
|
|
@ -363,6 +363,7 @@ const char *keyw[] =
|
||||||
"printmessage256",
|
"printmessage256",
|
||||||
"printext256",
|
"printext256",
|
||||||
"printext16",
|
"printext16",
|
||||||
|
"drawlabel",
|
||||||
"getnumber16",
|
"getnumber16",
|
||||||
"getnumber256",
|
"getnumber256",
|
||||||
"qsprintf",
|
"qsprintf",
|
||||||
|
@ -3266,14 +3267,18 @@ repeatcase:
|
||||||
case CON_QUOTE:
|
case CON_QUOTE:
|
||||||
case CON_ERRORINS:
|
case CON_ERRORINS:
|
||||||
case CON_PRINTMESSAGE16:
|
case CON_PRINTMESSAGE16:
|
||||||
|
case CON_PRINTMESSAGE256:
|
||||||
case CON_PRINTEXT256:
|
case CON_PRINTEXT256:
|
||||||
case CON_PRINTEXT16:
|
case CON_PRINTEXT16:
|
||||||
|
case CON_DRAWLABEL:
|
||||||
if (C_GetNextVarOrString()==-1)
|
if (C_GetNextVarOrString()==-1)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if (tw==CON_PRINTMESSAGE256)
|
if (tw==CON_PRINTMESSAGE256)
|
||||||
C_GetManyVars(2);
|
C_GetManyVars(2);
|
||||||
else if (tw==CON_PRINTEXT256 || tw==CON_PRINTEXT16)
|
else if (tw >= CON_PRINTEXT256)
|
||||||
C_GetManyVars(5);
|
C_GetManyVars(5);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case CON_GETNUMBER16:
|
case CON_GETNUMBER16:
|
||||||
|
|
|
@ -467,6 +467,7 @@ enum ScriptKeywords_t
|
||||||
CON_PRINTMESSAGE256,
|
CON_PRINTMESSAGE256,
|
||||||
CON_PRINTEXT256,
|
CON_PRINTEXT256,
|
||||||
CON_PRINTEXT16,
|
CON_PRINTEXT16,
|
||||||
|
CON_DRAWLABEL,
|
||||||
CON_GETNUMBER16,
|
CON_GETNUMBER16,
|
||||||
CON_GETNUMBER256,
|
CON_GETNUMBER256,
|
||||||
CON_QSPRINTF,
|
CON_QSPRINTF,
|
||||||
|
|
|
@ -2385,6 +2385,7 @@ badindex:
|
||||||
case CON_PRINTMESSAGE256:
|
case CON_PRINTMESSAGE256:
|
||||||
case CON_PRINTEXT256:
|
case CON_PRINTEXT256:
|
||||||
case CON_PRINTEXT16:
|
case CON_PRINTEXT16:
|
||||||
|
case CON_DRAWLABEL:
|
||||||
insptr++;
|
insptr++;
|
||||||
{
|
{
|
||||||
int32_t i=*insptr++;
|
int32_t i=*insptr++;
|
||||||
|
@ -2395,31 +2396,56 @@ badindex:
|
||||||
{
|
{
|
||||||
int32_t x=(tw>=CON_PRINTMESSAGE256)?Gv_GetVarX(*insptr++):0;
|
int32_t x=(tw>=CON_PRINTMESSAGE256)?Gv_GetVarX(*insptr++):0;
|
||||||
int32_t y=(tw>=CON_PRINTMESSAGE256)?Gv_GetVarX(*insptr++):0;
|
int32_t y=(tw>=CON_PRINTMESSAGE256)?Gv_GetVarX(*insptr++):0;
|
||||||
|
|
||||||
int32_t col=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
int32_t col=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
||||||
int32_t backcol=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
int32_t backcol=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
||||||
int32_t fontsize=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
int32_t fontsize=(tw>=CON_PRINTEXT256)?Gv_GetVarX(*insptr++):0;
|
||||||
|
|
||||||
if (tw==CON_ERRORINS) vm.flags |= VMFLAG_ERROR;
|
|
||||||
|
|
||||||
if (tw==CON_PRINT || tw==CON_ERRORINS)
|
if (tw==CON_PRINT || tw==CON_ERRORINS)
|
||||||
|
{
|
||||||
OSD_Printf("%s\n", quotetext);
|
OSD_Printf("%s\n", quotetext);
|
||||||
|
if (tw==CON_ERRORINS)
|
||||||
|
vm.flags |= VMFLAG_ERROR;
|
||||||
|
}
|
||||||
else if (tw==CON_QUOTE)
|
else if (tw==CON_QUOTE)
|
||||||
|
{
|
||||||
message("%s", quotetext);
|
message("%s", quotetext);
|
||||||
|
}
|
||||||
else if (tw==CON_PRINTMESSAGE16)
|
else if (tw==CON_PRINTMESSAGE16)
|
||||||
|
{
|
||||||
|
if (qsetmode != 200)
|
||||||
printmessage16("%s", quotetext);
|
printmessage16("%s", quotetext);
|
||||||
|
}
|
||||||
else if (tw==CON_PRINTMESSAGE256)
|
else if (tw==CON_PRINTMESSAGE256)
|
||||||
|
{
|
||||||
|
if (qsetmode == 200)
|
||||||
printmessage256(x, y, quotetext);
|
printmessage256(x, y, quotetext);
|
||||||
|
}
|
||||||
else if (tw==CON_PRINTEXT256)
|
else if (tw==CON_PRINTEXT256)
|
||||||
|
{
|
||||||
|
if (qsetmode == 200)
|
||||||
{
|
{
|
||||||
if (col<0 || col>=256) col=0;
|
if (col<0 || col>=256) col=0;
|
||||||
if (backcol<0 || backcol>=256) backcol=-1;
|
if (backcol<0 || backcol>=256) backcol=-1;
|
||||||
printext256(x, y, col, backcol, quotetext, fontsize);
|
printext256(x, y, col, backcol, quotetext, fontsize);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else if (tw==CON_PRINTEXT16)
|
else if (tw==CON_PRINTEXT16)
|
||||||
{
|
{
|
||||||
printext16(x, y, editorcolors[col&15], backcol<0 ? -1 : editorcolors[backcol&15],
|
if (qsetmode != 200)
|
||||||
|
printext16(x, y, editorcolors[col&255], backcol<0 ? -1 : editorcolors[backcol&255],
|
||||||
quotetext, fontsize);
|
quotetext, fontsize);
|
||||||
}
|
}
|
||||||
|
else if (tw==CON_DRAWLABEL)
|
||||||
|
{
|
||||||
|
if (qsetmode != 200)
|
||||||
|
{
|
||||||
|
drawsmallabel(quotetext,
|
||||||
|
editorcolors[backcol&255], // col
|
||||||
|
fontsize < 0 ? -1 : editorcolors[fontsize&255], // backcol
|
||||||
|
x, y, col); // x y z
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -668,6 +668,8 @@ static void Gv_AddSystemVars(void)
|
||||||
|
|
||||||
Gv_NewArray("tilesizx", (void *)tilesizx, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFSHORT);
|
Gv_NewArray("tilesizx", (void *)tilesizx, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFSHORT);
|
||||||
Gv_NewArray("tilesizy", (void *)tilesizy, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFSHORT);
|
Gv_NewArray("tilesizy", (void *)tilesizy, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFSHORT);
|
||||||
|
// Gv_NewArray("picsiz", (void *)picsiz, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFCHAR);
|
||||||
|
Gv_NewArray("picanm", (void *)picanm, MAXTILES, GAMEARRAY_READONLY|GAMEARRAY_OFINT);
|
||||||
|
|
||||||
Gv_NewArray("show2dsector", (void *)show2dsector, (MAXSECTORS+7)>>3, GAMEARRAY_READONLY|GAMEARRAY_OFCHAR);
|
Gv_NewArray("show2dsector", (void *)show2dsector, (MAXSECTORS+7)>>3, GAMEARRAY_READONLY|GAMEARRAY_OFCHAR);
|
||||||
Gv_NewArray("show2dwall", (void *)show2dwall, (MAXWALLS+7)>>3, GAMEARRAY_READONLY|GAMEARRAY_OFCHAR);
|
Gv_NewArray("show2dwall", (void *)show2dwall, (MAXWALLS+7)>>3, GAMEARRAY_READONLY|GAMEARRAY_OFCHAR);
|
||||||
|
|
Loading…
Reference in a new issue