summaryrefslogtreecommitdiffstats
path: root/external/skia/windows-text-gamma.patch.0
blob: 624636b7da9936757dedad0db370808cdea88220 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
--- ./src/ports/SkFontHost_win.cpp.sav	2020-03-18 10:26:52.470184300 +0100
+++ ./src/ports/SkFontHost_win.cpp	2020-03-18 12:08:04.598406700 +0100
@@ -1215,17 +1215,23 @@
         // since the caller may require A8 for maskfilters, we can't check for BW
         // ... until we have the caller tell us that explicitly
         const SkGdiRGB* src = (const SkGdiRGB*)bits;
+#if defined(SK_GAMMA_APPLY_TO_A8)
         if (fPreBlend.isApplicable()) {
             RGBToA8<true>(src, srcRB, glyph, fPreBlend.fG);
-        } else {
+        } else
+#endif
+        {
             RGBToA8<false>(src, srcRB, glyph, fPreBlend.fG);
         }
     } else {    // LCD16
         const SkGdiRGB* src = (const SkGdiRGB*)bits;
         SkASSERT(SkMask::kLCD16_Format == glyph.fMaskFormat);
+#if defined(SK_GAMMA_APPLY_TO_A8)
         if (fPreBlend.isApplicable()) {
             RGBToLcd16<true>(src, srcRB, glyph, fPreBlend.fR, fPreBlend.fG, fPreBlend.fB);
-        } else {
+        } else
+#endif
+        {
             RGBToLcd16<false>(src, srcRB, glyph, fPreBlend.fR, fPreBlend.fG, fPreBlend.fB);
         }
     }
--- ./src/ports/SkScalerContext_win_dw.cpp
+++ ./src/ports/SkScalerContext_win_dw.cpp
@@ -1132,27 +1132,36 @@ void SkScalerContext_DW::generateImage(const SkGlyph& glyph) {
         BilevelToBW(src, glyph);
     } else if (!isLCD(fRec)) {
         if (textureType == DWRITE_TEXTURE_ALIASED_1x1) {
+#if defined(SK_GAMMA_APPLY_TO_A8)
             if (fPreBlend.isApplicable()) {
                 GrayscaleToA8<true>(src, glyph, fPreBlend.fG);
-            } else {
+            } else
+#endif
+            {
                 GrayscaleToA8<false>(src, glyph, fPreBlend.fG);
             }
         } else {
+#if defined(SK_GAMMA_APPLY_TO_A8)
             if (fPreBlend.isApplicable()) {
                 RGBToA8<true>(src, glyph, fPreBlend.fG);
-            } else {
+            } else
+#endif
+            {
                 RGBToA8<false>(src, glyph, fPreBlend.fG);
             }
         }
     } else {
         SkASSERT(SkMask::kLCD16_Format == glyph.fMaskFormat);
+#if defined(SK_GAMMA_APPLY_TO_A8)
         if (fPreBlend.isApplicable()) {
             if (fRec.fFlags & SkScalerContext::kLCD_BGROrder_Flag) {
                 RGBToLcd16<true, false>(src, glyph, fPreBlend.fR, fPreBlend.fG, fPreBlend.fB);
             } else {
                 RGBToLcd16<true, true>(src, glyph, fPreBlend.fR, fPreBlend.fG, fPreBlend.fB);
             }
-        } else {
+        } else
+#endif
+        {
             if (fRec.fFlags & SkScalerContext::kLCD_BGROrder_Flag) {
                 RGBToLcd16<false, false>(src, glyph, fPreBlend.fR, fPreBlend.fG, fPreBlend.fB);
             } else {