summaryrefslogtreecommitdiff
path: root/test/ft-font-create-for-ft-face.c
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2009-05-15 20:37:52 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2009-05-15 21:31:03 +0100
commitc897f36a6b09f3591d858142e3236f256f0bd6a2 (patch)
tree35a76e6b47075f418e077a52e8f723f6647e5a7c /test/ft-font-create-for-ft-face.c
parent477df1f5504a507d0c5960aa7e21375284a6f99c (diff)
downloadcairo-c897f36a6b09f3591d858142e3236f256f0bd6a2.tar.gz
[test] Stress the ft from-face cache
Create a set of font faces using the same FT_Face to stress test the handling of from-face fonts within the backend cache.
Diffstat (limited to 'test/ft-font-create-for-ft-face.c')
-rw-r--r--test/ft-font-create-for-ft-face.c109
1 files changed, 102 insertions, 7 deletions
diff --git a/test/ft-font-create-for-ft-face.c b/test/ft-font-create-for-ft-face.c
index 702b846a9..52c838dd4 100644
--- a/test/ft-font-create-for-ft-face.c
+++ b/test/ft-font-create-for-ft-face.c
@@ -26,6 +26,84 @@
#include "cairo-test.h"
#include <cairo-ft.h>
+static void
+_stress_font_cache (FT_Face ft_face, cairo_t *cr, int lvl);
+
+static cairo_font_face_t *
+_load_font (FT_Face ft_face, int flags, cairo_t *cr, int lvl)
+{
+ cairo_font_face_t *font_face;
+ cairo_font_extents_t font_extents;
+
+ _stress_font_cache (ft_face, cr, lvl+1);
+
+ font_face = cairo_ft_font_face_create_for_ft_face (ft_face, flags);
+
+ cairo_set_font_face (cr, font_face);
+ cairo_font_extents (cr, &font_extents);
+
+ _stress_font_cache (ft_face, cr, lvl+1);
+
+ return font_face;
+}
+
+static void
+_stress_font_cache (FT_Face ft_face, cairo_t *cr, int lvl)
+{
+#define A _load_font (ft_face, 0, cr, lvl)
+#define B _load_font (ft_face, FT_LOAD_NO_BITMAP, cr, lvl)
+#define C _load_font (ft_face, FT_LOAD_NO_RECURSE, cr, lvl)
+#define D _load_font (ft_face, FT_LOAD_FORCE_AUTOHINT, cr, lvl)
+
+ cairo_font_face_t *font_face[4];
+
+ while (lvl++ < 5) {
+ font_face[0] = A; font_face[1] = A;
+ font_face[2] = A; font_face[3] = A;
+ cairo_font_face_destroy (font_face[0]);
+ cairo_font_face_destroy (font_face[1]);
+ cairo_font_face_destroy (font_face[2]);
+ cairo_font_face_destroy (font_face[3]);
+
+ font_face[0] = A; font_face[1] = B;
+ font_face[2] = C; font_face[3] = D;
+ cairo_font_face_destroy (font_face[0]);
+ cairo_font_face_destroy (font_face[1]);
+ cairo_font_face_destroy (font_face[2]);
+ cairo_font_face_destroy (font_face[3]);
+
+ font_face[0] = A; font_face[1] = B;
+ font_face[2] = C; font_face[3] = D;
+ cairo_font_face_destroy (font_face[3]);
+ cairo_font_face_destroy (font_face[2]);
+ cairo_font_face_destroy (font_face[1]);
+ cairo_font_face_destroy (font_face[0]);
+
+ font_face[0] = A;
+ font_face[1] = A;
+ cairo_font_face_destroy (font_face[0]);
+ font_face[2] = A;
+ cairo_font_face_destroy (font_face[1]);
+ font_face[3] = A;
+ cairo_font_face_destroy (font_face[2]);
+ cairo_font_face_destroy (font_face[3]);
+
+ font_face[0] = A;
+ font_face[1] = B;
+ cairo_font_face_destroy (font_face[0]);
+ font_face[2] = C;
+ cairo_font_face_destroy (font_face[1]);
+ font_face[3] = D;
+ cairo_font_face_destroy (font_face[2]);
+ cairo_font_face_destroy (font_face[3]);
+ }
+
+#undef A
+#undef B
+#undef C
+#undef D
+}
+
static cairo_test_status_t
draw (cairo_t *cr, int width, int height)
{
@@ -48,23 +126,31 @@ draw (cairo_t *cr, int width, int height)
pattern = FcPatternCreate ();
if (! pattern) {
cairo_test_log (ctx, "FcPatternCreate failed.\n");
- return CAIRO_TEST_FAILURE;
+ return cairo_test_status_from_status (ctx, CAIRO_STATUS_NO_MEMORY);
}
FcConfigSubstitute (NULL, pattern, FcMatchPattern);
FcDefaultSubstitute (pattern);
resolved = FcFontMatch (NULL, pattern, &result);
if (! resolved) {
+ FcPatternDestroy (pattern);
cairo_test_log (ctx, "FcFontMatch failed.\n");
- return CAIRO_TEST_FAILURE;
+ return cairo_test_status_from_status (ctx, CAIRO_STATUS_NO_MEMORY);
}
font_face = cairo_ft_font_face_create_for_pattern (resolved);
+ if (cairo_font_face_status (font_face)) {
+ FcPatternDestroy (resolved);
+ FcPatternDestroy (pattern);
+ return cairo_test_status_from_status (ctx, cairo_font_face_status (font_face));
+ }
if (cairo_font_face_get_type (font_face) != CAIRO_FONT_TYPE_FT) {
cairo_test_log (ctx, "Unexpected value from cairo_font_face_get_type: %d (expected %d)\n",
cairo_font_face_get_type (font_face), CAIRO_FONT_TYPE_FT);
cairo_font_face_destroy (font_face);
+ FcPatternDestroy (resolved);
+ FcPatternDestroy (pattern);
return CAIRO_TEST_FAILURE;
}
@@ -81,13 +167,16 @@ draw (cairo_t *cr, int width, int height)
&ctm,
font_options);
- ft_face = cairo_ft_scaled_font_lock_face (scaled_font);
-
cairo_font_options_destroy (font_options);
cairo_font_face_destroy (font_face);
FcPatternDestroy (pattern);
FcPatternDestroy (resolved);
+ if (cairo_scaled_font_status (scaled_font)) {
+ return cairo_test_status_from_status (ctx,
+ cairo_scaled_font_status (scaled_font));
+ }
+
if (cairo_scaled_font_get_type (scaled_font) != CAIRO_FONT_TYPE_FT) {
cairo_test_log (ctx, "Unexpected value from cairo_scaled_font_get_type: %d (expected %d)\n",
cairo_scaled_font_get_type (scaled_font), CAIRO_FONT_TYPE_FT);
@@ -95,7 +184,8 @@ draw (cairo_t *cr, int width, int height)
return CAIRO_TEST_FAILURE;
}
- if (!ft_face) {
+ ft_face = cairo_ft_scaled_font_lock_face (scaled_font);
+ if (ft_face == NULL) {
cairo_test_log (ctx, "Failed to get an ft_face with cairo_ft_scaled_font_lock_face\n");
cairo_scaled_font_destroy (scaled_font);
return CAIRO_TEST_FAILURE;
@@ -107,13 +197,18 @@ draw (cairo_t *cr, int width, int height)
*
* Now, on to the simple thing we actually want to test.
*/
- font_face = cairo_ft_font_face_create_for_ft_face (ft_face, 0);
+
+ cairo_save (cr);
+
+ /* First we want to test caching behaviour */
+ _stress_font_cache (ft_face, cr, 0);
/* Set the font_face and force cairo to actually use it for
* something. */
- cairo_save (cr);
+ font_face = cairo_ft_font_face_create_for_ft_face (ft_face, 0);
cairo_set_font_face (cr, font_face);
cairo_font_extents (cr, &font_extents);
+
cairo_restore (cr);
/* Finally, even more cleanup */