summaryrefslogtreecommitdiff
path: root/perf/micro/twin.c
diff options
context:
space:
mode:
Diffstat (limited to 'perf/micro/twin.c')
-rw-r--r--perf/micro/twin.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/perf/micro/twin.c b/perf/micro/twin.c
new file mode 100644
index 00000000..b2c37a25
--- /dev/null
+++ b/perf/micro/twin.c
@@ -0,0 +1,56 @@
+#define WIDTH 1350
+#define HEIGHT 900
+
+#include "cairo-perf.h"
+
+static cairo_perf_ticks_t
+do_twin (cairo_t *cr,
+ int width,
+ int height,
+ int loops)
+{
+ int i, j, h;
+ unsigned char s[2] = {0, 0};
+
+ cairo_set_source_rgb (cr, 1.0, 1.0, 1.0); /* white */
+ cairo_paint (cr);
+ cairo_set_source_rgb (cr, 0, 0, 0);
+
+ cairo_select_font_face (cr,
+ "@cairo:",
+ CAIRO_FONT_SLANT_NORMAL,
+ CAIRO_FONT_WEIGHT_NORMAL);
+
+ cairo_perf_timer_start ();
+
+ while (loops--) {
+ h = 2;
+ for (i = 8; i < 48; i >= 24 ? i+=3 : i++) {
+ cairo_set_font_size (cr, i);
+ for (j = 33; j < 128; j++) {
+ if (j == 33 || (j == 80 && i > 24)) {
+ h += i + 2;
+ cairo_move_to (cr, 10, h);
+ }
+ s[0] = j;
+ cairo_text_path (cr, (const char *) s);
+ }
+ }
+ cairo_fill (cr);
+ }
+
+ cairo_perf_timer_stop ();
+ return cairo_perf_timer_elapsed ();
+}
+
+void
+twin (cairo_perf_t *perf,
+ cairo_t *cr,
+ int width,
+ int height)
+{
+ if (! cairo_perf_can_run (perf, "twin", NULL))
+ return;
+
+ cairo_perf_run (perf, "twin", do_twin);
+}