summaryrefslogtreecommitdiff
path: root/src/cairo-surface.c
diff options
context:
space:
mode:
authorBehdad Esfahbod <behdad@behdad.org>2017-09-12 01:35:15 -0400
committerBehdad Esfahbod <behdad@behdad.org>2017-09-12 01:35:15 -0400
commit99427c3f4f6ce7ce3c95c4caa4d2b8ff7c0093d9 (patch)
tree78aa135d7f5ee66c2e1ffc86f06e25711d967a57 /src/cairo-surface.c
parent7f6b57a2386c051e4bb6a156cf14904fe061f837 (diff)
downloadcairo-99427c3f4f6ce7ce3c95c4caa4d2b8ff7c0093d9.tar.gz
Handle SOURCE and CLEAR operators when painting color glyphs
In cairo, most operators are composited this way: ((src IN mask) OP dst) LERP_clip dst but SOURCE and CLEAR operators are composited this way: (src OP dst) LERP_(clip IN mask) dst (why is this not specified anywhere in the docs or source tree?) With color glyphs, we were not special-casing SOURCE and CLEAR. We do now. Fixes https://bugs.freedesktop.org/show_bug.cgi?id=102661
Diffstat (limited to 'src/cairo-surface.c')
-rw-r--r--src/cairo-surface.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/cairo-surface.c b/src/cairo-surface.c
index 6f25bd7c0..35c63d7b8 100644
--- a/src/cairo-surface.c
+++ b/src/cairo-surface.c
@@ -2571,7 +2571,10 @@ composite_one_color_glyph (cairo_surface_t *surface,
pattern = cairo_pattern_create_for_surface ((cairo_surface_t *)glyph_surface);
cairo_matrix_init_translate (&matrix, - x, - y);
cairo_pattern_set_matrix (pattern, &matrix);
- status = surface->backend->paint (surface, op, pattern, clip);
+ if (op == CAIRO_OPERATOR_SOURCE || op == CAIRO_OPERATOR_CLEAR)
+ status = surface->backend->mask (surface, op, pattern, pattern, clip);
+ else
+ status = surface->backend->paint (surface, op, pattern, clip);
}
return status;