# HG changeset patch # User Sam Lantinga # Date 1081713280 0 # Node ID 50f5a29c6a1790062efe8c2d20708bd03e4b7b65 # Parent 9301b429c99f3868953ca908658dc619982081da Date: Sat, 10 Apr 2004 02:25:33 -0400 From: Glenn Maynard To: sdl@libsdl.org Subject: [SDL] SDL_SetVideoMode() failing and not setting an error (patch) Running an OpenGL SDL application off 1.2.7, at SDL_InitSubSystem(SDL_INIT_VIDEO) time: Warning: Unable to initialize AAlib mouseUsing AAlib driver: Slang driver 1.0 (slang) SDL_SetVideoMode then fails; SDL_GetError() returns "". The installation problem is straightforward: X (the higher priority driver) isn't running, so SDL is falling back on aalib. However, no error is being set when aalib fails to initialize. This also happens with the svgalib driver. SDL_video.c line ~653 sets mode to NULL, since aalib didn't return an OpenGL surface. Line ~711 ("failed setting a video mode") returns NULL. The attached patch sets an error. It's a horrible, useless error message--it should really say eg. "aalib does not support OpenGL"; this should probably be done earlier in the individual drivers, too. diff -r 9301b429c99f -r 50f5a29c6a17 src/video/SDL_video.c --- a/src/video/SDL_video.c Sun Apr 11 19:52:58 2004 +0000 +++ b/src/video/SDL_video.c Sun Apr 11 19:54:40 2004 +0000 @@ -661,6 +661,7 @@ /* Sam - If we asked for OpenGL mode, and didn't get it, fail */ if ( is_opengl && !(mode->flags & SDL_OPENGL) ) { mode = NULL; + SDL_SetError("OpenGL not available"); } } /*