mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 15:11:51 +00:00
minor changes from my tree that I'm committing to test automated synthesis builds
git-svn-id: https://svn.eduke32.com/eduke32@1645 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
8077dcd633
commit
45052b8273
16 changed files with 228 additions and 174 deletions
|
@ -3,8 +3,8 @@
|
|||
ENGINELIB=libengine.a
|
||||
EDITORLIB=libbuild.a
|
||||
|
||||
SDLCONFIG = /usr/local/bin/sdl-config
|
||||
# SDLCONFIG = sdl-config
|
||||
# SDLCONFIG = /usr/local/bin/sdl-config
|
||||
SDLCONFIG = /usr/bin/sdl-config
|
||||
|
||||
ifeq ($(wildcard $(SDLCONFIG)),$(SDLCONFIG))
|
||||
SDLROOT = /usr/local
|
||||
|
|
|
@ -98,7 +98,7 @@ void debugprintf(const char *,...);
|
|||
int32_t handleevents(void);
|
||||
extern inline void idle(void);
|
||||
extern inline void idle_waitevent(void);
|
||||
extern inline void idle_waitevent_timeout(int32_t timeout);
|
||||
extern inline void idle_waitevent_timeout(uint32_t timeout);
|
||||
|
||||
typedef void (*KeyPressCallback)(int32_t,int32_t);
|
||||
typedef void (*MousePressCallback)(int32_t,int32_t);
|
||||
|
|
|
@ -1267,7 +1267,7 @@ void overheadeditor(void)
|
|||
walltype *wal;
|
||||
int32_t prefixarg = 0;
|
||||
hitdata_t hitinfo;
|
||||
int32_t resetsynctics = 0, lasttick=getticks();
|
||||
int32_t resetsynctics = 0, lasttick=getticks(), waitdelay=totalclock, lastdraw=getticks();
|
||||
int32_t tsign;
|
||||
|
||||
//qsetmode640480();
|
||||
|
@ -1322,11 +1322,16 @@ void overheadeditor(void)
|
|||
if (!((vel|angvel|svel) //DOWN_BK(MOVEFORWARD) || DOWN_BK(MOVEBACKWARD) || DOWN_BK(TURNLEFT) || DOWN_BK(TURNRIGHT)
|
||||
|| DOWN_BK(MOVEUP) || DOWN_BK(MOVEDOWN) || bstatus || OSD_IsMoving()))
|
||||
{
|
||||
// wait for event, timeout after 200 ms - (last loop time)
|
||||
idle_waitevent_timeout(200 - min(getticks()-lasttick, 200));
|
||||
// have synctics reset to 0 after we've slept to avoid zooming out to the max instantly
|
||||
resetsynctics = 1;
|
||||
if (totalclock > waitdelay)
|
||||
{
|
||||
// wait for event, timeout after 200 ms - (last loop time)
|
||||
idle_waitevent_timeout(200 - min(getticks()-lasttick, 200));
|
||||
// have synctics reset to 0 after we've slept to avoid zooming out to the max instantly
|
||||
resetsynctics = 1;
|
||||
}
|
||||
}
|
||||
else waitdelay = totalclock + 30; // should be 250 ms
|
||||
|
||||
lasttick = getticks();
|
||||
|
||||
if (handleevents())
|
||||
|
@ -1429,8 +1434,11 @@ void overheadeditor(void)
|
|||
numwalls = newnumwalls;
|
||||
if (numwalls < 0) numwalls = tempint;
|
||||
|
||||
if (DOWN_BK(MOVEUP) || DOWN_BK(MOVEDOWN) || mousx || mousy || bstatus || (totalclock & 8) == 0 || newnumwalls>=0)
|
||||
if ((getticks() - lastdraw) >= 5 || (vel|angvel|svel) || DOWN_BK(MOVEUP) || DOWN_BK(MOVEDOWN) || mousx || mousy || bstatus ||
|
||||
newnumwalls>=0 || OSD_IsMoving())
|
||||
{
|
||||
lastdraw = getticks();
|
||||
|
||||
clear2dscreen();
|
||||
|
||||
if (graphicsmode)
|
||||
|
|
|
@ -301,7 +301,7 @@ int32_t addsearchpath(const char *p)
|
|||
|
||||
Bcorrectfilename(srch->path,0);
|
||||
|
||||
initprintf("addsearchpath(): Added %s\n", srch->path);
|
||||
initprintf("Using %s for game data\n", srch->path);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -5492,21 +5492,45 @@ int32_t preinitengine(void)
|
|||
|
||||
makeasmwriteable();
|
||||
|
||||
// this shite is to help get around data segment size limits on some platforms
|
||||
|
||||
state_compress = (qlz_state_compress *)Bmalloc(sizeof(qlz_state_compress));
|
||||
state_decompress = (qlz_state_decompress *)Bmalloc(sizeof(qlz_state_decompress));
|
||||
|
||||
#ifdef DYNALLOC_ARRAYS
|
||||
sector = Bcalloc(MAXSECTORS,sizeof(sectortype));
|
||||
wall = Bcalloc(MAXWALLS,sizeof(walltype));
|
||||
sprite = Bcalloc(MAXSPRITES,sizeof(spritetype));
|
||||
tsprite = Bcalloc(MAXSPRITESONSCREEN,sizeof(spritetype));
|
||||
spriteext = Bcalloc(MAXSPRITES+MAXUNIQHUDID,sizeof(spriteext_t));
|
||||
spritesmooth = Bcalloc(MAXSPRITES+MAXUNIQHUDID,sizeof(spritesmooth_t));
|
||||
{
|
||||
size_t i, size = 0;
|
||||
int8_t *ptr;
|
||||
|
||||
// allocate everything at once... why not? entries can just be added to this table
|
||||
// to allocate future arrays without further intervention
|
||||
struct
|
||||
{
|
||||
void **ptr;
|
||||
size_t size;
|
||||
}
|
||||
dynarray[] =
|
||||
{
|
||||
{ (void **)§or, sizeof(sectortype) * MAXSECTORS },
|
||||
{ (void **)&wall, sizeof(walltype) * MAXWALLS },
|
||||
{ (void **)&sprite, sizeof(spritetype) * MAXSPRITES },
|
||||
{ (void **)&tsprite, sizeof(spritetype) * MAXSPRITESONSCREEN },
|
||||
{ (void **)&spriteext, sizeof(spriteext_t) * (MAXSPRITES+MAXUNIQHUDID) },
|
||||
{ (void **)&spritesmooth, sizeof(spritesmooth_t) * (MAXSPRITES+MAXUNIQHUDID) },
|
||||
{ (void **)&state_compress, sizeof(qlz_state_compress) },
|
||||
{ (void **)&state_decompress, sizeof(qlz_state_decompress) }
|
||||
};
|
||||
|
||||
for (i=0;i<(signed)(sizeof(dynarray)/sizeof(dynarray[0])); i++)
|
||||
size += dynarray[i].size;
|
||||
|
||||
if ((ptr = (int8_t *)Bcalloc(1, size)) == NULL)
|
||||
return 1;
|
||||
|
||||
size = 0;
|
||||
|
||||
for (i=0;i<(signed)(sizeof(dynarray)/sizeof(dynarray[0])); i++)
|
||||
{
|
||||
*dynarray[i].ptr = ptr + size;
|
||||
size += dynarray[i].size;
|
||||
}
|
||||
}
|
||||
|
||||
if (!sector || !wall || !sprite || !tsprite || !spriteext || !spritesmooth)
|
||||
return 1;
|
||||
#else
|
||||
sector = sector_s;
|
||||
wall = wall_s;
|
||||
|
@ -5514,6 +5538,8 @@ int32_t preinitengine(void)
|
|||
tsprite = tsprite_s;
|
||||
spriteext = spriteext_s;
|
||||
spritesmooth = spritesmooth_s;
|
||||
state_compress = (qlz_state_compress *) Bmalloc(sizeof(qlz_state_compress) + sizeof(qlz_state_decompress));
|
||||
state_decompress = (qlz_state_decompress *) ((int8_t *)(state_compress) + sizeof(qlz_state_compress));
|
||||
#endif
|
||||
|
||||
if ((e = Bgetenv("BUILD_NOP6")) != NULL)
|
||||
|
@ -5632,7 +5658,6 @@ void uninitengine(void)
|
|||
Bfclose(cacheindexptr); */
|
||||
#endif
|
||||
|
||||
uninitsystem();
|
||||
if (artfil != -1) kclose(artfil);
|
||||
|
||||
i=(sizeof(artptrs)/sizeof(intptr_t))-1;
|
||||
|
@ -5662,20 +5687,11 @@ void uninitengine(void)
|
|||
#ifdef DYNALLOC_ARRAYS
|
||||
if (sector != NULL)
|
||||
Bfree(sector);
|
||||
if (wall != NULL)
|
||||
Bfree(wall);
|
||||
if (sprite != NULL)
|
||||
Bfree(sprite);
|
||||
if (tsprite != NULL)
|
||||
Bfree(tsprite);
|
||||
if (spriteext != NULL)
|
||||
Bfree(spriteext);
|
||||
if (spritesmooth != NULL)
|
||||
Bfree(spritesmooth);
|
||||
#else
|
||||
if (state_compress) Bfree(state_compress);
|
||||
#endif
|
||||
|
||||
if (state_compress) Bfree(state_compress);
|
||||
if (state_decompress) Bfree(state_decompress);
|
||||
uninitsystem();
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -775,7 +775,7 @@ void polymer_loadboard(void)
|
|||
|
||||
polymer_resetlights();
|
||||
|
||||
if (pr_verbosity >= 1) OSD_Printf("PR : Board loaded.\n");
|
||||
if (pr_verbosity >= 1 && numsectors) OSD_Printf("PR : Board loaded.\n");
|
||||
}
|
||||
|
||||
void polymer_drawrooms(int32_t daposx, int32_t daposy, int32_t daposz, int16_t daang, int32_t dahoriz, int16_t dacursectnum)
|
||||
|
@ -4318,7 +4318,7 @@ static void polymer_compileprogram(int32_t programbits)
|
|||
|
||||
prprograms[programbits].handle = program;
|
||||
|
||||
if (pr_verbosity >= 1) OSD_Printf("PR : Compiling GPU program with bits %i...\n", programbits);
|
||||
if (pr_verbosity >= 2) OSD_Printf("PR : Compiling GPU program with bits %i...\n", programbits);
|
||||
if (!linkstatus) {
|
||||
OSD_Printf("PR : Failed to compile GPU program with bits %i!\n", programbits);
|
||||
if (pr_verbosity >= 1) OSD_Printf("PR : Compilation log:\n%s\n", infobuffer);
|
||||
|
|
|
@ -105,7 +105,7 @@ static double dxb1[MAXWALLSB], dxb2[MAXWALLSB];
|
|||
#define LINTERPSIZ 4 //log2 of interpolation size. 4:pretty fast&acceptable quality, 0:best quality/slow!
|
||||
#define DEPTHDEBUG 0 //1:render distance instead of texture, for debugging only!, 0:default
|
||||
|
||||
float shadescale = 1.050f;
|
||||
float shadescale = 1.0f;
|
||||
|
||||
double gyxscale, gxyaspect, gviewxrange, ghalfx, grhalfxdown10, grhalfxdown10x, ghoriz;
|
||||
double gcosang, gsinang, gcosang2, gsinang2;
|
||||
|
|
|
@ -1896,7 +1896,7 @@ static int32_t SDL_WaitEventTimeout(SDL_Event * event, int32_t timeout)
|
|||
}
|
||||
#endif
|
||||
|
||||
inline void idle_waitevent_timeout(int32_t timeout)
|
||||
inline void idle_waitevent_timeout(uint32_t timeout)
|
||||
{
|
||||
SDL_WaitEventTimeout(NULL, timeout);
|
||||
}
|
||||
|
|
|
@ -98,8 +98,6 @@ static BOOL RegisterWindowClass(void);
|
|||
static BOOL CreateAppWindow(int32_t modenum);
|
||||
static void DestroyAppWindow(void);
|
||||
|
||||
static BOOL bDInputInited = FALSE;
|
||||
|
||||
// video
|
||||
static int32_t desktopxdim=0,desktopydim=0,desktopbpp=0,modesetusing=-1;
|
||||
int32_t xres=-1, yres=-1, fullscreen=0, bpp=0, bytesperline=0, imageSize=0;
|
||||
|
@ -144,6 +142,36 @@ void (*mousepresscallback)(int32_t,int32_t) = 0;
|
|||
void (*joypresscallback)(int32_t,int32_t) = 0;
|
||||
|
||||
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
// DINPUT (JOYSTICK)
|
||||
//=================================================================================================
|
||||
|
||||
#define JOYSTICK 0
|
||||
|
||||
static HMODULE hDInputDLL = NULL;
|
||||
static LPDIRECTINPUT7A lpDI = NULL;
|
||||
static LPDIRECTINPUTDEVICE7A lpDID = NULL;
|
||||
#define INPUT_BUFFER_SIZE 32
|
||||
static GUID guidDevs;
|
||||
|
||||
static char di_devacquired;
|
||||
static HANDLE di_inputevt;
|
||||
static int32_t joyblast=0;
|
||||
volatile uint8_t moustat = 0, mousegrab = 0;
|
||||
|
||||
static struct
|
||||
{
|
||||
char *name;
|
||||
LPDIRECTINPUTDEVICE7A *did;
|
||||
const DIDATAFORMAT *df;
|
||||
} devicedef = { "joystick", &lpDID, &c_dfDIJoystick };
|
||||
|
||||
static struct _joydef
|
||||
{
|
||||
const char *name;
|
||||
uint32_t ofs; // directinput 'dwOfs' value
|
||||
} *axisdefs = NULL, *buttondefs = NULL, *hatdefs = NULL;
|
||||
|
||||
|
||||
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
|
@ -542,9 +570,8 @@ static void printsysversion(void)
|
|||
break;
|
||||
}
|
||||
|
||||
initprintf("Running under Windows %s (build %lu.%lu.%lu) %s", ver, osv.dwMajorVersion, osv.dwMinorVersion,
|
||||
osv.dwPlatformId == VER_PLATFORM_WIN32_NT ? osv.dwBuildNumber : osv.dwBuildNumber&0xffff,
|
||||
osv.szCSDVersion);
|
||||
initprintf("Windows %s (build %lu.%lu.%lu) %s", ver,
|
||||
osv.dwMajorVersion, osv.dwMinorVersion, osv.dwBuildNumber, osv.szCSDVersion);
|
||||
|
||||
#ifdef NEDMALLOC
|
||||
initprintf("\n");
|
||||
|
@ -552,7 +579,7 @@ static void printsysversion(void)
|
|||
if (largepagesavailable)
|
||||
initprintf("Large page support available\n");
|
||||
#else
|
||||
if (nedhandle) initprintf("with nedmalloc\n");
|
||||
initprintf(nedhandle ? "w/ nedmalloc.dll\n" : "\n");
|
||||
#endif
|
||||
|
||||
}
|
||||
|
@ -691,7 +718,7 @@ int32_t handleevents(void)
|
|||
|
||||
RI_PollDevices(TRUE);
|
||||
|
||||
if (bDInputInited)
|
||||
if (hDInputDLL)
|
||||
DI_PollJoysticks();
|
||||
|
||||
while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
|
||||
|
@ -721,36 +748,6 @@ int32_t handleevents(void)
|
|||
return rv;
|
||||
}
|
||||
|
||||
//-------------------------------------------------------------------------------------------------
|
||||
// DINPUT (JOYSTICK)
|
||||
//=================================================================================================
|
||||
|
||||
#define JOYSTICK 0
|
||||
|
||||
static HMODULE hDInputDLL = NULL;
|
||||
static LPDIRECTINPUT7A lpDI = NULL;
|
||||
static LPDIRECTINPUTDEVICE7A lpDID = NULL;
|
||||
#define INPUT_BUFFER_SIZE 32
|
||||
static GUID guidDevs;
|
||||
|
||||
static char di_devacquired;
|
||||
static HANDLE di_inputevt;
|
||||
static int32_t joyblast=0;
|
||||
volatile uint8_t moustat = 0, mousegrab = 0;
|
||||
|
||||
static struct
|
||||
{
|
||||
char *name;
|
||||
LPDIRECTINPUTDEVICE7A *did;
|
||||
const DIDATAFORMAT *df;
|
||||
} devicedef = { "joystick", &lpDID, &c_dfDIJoystick };
|
||||
|
||||
static struct _joydef
|
||||
{
|
||||
const char *name;
|
||||
uint32_t ofs; // directinput 'dwOfs' value
|
||||
} *axisdefs = NULL, *buttondefs = NULL, *hatdefs = NULL;
|
||||
|
||||
|
||||
// I don't see any pressing need to store the key-up events yet
|
||||
inline void SetKey(int32_t key, int32_t state)
|
||||
|
@ -842,9 +839,10 @@ void setkeypresscallback(void (*callback)(int32_t, int32_t)) { keypresscallback
|
|||
void setmousepresscallback(void (*callback)(int32_t, int32_t)) { mousepresscallback = callback; }
|
||||
void setjoypresscallback(void (*callback)(int32_t, int32_t)) { joypresscallback = callback; }
|
||||
|
||||
inline void idle_waitevent(void)
|
||||
inline void idle_waitevent_timeout(uint32_t timeout)
|
||||
{
|
||||
int32_t i = 10;
|
||||
// timeout becomes a completion deadline
|
||||
timeout += getticks();
|
||||
|
||||
do
|
||||
{
|
||||
|
@ -858,12 +856,12 @@ inline void idle_waitevent(void)
|
|||
|
||||
Sleep(10);
|
||||
}
|
||||
while (--i);
|
||||
while (timeout > (getticks() + 10));
|
||||
}
|
||||
|
||||
inline void idle_waitevent_timeout(int32_t timeout)
|
||||
inline void idle_waitevent(void)
|
||||
{
|
||||
idle_waitevent();
|
||||
idle_waitevent_timeout(100);
|
||||
}
|
||||
|
||||
inline void idle(void)
|
||||
|
@ -1077,7 +1075,7 @@ static BOOL InitDirectInput(void)
|
|||
LPDIRECTINPUTDEVICE7A dev2;
|
||||
DIDEVCAPS didc;
|
||||
|
||||
if (bDInputInited) return FALSE;
|
||||
if (hDInputDLL) return FALSE;
|
||||
|
||||
initprintf("Initializing DirectInput...\n");
|
||||
|
||||
|
@ -1108,7 +1106,6 @@ static BOOL InitDirectInput(void)
|
|||
if (inputdevices == (1|2))
|
||||
{
|
||||
initprintf(" - No game controllers found\n");
|
||||
bDInputInited = TRUE;
|
||||
UninitDirectInput();
|
||||
return TRUE;
|
||||
}
|
||||
|
@ -1186,7 +1183,6 @@ static BOOL InitDirectInput(void)
|
|||
|
||||
di_devacquired = 0;
|
||||
|
||||
bDInputInited = TRUE;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
@ -1198,7 +1194,7 @@ static void UninitDirectInput(void)
|
|||
{
|
||||
int32_t i;
|
||||
|
||||
if (bDInputInited) initprintf("Uninitializing DirectInput...\n");
|
||||
if (hDInputDLL) initprintf("Uninitializing DirectInput...\n");
|
||||
|
||||
AcquireInputDevices(0);
|
||||
|
||||
|
@ -1240,8 +1236,6 @@ static void UninitDirectInput(void)
|
|||
FreeLibrary(hDInputDLL);
|
||||
hDInputDLL = NULL;
|
||||
}
|
||||
|
||||
bDInputInited = FALSE;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1291,7 +1285,7 @@ static void AcquireInputDevices(char acquire)
|
|||
DWORD flags;
|
||||
HRESULT result;
|
||||
|
||||
if (!bDInputInited) return;
|
||||
if (!hDInputDLL) return;
|
||||
if (!hWindow) return;
|
||||
|
||||
if (acquire)
|
||||
|
@ -1616,11 +1610,6 @@ int32_t gettimerfreq(void)
|
|||
// VIDEO
|
||||
//=================================================================================================
|
||||
|
||||
// DWM stuff
|
||||
static HMODULE hDWMApiDLL = NULL;
|
||||
static BOOL bDWMApiInited = FALSE;
|
||||
HRESULT(WINAPI *aDwmEnableComposition)(UINT);
|
||||
|
||||
// DirectDraw objects
|
||||
static HMODULE hDDrawDLL = NULL;
|
||||
static LPDIRECTDRAW lpDD = NULL;
|
||||
|
@ -1643,23 +1632,17 @@ static int32_t getgammaramp(WORD gt[3][256]);
|
|||
|
||||
static void ToggleDesktopComposition(BOOL compEnable)
|
||||
{
|
||||
if (!bDWMApiInited)
|
||||
{
|
||||
hDWMApiDLL = LoadLibrary("DWMAPI.DLL");
|
||||
if (hDWMApiDLL)
|
||||
{
|
||||
aDwmEnableComposition = (void *)GetProcAddress(hDWMApiDLL, "DwmEnableComposition");
|
||||
}
|
||||
bDWMApiInited = TRUE;
|
||||
}
|
||||
static HMODULE hDWMApiDLL = NULL;
|
||||
static HRESULT(WINAPI *aDwmEnableComposition)(UINT);
|
||||
|
||||
if (!hDWMApiDLL && (hDWMApiDLL = LoadLibrary("DWMAPI.DLL")))
|
||||
aDwmEnableComposition = (void *)GetProcAddress(hDWMApiDLL, "DwmEnableComposition");
|
||||
|
||||
if (aDwmEnableComposition)
|
||||
{
|
||||
aDwmEnableComposition(compEnable);
|
||||
if (!silentvideomodeswitch)
|
||||
{
|
||||
initprintf("%s desktop composition.\n", (compEnable) ? "Enabling" : "Disabling");
|
||||
}
|
||||
initprintf("%sabling desktop composition...\n", (compEnable) ? "En" : "Dis");
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1760,7 +1743,8 @@ int32_t setvideomode(int32_t x, int32_t y, int32_t c, int32_t fs)
|
|||
gammabrightness = 0;
|
||||
}
|
||||
|
||||
ToggleDesktopComposition(c < 16);
|
||||
if (osv.dwMajorVersion >= 6)
|
||||
ToggleDesktopComposition(c < 16);
|
||||
|
||||
if (!silentvideomodeswitch)
|
||||
initprintf("Setting video mode %dx%d (%d-bit %s)\n",
|
||||
|
|
|
@ -8002,7 +8002,8 @@ void G_MoveWorld(void)
|
|||
{
|
||||
int32_t x, y;
|
||||
|
||||
if ((s->cstat & 32768) || A_CheckSpriteFlags(i, SPRITE_NOLIGHT) || !inside(s->x+((sintable[(s->ang+512)&2047])>>9), s->y+((sintable[(s->ang)&2047])>>9), s->sectnum))
|
||||
if ((s->cstat & 32768) || A_CheckSpriteFlags(i, SPRITE_NOLIGHT) ||
|
||||
!inside(s->x+((sintable[(s->ang+512)&2047])>>9), s->y+((sintable[(s->ang)&2047])>>9), s->sectnum))
|
||||
{
|
||||
if (actor[i].lightptr != NULL)
|
||||
{
|
||||
|
@ -8029,11 +8030,13 @@ void G_MoveWorld(void)
|
|||
switch (DynamicTileMap[sprite[i].picnum])
|
||||
{
|
||||
case ATOMICHEALTH__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD2<<2, 128+(128<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD2 * 3, 128+(128<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
||||
case FIRE__STATIC:
|
||||
case FIRE2__STATIC:
|
||||
case BURNING__STATIC:
|
||||
case BURNING2__STATIC:
|
||||
/*
|
||||
if (Actor[i].floorz - Actor[i].ceilingz < 128) break;
|
||||
if (s->z > Actor[i].floorz+2048) break;
|
||||
|
@ -8041,18 +8044,9 @@ void G_MoveWorld(void)
|
|||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD2, 255+(95<<8),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
||||
case BURNING__STATIC:
|
||||
case BURNING2__STATIC:
|
||||
/*
|
||||
if (Actor[i].floorz - Actor[i].ceilingz < 128) break;
|
||||
if (s->z > Actor[i].floorz + 2048) break;
|
||||
*/
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD2, 255+(95<<8),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
||||
case OOZFILTER__STATIC:
|
||||
if (s->xrepeat > 4)
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 6144, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 4096, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
case FLOORFLAME__STATIC:
|
||||
case FIREBARREL__STATIC:
|
||||
|
@ -8062,25 +8056,58 @@ void G_MoveWorld(void)
|
|||
|
||||
case EXPLOSION2__STATIC:
|
||||
if (!actor[i].lightcount)
|
||||
{
|
||||
int32_t x = ((sintable[(s->ang+512)&2047])>>6);
|
||||
int32_t y = ((sintable[(s->ang)&2047])>>6);
|
||||
|
||||
s->x -= x;
|
||||
s->y -= y;
|
||||
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 255+(95<<8),
|
||||
s->yrepeat > 32 ? PR_LIGHT_PRIO_HIGH_GAME : PR_LIGHT_PRIO_LOW_GAME);
|
||||
|
||||
s->x += x;
|
||||
s->y += y;
|
||||
}
|
||||
break;
|
||||
case FORCERIPPLE__STATIC:
|
||||
// case TRANSPORTERSTAR__STATIC:
|
||||
case TRANSPORTERBEAM__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 80+(80<<8)+(255<<16),PR_LIGHT_PRIO_LOW_GAME);
|
||||
break;
|
||||
case GROWSPARK__STATIC:
|
||||
{
|
||||
int32_t x = ((sintable[(s->ang+512)&2047])>>6);
|
||||
int32_t y = ((sintable[(s->ang)&2047])>>6);
|
||||
|
||||
s->x -= x;
|
||||
s->y -= y;
|
||||
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 2048, 255+(95<<8),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
|
||||
s->x += x;
|
||||
s->y += y;
|
||||
}
|
||||
break;
|
||||
case SHRINKEREXPLOSION__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 2048, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
{
|
||||
int32_t x = ((sintable[(s->ang+512)&2047])>>6);
|
||||
int32_t y = ((sintable[(s->ang)&2047])>>6);
|
||||
|
||||
s->x -= x;
|
||||
s->y -= y;
|
||||
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 2048, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
|
||||
s->x += x;
|
||||
s->y += y;
|
||||
}
|
||||
break;
|
||||
case FREEZEBLAST__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD<<2, 128+(128<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
||||
case COOLEXPLOSION1__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD<<3, 128+(0<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD<<2, 128+(0<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
||||
case SHRINKSPARK__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
|
||||
break;
|
||||
|
@ -8088,9 +8115,22 @@ void G_MoveWorld(void)
|
|||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 64 * s->yrepeat, 255+(95<<8),PR_LIGHT_PRIO_LOW_GAME);
|
||||
break;
|
||||
case RPG__STATIC:
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 64 * s->yrepeat, 255+(95<<8),PR_LIGHT_PRIO_LOW_GAME);
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 128 * s->yrepeat, 255+(95<<8),PR_LIGHT_PRIO_LOW_GAME);
|
||||
break;
|
||||
case SHOTSPARK1__STATIC:
|
||||
{
|
||||
int32_t x = ((sintable[(s->ang+512)&2047])>>7);
|
||||
int32_t y = ((sintable[(s->ang)&2047])>>7);
|
||||
|
||||
s->x -= x;
|
||||
s->y -= y;
|
||||
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 16 * s->yrepeat, 255+(95<<8),PR_LIGHT_PRIO_LOW_GAME);
|
||||
|
||||
s->x += x;
|
||||
s->y += y;
|
||||
}
|
||||
break;
|
||||
case DIPSWITCH__STATIC:
|
||||
case DIPSWITCH2__STATIC:
|
||||
case DIPSWITCH3__STATIC:
|
||||
|
@ -8126,7 +8166,7 @@ void G_MoveWorld(void)
|
|||
s->x += x;
|
||||
s->y += y;
|
||||
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 1024, 255+(48<<8)+(48<<16),PR_LIGHT_PRIO_LOW);
|
||||
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 768, 255+(48<<8)+(48<<16),PR_LIGHT_PRIO_LOW);
|
||||
s->x -= x;
|
||||
s->y -= y;
|
||||
}
|
||||
|
|
|
@ -6382,18 +6382,30 @@ static void Keys2d(void)
|
|||
else if (!(keystatus[KEYSC_F5]|keystatus[KEYSC_F6]|keystatus[KEYSC_F7]|keystatus[KEYSC_F8]))
|
||||
{
|
||||
static int32_t counter = 0;
|
||||
static int32_t omx = 0, omy = 0;
|
||||
/*
|
||||
static int32_t opointhighlight, olinehighlight, ocursectornum;
|
||||
|
||||
if (pointhighlight == opointhighlight && linehighlight == olinehighlight && cursectornum == ocursectornum)
|
||||
counter++;
|
||||
else
|
||||
counter = 0;
|
||||
*/
|
||||
if (omx == mousxplc && omy == mousyplc)
|
||||
{
|
||||
if (counter < 6)
|
||||
counter++;
|
||||
}
|
||||
else if (counter > 0)
|
||||
counter--;
|
||||
|
||||
omx = mousxplc;
|
||||
omy = mousyplc;
|
||||
|
||||
/*
|
||||
opointhighlight = pointhighlight;
|
||||
olinehighlight = linehighlight;
|
||||
ocursectornum = cursectornum;
|
||||
*/
|
||||
|
||||
if (counter >= 40 && totalclock >= 120*6)
|
||||
if (counter >= 2 && totalclock >= 120*6)
|
||||
{
|
||||
if (pointhighlight >= 16384)
|
||||
{
|
||||
|
|
|
@ -216,7 +216,7 @@ void CONFIG_SetDefaults(void)
|
|||
ud.config.NumChannels = 2;
|
||||
ud.config.NumVoices = 32;
|
||||
ud.config.ReverseStereo = 0;
|
||||
ud.config.RunMode = ud.auto_run = 1;
|
||||
ud.auto_run = 1;
|
||||
ud.config.ShowOpponentWeapons = 0;
|
||||
ud.config.SmoothInput = 1;
|
||||
ud.config.SoundToggle = 1;
|
||||
|
|
|
@ -342,7 +342,6 @@ typedef struct {
|
|||
struct {
|
||||
int32_t UseJoystick;
|
||||
int32_t UseMouse;
|
||||
int32_t RunMode;
|
||||
int32_t AutoAim;
|
||||
int32_t ShowOpponentWeapons;
|
||||
int32_t MouseDeadZone,MouseBias;
|
||||
|
|
|
@ -1004,7 +1004,7 @@ void Net_ParseServerPacket(ENetEvent * event)
|
|||
|
||||
if (i == myconnectindex && !g_player[i].ps->dead_flag)
|
||||
{
|
||||
j += (sizeof(input_t) - sizeof(loc.filler)) +
|
||||
j += offsetof(input_t, filler) +
|
||||
(sizeof(vec3_t) * 3) + // position and velocity
|
||||
(sizeof(int16_t) * 3); // ang and horiz
|
||||
goto process;
|
||||
|
@ -1014,7 +1014,7 @@ void Net_ParseServerPacket(ENetEvent * event)
|
|||
|
||||
Bmemcpy(&nsyn[i], &packbuf[j], sizeof(input_t));
|
||||
|
||||
j += sizeof(input_t)-sizeof(loc.filler);
|
||||
j += offsetof(input_t, filler);
|
||||
|
||||
if (TEST_SYNC_KEY(nsyn[i].bits,SK_GAMEQUIT)) g_player[i].playerquitflag = 0;
|
||||
g_player[i].movefifoend++;
|
||||
|
@ -1206,7 +1206,8 @@ process:
|
|||
|
||||
if (var_id == MAXGAMEVARS) break;
|
||||
|
||||
aGameVars[var_id].val.plValues[i] = *(int32_t *)&packbuf[j];
|
||||
if (aGameVars[var_id].val.plValues)
|
||||
aGameVars[var_id].val.plValues[i] = *(int32_t *)&packbuf[j];
|
||||
j += sizeof(int32_t);
|
||||
}
|
||||
while (1);
|
||||
|
@ -1503,7 +1504,7 @@ void Net_ParseClientPacket(ENetEvent * event)
|
|||
|
||||
Bmemcpy(&nsyn[other], &packbuf[j], sizeof(input_t));
|
||||
|
||||
j += sizeof(input_t)-sizeof(loc.filler);
|
||||
j += offsetof(input_t, filler);
|
||||
|
||||
g_player[other].movefifoend++;
|
||||
|
||||
|
@ -1957,13 +1958,13 @@ void Net_UpdateClients(void)
|
|||
{
|
||||
if (g_player[i].playerquitflag == 0) continue;
|
||||
|
||||
Bmemcpy(&osyn[i], &nsyn[i], sizeof(input_t));
|
||||
Bmemcpy(&osyn[i], &nsyn[i], offsetof(input_t, filler));
|
||||
|
||||
*(int16_t *)&packbuf[j] = g_player[i].ps->dead_flag;
|
||||
j += sizeof(int16_t);
|
||||
|
||||
Bmemcpy(&packbuf[j], &nsyn[i], sizeof(input_t)-sizeof(loc.filler));
|
||||
j += sizeof(input_t)-sizeof(loc.filler);
|
||||
Bmemcpy(&packbuf[j], &nsyn[i], offsetof(input_t, filler));
|
||||
j += offsetof(input_t, filler);
|
||||
|
||||
Bmemcpy(&packbuf[j], &g_player[i].ps->pos.x, sizeof(vec3_t) * 2);
|
||||
j += sizeof(vec3_t) * 2;
|
||||
|
@ -2041,11 +2042,11 @@ void Net_UpdateClients(void)
|
|||
if (packbuf[jj] & 2) T5 += (intptr_t)&script[0];
|
||||
}
|
||||
|
||||
i = l;
|
||||
/*i = l;*/
|
||||
{
|
||||
int16_t ii=g_gameVarCount-1, kk = 0;
|
||||
|
||||
for (; ii>=0; ii--)
|
||||
for (; ii>=0 && kk <= 64; ii--)
|
||||
{
|
||||
if ((aGameVars[ii].dwFlags & (GAMEVAR_PERACTOR|GAMEVAR_NOMULTI)) == GAMEVAR_PERACTOR && aGameVars[ii].val.plValues)
|
||||
{
|
||||
|
@ -2060,7 +2061,6 @@ void Net_UpdateClients(void)
|
|||
kk++;
|
||||
}
|
||||
}
|
||||
if (kk > 64) break;
|
||||
}
|
||||
*(int16_t *)&packbuf[j] = MAXGAMEVARS;
|
||||
j += sizeof(int16_t);
|
||||
|
@ -2070,7 +2070,7 @@ void Net_UpdateClients(void)
|
|||
{
|
||||
int16_t ii=g_gameVarCount-1, kk = 0;
|
||||
|
||||
for (; ii>=0; ii--)
|
||||
for (; ii>=0 && kk <= 64; ii--)
|
||||
{
|
||||
if ((aGameVars[ii].dwFlags & (GAMEVAR_PERPLAYER|GAMEVAR_NOMULTI)) == GAMEVAR_PERPLAYER && aGameVars[ii].val.plValues)
|
||||
{
|
||||
|
@ -2085,7 +2085,6 @@ void Net_UpdateClients(void)
|
|||
kk++;
|
||||
}
|
||||
}
|
||||
if (kk > 64) break;
|
||||
}
|
||||
*(int16_t *)&packbuf[j] = MAXGAMEVARS;
|
||||
j += sizeof(int16_t);
|
||||
|
@ -2099,17 +2098,17 @@ void Net_UpdateClients(void)
|
|||
|
||||
packbuf[(zj = j++)] = 0;
|
||||
|
||||
for (zz = 0; (unsigned)zz < (sizeof(g_netStatnums)/sizeof(g_netStatnums[0])); zz++)
|
||||
for (zz = 0; (unsigned)zz < (sizeof(g_netStatnums)/sizeof(g_netStatnums[0])) && k <= 8; zz++)
|
||||
TRAVERSE_SPRITE_STAT(headspritestat[g_netStatnums[zz]], i, nexti)
|
||||
{
|
||||
if (totalclock > (lastupdate[i] + TICRATE))
|
||||
// only send STAT_MISC sprites at spawn time and let the client handle it from there
|
||||
if (totalclock > (lastupdate[i] + TICRATE) && (!lastupdate[i] || sprite[i].statnum != STAT_MISC))
|
||||
{
|
||||
l = crc32once((uint8_t *)&sprite[i], sizeof(spritetype));
|
||||
|
||||
// only send STAT_MISC sprites at spawn time and let the client handle it from there
|
||||
if (!lastupdate[i] || (spritecrc[i] != l && sprite[i].statnum != STAT_MISC))
|
||||
if (!lastupdate[i] || spritecrc[i] != l)
|
||||
{
|
||||
int32_t jj = 0;
|
||||
int32_t jj;
|
||||
|
||||
/*initprintf("updating sprite %d (%d)\n",i,sprite[i].picnum);*/
|
||||
spritecrc[i] = l;
|
||||
|
@ -2126,16 +2125,19 @@ void Net_UpdateClients(void)
|
|||
packbuf[jj] |= 1;
|
||||
T2 -= (intptr_t)&script[0];
|
||||
}
|
||||
|
||||
if (T5 >= (intptr_t)&script[0] && T5 < (intptr_t)(&script[g_scriptSize]))
|
||||
{
|
||||
packbuf[jj] |= 2;
|
||||
T5 -= (intptr_t)&script[0];
|
||||
}
|
||||
|
||||
if (T6 >= (intptr_t)&script[0] && T6 < (intptr_t)(&script[g_scriptSize]))
|
||||
{
|
||||
packbuf[jj] |= 4;
|
||||
T6 -= (intptr_t)&script[0];
|
||||
}
|
||||
|
||||
Bmemcpy(&packbuf[j], &actor[i], sizeof(NetActorData_t));
|
||||
j += sizeof(NetActorData_t);
|
||||
|
||||
|
@ -2146,7 +2148,7 @@ void Net_UpdateClients(void)
|
|||
{
|
||||
int16_t ii=g_gameVarCount-1, kk = 0;
|
||||
|
||||
for (; ii>=0; ii--)
|
||||
for (; ii>=0 && kk <= 64; ii--)
|
||||
{
|
||||
if ((aGameVars[ii].dwFlags & GAMEVAR_PERACTOR) && aGameVars[ii].val.plValues)
|
||||
{
|
||||
|
@ -2161,7 +2163,6 @@ void Net_UpdateClients(void)
|
|||
kk++;
|
||||
}
|
||||
}
|
||||
if (kk > 64) break;
|
||||
}
|
||||
*(int16_t *)&packbuf[j] = MAXGAMEVARS;
|
||||
j += sizeof(int16_t);
|
||||
|
@ -2170,14 +2171,13 @@ void Net_UpdateClients(void)
|
|||
k++;
|
||||
}
|
||||
}
|
||||
if (k > 8) break;
|
||||
}
|
||||
|
||||
packbuf[zj] = k;
|
||||
k = 0;
|
||||
|
||||
|
||||
packbuf[(zj = j++)] = 0;
|
||||
for (i = numsectors-1; i >= 0; i--)
|
||||
for (i = numsectors-1; i >= 0 && k <= 6; i--)
|
||||
{
|
||||
if (totalclock > (lastsectupdate[i] + TICRATE))
|
||||
{
|
||||
|
@ -2194,13 +2194,12 @@ void Net_UpdateClients(void)
|
|||
k++;
|
||||
}
|
||||
}
|
||||
if (k > 6) break;
|
||||
}
|
||||
packbuf[zj] = k;
|
||||
k = 0;
|
||||
|
||||
packbuf[(zj = j++)] = 0;
|
||||
for (i = numwalls-1; i >= 0; i--)
|
||||
for (i = numwalls-1; i >= 0 && k <= 6; i--)
|
||||
{
|
||||
if (totalclock > (lastwallupdate[i] + TICRATE))
|
||||
{
|
||||
|
@ -2217,7 +2216,6 @@ void Net_UpdateClients(void)
|
|||
k++;
|
||||
}
|
||||
}
|
||||
if (k > 6) break;
|
||||
}
|
||||
packbuf[zj] = k;
|
||||
|
||||
|
@ -9445,7 +9443,6 @@ FAKE_F3:
|
|||
{
|
||||
CONTROL_ClearButton(gamefunc_AutoRun);
|
||||
ud.auto_run = 1-ud.auto_run;
|
||||
ud.config.RunMode = ud.auto_run;
|
||||
P_DoQuote(85+ud.auto_run,g_player[myconnectindex].ps);
|
||||
}
|
||||
|
||||
|
@ -11779,7 +11776,6 @@ MAIN_LOOP_RESTART:
|
|||
}
|
||||
else G_UpdateScreenArea();
|
||||
|
||||
ud.auto_run = ud.config.RunMode;
|
||||
ud.showweapons = ud.config.ShowOpponentWeapons;
|
||||
g_player[myconnectindex].ps->aim_mode = ud.mouseaiming;
|
||||
g_player[myconnectindex].ps->auto_aim = ud.config.AutoAim;
|
||||
|
@ -12725,8 +12721,8 @@ GAME_STATIC int32_t G_DoMoveThings(void)
|
|||
packbuf[0] = PACKET_SLAVE_TO_MASTER;
|
||||
j = 1;
|
||||
|
||||
Bmemcpy(&packbuf[j], &nsyn[0], sizeof(input_t) - sizeof(loc.filler));
|
||||
j += sizeof(input_t) - sizeof(loc.filler);
|
||||
Bmemcpy(&packbuf[j], &nsyn[0], offsetof(input_t, filler));
|
||||
j += offsetof(input_t, filler);
|
||||
|
||||
Bmemcpy(&packbuf[j], &g_player[myconnectindex].ps->pos.x, sizeof(vec3_t) * 2);
|
||||
j += sizeof(vec3_t) * 2;
|
||||
|
|
|
@ -6155,7 +6155,7 @@ void C_Compile(const char *filenam)
|
|||
}
|
||||
else
|
||||
{
|
||||
int32_t j=0, k=0;
|
||||
int32_t j=0, k=0, l=0;
|
||||
|
||||
hash_free(&h_keywords);
|
||||
freehashnames();
|
||||
|
@ -6174,12 +6174,9 @@ void C_Compile(const char *filenam)
|
|||
|
||||
C_SetScriptSize(g_scriptPtr-script+8);
|
||||
|
||||
initprintf("Script compiled in %dms\n", getticks() - startcompiletime);
|
||||
initprintf("Script compiled in %dms, %ld*%db, version %s\n", getticks() - startcompiletime,
|
||||
(unsigned)(g_scriptPtr-script), sizeof(intptr_t), (g_scriptVersion == 14?"1.4+":"1.3D"));
|
||||
|
||||
initprintf("Compiled code size: %ld*%d bytes, version %s\n",
|
||||
(unsigned)(g_scriptPtr-script), sizeof(intptr_t), (g_scriptVersion == 14?"1.4+":"1.3D"));
|
||||
|
||||
initprintf("Pointer bitmap size: %ld bytes\n",(g_scriptSize+7)>>3);
|
||||
initprintf("%ld/%ld labels, %d/%d variables\n", g_numLabels,
|
||||
min((MAXSECTORS * sizeof(sectortype)/sizeof(int32_t)),
|
||||
MAXSPRITES * sizeof(spritetype)/(1<<6)),
|
||||
|
@ -6188,18 +6185,19 @@ void C_Compile(const char *filenam)
|
|||
for (i=MAXQUOTES-1; i>=0; i--)
|
||||
if (ScriptQuotes[i])
|
||||
j++;
|
||||
|
||||
initprintf("%ld/%d quotes, %d quote redefinitions\n",j,MAXQUOTES,g_numQuoteRedefinitions);
|
||||
|
||||
j = 0;
|
||||
for (i=MAXGAMEEVENTS-1; i>=0; i--)
|
||||
if (apScriptGameEvent[i])
|
||||
j++;
|
||||
k++;
|
||||
for (i=MAXTILES-1; i>=0; i--)
|
||||
if (actorscrptr[i])
|
||||
k++;
|
||||
l++;
|
||||
|
||||
initprintf("%ld/%d event definitions, %ld defined actors\n",j,MAXEVENTS,k);
|
||||
if (j) initprintf("%ld quotes, ", j);
|
||||
if (g_numQuoteRedefinitions) initprintf("%d strings, ", g_numQuoteRedefinitions);
|
||||
if (k) initprintf("%ld events, ", k);
|
||||
if (l) initprintf("%ld actors", l);
|
||||
|
||||
initprintf("\n");
|
||||
|
||||
for (i=127; i>=0; i--)
|
||||
if (ScriptQuotes[i] == NULL)
|
||||
|
|
|
@ -1373,6 +1373,7 @@ int32_t registerosdcommands(void)
|
|||
|
||||
{ "cl_autoaim", "cl_autoaim: enable/disable weapon autoaim", (void*)&ud.config.AutoAim, CVAR_INT|CVAR_MULTI, 0, 2 },
|
||||
{ "cl_automsg", "cl_automsg: enable/disable automatically sending messages to all players", (void*)&ud.automsg, CVAR_BOOL, 0, 1 },
|
||||
{ "cl_autorun", "cl_autorun", (void*)&ud.auto_run, CVAR_BOOL, 0, 1 },
|
||||
{ "cl_autovote", "cl_autovote: enable/disable automatic voting", (void*)&ud.autovote, CVAR_INT, 0, 2 },
|
||||
|
||||
{ "cl_obituaries", "cl_obituaries: enable/disable multiplayer death messages", (void*)&ud.obituaries, CVAR_BOOL, 0, 1 },
|
||||
|
|
Loading…
Reference in a new issue