]> code.delx.au - gnu-emacs/commitdiff
* ftcrfont.c (ftcrfont_draw): Don't flush when drawing to screen.
authorYAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
Thu, 19 Feb 2015 07:17:28 +0000 (16:17 +0900)
committerYAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
Thu, 19 Feb 2015 07:17:28 +0000 (16:17 +0900)
src/ChangeLog
src/ftcrfont.c

index fea9e379d7317d5999040e7d5dba7acdc4064ff6..d2cb70e2d0889a30c75ee9804971efd5d59ae25e 100644 (file)
@@ -1,3 +1,7 @@
+2015-02-19  YAMAMOTO Mitsuharu  <mituharu@math.s.chiba-u.ac.jp>
+
+       * ftcrfont.c (ftcrfont_draw): Don't flush when drawing to screen.
+
 2015-02-17  YAMAMOTO Mitsuharu  <mituharu@math.s.chiba-u.ac.jp>
 
        * xterm.c [USE_CAIRO]: Include math.h.
index d60c1202b9d161d136f0a0c121e34d37e66450d3..fc4e6dae8731bb6a53870d91f73128f9753bfdf0 100644 (file)
@@ -246,6 +246,7 @@ ftcrfont_draw (struct glyph_string *s,
   cairo_t *cr;
   cairo_glyph_t *glyphs;
   cairo_surface_t *surface;
+  cairo_surface_type_t surface_type;
   int len = to - from;
   int i;
 
@@ -282,7 +283,12 @@ ftcrfont_draw (struct glyph_string *s,
   FT_Activate_Size (ftcrfont_info->ft_size_draw);
   cairo_show_glyphs (cr, glyphs, len);
   surface = cairo_get_target (cr);
-  if (cairo_surface_get_type (surface) != CAIRO_SURFACE_TYPE_XLIB)
+  /* XXX: It used to be necessary to flush when exporting.  It might
+     be the case that this is no longer necessary.  */
+  surface_type = cairo_surface_get_type (surface);
+  if (surface_type != CAIRO_SURFACE_TYPE_XLIB
+      && (surface_type != CAIRO_SURFACE_TYPE_IMAGE
+         || cairo_image_surface_get_format (surface) != CAIRO_FORMAT_ARGB32))
     cairo_surface_flush (surface);
 
   x_end_cr_clip (f);