mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 14:20:21 +00:00
wgl: Improve error messages when GL init fails
In particular, we want to get the GL version, when the Windows box/VM has an unsuitable GL implementation. This is somewhat helpful in analyzing failures to bring up GL on machines where users claim GL does work.
This commit is contained in:
parent
d6afcee1e4
commit
9254ab8503
@ -328,10 +328,11 @@ gdk_win32_display_init_wgl (GdkDisplay *display,
|
|||||||
|
|
||||||
/* Setup the legacy context after creating it */
|
/* Setup the legacy context after creating it */
|
||||||
static gboolean
|
static gboolean
|
||||||
ensure_legacy_wgl_context (HDC hdc,
|
ensure_legacy_wgl_context (HDC hdc,
|
||||||
HGLRC hglrc_legacy,
|
HGLRC hglrc_legacy,
|
||||||
GdkGLContext *share,
|
GdkGLContext *share,
|
||||||
GdkGLVersion *version)
|
GdkGLVersion *version,
|
||||||
|
GError **error)
|
||||||
{
|
{
|
||||||
GdkWin32GLContextWGL *context_wgl;
|
GdkWin32GLContextWGL *context_wgl;
|
||||||
GdkGLVersion legacy_version;
|
GdkGLVersion legacy_version;
|
||||||
@ -342,11 +343,25 @@ ensure_legacy_wgl_context (HDC hdc,
|
|||||||
gdk_gl_version_get_minor (version)));
|
gdk_gl_version_get_minor (version)));
|
||||||
|
|
||||||
if (!wglMakeCurrent (hdc, hglrc_legacy))
|
if (!wglMakeCurrent (hdc, hglrc_legacy))
|
||||||
return FALSE;
|
{
|
||||||
|
g_set_error_literal (error, GDK_GL_ERROR,
|
||||||
|
GDK_GL_ERROR_NOT_AVAILABLE,
|
||||||
|
_("Unable to create a GL context"));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
gdk_gl_version_init_epoxy (&legacy_version);
|
gdk_gl_version_init_epoxy (&legacy_version);
|
||||||
if (!gdk_gl_version_greater_equal (&legacy_version, version))
|
if (!gdk_gl_version_greater_equal (&legacy_version, version))
|
||||||
return FALSE;
|
{
|
||||||
|
g_set_error (error, GDK_GL_ERROR,
|
||||||
|
GDK_GL_ERROR_NOT_AVAILABLE,
|
||||||
|
_("WGL version %d.%d is too low, need at least %d.%d"),
|
||||||
|
gdk_gl_version_get_major (&legacy_version),
|
||||||
|
gdk_gl_version_get_minor (&legacy_version),
|
||||||
|
gdk_gl_version_get_major (version),
|
||||||
|
gdk_gl_version_get_minor (version));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
*version = legacy_version;
|
*version = legacy_version;
|
||||||
|
|
||||||
@ -354,7 +369,13 @@ ensure_legacy_wgl_context (HDC hdc,
|
|||||||
{
|
{
|
||||||
context_wgl = GDK_WIN32_GL_CONTEXT_WGL (share);
|
context_wgl = GDK_WIN32_GL_CONTEXT_WGL (share);
|
||||||
|
|
||||||
return wglShareLists (hglrc_legacy, context_wgl->wgl_context);
|
if (!wglShareLists (hglrc_legacy, context_wgl->wgl_context))
|
||||||
|
{
|
||||||
|
g_set_error (error, GDK_GL_ERROR,
|
||||||
|
GDK_GL_ERROR_UNSUPPORTED_PROFILE,
|
||||||
|
_("GL implementation cannot share GL contexts"));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -416,12 +437,13 @@ create_wgl_context_with_attribs (HDC hdc,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static HGLRC
|
static HGLRC
|
||||||
create_wgl_context (GdkGLContext *context,
|
create_wgl_context (GdkGLContext *context,
|
||||||
HDC hdc,
|
HDC hdc,
|
||||||
gboolean hasWglARBCreateContext,
|
gboolean hasWglARBCreateContext,
|
||||||
GdkGLContext *share,
|
GdkGLContext *share,
|
||||||
int flags,
|
int flags,
|
||||||
gboolean legacy)
|
gboolean legacy,
|
||||||
|
GError **error)
|
||||||
{
|
{
|
||||||
/* We need a legacy context for *all* cases */
|
/* We need a legacy context for *all* cases */
|
||||||
HGLRC hglrc_base, hglrc;
|
HGLRC hglrc_base, hglrc;
|
||||||
@ -431,7 +453,15 @@ create_wgl_context (GdkGLContext *context,
|
|||||||
HGLRC hglrc_current = wglGetCurrentContext ();
|
HGLRC hglrc_current = wglGetCurrentContext ();
|
||||||
|
|
||||||
hglrc_base = wglCreateContext (hdc);
|
hglrc_base = wglCreateContext (hdc);
|
||||||
wglMakeCurrent (hdc, hglrc_base);
|
if (hglrc_base == NULL ||
|
||||||
|
!wglMakeCurrent (hdc, hglrc_base))
|
||||||
|
{
|
||||||
|
g_clear_pointer (&hglrc_base, wglDeleteContext);
|
||||||
|
g_set_error_literal (error, GDK_GL_ERROR,
|
||||||
|
GDK_GL_ERROR_NOT_AVAILABLE,
|
||||||
|
_("Unable to create a GL context"));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
hglrc = NULL;
|
hglrc = NULL;
|
||||||
|
|
||||||
@ -473,7 +503,7 @@ create_wgl_context (GdkGLContext *context,
|
|||||||
GDK_GL_API_GL,
|
GDK_GL_API_GL,
|
||||||
TRUE,
|
TRUE,
|
||||||
&version);
|
&version);
|
||||||
if (ensure_legacy_wgl_context (hdc, hglrc_base, share, &version))
|
if (ensure_legacy_wgl_context (hdc, hglrc_base, share, &version, error))
|
||||||
hglrc = g_steal_pointer (&hglrc_base);
|
hglrc = g_steal_pointer (&hglrc_base);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -585,15 +615,10 @@ gdk_win32_gl_context_wgl_realize (GdkGLContext *context,
|
|||||||
display_win32->hasWglARBCreateContext,
|
display_win32->hasWglARBCreateContext,
|
||||||
share,
|
share,
|
||||||
flags,
|
flags,
|
||||||
legacy_bit);
|
legacy_bit,
|
||||||
|
error);
|
||||||
if (hglrc == NULL)
|
if (hglrc == NULL)
|
||||||
{
|
return 0;
|
||||||
g_set_error_literal (error, GDK_GL_ERROR,
|
|
||||||
GDK_GL_ERROR_NOT_AVAILABLE,
|
|
||||||
_("Unable to create a GL context"));
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
GDK_NOTE (OPENGL,
|
GDK_NOTE (OPENGL,
|
||||||
g_print ("Created WGL context[%p], pixel_format=%d\n",
|
g_print ("Created WGL context[%p], pixel_format=%d\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user