[WIN32K]
authorTimo Kreuzer <timo.kreuzer@reactos.org>
Mon, 14 Feb 2011 16:04:01 +0000 (16:04 +0000)
committerTimo Kreuzer <timo.kreuzer@reactos.org>
Mon, 14 Feb 2011 16:04:01 +0000 (16:04 +0000)
Fix initialization of XLATEOBJ, when source and dest format are equal. Patch by Thomas Faber (thfabba at gmx de)

See issue #5828 for more details.

svn path=/trunk/; revision=50694

reactos/subsystems/win32/win32k/eng/xlate.c

index f6aa48c..1f0fde6 100644 (file)
@@ -361,9 +361,7 @@ EXLATEOBJ_vInitialize(
 
     EXLATEOBJ_vInitTrivial(pexlo);
 
-    if (ppalDst == ppalSrc || !ppalSrc || !ppalDst ||
-        ((ppalDst->flFlags == PAL_RGB || ppalDst->flFlags == PAL_BGR) &&
-         ppalDst->flFlags == ppalSrc->flFlags))
+    if (!ppalSrc || !ppalDst)
     {
         return;
     }
@@ -372,6 +370,13 @@ EXLATEOBJ_vInitialize(
     pexlo->ppalDst = ppalDst;
     pexlo->xlo.iSrcType = ppalSrc->flFlags;
     pexlo->xlo.iDstType = ppalDst->flFlags;
+    
+    if (ppalDst == ppalSrc ||
+        ((ppalDst->flFlags == PAL_RGB || ppalDst->flFlags == PAL_BGR) &&
+         ppalDst->flFlags == ppalSrc->flFlags))
+    {
+        return;
+    }
 
     /* Chack if both of the pallettes are indexed */
     if (!(ppalSrc->flFlags & PAL_INDEXED) || !(ppalDst->flFlags & PAL_INDEXED))
@@ -607,13 +612,6 @@ EXLATEOBJ_vInitXlateFromDCs(
     psurfDst = pdcDst->dclevel.pSurface;
     psurfSrc = pdcSrc->dclevel.pSurface;
 
-    /* Check for trivial color translation */
-    if (psurfDst == psurfSrc)
-    {
-        EXLATEOBJ_vInitTrivial(pexlo);
-        return;
-    }
-
     /* Normal initialisation. No surface means DEFAULT_BITMAP */
     EXLATEOBJ_vInitialize(pexlo,
                           psurfSrc ? psurfSrc->ppal : &gpalMono,