changeset 1771:8d3ca155c396

Fixed bug #217 Sort the DirectX video modes largest to smallest
author Sam Lantinga <slouken@libsdl.org>
date Sun, 07 May 2006 04:02:48 +0000
parents 1632155c67e5
children 5115185b6e3c
files src/video/windib/SDL_dibvideo.c src/video/windx5/SDL_dx5video.c src/video/x11/SDL_x11modes.c
diffstat 3 files changed, 16 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/src/video/windib/SDL_dibvideo.c	Sun May 07 03:44:58 2006 +0000
+++ b/src/video/windib/SDL_dibvideo.c	Sun May 07 04:02:48 2006 +0000
@@ -348,7 +348,6 @@
 #endif
 	}
 	/* Sort the mode lists */
-	if( i > 1 )
 	for ( i=0; i<NUM_MODELISTS; ++i ) {
 		if ( SDL_nummodes[i] > 0 ) {
 			SDL_qsort(SDL_modelist[i], SDL_nummodes[i], sizeof *SDL_modelist[i], cmpmodes);
@@ -361,7 +360,7 @@
 	// because SDL surface conversion is much faster than the WinCE one.
 	// Although it should be tested on devices with graphics accelerator.
 
-    DIB_AddMode(this, vformat->BitsPerPixel,
+	DIB_AddMode(this, vformat->BitsPerPixel,
 			GetDeviceCaps(GetDC(NULL), HORZRES), 
 			GetDeviceCaps(GetDC(NULL), VERTRES));
 
--- a/src/video/windx5/SDL_dx5video.c	Sun May 07 03:44:58 2006 +0000
+++ b/src/video/windx5/SDL_dx5video.c	Sun May 07 04:02:48 2006 +0000
@@ -636,6 +636,16 @@
 	DX5_Available, DX5_CreateDevice
 };
 
+static int cmpmodes(const void *va, const void *vb)
+{
+    SDL_Rect *a = *(SDL_Rect **)va;
+    SDL_Rect *b = *(SDL_Rect **)vb;
+    if ( a->w == b->w )
+        return b->h - a->h;
+    else
+        return b->w - a->w;
+}
+
 static HRESULT WINAPI EnumModes2(DDSURFACEDESC *desc, VOID *udata)
 {
 	SDL_VideoDevice *this = (SDL_VideoDevice *)udata;
@@ -955,6 +965,10 @@
 			SDL_modelist[i][j] = &rect->r;
 		}
 		SDL_modelist[i][j] = NULL;
+
+		if ( SDL_nummodes[i] > 0 ) {
+			SDL_qsort(SDL_modelist[i], SDL_nummodes[i], sizeof *SDL_modelist[i], cmpmodes);
+		}
 	}
 	
 	/* Fill in some window manager capabilities */
--- a/src/video/x11/SDL_x11modes.c	Sun May 07 03:44:58 2006 +0000
+++ b/src/video/x11/SDL_x11modes.c	Sun May 07 04:02:48 2006 +0000
@@ -617,7 +617,7 @@
 
             }
             /* sort the mode list descending as SDL expects */
-            qsort(SDL_modelist, nsizes, sizeof *SDL_modelist, cmpmodelist);
+            SDL_qsort(SDL_modelist, nsizes, sizeof *SDL_modelist, cmpmodelist);
             SDL_modelist[i] = NULL; /* terminator */
 
             use_xrandr = xrandr_major * 100 + xrandr_minor;