summaryrefslogtreecommitdiff
path: root/chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp')
-rw-r--r--chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp20
1 files changed, 18 insertions, 2 deletions
diff --git a/chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp b/chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp
index 3b28b442fea..4b0ab303709 100644
--- a/chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp
+++ b/chromium/third_party/skia/src/ports/SkFontHost_FreeType_common.cpp
@@ -64,6 +64,8 @@ bool operator==(const FT_OpaquePaint& a, const FT_OpaquePaint& b) {
}
#endif
+#define SK_AFTER_FT_TRANSFORM_RENAME FREETYPE_MAJOR >= 2 && FREETYPE_MINOR >= 11
+
namespace {
FT_Pixel_Mode compute_pixel_mode(SkMask::Format format) {
@@ -759,8 +761,13 @@ void colrv1_transform(SkCanvas* canvas, FT_Face face, FT_COLR_Paint colrv1_paint
SkMatrix transform;
switch (colrv1_paint.format) {
+#if SK_AFTER_FT_TRANSFORM_RENAME
+ case FT_COLR_PAINTFORMAT_TRANSFORM: {
+ transform = ToSkMatrix(colrv1_paint.u.transform.affine);
+#else
case FT_COLR_PAINTFORMAT_TRANSFORMED: {
transform = ToSkMatrix(colrv1_paint.u.transformed.affine);
+#endif
break;
}
case FT_COLR_PAINTFORMAT_TRANSLATE: {
@@ -880,10 +887,19 @@ bool colrv1_traverse_paint(SkCanvas* canvas,
traverse_result = colrv1_start_glyph(canvas, palette, face, paint.u.colr_glyph.glyphID,
FT_COLOR_NO_ROOT_TRANSFORM);
break;
+#if SK_AFTER_FT_TRANSFORM_RENAME
+ case FT_COLR_PAINTFORMAT_TRANSFORM:
+#else
case FT_COLR_PAINTFORMAT_TRANSFORMED:
+#endif
colrv1_transform(canvas, face, paint);
- traverse_result = colrv1_traverse_paint(canvas, palette, face,
- paint.u.transformed.paint, visited_set);
+ traverse_result =
+ colrv1_traverse_paint(canvas, palette, face,
+#if SK_AFTER_FT_TRANSFORM_RENAME
+ paint.u.transform.paint, visited_set);
+#else
+ paint.u.transformed.paint, visited_set);
+#endif
break;
case FT_COLR_PAINTFORMAT_TRANSLATE:
colrv1_transform(canvas, face, paint);