[cairo-commit] cairo/test fill_rule-ref.png, 1.1, 1.2 fill_rule.c,
1.1, 1.2
Carl Worth
commit at pdx.freedesktop.org
Wed Jan 12 14:38:24 PST 2005
- Previous message: [cairo-commit] pycairo RELEASING,1.4,1.5
- Next message: [cairo-commit] cairo BUGS, 1.22, 1.23 ChangeLog, 1.297, 1.298 TODO,
1.27, 1.28 cairo.pc.in, 1.17, 1.18
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Committed by: cworth
Update of /cvs/cairo/cairo/test
In directory gabe:/tmp/cvs-serv4754
Modified Files:
fill_rule-ref.png fill_rule.c
Log Message:
* test/fill_rule.c: Add big_star_path which shows we still have
fill bugs, (even now that little_star_path is working).
Index: fill_rule-ref.png
===================================================================
RCS file: /cvs/cairo/cairo/test/fill_rule-ref.png,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -d -r1.1 -r1.2
Binary files /tmp/cvsYOa4QF and /tmp/cvsGMzbp2 differ
Index: fill_rule.c
===================================================================
RCS file: /cvs/cairo/cairo/test/fill_rule.c,v
retrieving revision 1.1
retrieving revision 1.2
diff -u -d -r1.1 -r1.2
--- fill_rule.c 27 Oct 2004 17:48:58 -0000 1.1
+++ fill_rule.c 12 Jan 2005 22:38:22 -0000 1.2
@@ -42,22 +42,39 @@
* planning on doing the new tessellator which should fix this
* problem.
*
+ * 2005-01-11 Carl Worth <cworth at cworth.org>
+ *
+ * Keith committed some fixes that fix the original size-20
+ * star_path:
+ *
+ * * src/cairo_wideint.c: (_cairo_int32x32_64_mul),
+ * (_cairo_int64x64_128_mul):
+ * * src/cairo_wideint.h:
+ * int32x32_64_mul and int64x64_128_mul are different from their
+ * unsigned compatriots
+ *
+ * 2005-01-12 Carl Worth <cworth at cworth.org>
+ *
+ * Going back to the SVG test suite, however, the original star
+ * shape is still broken. Adding both shapes now as little_star_path
+ * and big_star_path.
+ *
*/
#include "cairo_test.h"
-#define STAR_SIZE 20
+#define LITTLE_STAR_SIZE 20
+#define BIG_STAR_SIZE 80
cairo_test_t test = {
"fill_rule",
- "Tests cairo_set_full_rule with a star shape",
- STAR_SIZE * 2 + 3, STAR_SIZE +2
+ "Tests cairo_set_full_rule with some star shapes",
+ BIG_STAR_SIZE * 2 + 3, BIG_STAR_SIZE + LITTLE_STAR_SIZE + 3
};
-
-/* Not a perfect star, but one that does show the tessellation bug. */
+/* The SVG start trimmed down, but still showing the bug (originally) */
static void
-star_path (cairo_t *cr)
+little_star_path (cairo_t *cr)
{
cairo_move_to (cr, 10, 0);
cairo_rel_line_to (cr, 6, 20);
@@ -66,6 +83,19 @@
cairo_rel_line_to (cr, -16, 12);
}
+/* The star shape from the SVG test suite. This was is still buggy even after
+ we got little_star_path working. */
+static void
+big_star_path (cairo_t *cr)
+{
+ cairo_move_to (cr, 40, 0);
+ cairo_rel_line_to (cr, 25, 80);
+ cairo_rel_line_to (cr, -65, -50);
+ cairo_rel_line_to (cr, 80, 0);
+ cairo_rel_line_to (cr, -65, 50);
+ cairo_close_path (cr);
+}
+
/* Fill the same path twice, once with each fill rule */
static void
draw (cairo_t *cr, int width, int height)
@@ -73,12 +103,22 @@
cairo_set_rgb_color (cr, 1, 0, 0);
cairo_translate (cr, 1, 1);
- star_path (cr);
+ little_star_path (cr);
cairo_set_fill_rule (cr, CAIRO_FILL_RULE_WINDING);
cairo_fill (cr);
- cairo_translate (cr, STAR_SIZE + 1, 0);
- star_path (cr);
+ cairo_translate (cr, LITTLE_STAR_SIZE + 1, 0);
+ little_star_path (cr);
+ cairo_set_fill_rule (cr, CAIRO_FILL_RULE_EVEN_ODD);
+ cairo_fill (cr);
+
+ cairo_translate (cr, -(LITTLE_STAR_SIZE + 1), LITTLE_STAR_SIZE + 1);
+ big_star_path (cr);
+ cairo_set_fill_rule (cr, CAIRO_FILL_RULE_WINDING);
+ cairo_fill (cr);
+
+ cairo_translate (cr, BIG_STAR_SIZE + 1, 0);
+ big_star_path (cr);
cairo_set_fill_rule (cr, CAIRO_FILL_RULE_EVEN_ODD);
cairo_fill (cr);
}
- Previous message: [cairo-commit] pycairo RELEASING,1.4,1.5
- Next message: [cairo-commit] cairo BUGS, 1.22, 1.23 ChangeLog, 1.297, 1.298 TODO,
1.27, 1.28 cairo.pc.in, 1.17, 1.18
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the cairo-commit
mailing list