mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-14 22:00:50 +00:00
Fix opengl crashing on startup due to lack of checks
Also fixes the log file not being written to the home directory.
This commit is contained in:
parent
e229aabf22
commit
3f3cb2c976
2 changed files with 24 additions and 8 deletions
|
@ -143,7 +143,7 @@ static const GLfloat byte2float[256] = {
|
||||||
// -----------------+
|
// -----------------+
|
||||||
|
|
||||||
#ifdef DEBUG_TO_FILE
|
#ifdef DEBUG_TO_FILE
|
||||||
FILE *gllogstream;
|
FILE *gllogstream = NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
FUNCPRINTF void GL_DBG_Printf(const char *format, ...)
|
FUNCPRINTF void GL_DBG_Printf(const char *format, ...)
|
||||||
|
@ -152,14 +152,14 @@ FUNCPRINTF void GL_DBG_Printf(const char *format, ...)
|
||||||
char str[4096] = "";
|
char str[4096] = "";
|
||||||
va_list arglist;
|
va_list arglist;
|
||||||
|
|
||||||
if (!gllogstream)
|
if (gllogstream)
|
||||||
gllogstream = fopen("ogllog.txt", "w");
|
{
|
||||||
|
va_start(arglist, format);
|
||||||
|
vsnprintf(str, 4096, format, arglist);
|
||||||
|
va_end(arglist);
|
||||||
|
|
||||||
va_start(arglist, format);
|
fwrite(str, strlen(str), 1, gllogstream);
|
||||||
vsnprintf(str, 4096, format, arglist);
|
}
|
||||||
va_end(arglist);
|
|
||||||
|
|
||||||
fwrite(str, strlen(str), 1, gllogstream);
|
|
||||||
#else
|
#else
|
||||||
(void)format;
|
(void)format;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "../doomdef.h"
|
#include "../doomdef.h"
|
||||||
|
#include "../d_main.h"
|
||||||
|
|
||||||
#ifdef HWRENDER
|
#ifdef HWRENDER
|
||||||
#include "../hardware/r_opengl/r_opengl.h"
|
#include "../hardware/r_opengl/r_opengl.h"
|
||||||
|
@ -154,11 +155,26 @@ boolean OglSdlSurface(INT32 w, INT32 h)
|
||||||
{
|
{
|
||||||
INT32 cbpp = cv_scr_depth.value < 16 ? 16 : cv_scr_depth.value;
|
INT32 cbpp = cv_scr_depth.value < 16 ? 16 : cv_scr_depth.value;
|
||||||
static boolean first_init = false;
|
static boolean first_init = false;
|
||||||
|
const char *gllogdir = NULL;
|
||||||
|
|
||||||
oglflags = 0;
|
oglflags = 0;
|
||||||
|
|
||||||
if (!first_init)
|
if (!first_init)
|
||||||
{
|
{
|
||||||
|
if (!gllogstream)
|
||||||
|
{
|
||||||
|
gllogdir = D_Home();
|
||||||
|
|
||||||
|
#ifdef DEBUG_TO_FILE
|
||||||
|
#ifdef DEFAULTDIR
|
||||||
|
if (gllogdir)
|
||||||
|
gllogstream = fopen(va("%s/"DEFAULTDIR"/ogllog.txt",gllogdir), "wt");
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
gllogstream = fopen("./ogllog.txt", "wt");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
gl_version = pglGetString(GL_VERSION);
|
gl_version = pglGetString(GL_VERSION);
|
||||||
gl_renderer = pglGetString(GL_RENDERER);
|
gl_renderer = pglGetString(GL_RENDERER);
|
||||||
gl_extensions = pglGetString(GL_EXTENSIONS);
|
gl_extensions = pglGetString(GL_EXTENSIONS);
|
||||||
|
|
Loading…
Reference in a new issue