mirror of
https://gitlab.freedesktop.org/cairo/cairo.git
synced 2025-12-21 19:10:10 +01:00
By ensuring that tests take longer than a couple of seconds we eliminate systematic errors in our measurements. However, we also effectively eliminate the synchronisation overhead. To compensate, we attempt to estimate the overhead by reporting the difference between a single instance and the minimum averaged instance.
56 lines
1.1 KiB
C
56 lines
1.1 KiB
C
#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"))
|
|
return;
|
|
|
|
cairo_perf_run (perf, "twin", do_twin);
|
|
}
|