Fix -OGLlib

This commit is contained in:
Jaime Passos 2020-01-27 01:57:55 -03:00
parent 7dac10f5f9
commit b6089ccdaf
4 changed files with 65 additions and 16 deletions

View file

@ -32,10 +32,13 @@ typedef enum
render_none = 3 // for dedicated server render_none = 3 // for dedicated server
} rendermode_t; } rendermode_t;
/** \brief currect render mode /** \brief current render mode
*/ */
extern rendermode_t rendermode; extern rendermode_t rendermode;
/** \brief hardware renderer loaded
*/
extern boolean hwrenderloaded;
/** \brief use highcolor modes if true /** \brief use highcolor modes if true
*/ */
@ -44,6 +47,9 @@ extern boolean highcolor;
/** \brief setup video mode /** \brief setup video mode
*/ */
void I_StartupGraphics(void); void I_StartupGraphics(void);
/** \brief setup hardware mode
*/
void I_StartupHardwareGraphics(void); void I_StartupHardwareGraphics(void);
/** \brief restore old video mode /** \brief restore old video mode
@ -82,9 +88,12 @@ INT32 VID_GetModeForSize(INT32 w, INT32 h);
\param modenum video mode to set to \param modenum video mode to set to
\return currect video mode \return current video mode
*/ */
INT32 VID_SetMode(INT32 modenum); INT32 VID_SetMode(INT32 modenum);
/** \brief Checks the render state
*/
void VID_CheckRenderer(void); void VID_CheckRenderer(void);
/** \brief The VID_GetModeName function /** \brief The VID_GetModeName function

View file

@ -464,7 +464,7 @@ void SCR_ChangeRenderer(void)
{ {
target_renderer = cv_renderer.value; target_renderer = cv_renderer.value;
#ifdef HWRENDER #ifdef HWRENDER
if (M_CheckParm("-opengl")) if (M_CheckParm("-opengl") && hwrenderloaded)
target_renderer = rendermode = render_opengl; target_renderer = rendermode = render_opengl;
else else
#endif #endif

View file

@ -93,7 +93,8 @@ static INT32 numVidModes = -1;
*/ */
static char vidModeName[33][32]; // allow 33 different modes static char vidModeName[33][32]; // allow 33 different modes
rendermode_t rendermode=render_soft; rendermode_t rendermode = render_soft;
static rendermode_t chosenrendermode = render_soft; // set by command line arguments
boolean highcolor = false; boolean highcolor = false;
@ -103,6 +104,7 @@ static consvar_t cv_stretch = {"stretch", "Off", CV_SAVE|CV_NOSHOWHELP, CV_OnOff
static consvar_t cv_alwaysgrabmouse = {"alwaysgrabmouse", "Off", CV_SAVE, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL}; static consvar_t cv_alwaysgrabmouse = {"alwaysgrabmouse", "Off", CV_SAVE, CV_OnOff, NULL, 0, NULL, NULL, 0, 0, NULL};
UINT8 graphics_started = 0; // Is used in console.c and screen.c UINT8 graphics_started = 0; // Is used in console.c and screen.c
boolean hwrenderloaded = false;
// To disable fullscreen at startup; is set in VID_PrepareModeList // To disable fullscreen at startup; is set in VID_PrepareModeList
boolean allow_fullscreen = false; boolean allow_fullscreen = false;
@ -1468,14 +1470,44 @@ static SDL_bool Impl_CreateContext(void)
return SDL_TRUE; return SDL_TRUE;
} }
#ifdef HWRENDER
static void VID_CheckGLLoaded(rendermode_t oldrender)
{
if (!hwrenderloaded) // Well, it didn't work the first time anyway.
{
CONS_Alert(CONS_ERROR, "OpenGL never loaded\n");
rendermode = oldrender;
if (chosenrendermode == render_opengl) // fallback to software
rendermode = render_soft;
if (setrenderneeded)
{
CV_StealthSetValue(&cv_renderer, oldrender);
CV_StealthSetValue(&cv_newrenderer, oldrender);
setrenderneeded = 0;
}
}
}
#endif
void VID_CheckRenderer(void) void VID_CheckRenderer(void)
{ {
rendermode_t oldrenderer = rendermode;
if (dedicated) if (dedicated)
return; return;
#ifdef HWRENDER
if (!graphics_started)
VID_CheckGLLoaded(oldrenderer);
#endif
if (setrenderneeded) if (setrenderneeded)
{ {
rendermode = setrenderneeded; rendermode = setrenderneeded;
#ifdef HWRENDER
if (setrenderneeded == render_opengl)
VID_CheckGLLoaded(oldrenderer);
#endif
Impl_CreateContext(); Impl_CreateContext();
} }
@ -1498,9 +1530,15 @@ void VID_CheckRenderer(void)
else if (rendermode == render_opengl) else if (rendermode == render_opengl)
{ {
I_StartupHardwareGraphics(); I_StartupHardwareGraphics();
R_InitHardwareMode(); // Needs to check if switching failed somehow, too.
HWR_Switch(); if (rendermode == render_opengl)
{
R_InitHardwareMode();
HWR_Switch();
}
} }
#else
(void)oldrenderer;
#endif #endif
} }
@ -1665,10 +1703,10 @@ void I_StartupGraphics(void)
#ifdef HWRENDER #ifdef HWRENDER
if (M_CheckParm("-opengl")) if (M_CheckParm("-opengl"))
rendermode = render_opengl; chosenrendermode = rendermode = render_opengl;
else if (M_CheckParm("-software")) else if (M_CheckParm("-software"))
#endif #endif
rendermode = render_soft; chosenrendermode = rendermode = render_soft;
usesdl2soft = M_CheckParm("-softblit"); usesdl2soft = M_CheckParm("-softblit");
borderlesswindow = M_CheckParm("-borderless"); borderlesswindow = M_CheckParm("-borderless");
@ -1764,13 +1802,15 @@ void I_StartupHardwareGraphics(void)
HWD.pfnMakeScreenTexture= hwSym("MakeScreenTexture",NULL); HWD.pfnMakeScreenTexture= hwSym("MakeScreenTexture",NULL);
HWD.pfnMakeScreenFinalTexture=hwSym("MakeScreenFinalTexture",NULL); HWD.pfnMakeScreenFinalTexture=hwSym("MakeScreenFinalTexture",NULL);
HWD.pfnDrawScreenFinalTexture=hwSym("DrawScreenFinalTexture",NULL); HWD.pfnDrawScreenFinalTexture=hwSym("DrawScreenFinalTexture",NULL);
// check gl renderer lib
if (HWD.pfnGetRenderVersion() != VERSION)
I_Error("%s", M_GetText("The version of the renderer doesn't match the version of the executable\nBe sure you have installed SRB2 properly.\n"));
if (!HWD.pfnInit(I_Error)) // let load the OpenGL library if (!HWD.pfnInit(I_Error)) // let load the OpenGL library
{
rendermode = render_soft; rendermode = render_soft;
setrenderneeded = 0;
}
else else
glstartup = true; hwrenderloaded = true;
glstartup = true;
} }
#endif #endif
} }

View file

@ -128,15 +128,15 @@ boolean LoadGL(void)
return SetupGLfunc(); return SetupGLfunc();
else else
{ {
I_OutputMsg("Could not load GLU Library: %s\n", GLULibname); CONS_Alert(CONS_ERROR, "Could not load GLU Library: %s\n", GLULibname);
if (!M_CheckParm ("-GLUlib")) if (!M_CheckParm ("-GLUlib"))
I_OutputMsg("If you know what is the GLU library's name, use -GLUlib\n"); CONS_Alert(CONS_ERROR, "If you know what is the GLU library's name, use -GLUlib\n");
} }
} }
else else
{ {
I_OutputMsg("Could not load GLU Library\n"); CONS_Alert(CONS_ERROR, "Could not load GLU Library\n");
I_OutputMsg("If you know what is the GLU library's name, use -GLUlib\n"); CONS_Alert(CONS_ERROR, "If you know what is the GLU library's name, use -GLUlib\n");
} }
#endif #endif
return SetupGLfunc(); return SetupGLfunc();