[cairo-commit] 2 commits - src/cairo-pattern.c test/gradient-zero-stops-mask.argb32.ref.png test/gradient-zero-stops-mask.c test/gradient-zero-stops-mask.rgb24.ref.png test/Makefile.am test/Makefile.sources

Andrea Canciani ranma42 at kemper.freedesktop.org
Wed Mar 31 03:53:01 PDT 2010


 src/cairo-pattern.c                          |    3 +
 test/Makefile.am                             |    2 
 test/Makefile.sources                        |    1 
 test/gradient-zero-stops-mask.argb32.ref.png |binary
 test/gradient-zero-stops-mask.c              |   59 +++++++++++++++++++++++++++
 test/gradient-zero-stops-mask.rgb24.ref.png  |binary
 6 files changed, 65 insertions(+)

New commits:
commit 35f19bc084792bbad42b86a399103ebfbf407d05
Author: Andrea Canciani <ranma42 at gmail.com>
Date:   Wed Mar 31 12:18:01 2010 +0200

    pattern: Fix _gradient_is_opaque() for zero stops
    
    _gradient_is_opaque() previously returned TRUE for gradient with
    no stops, triggering a false optimization in _cairo_gstate_mask().
    
    Fixes test/gradient-zero-stops-mask
    
    Reviewed-by: Chris Wilson <chris at chris-wilson.co.uk>

diff --git a/src/cairo-pattern.c b/src/cairo-pattern.c
index a1c8162..8ae4b81 100644
--- a/src/cairo-pattern.c
+++ b/src/cairo-pattern.c
@@ -1795,6 +1795,9 @@ _gradient_is_opaque (const cairo_gradient_pattern_t *gradient)
 {
     unsigned int i;
 
+    if (gradient->n_stops == 0)
+	return FALSE;
+
     for (i = 0; i < gradient->n_stops; i++)
 	if (! CAIRO_COLOR_IS_OPAQUE (&gradient->stops[i].color))
 	    return FALSE;
commit 01e182194224e0eb7493b2ae3c8367ed455cfd54
Author: Andrea Canciani <ranma42 at gmail.com>
Date:   Wed Mar 31 12:14:25 2010 +0200

    test: Add gradient-zero-stops-mask
    
    Add a test to check that gradient with no stops are not considered
    opaque by gstate (and thus masking with them is not optimized to
    paint).

diff --git a/test/Makefile.am b/test/Makefile.am
index 7d4e70a..62c36ba 100644
--- a/test/Makefile.am
+++ b/test/Makefile.am
@@ -540,6 +540,8 @@ REFERENCE_IMAGES = \
 	gradient-constant-alpha.rgb24.ref.png \
 	gradient-zero-stops.ref.png \
 	gradient-zero-stops.rgb24.ref.png \
+	gradient-zero-stops-mask.argb32.ref.png \
+	gradient-zero-stops-mask.rgb24.ref.png \
 	group-clip.ref.png \
 	group-paint.ref.png \
 	group-unaligned.pdf.new.png \
diff --git a/test/Makefile.sources b/test/Makefile.sources
index bef7529..2397824 100644
--- a/test/Makefile.sources
+++ b/test/Makefile.sources
@@ -106,6 +106,7 @@ test_sources = \
 	gradient-alpha.c				\
 	gradient-constant-alpha.c			\
 	gradient-zero-stops.c				\
+	gradient-zero-stops-mask.c			\
 	group-clip.c					\
 	group-paint.c					\
 	group-unaligned.c				\
diff --git a/test/gradient-zero-stops-mask.argb32.ref.png b/test/gradient-zero-stops-mask.argb32.ref.png
new file mode 100644
index 0000000..0a50f4c
Binary files /dev/null and b/test/gradient-zero-stops-mask.argb32.ref.png differ
diff --git a/test/gradient-zero-stops-mask.c b/test/gradient-zero-stops-mask.c
new file mode 100644
index 0000000..b2a10ec
--- /dev/null
+++ b/test/gradient-zero-stops-mask.c
@@ -0,0 +1,59 @@
+/* -*- Mode: c; c-basic-offset: 4; indent-tabs-mode: t; tab-width: 8; -*- */
+/*
+ * Copyright © 2007 Brian Ewins
+ *
+ * Permission is hereby granted, free of charge, to any person
+ * obtaining a copy of this software and associated documentation
+ * files (the "Software"), to deal in the Software without
+ * restriction, including without limitation the rights to use, copy,
+ * modify, merge, publish, distribute, sublicense, and/or sell copies
+ * of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be
+ * included in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
+ * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+ * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ *
+ * Author: Brian Ewins <Brian.Ewins at gmail.com>
+ * Contributor(s):
+ *      Andrea Canciani <ranma42 at gmail.com>
+ */
+
+#include "cairo-test.h"
+
+/* This test case is designed to exercise the opaque test for
+ * gradients with no stop.
+ */
+
+static cairo_test_status_t
+draw (cairo_t *cr, int width, int height)
+{
+    cairo_pattern_t *pat;
+
+    cairo_set_source_rgb (cr, 1., 0., 0.);
+
+    pat = cairo_pattern_create_linear (0., 0., 1., 1.);
+    cairo_mask (cr, pat);
+    cairo_pattern_destroy (pat);
+
+    pat = cairo_pattern_create_radial (0., 0., 0., 1., 1., 1.);
+    cairo_mask (cr, pat);
+    cairo_pattern_destroy (pat);
+
+    return CAIRO_TEST_SUCCESS;
+}
+
+CAIRO_TEST (gradient_zero_stops_mask,
+	    "Verifies that gradients with no stops are considered clear.",
+	    "gradient", /* keywords */
+	    NULL, /* requirements */
+	    2, 2,
+	    NULL, draw)
diff --git a/test/gradient-zero-stops-mask.rgb24.ref.png b/test/gradient-zero-stops-mask.rgb24.ref.png
new file mode 100644
index 0000000..21465ce
Binary files /dev/null and b/test/gradient-zero-stops-mask.rgb24.ref.png differ


More information about the cairo-commit mailing list