Tizen 2.0 Release
[framework/graphics/cairo.git] / test / random-intersections-eo.c
1 /*
2  * Copyright © 2006 M Joonas Pihlaja
3  *
4  * Permission is hereby granted, free of charge, to any person
5  * obtaining a copy of this software and associated documentation
6  * files (the "Software"), to deal in the Software without
7  * restriction, including without limitation the rights to use, copy,
8  * modify, merge, publish, distribute, sublicense, and/or sell copies
9  * of the Software, and to permit persons to whom the Software is
10  * furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be
13  * included in all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
19  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
20  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
21  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22  * SOFTWARE.
23  *
24  * Author: M Joonas Pihlaja <jpihlaja@cc.helsinki.fi>
25  */
26 #include "cairo-test.h"
27
28 #define SIZE 512
29 #define NUM_SEGMENTS 128
30
31 static uint32_t state;
32
33 static double
34 uniform_random (double minval, double maxval)
35 {
36     static uint32_t const poly = 0x9a795537U;
37     uint32_t n = 32;
38     while (n-->0)
39         state = 2*state < state ? (2*state ^ poly) : 2*state;
40     return minval + state * (maxval - minval) / 4294967296.0;
41 }
42
43 static cairo_test_status_t
44 draw (cairo_t *cr, int width, int height)
45 {
46     int i;
47
48     cairo_set_source_rgb (cr, 0, 0, 0);
49     cairo_paint (cr);
50
51     state = 0x12345678;
52     cairo_translate (cr, 1, 1);
53     cairo_set_fill_rule (cr, CAIRO_FILL_RULE_EVEN_ODD);
54
55     cairo_move_to (cr, 0, 0);
56     for (i = 0; i < NUM_SEGMENTS; i++) {
57         double x = uniform_random (0, width);
58         double y = uniform_random (0, height);
59         cairo_line_to (cr, x, y);
60     }
61     cairo_close_path (cr);
62
63     cairo_set_source_rgb (cr, 1, 0, 0);
64     cairo_fill_preserve (cr);
65     cairo_set_source_rgb (cr, 0, 1, 0);
66     cairo_set_line_width (cr, 0.5);
67     cairo_stroke (cr);
68
69     return CAIRO_TEST_SUCCESS;
70 }
71
72 CAIRO_TEST (random_intersections_eo,
73             "Tests the tessellator trapezoid generation and intersection computation",
74             "trap", /* keywords */
75             NULL, /* requirements */
76             SIZE+3, SIZE+3,
77             NULL, draw)
78