colorscale: Don't free surface data before surface
authorBenjamin Otte <otte@redhat.com>
Sun, 25 Mar 2018 20:37:09 +0000 (22:37 +0200)
committerBenjamin Otte <otte@redhat.com>
Sun, 25 Mar 2018 20:38:42 +0000 (22:38 +0200)
When drawing onto a recording surface, source surfaces get cached.

But if we g_free() the surface data after we're done, that cache is
gonna point at invalid data...

gtk/gtkcolorscale.c

index 928addb165f7d96db50aaf3c0cc545be14b88a13..0683924dd704307c80796ab1e7b7735266bb3cb3 100644 (file)
@@ -90,9 +90,10 @@ gtk_color_scale_snapshot_trough (GtkColorScale  *scale,
       gdouble f;
       int hue_x, hue_y;
 
-      stride = cairo_format_stride_for_width (CAIRO_FORMAT_RGB24, width);
-
-      data = g_malloc (height * stride);
+      tmp = cairo_image_surface_create (CAIRO_FORMAT_RGB24,
+                                        width, height);
+      stride = cairo_image_surface_get_stride (tmp);
+      data = (guint32* )cairo_image_surface_get_data (tmp);
 
       f = 1.0 / (height - 1);
       for (hue_y = 0; hue_y < height; hue_y++)
@@ -105,18 +106,16 @@ gtk_color_scale_snapshot_trough (GtkColorScale  *scale,
               red = CLAMP (r * 255, 0, 255);
               green = CLAMP (g * 255, 0, 255);
               blue = CLAMP (b * 255, 0, 255);
-              p[hue_x] = (red << 16) | (green << 8) | blue;
+              p[hue_x] = 0xFF000000 | (red << 16) | (green << 8) | blue;
             }
         }
 
-      tmp = cairo_image_surface_create_for_data ((guchar *)data, CAIRO_FORMAT_RGB24,
-                                                 width, height, stride);
+      cairo_surface_mark_dirty (tmp);
 
       cairo_set_source_surface (cr, tmp, 0, 0);
       cairo_paint (cr);
 
       cairo_surface_destroy (tmp);
-      g_free (data);
     }
   else if (scale->priv->type == GTK_COLOR_SCALE_ALPHA)
     {