1 | /* |
2 | * Copyright © 2018 Ebrahim Byagowi |
3 | * |
4 | * This is part of HarfBuzz, a text shaping library. |
5 | * |
6 | * Permission is hereby granted, without written agreement and without |
7 | * license or royalty fees, to use, copy, modify, and distribute this |
8 | * software and its documentation for any purpose, provided that the |
9 | * above copyright notice and the following two paragraphs appear in |
10 | * all copies of this software. |
11 | * |
12 | * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR |
13 | * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES |
14 | * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN |
15 | * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH |
16 | * DAMAGE. |
17 | * |
18 | * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, |
19 | * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND |
20 | * FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS |
21 | * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO |
22 | * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. |
23 | */ |
24 | |
25 | #ifndef HB_AAT_LAYOUT_BSLN_TABLE_HH |
26 | #define HB_AAT_LAYOUT_BSLN_TABLE_HH |
27 | |
28 | #include "hb-aat-layout-common.hh" |
29 | |
30 | /* |
31 | * bsln -- Baseline |
32 | * https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6bsln.html |
33 | */ |
34 | #define HB_AAT_TAG_bsln HB_TAG('b','s','l','n') |
35 | |
36 | |
37 | namespace AAT { |
38 | |
39 | |
40 | struct BaselineTableFormat0Part |
41 | { |
42 | bool sanitize (hb_sanitize_context_t *c) const |
43 | { |
44 | TRACE_SANITIZE (this); |
45 | return_trace (likely (c->check_struct (this))); |
46 | } |
47 | |
48 | protected: |
49 | // Roman, Ideographic centered, Ideographic low, Hanging and Math |
50 | // are the default defined ones, but any other maybe accessed also. |
51 | HBINT16 deltas[32]; /* These are the FUnit distance deltas from |
52 | * the font's natural baseline to the other |
53 | * baselines used in the font. */ |
54 | public: |
55 | DEFINE_SIZE_STATIC (64); |
56 | }; |
57 | |
58 | struct BaselineTableFormat1Part |
59 | { |
60 | bool sanitize (hb_sanitize_context_t *c) const |
61 | { |
62 | TRACE_SANITIZE (this); |
63 | return_trace (likely (c->check_struct (this) && |
64 | lookupTable.sanitize (c))); |
65 | } |
66 | |
67 | protected: |
68 | HBINT16 deltas[32]; /* ditto */ |
69 | Lookup<HBUINT16> |
70 | lookupTable; /* Lookup table that maps glyphs to their |
71 | * baseline values. */ |
72 | public: |
73 | DEFINE_SIZE_MIN (66); |
74 | }; |
75 | |
76 | struct BaselineTableFormat2Part |
77 | { |
78 | bool sanitize (hb_sanitize_context_t *c) const |
79 | { |
80 | TRACE_SANITIZE (this); |
81 | return_trace (likely (c->check_struct (this))); |
82 | } |
83 | |
84 | protected: |
85 | HBGlyphID stdGlyph; /* The specific glyph index number in this |
86 | * font that is used to set the baseline values. |
87 | * This is the standard glyph. |
88 | * This glyph must contain a set of control points |
89 | * (whose numbers are contained in the ctlPoints field) |
90 | * that are used to determine baseline distances. */ |
91 | HBUINT16 ctlPoints[32]; /* Set of control point numbers, |
92 | * associated with the standard glyph. |
93 | * A value of 0xFFFF means there is no corresponding |
94 | * control point in the standard glyph. */ |
95 | public: |
96 | DEFINE_SIZE_STATIC (66); |
97 | }; |
98 | |
99 | struct BaselineTableFormat3Part |
100 | { |
101 | bool sanitize (hb_sanitize_context_t *c) const |
102 | { |
103 | TRACE_SANITIZE (this); |
104 | return_trace (likely (c->check_struct (this) && lookupTable.sanitize (c))); |
105 | } |
106 | |
107 | protected: |
108 | HBGlyphID stdGlyph; /* ditto */ |
109 | HBUINT16 ctlPoints[32]; /* ditto */ |
110 | Lookup<HBUINT16> |
111 | lookupTable; /* Lookup table that maps glyphs to their |
112 | * baseline values. */ |
113 | public: |
114 | DEFINE_SIZE_MIN (68); |
115 | }; |
116 | |
117 | struct bsln |
118 | { |
119 | static constexpr hb_tag_t tableTag = HB_AAT_TAG_bsln; |
120 | |
121 | bool sanitize (hb_sanitize_context_t *c) const |
122 | { |
123 | TRACE_SANITIZE (this); |
124 | if (unlikely (!(c->check_struct (this) && defaultBaseline < 32))) |
125 | return_trace (false); |
126 | |
127 | switch (format) |
128 | { |
129 | case 0: return_trace (parts.format0.sanitize (c)); |
130 | case 1: return_trace (parts.format1.sanitize (c)); |
131 | case 2: return_trace (parts.format2.sanitize (c)); |
132 | case 3: return_trace (parts.format3.sanitize (c)); |
133 | default:return_trace (true); |
134 | } |
135 | } |
136 | |
137 | protected: |
138 | FixedVersion<>version; /* Version number of the Baseline table. */ |
139 | HBUINT16 format; /* Format of the baseline table. Only one baseline |
140 | * format may be selected for the font. */ |
141 | HBUINT16 defaultBaseline;/* Default baseline value for all glyphs. |
142 | * This value can be from 0 through 31. */ |
143 | union { |
144 | // Distance-Based Formats |
145 | BaselineTableFormat0Part format0; |
146 | BaselineTableFormat1Part format1; |
147 | // Control Point-based Formats |
148 | BaselineTableFormat2Part format2; |
149 | BaselineTableFormat3Part format3; |
150 | } parts; |
151 | public: |
152 | DEFINE_SIZE_MIN (8); |
153 | }; |
154 | |
155 | } /* namespace AAT */ |
156 | |
157 | |
158 | #endif /* HB_AAT_LAYOUT_BSLN_TABLE_HH */ |
159 | |