X-Git-Url: https://git.xonotic.org/?a=blobdiff_plain;f=console.c;h=21148248e1ccaf21ec9cc676e164f70877ca4ff1;hb=57252d1b300d96b2353bf9d564b0de281552d2c5;hp=6c5c6497f3c723a55b85410ab6efe23b938d92b1;hpb=f3a0ca9464dc2f1e3ee948259f723c27fbe29dc4;p=xonotic%2Fdarkplaces.git diff --git a/console.c b/console.c index 6c5c6497..21148248 100644 --- a/console.c +++ b/console.c @@ -51,11 +51,12 @@ char *con_text = 0; //seconds cvar_t con_notifytime = {CVAR_SAVE, "con_notifytime","3"}; +cvar_t con_notify = {CVAR_SAVE, "con_notify","4"}; cvar_t logfile = {0, "logfile","0"}; -#define NUM_CON_TIMES 4 +#define MAX_NOTIFYLINES 32 // realtime time the line was generated for transparent notify lines -float con_times[NUM_CON_TIMES]; +float con_times[MAX_NOTIFYLINES]; int con_vislines; @@ -110,7 +111,7 @@ void Con_ClearNotify (void) { int i; - for (i=0 ; i= 0) - con_times[con_current % NUM_CON_TIMES] = realtime; + { + if (con_notify.integer < 0) + Cvar_SetValueQuick(&con_notify, 0); + if (con_notifylines > MAX_NOTIFYLINES) + Cvar_SetValueQuick(&con_notify, MAX_NOTIFYLINES); + if (con_notify.integer > 0) + con_times[con_current % con_notify.integer] = realtime; + } } switch (c) @@ -346,16 +355,16 @@ void Con_Print (const char *txt) Con_DebugLog ================ */ -void Con_DebugLog(const char *file, const char *fmt, ...) +void Con_DebugLog (const char *msg) { - va_list argptr; - FILE* fd; - - fd = fopen(file, "at"); - va_start(argptr, fmt); - vfprintf (fd, fmt, argptr); - va_end(argptr); - fclose(fd); + qfile_t* file; + + file = FS_Open ("qconsole.log", "at", true); + if (file) + { + FS_Printf (file, "%s", msg); + FS_Close (file); + } } @@ -378,17 +387,12 @@ void Con_Printf (const char *fmt, ...) vsprintf (msg,fmt,argptr); va_end (argptr); -// also echo to debugging console + // also echo to debugging console Sys_Printf ("%s", msg); -// log all messages to file + // log all messages to file if (con_debuglog) - { - // can't use va() here because it might overwrite other important things - char logname[MAX_OSPATH]; - sprintf(logname, "%s/qconsole.log", com_gamedir); - Con_DebugLog(logname, "%s", msg); - } + Con_DebugLog (msg); if (!con_initialized) return; @@ -396,7 +400,7 @@ void Con_Printf (const char *fmt, ...) if (cls.state == ca_dedicated) return; // no graphics mode -// write it to the scrollable buffer + // write it to the scrollable buffer Con_Print (msg); } @@ -509,12 +513,16 @@ void Con_DrawNotify (void) extern char chat_buffer[]; char temptext[256]; + if (con_notify.integer < 0) + Cvar_SetValueQuick(&con_notify, 0); + if (con_notifylines > MAX_NOTIFYLINES) + Cvar_SetValueQuick(&con_notify, MAX_NOTIFYLINES); v = 0; - for (i= con_current-NUM_CON_TIMES+1 ; i<=con_current ; i++) + for (i= con_current-con_notify.integer+1 ; i<=con_current ; i++) { if (i < 0) continue; - time = con_times[i % NUM_CON_TIMES]; + time = con_times[i % con_notify.integer]; if (time == 0) continue; time = realtime - time; @@ -554,7 +562,7 @@ void Con_DrawNotify (void) } } - if (v > con_notifylines) + if (con_notifylines < v) con_notifylines = v; }