1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
/* -*- Mode: c; c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t; -*- */
/* cairo - a vector graphics library with display and print output
*
* Copyright © 2006 Brian Ewins.
*
* Permission to use, copy, modify, distribute, and sell this software
* and its documentation for any purpose is hereby granted without
* fee, provided that the above copyright notice appear in all copies
* and that both that copyright notice and this permission notice
* appear in supporting documentation, and that the name of
* Brian Ewins not be used in advertising or publicity pertaining to
* distribution of the software without specific, written prior
* permission. Brian Ewins makes no representations about the
* suitability of this software for any purpose. It is provided "as
* is" without express or implied warranty.
*
* BRIAN EWINS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS, IN NO EVENT SHALL BRIAN EWINS BE LIABLE FOR ANY SPECIAL,
* INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
* IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
* Author: Brian Ewins <Brian.Ewins@gmail.com>
*/
/* Related to bug 9530
*
* cairo_glyph_t can contain any unsigned long in its 'index', the intention
* being that it is large enough to hold a pointer. However, this means that
* it can specify many glyph indexes which don't exist in the font, and may
* exceed the range of legal glyph indexes for the font backend. It may
* also contain special values that are not usable as indexes - e.g. 0xffff is
* kATSDeletedGlyphcode in ATSUI, a glyph that should not be drawn.
* The font backends should handle all legal and out-of-range values
* consistently.
*
* This test expects that operations on out-of-range and missing glyphs should
* act as if they were zero-width.
*/
#include "cairo-test.h"
#define WIDTH 100
#define HEIGHT 75
#define NUM_TEXT 20
#define TEXT_SIZE 12
static cairo_test_status_t
draw (cairo_t *cr, int width, int height)
{
cairo_text_extents_t extents;
int i;
/* Glyphs with no paths followed by 'cairo', the additional
* text is to make the space obvious.
*/
long int index[] = {
0, /* 'no matching glyph' */
0xffff, /* kATSDeletedGlyphCode */
0x1ffff, /* out of range */
-1L, /* out of range */
70, 68, 76, 85, 82 /* 'cairo' */
};
/* We draw in the default black, so paint white first. */
cairo_save (cr);
cairo_set_source_rgb (cr, 1.0, 1.0, 1.0); /* white */
cairo_paint (cr);
cairo_restore (cr);
cairo_select_font_face (cr, CAIRO_TEST_FONT_FAMILY " Sans",
CAIRO_FONT_SLANT_NORMAL,
CAIRO_FONT_WEIGHT_NORMAL);
cairo_set_font_size (cr, 16);
for (i = 0; i < 9; i++) {
/* since we're just drawing glyphs directly we need to position them. */
cairo_glyph_t glyph = {
index[i], 10 * i, 25
};
/* test cairo_glyph_extents. Every glyph index should
* have extents, invalid glyphs should be zero-width.
*/
cairo_move_to (cr, glyph.x, glyph.y);
cairo_set_line_width (cr, 1.0);
cairo_glyph_extents (cr, &glyph, 1, &extents);
cairo_rectangle (cr,
glyph.x + extents.x_bearing - 0.5,
glyph.y + extents.y_bearing - 0.5,
extents.width + 1,
extents.height + 1);
cairo_set_source_rgb (cr, 1, 0, 0); /* red */
cairo_stroke (cr);
/* test cairo_show_glyphs. Every glyph index should be
* drawable, invalid glyph indexes should draw nothing.
*/
cairo_set_source_rgb (cr, 0, 0, 0); /* black */
cairo_show_glyphs (cr, &glyph, 1);
cairo_move_to (cr, glyph.x, glyph.y);
/* test cairo_glyph_path. Every glyph index should produce
* a path, invalid glyph indexes should have empty paths.
*/
/* Change the glyph position
* so that the paths are visible.
*/
glyph.y = 55;
cairo_move_to (cr, glyph.x, glyph.y);
cairo_glyph_path (cr, &glyph, 1);
cairo_fill (cr);
}
return CAIRO_TEST_SUCCESS;
}
CAIRO_TEST (text_glyph_range,
"Tests show_glyphs, glyph_path, glyph_extents with out of range glyph ids."
"\nft and atsui font backends fail, misreporting errors from FT_Load_Glyph and ATSUGlyphGetCubicPaths",
"text, stress", /* keywords */
NULL, /* requirements */
WIDTH, HEIGHT,
NULL, draw)
|