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:
terminx 2010-05-19 10:02:35 +00:00
parent 8077dcd633
commit 45052b8273
16 changed files with 228 additions and 174 deletions

View file

@ -3,8 +3,8 @@
ENGINELIB=libengine.a ENGINELIB=libengine.a
EDITORLIB=libbuild.a EDITORLIB=libbuild.a
SDLCONFIG = /usr/local/bin/sdl-config # SDLCONFIG = /usr/local/bin/sdl-config
# SDLCONFIG = sdl-config SDLCONFIG = /usr/bin/sdl-config
ifeq ($(wildcard $(SDLCONFIG)),$(SDLCONFIG)) ifeq ($(wildcard $(SDLCONFIG)),$(SDLCONFIG))
SDLROOT = /usr/local SDLROOT = /usr/local

View file

@ -98,7 +98,7 @@ void debugprintf(const char *,...);
int32_t handleevents(void); int32_t handleevents(void);
extern inline void idle(void); extern inline void idle(void);
extern inline void idle_waitevent(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 (*KeyPressCallback)(int32_t,int32_t);
typedef void (*MousePressCallback)(int32_t,int32_t); typedef void (*MousePressCallback)(int32_t,int32_t);

View file

@ -1267,7 +1267,7 @@ void overheadeditor(void)
walltype *wal; walltype *wal;
int32_t prefixarg = 0; int32_t prefixarg = 0;
hitdata_t hitinfo; hitdata_t hitinfo;
int32_t resetsynctics = 0, lasttick=getticks(); int32_t resetsynctics = 0, lasttick=getticks(), waitdelay=totalclock, lastdraw=getticks();
int32_t tsign; int32_t tsign;
//qsetmode640480(); //qsetmode640480();
@ -1321,12 +1321,17 @@ void overheadeditor(void)
{ {
if (!((vel|angvel|svel) //DOWN_BK(MOVEFORWARD) || DOWN_BK(MOVEBACKWARD) || DOWN_BK(TURNLEFT) || DOWN_BK(TURNRIGHT) 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())) || DOWN_BK(MOVEUP) || DOWN_BK(MOVEDOWN) || bstatus || OSD_IsMoving()))
{
if (totalclock > waitdelay)
{ {
// wait for event, timeout after 200 ms - (last loop time) // wait for event, timeout after 200 ms - (last loop time)
idle_waitevent_timeout(200 - min(getticks()-lasttick, 200)); 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 // have synctics reset to 0 after we've slept to avoid zooming out to the max instantly
resetsynctics = 1; resetsynctics = 1;
} }
}
else waitdelay = totalclock + 30; // should be 250 ms
lasttick = getticks(); lasttick = getticks();
if (handleevents()) if (handleevents())
@ -1429,8 +1434,11 @@ void overheadeditor(void)
numwalls = newnumwalls; numwalls = newnumwalls;
if (numwalls < 0) numwalls = tempint; 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(); clear2dscreen();
if (graphicsmode) if (graphicsmode)

View file

@ -301,7 +301,7 @@ int32_t addsearchpath(const char *p)
Bcorrectfilename(srch->path,0); Bcorrectfilename(srch->path,0);
initprintf("addsearchpath(): Added %s\n", srch->path); initprintf("Using %s for game data\n", srch->path);
return 0; return 0;
} }

View file

@ -5492,21 +5492,45 @@ int32_t preinitengine(void)
makeasmwriteable(); 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 #ifdef DYNALLOC_ARRAYS
sector = Bcalloc(MAXSECTORS,sizeof(sectortype)); {
wall = Bcalloc(MAXWALLS,sizeof(walltype)); size_t i, size = 0;
sprite = Bcalloc(MAXSPRITES,sizeof(spritetype)); int8_t *ptr;
tsprite = Bcalloc(MAXSPRITESONSCREEN,sizeof(spritetype));
spriteext = Bcalloc(MAXSPRITES+MAXUNIQHUDID,sizeof(spriteext_t));
spritesmooth = Bcalloc(MAXSPRITES+MAXUNIQHUDID,sizeof(spritesmooth_t));
if (!sector || !wall || !sprite || !tsprite || !spriteext || !spritesmooth) // 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 **)&sector, 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; return 1;
size = 0;
for (i=0;i<(signed)(sizeof(dynarray)/sizeof(dynarray[0])); i++)
{
*dynarray[i].ptr = ptr + size;
size += dynarray[i].size;
}
}
#else #else
sector = sector_s; sector = sector_s;
wall = wall_s; wall = wall_s;
@ -5514,6 +5538,8 @@ int32_t preinitengine(void)
tsprite = tsprite_s; tsprite = tsprite_s;
spriteext = spriteext_s; spriteext = spriteext_s;
spritesmooth = spritesmooth_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 #endif
if ((e = Bgetenv("BUILD_NOP6")) != NULL) if ((e = Bgetenv("BUILD_NOP6")) != NULL)
@ -5632,7 +5658,6 @@ void uninitengine(void)
Bfclose(cacheindexptr); */ Bfclose(cacheindexptr); */
#endif #endif
uninitsystem();
if (artfil != -1) kclose(artfil); if (artfil != -1) kclose(artfil);
i=(sizeof(artptrs)/sizeof(intptr_t))-1; i=(sizeof(artptrs)/sizeof(intptr_t))-1;
@ -5662,20 +5687,11 @@ void uninitengine(void)
#ifdef DYNALLOC_ARRAYS #ifdef DYNALLOC_ARRAYS
if (sector != NULL) if (sector != NULL)
Bfree(sector); Bfree(sector);
if (wall != NULL) #else
Bfree(wall); if (state_compress) Bfree(state_compress);
if (sprite != NULL)
Bfree(sprite);
if (tsprite != NULL)
Bfree(tsprite);
if (spriteext != NULL)
Bfree(spriteext);
if (spritesmooth != NULL)
Bfree(spritesmooth);
#endif #endif
if (state_compress) Bfree(state_compress); uninitsystem();
if (state_decompress) Bfree(state_decompress);
} }

View file

@ -775,7 +775,7 @@ void polymer_loadboard(void)
polymer_resetlights(); 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) 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; 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) { if (!linkstatus) {
OSD_Printf("PR : Failed to compile GPU program with bits %i!\n", programbits); 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); if (pr_verbosity >= 1) OSD_Printf("PR : Compilation log:\n%s\n", infobuffer);

View file

@ -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 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 #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 gyxscale, gxyaspect, gviewxrange, ghalfx, grhalfxdown10, grhalfxdown10x, ghoriz;
double gcosang, gsinang, gcosang2, gsinang2; double gcosang, gsinang, gcosang2, gsinang2;

View file

@ -1896,7 +1896,7 @@ static int32_t SDL_WaitEventTimeout(SDL_Event * event, int32_t timeout)
} }
#endif #endif
inline void idle_waitevent_timeout(int32_t timeout) inline void idle_waitevent_timeout(uint32_t timeout)
{ {
SDL_WaitEventTimeout(NULL, timeout); SDL_WaitEventTimeout(NULL, timeout);
} }

View file

@ -98,8 +98,6 @@ static BOOL RegisterWindowClass(void);
static BOOL CreateAppWindow(int32_t modenum); static BOOL CreateAppWindow(int32_t modenum);
static void DestroyAppWindow(void); static void DestroyAppWindow(void);
static BOOL bDInputInited = FALSE;
// video // video
static int32_t desktopxdim=0,desktopydim=0,desktopbpp=0,modesetusing=-1; 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; 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; 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; break;
} }
initprintf("Running under Windows %s (build %lu.%lu.%lu) %s", ver, osv.dwMajorVersion, osv.dwMinorVersion, initprintf("Windows %s (build %lu.%lu.%lu) %s", ver,
osv.dwPlatformId == VER_PLATFORM_WIN32_NT ? osv.dwBuildNumber : osv.dwBuildNumber&0xffff, osv.dwMajorVersion, osv.dwMinorVersion, osv.dwBuildNumber, osv.szCSDVersion);
osv.szCSDVersion);
#ifdef NEDMALLOC #ifdef NEDMALLOC
initprintf("\n"); initprintf("\n");
@ -552,7 +579,7 @@ static void printsysversion(void)
if (largepagesavailable) if (largepagesavailable)
initprintf("Large page support available\n"); initprintf("Large page support available\n");
#else #else
if (nedhandle) initprintf("with nedmalloc\n"); initprintf(nedhandle ? "w/ nedmalloc.dll\n" : "\n");
#endif #endif
} }
@ -691,7 +718,7 @@ int32_t handleevents(void)
RI_PollDevices(TRUE); RI_PollDevices(TRUE);
if (bDInputInited) if (hDInputDLL)
DI_PollJoysticks(); DI_PollJoysticks();
while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE)) while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
@ -721,36 +748,6 @@ int32_t handleevents(void)
return rv; 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 // I don't see any pressing need to store the key-up events yet
inline void SetKey(int32_t key, int32_t state) 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 setmousepresscallback(void (*callback)(int32_t, int32_t)) { mousepresscallback = callback; }
void setjoypresscallback(void (*callback)(int32_t, int32_t)) { joypresscallback = 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 do
{ {
@ -858,12 +856,12 @@ inline void idle_waitevent(void)
Sleep(10); 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) inline void idle(void)
@ -1077,7 +1075,7 @@ static BOOL InitDirectInput(void)
LPDIRECTINPUTDEVICE7A dev2; LPDIRECTINPUTDEVICE7A dev2;
DIDEVCAPS didc; DIDEVCAPS didc;
if (bDInputInited) return FALSE; if (hDInputDLL) return FALSE;
initprintf("Initializing DirectInput...\n"); initprintf("Initializing DirectInput...\n");
@ -1108,7 +1106,6 @@ static BOOL InitDirectInput(void)
if (inputdevices == (1|2)) if (inputdevices == (1|2))
{ {
initprintf(" - No game controllers found\n"); initprintf(" - No game controllers found\n");
bDInputInited = TRUE;
UninitDirectInput(); UninitDirectInput();
return TRUE; return TRUE;
} }
@ -1186,7 +1183,6 @@ static BOOL InitDirectInput(void)
di_devacquired = 0; di_devacquired = 0;
bDInputInited = TRUE;
return FALSE; return FALSE;
} }
@ -1198,7 +1194,7 @@ static void UninitDirectInput(void)
{ {
int32_t i; int32_t i;
if (bDInputInited) initprintf("Uninitializing DirectInput...\n"); if (hDInputDLL) initprintf("Uninitializing DirectInput...\n");
AcquireInputDevices(0); AcquireInputDevices(0);
@ -1240,8 +1236,6 @@ static void UninitDirectInput(void)
FreeLibrary(hDInputDLL); FreeLibrary(hDInputDLL);
hDInputDLL = NULL; hDInputDLL = NULL;
} }
bDInputInited = FALSE;
} }
@ -1291,7 +1285,7 @@ static void AcquireInputDevices(char acquire)
DWORD flags; DWORD flags;
HRESULT result; HRESULT result;
if (!bDInputInited) return; if (!hDInputDLL) return;
if (!hWindow) return; if (!hWindow) return;
if (acquire) if (acquire)
@ -1616,11 +1610,6 @@ int32_t gettimerfreq(void)
// VIDEO // VIDEO
//================================================================================================= //=================================================================================================
// DWM stuff
static HMODULE hDWMApiDLL = NULL;
static BOOL bDWMApiInited = FALSE;
HRESULT(WINAPI *aDwmEnableComposition)(UINT);
// DirectDraw objects // DirectDraw objects
static HMODULE hDDrawDLL = NULL; static HMODULE hDDrawDLL = NULL;
static LPDIRECTDRAW lpDD = NULL; static LPDIRECTDRAW lpDD = NULL;
@ -1643,23 +1632,17 @@ static int32_t getgammaramp(WORD gt[3][256]);
static void ToggleDesktopComposition(BOOL compEnable) static void ToggleDesktopComposition(BOOL compEnable)
{ {
if (!bDWMApiInited) static HMODULE hDWMApiDLL = NULL;
{ static HRESULT(WINAPI *aDwmEnableComposition)(UINT);
hDWMApiDLL = LoadLibrary("DWMAPI.DLL");
if (hDWMApiDLL) if (!hDWMApiDLL && (hDWMApiDLL = LoadLibrary("DWMAPI.DLL")))
{
aDwmEnableComposition = (void *)GetProcAddress(hDWMApiDLL, "DwmEnableComposition"); aDwmEnableComposition = (void *)GetProcAddress(hDWMApiDLL, "DwmEnableComposition");
}
bDWMApiInited = TRUE;
}
if (aDwmEnableComposition) if (aDwmEnableComposition)
{ {
aDwmEnableComposition(compEnable); aDwmEnableComposition(compEnable);
if (!silentvideomodeswitch) if (!silentvideomodeswitch)
{ initprintf("%sabling desktop composition...\n", (compEnable) ? "En" : "Dis");
initprintf("%s desktop composition.\n", (compEnable) ? "Enabling" : "Disabling");
}
} }
} }
@ -1760,6 +1743,7 @@ int32_t setvideomode(int32_t x, int32_t y, int32_t c, int32_t fs)
gammabrightness = 0; gammabrightness = 0;
} }
if (osv.dwMajorVersion >= 6)
ToggleDesktopComposition(c < 16); ToggleDesktopComposition(c < 16);
if (!silentvideomodeswitch) if (!silentvideomodeswitch)

View file

@ -8002,7 +8002,8 @@ void G_MoveWorld(void)
{ {
int32_t x, y; 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) if (actor[i].lightptr != NULL)
{ {
@ -8029,18 +8030,11 @@ void G_MoveWorld(void)
switch (DynamicTileMap[sprite[i].picnum]) switch (DynamicTileMap[sprite[i].picnum])
{ {
case ATOMICHEALTH__STATIC: 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; break;
case FIRE__STATIC: case FIRE__STATIC:
case FIRE2__STATIC: case FIRE2__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 BURNING__STATIC: case BURNING__STATIC:
case BURNING2__STATIC: case BURNING2__STATIC:
/* /*
@ -8052,7 +8046,7 @@ void G_MoveWorld(void)
case OOZFILTER__STATIC: case OOZFILTER__STATIC:
if (s->xrepeat > 4) 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; break;
case FLOORFLAME__STATIC: case FLOORFLAME__STATIC:
case FIREBARREL__STATIC: case FIREBARREL__STATIC:
@ -8062,25 +8056,58 @@ void G_MoveWorld(void)
case EXPLOSION2__STATIC: case EXPLOSION2__STATIC:
if (!actor[i].lightcount) 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), 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->yrepeat > 32 ? PR_LIGHT_PRIO_HIGH_GAME : PR_LIGHT_PRIO_LOW_GAME);
s->x += x;
s->y += y;
}
break; break;
case FORCERIPPLE__STATIC: case FORCERIPPLE__STATIC:
// case TRANSPORTERSTAR__STATIC:
case TRANSPORTERBEAM__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); G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 80+(80<<8)+(255<<16),PR_LIGHT_PRIO_LOW_GAME);
break; 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: case SHRINKEREXPLOSION__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, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME); 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; break;
case FREEZEBLAST__STATIC: 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); G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD<<2, 128+(128<<8)+(255<<16),PR_LIGHT_PRIO_HIGH_GAME);
break; break;
case COOLEXPLOSION1__STATIC: 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; break;
case SHRINKSPARK__STATIC: case SHRINKSPARK__STATIC:
G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME); G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), LIGHTRAD, 128+(255<<8)+(128<<16),PR_LIGHT_PRIO_HIGH_GAME);
break; 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); G_AddGameLight(0, i, ((s->yrepeat*tilesizy[s->picnum])<<1), 64 * s->yrepeat, 255+(95<<8),PR_LIGHT_PRIO_LOW_GAME);
break; break;
case RPG__STATIC: 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; 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 DIPSWITCH__STATIC:
case DIPSWITCH2__STATIC: case DIPSWITCH2__STATIC:
case DIPSWITCH3__STATIC: case DIPSWITCH3__STATIC:
@ -8126,7 +8166,7 @@ void G_MoveWorld(void)
s->x += x; s->x += x;
s->y += y; 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->x -= x;
s->y -= y; s->y -= y;
} }

View file

@ -6382,18 +6382,30 @@ static void Keys2d(void)
else if (!(keystatus[KEYSC_F5]|keystatus[KEYSC_F6]|keystatus[KEYSC_F7]|keystatus[KEYSC_F8])) else if (!(keystatus[KEYSC_F5]|keystatus[KEYSC_F6]|keystatus[KEYSC_F7]|keystatus[KEYSC_F8]))
{ {
static int32_t counter = 0; static int32_t counter = 0;
static int32_t omx = 0, omy = 0;
/*
static int32_t opointhighlight, olinehighlight, ocursectornum; static int32_t opointhighlight, olinehighlight, ocursectornum;
if (pointhighlight == opointhighlight && linehighlight == olinehighlight && cursectornum == ocursectornum) if (pointhighlight == opointhighlight && linehighlight == olinehighlight && cursectornum == ocursectornum)
*/
if (omx == mousxplc && omy == mousyplc)
{
if (counter < 6)
counter++; counter++;
else }
counter = 0; else if (counter > 0)
counter--;
omx = mousxplc;
omy = mousyplc;
/*
opointhighlight = pointhighlight; opointhighlight = pointhighlight;
olinehighlight = linehighlight; olinehighlight = linehighlight;
ocursectornum = cursectornum; ocursectornum = cursectornum;
*/
if (counter >= 40 && totalclock >= 120*6) if (counter >= 2 && totalclock >= 120*6)
{ {
if (pointhighlight >= 16384) if (pointhighlight >= 16384)
{ {

View file

@ -216,7 +216,7 @@ void CONFIG_SetDefaults(void)
ud.config.NumChannels = 2; ud.config.NumChannels = 2;
ud.config.NumVoices = 32; ud.config.NumVoices = 32;
ud.config.ReverseStereo = 0; ud.config.ReverseStereo = 0;
ud.config.RunMode = ud.auto_run = 1; ud.auto_run = 1;
ud.config.ShowOpponentWeapons = 0; ud.config.ShowOpponentWeapons = 0;
ud.config.SmoothInput = 1; ud.config.SmoothInput = 1;
ud.config.SoundToggle = 1; ud.config.SoundToggle = 1;

View file

@ -342,7 +342,6 @@ typedef struct {
struct { struct {
int32_t UseJoystick; int32_t UseJoystick;
int32_t UseMouse; int32_t UseMouse;
int32_t RunMode;
int32_t AutoAim; int32_t AutoAim;
int32_t ShowOpponentWeapons; int32_t ShowOpponentWeapons;
int32_t MouseDeadZone,MouseBias; int32_t MouseDeadZone,MouseBias;

View file

@ -1004,7 +1004,7 @@ void Net_ParseServerPacket(ENetEvent * event)
if (i == myconnectindex && !g_player[i].ps->dead_flag) 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(vec3_t) * 3) + // position and velocity
(sizeof(int16_t) * 3); // ang and horiz (sizeof(int16_t) * 3); // ang and horiz
goto process; goto process;
@ -1014,7 +1014,7 @@ void Net_ParseServerPacket(ENetEvent * event)
Bmemcpy(&nsyn[i], &packbuf[j], sizeof(input_t)); 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; if (TEST_SYNC_KEY(nsyn[i].bits,SK_GAMEQUIT)) g_player[i].playerquitflag = 0;
g_player[i].movefifoend++; g_player[i].movefifoend++;
@ -1206,6 +1206,7 @@ process:
if (var_id == MAXGAMEVARS) break; if (var_id == MAXGAMEVARS) break;
if (aGameVars[var_id].val.plValues)
aGameVars[var_id].val.plValues[i] = *(int32_t *)&packbuf[j]; aGameVars[var_id].val.plValues[i] = *(int32_t *)&packbuf[j];
j += sizeof(int32_t); j += sizeof(int32_t);
} }
@ -1503,7 +1504,7 @@ void Net_ParseClientPacket(ENetEvent * event)
Bmemcpy(&nsyn[other], &packbuf[j], sizeof(input_t)); Bmemcpy(&nsyn[other], &packbuf[j], sizeof(input_t));
j += sizeof(input_t)-sizeof(loc.filler); j += offsetof(input_t, filler);
g_player[other].movefifoend++; g_player[other].movefifoend++;
@ -1957,13 +1958,13 @@ void Net_UpdateClients(void)
{ {
if (g_player[i].playerquitflag == 0) continue; 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; *(int16_t *)&packbuf[j] = g_player[i].ps->dead_flag;
j += sizeof(int16_t); j += sizeof(int16_t);
Bmemcpy(&packbuf[j], &nsyn[i], sizeof(input_t)-sizeof(loc.filler)); Bmemcpy(&packbuf[j], &nsyn[i], offsetof(input_t, filler));
j += sizeof(input_t)-sizeof(loc.filler); j += offsetof(input_t, filler);
Bmemcpy(&packbuf[j], &g_player[i].ps->pos.x, sizeof(vec3_t) * 2); Bmemcpy(&packbuf[j], &g_player[i].ps->pos.x, sizeof(vec3_t) * 2);
j += 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]; if (packbuf[jj] & 2) T5 += (intptr_t)&script[0];
} }
i = l; /*i = l;*/
{ {
int16_t ii=g_gameVarCount-1, kk = 0; 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) if ((aGameVars[ii].dwFlags & (GAMEVAR_PERACTOR|GAMEVAR_NOMULTI)) == GAMEVAR_PERACTOR && aGameVars[ii].val.plValues)
{ {
@ -2060,7 +2061,6 @@ void Net_UpdateClients(void)
kk++; kk++;
} }
} }
if (kk > 64) break;
} }
*(int16_t *)&packbuf[j] = MAXGAMEVARS; *(int16_t *)&packbuf[j] = MAXGAMEVARS;
j += sizeof(int16_t); j += sizeof(int16_t);
@ -2070,7 +2070,7 @@ void Net_UpdateClients(void)
{ {
int16_t ii=g_gameVarCount-1, kk = 0; 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) if ((aGameVars[ii].dwFlags & (GAMEVAR_PERPLAYER|GAMEVAR_NOMULTI)) == GAMEVAR_PERPLAYER && aGameVars[ii].val.plValues)
{ {
@ -2085,7 +2085,6 @@ void Net_UpdateClients(void)
kk++; kk++;
} }
} }
if (kk > 64) break;
} }
*(int16_t *)&packbuf[j] = MAXGAMEVARS; *(int16_t *)&packbuf[j] = MAXGAMEVARS;
j += sizeof(int16_t); j += sizeof(int16_t);
@ -2099,17 +2098,17 @@ void Net_UpdateClients(void)
packbuf[(zj = j++)] = 0; 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) 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)); 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)
if (!lastupdate[i] || (spritecrc[i] != l && sprite[i].statnum != STAT_MISC))
{ {
int32_t jj = 0; int32_t jj;
/*initprintf("updating sprite %d (%d)\n",i,sprite[i].picnum);*/ /*initprintf("updating sprite %d (%d)\n",i,sprite[i].picnum);*/
spritecrc[i] = l; spritecrc[i] = l;
@ -2126,16 +2125,19 @@ void Net_UpdateClients(void)
packbuf[jj] |= 1; packbuf[jj] |= 1;
T2 -= (intptr_t)&script[0]; T2 -= (intptr_t)&script[0];
} }
if (T5 >= (intptr_t)&script[0] && T5 < (intptr_t)(&script[g_scriptSize])) if (T5 >= (intptr_t)&script[0] && T5 < (intptr_t)(&script[g_scriptSize]))
{ {
packbuf[jj] |= 2; packbuf[jj] |= 2;
T5 -= (intptr_t)&script[0]; T5 -= (intptr_t)&script[0];
} }
if (T6 >= (intptr_t)&script[0] && T6 < (intptr_t)(&script[g_scriptSize])) if (T6 >= (intptr_t)&script[0] && T6 < (intptr_t)(&script[g_scriptSize]))
{ {
packbuf[jj] |= 4; packbuf[jj] |= 4;
T6 -= (intptr_t)&script[0]; T6 -= (intptr_t)&script[0];
} }
Bmemcpy(&packbuf[j], &actor[i], sizeof(NetActorData_t)); Bmemcpy(&packbuf[j], &actor[i], sizeof(NetActorData_t));
j += sizeof(NetActorData_t); j += sizeof(NetActorData_t);
@ -2146,7 +2148,7 @@ void Net_UpdateClients(void)
{ {
int16_t ii=g_gameVarCount-1, kk = 0; 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) if ((aGameVars[ii].dwFlags & GAMEVAR_PERACTOR) && aGameVars[ii].val.plValues)
{ {
@ -2161,7 +2163,6 @@ void Net_UpdateClients(void)
kk++; kk++;
} }
} }
if (kk > 64) break;
} }
*(int16_t *)&packbuf[j] = MAXGAMEVARS; *(int16_t *)&packbuf[j] = MAXGAMEVARS;
j += sizeof(int16_t); j += sizeof(int16_t);
@ -2170,14 +2171,13 @@ void Net_UpdateClients(void)
k++; k++;
} }
} }
if (k > 8) break;
} }
packbuf[zj] = k; packbuf[zj] = k;
k = 0; k = 0;
packbuf[(zj = j++)] = 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)) if (totalclock > (lastsectupdate[i] + TICRATE))
{ {
@ -2194,13 +2194,12 @@ void Net_UpdateClients(void)
k++; k++;
} }
} }
if (k > 6) break;
} }
packbuf[zj] = k; packbuf[zj] = k;
k = 0; k = 0;
packbuf[(zj = j++)] = 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)) if (totalclock > (lastwallupdate[i] + TICRATE))
{ {
@ -2217,7 +2216,6 @@ void Net_UpdateClients(void)
k++; k++;
} }
} }
if (k > 6) break;
} }
packbuf[zj] = k; packbuf[zj] = k;
@ -9445,7 +9443,6 @@ FAKE_F3:
{ {
CONTROL_ClearButton(gamefunc_AutoRun); CONTROL_ClearButton(gamefunc_AutoRun);
ud.auto_run = 1-ud.auto_run; ud.auto_run = 1-ud.auto_run;
ud.config.RunMode = ud.auto_run;
P_DoQuote(85+ud.auto_run,g_player[myconnectindex].ps); P_DoQuote(85+ud.auto_run,g_player[myconnectindex].ps);
} }
@ -11779,7 +11776,6 @@ MAIN_LOOP_RESTART:
} }
else G_UpdateScreenArea(); else G_UpdateScreenArea();
ud.auto_run = ud.config.RunMode;
ud.showweapons = ud.config.ShowOpponentWeapons; ud.showweapons = ud.config.ShowOpponentWeapons;
g_player[myconnectindex].ps->aim_mode = ud.mouseaiming; g_player[myconnectindex].ps->aim_mode = ud.mouseaiming;
g_player[myconnectindex].ps->auto_aim = ud.config.AutoAim; 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; packbuf[0] = PACKET_SLAVE_TO_MASTER;
j = 1; j = 1;
Bmemcpy(&packbuf[j], &nsyn[0], sizeof(input_t) - sizeof(loc.filler)); Bmemcpy(&packbuf[j], &nsyn[0], offsetof(input_t, filler));
j += sizeof(input_t) - sizeof(loc.filler); j += offsetof(input_t, filler);
Bmemcpy(&packbuf[j], &g_player[myconnectindex].ps->pos.x, sizeof(vec3_t) * 2); Bmemcpy(&packbuf[j], &g_player[myconnectindex].ps->pos.x, sizeof(vec3_t) * 2);
j += sizeof(vec3_t) * 2; j += sizeof(vec3_t) * 2;

View file

@ -6155,7 +6155,7 @@ void C_Compile(const char *filenam)
} }
else else
{ {
int32_t j=0, k=0; int32_t j=0, k=0, l=0;
hash_free(&h_keywords); hash_free(&h_keywords);
freehashnames(); freehashnames();
@ -6174,12 +6174,9 @@ void C_Compile(const char *filenam)
C_SetScriptSize(g_scriptPtr-script+8); 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,
initprintf("Compiled code size: %ld*%d bytes, version %s\n",
(unsigned)(g_scriptPtr-script), sizeof(intptr_t), (g_scriptVersion == 14?"1.4+":"1.3D")); (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, initprintf("%ld/%ld labels, %d/%d variables\n", g_numLabels,
min((MAXSECTORS * sizeof(sectortype)/sizeof(int32_t)), min((MAXSECTORS * sizeof(sectortype)/sizeof(int32_t)),
MAXSPRITES * sizeof(spritetype)/(1<<6)), MAXSPRITES * sizeof(spritetype)/(1<<6)),
@ -6188,18 +6185,19 @@ void C_Compile(const char *filenam)
for (i=MAXQUOTES-1; i>=0; i--) for (i=MAXQUOTES-1; i>=0; i--)
if (ScriptQuotes[i]) if (ScriptQuotes[i])
j++; j++;
initprintf("%ld/%d quotes, %d quote redefinitions\n",j,MAXQUOTES,g_numQuoteRedefinitions);
j = 0;
for (i=MAXGAMEEVENTS-1; i>=0; i--) for (i=MAXGAMEEVENTS-1; i>=0; i--)
if (apScriptGameEvent[i]) if (apScriptGameEvent[i])
j++; k++;
for (i=MAXTILES-1; i>=0; i--) for (i=MAXTILES-1; i>=0; i--)
if (actorscrptr[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--) for (i=127; i>=0; i--)
if (ScriptQuotes[i] == NULL) if (ScriptQuotes[i] == NULL)

View file

@ -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_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_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_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 }, { "cl_obituaries", "cl_obituaries: enable/disable multiplayer death messages", (void*)&ud.obituaries, CVAR_BOOL, 0, 1 },