9eec91
# HG changeset patch
9eec91
# Parent  46ea866ca3acb8bb5e1709ceb799b9c94f591dec
9eec91
Problem description: Tab-titles that are too long to fit into a tab get faded out.
9eec91
                     On big endian this is broken and instead of fading out, the 
9eec91
                     tab gets white and the font transparent, leading to an unreadable
9eec91
                     tab-title
9eec91
Solution: This is not a real solution, but a hack. The real solution would have been
9eec91
          to byte-swap the correct buffer, but I could not find it.
9eec91
          So the next best thing is to deactivate the fading-effect. Now all tab-titles
9eec91
          are readable, albeit not as pretty to look at as they could be. 
9eec91
Side-effects: I have not yet found an unwanted side-effect.
9eec91
9eec91
diff -r 46ea866ca3ac -r 6ef20eee3f8f gfx/2d/DrawTargetSkia.cpp
9eec91
--- a/gfx/2d/DrawTargetSkia.cpp	Tue Oct 22 12:27:22 2019 +0200
9eec91
+++ b/gfx/2d/DrawTargetSkia.cpp	Thu Oct 31 09:11:56 2019 +0100
9eec91
@@ -1861,6 +1861,14 @@
9eec91
       SkCanvas::kPreserveLCDText_SaveLayerFlag |
9eec91
           (aCopyBackground ? SkCanvas::kInitWithPrevious_SaveLayerFlag : 0));
9eec91
 
9eec91
+#if MOZ_BIG_ENDIAN
9eec91
+  // Pushing a layer where an aMask is defined produces wrong output.
9eec91
+  // We _should_ endian swap the data, but I couldn't find a workable way to do so
9eec91
+  // Therefore I deactivate those layers in the meantime.
9eec91
+  // The result is: Tab-titles that are longer than the available space should be faded out.
9eec91
+  //                The fading doesn't work, so we deactivate the fading-effect here.
9eec91
+  if (!aMask)
9eec91
+#endif
9eec91
   mCanvas->saveLayer(saveRec);
9eec91
 
9eec91
   SetPermitSubpixelAA(aOpaque);