50352
|
1 |
/*
|
|
2 |
* Copyright © 2018 Google, Inc.
|
|
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 |
* Google Author(s): Garret Rieger, Roderick Sheeter
|
|
25 |
*/
|
|
26 |
|
|
27 |
#ifndef HB_SUBSET_PLAN_HH
|
|
28 |
#define HB_SUBSET_PLAN_HH
|
|
29 |
|
|
30 |
#include "hb-private.hh"
|
|
31 |
|
|
32 |
#include "hb-subset.h"
|
50826
|
33 |
#include "hb-subset-private.hh"
|
50352
|
34 |
|
|
35 |
#include "hb-object-private.hh"
|
50826
|
36 |
#include "hb-map-private.hh"
|
50352
|
37 |
|
50826
|
38 |
struct hb_subset_plan_t
|
|
39 |
{
|
50352
|
40 |
hb_object_header_t header;
|
|
41 |
ASSERT_POD ();
|
|
42 |
|
|
43 |
hb_bool_t drop_hints;
|
50826
|
44 |
hb_bool_t drop_ot_layout;
|
50352
|
45 |
|
50826
|
46 |
// For each cp that we'd like to retain maps to the corresponding gid.
|
|
47 |
hb_set_t *unicodes;
|
50352
|
48 |
|
|
49 |
// This list contains the complete set of glyphs to retain and may contain
|
|
50 |
// more glyphs then the lists above.
|
50826
|
51 |
hb_vector_t<hb_codepoint_t> glyphs;
|
|
52 |
|
|
53 |
hb_map_t *codepoint_to_glyph;
|
|
54 |
hb_map_t *glyph_map;
|
50352
|
55 |
|
|
56 |
// Plan is only good for a specific source/dest so keep them with it
|
|
57 |
hb_face_t *source;
|
|
58 |
hb_face_t *dest;
|
50826
|
59 |
|
|
60 |
inline hb_bool_t
|
|
61 |
new_gid_for_codepoint (hb_codepoint_t codepoint,
|
|
62 |
hb_codepoint_t *new_gid) const
|
|
63 |
{
|
|
64 |
hb_codepoint_t old_gid = codepoint_to_glyph->get (codepoint);
|
|
65 |
if (old_gid == HB_MAP_VALUE_INVALID)
|
|
66 |
return false;
|
|
67 |
|
|
68 |
return new_gid_for_old_gid (old_gid, new_gid);
|
|
69 |
}
|
|
70 |
|
|
71 |
inline hb_bool_t
|
|
72 |
new_gid_for_old_gid (hb_codepoint_t old_gid,
|
|
73 |
hb_codepoint_t *new_gid) const
|
|
74 |
{
|
|
75 |
hb_codepoint_t gid = glyph_map->get (old_gid);
|
|
76 |
if (gid == HB_MAP_VALUE_INVALID)
|
|
77 |
return false;
|
|
78 |
|
|
79 |
*new_gid = gid;
|
|
80 |
return true;
|
|
81 |
}
|
|
82 |
|
|
83 |
inline hb_bool_t
|
|
84 |
add_table (hb_tag_t tag,
|
|
85 |
hb_blob_t *contents)
|
|
86 |
{
|
|
87 |
hb_blob_t *source_blob = source->reference_table (tag);
|
|
88 |
DEBUG_MSG(SUBSET, nullptr, "add table %c%c%c%c, dest %d bytes, source %d bytes",
|
|
89 |
HB_UNTAG(tag),
|
|
90 |
hb_blob_get_length (contents),
|
|
91 |
hb_blob_get_length (source_blob));
|
|
92 |
hb_blob_destroy (source_blob);
|
|
93 |
return hb_subset_face_add_table(dest, tag, contents);
|
|
94 |
}
|
50352
|
95 |
};
|
|
96 |
|
|
97 |
typedef struct hb_subset_plan_t hb_subset_plan_t;
|
|
98 |
|
|
99 |
HB_INTERNAL hb_subset_plan_t *
|
|
100 |
hb_subset_plan_create (hb_face_t *face,
|
|
101 |
hb_subset_profile_t *profile,
|
|
102 |
hb_subset_input_t *input);
|
|
103 |
|
|
104 |
HB_INTERNAL void
|
|
105 |
hb_subset_plan_destroy (hb_subset_plan_t *plan);
|
|
106 |
|
|
107 |
#endif /* HB_SUBSET_PLAN_HH */
|