[glyf] Split off glyf-helpers.hh
This commit is contained in:
parent
7c4b8c9bf4
commit
11d2670676
|
@ -89,6 +89,7 @@ HB_BASE_sources = \
|
||||||
hb-ot-layout-gpos-table.hh \
|
hb-ot-layout-gpos-table.hh \
|
||||||
hb-ot-layout-gsub-table.hh \
|
hb-ot-layout-gsub-table.hh \
|
||||||
OT/glyf/glyf.hh \
|
OT/glyf/glyf.hh \
|
||||||
|
OT/glyf/glyf-helpers.hh \
|
||||||
OT/glyf/loca.hh \
|
OT/glyf/loca.hh \
|
||||||
OT/glyf/path-builder.hh \
|
OT/glyf/path-builder.hh \
|
||||||
OT/glyf/Glyph.hh \
|
OT/glyf/Glyph.hh \
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
#ifndef OT_GLYF_GLYF_HELPERS_HH
|
||||||
|
#define OT_GLYF_GLYF_HELPERS_HH
|
||||||
|
|
||||||
|
|
||||||
|
#include "../../hb-open-type.hh"
|
||||||
|
#include "../../hb-subset-plan.hh"
|
||||||
|
|
||||||
|
#include "loca.hh"
|
||||||
|
|
||||||
|
|
||||||
|
namespace OT {
|
||||||
|
namespace glyf_impl {
|
||||||
|
|
||||||
|
|
||||||
|
template<typename IteratorIn, typename IteratorOut,
|
||||||
|
hb_requires (hb_is_source_of (IteratorIn, unsigned int)),
|
||||||
|
hb_requires (hb_is_sink_of (IteratorOut, unsigned))>
|
||||||
|
static void
|
||||||
|
_write_loca (IteratorIn it, bool short_offsets, IteratorOut dest)
|
||||||
|
{
|
||||||
|
unsigned right_shift = short_offsets ? 1 : 0;
|
||||||
|
unsigned int offset = 0;
|
||||||
|
dest << 0;
|
||||||
|
+ it
|
||||||
|
| hb_map ([=, &offset] (unsigned int padded_size)
|
||||||
|
{
|
||||||
|
offset += padded_size;
|
||||||
|
DEBUG_MSG (SUBSET, nullptr, "loca entry offset %d", offset);
|
||||||
|
return offset >> right_shift;
|
||||||
|
})
|
||||||
|
| hb_sink (dest)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool
|
||||||
|
_add_head_and_set_loca_version (hb_subset_plan_t *plan, bool use_short_loca)
|
||||||
|
{
|
||||||
|
hb_blob_t *head_blob = hb_sanitize_context_t ().reference_table<head> (plan->source);
|
||||||
|
hb_blob_t *head_prime_blob = hb_blob_copy_writable_or_fail (head_blob);
|
||||||
|
hb_blob_destroy (head_blob);
|
||||||
|
|
||||||
|
if (unlikely (!head_prime_blob))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
head *head_prime = (head *) hb_blob_get_data_writable (head_prime_blob, nullptr);
|
||||||
|
head_prime->indexToLocFormat = use_short_loca ? 0 : 1;
|
||||||
|
bool success = plan->add_table (HB_OT_TAG_head, head_prime_blob);
|
||||||
|
|
||||||
|
hb_blob_destroy (head_prime_blob);
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Iterator,
|
||||||
|
hb_requires (hb_is_source_of (Iterator, unsigned int))>
|
||||||
|
static bool
|
||||||
|
_add_loca_and_head (hb_subset_plan_t * plan, Iterator padded_offsets, bool use_short_loca)
|
||||||
|
{
|
||||||
|
unsigned num_offsets = padded_offsets.len () + 1;
|
||||||
|
unsigned entry_size = use_short_loca ? 2 : 4;
|
||||||
|
char *loca_prime_data = (char *) hb_calloc (entry_size, num_offsets);
|
||||||
|
|
||||||
|
if (unlikely (!loca_prime_data)) return false;
|
||||||
|
|
||||||
|
DEBUG_MSG (SUBSET, nullptr, "loca entry_size %d num_offsets %d size %d",
|
||||||
|
entry_size, num_offsets, entry_size * num_offsets);
|
||||||
|
|
||||||
|
if (use_short_loca)
|
||||||
|
_write_loca (padded_offsets, true, hb_array ((HBUINT16 *) loca_prime_data, num_offsets));
|
||||||
|
else
|
||||||
|
_write_loca (padded_offsets, false, hb_array ((HBUINT32 *) loca_prime_data, num_offsets));
|
||||||
|
|
||||||
|
hb_blob_t *loca_blob = hb_blob_create (loca_prime_data,
|
||||||
|
entry_size * num_offsets,
|
||||||
|
HB_MEMORY_MODE_WRITABLE,
|
||||||
|
loca_prime_data,
|
||||||
|
hb_free);
|
||||||
|
|
||||||
|
bool result = plan->add_table (HB_OT_TAG_loca, loca_blob)
|
||||||
|
&& _add_head_and_set_loca_version (plan, use_short_loca);
|
||||||
|
|
||||||
|
hb_blob_destroy (loca_blob);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} /* namespace glyf_impl */
|
||||||
|
} /* namespace OT */
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* OT_GLYF_GLYF_HELPERS_HH */
|
|
@ -8,6 +8,7 @@
|
||||||
#include "../../hb-ot-var-gvar-table.hh"
|
#include "../../hb-ot-var-gvar-table.hh"
|
||||||
#include "../../hb-draw.hh"
|
#include "../../hb-draw.hh"
|
||||||
|
|
||||||
|
#include "glyf-helpers.hh"
|
||||||
#include "Glyph.hh"
|
#include "Glyph.hh"
|
||||||
#include "SubsetGlyph.hh"
|
#include "SubsetGlyph.hh"
|
||||||
#include "loca.hh"
|
#include "loca.hh"
|
||||||
|
@ -37,58 +38,6 @@ struct glyf
|
||||||
return_trace (true);
|
return_trace (true);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename Iterator,
|
|
||||||
hb_requires (hb_is_source_of (Iterator, unsigned int))>
|
|
||||||
static bool
|
|
||||||
_add_loca_and_head (hb_subset_plan_t * plan, Iterator padded_offsets, bool use_short_loca)
|
|
||||||
{
|
|
||||||
unsigned num_offsets = padded_offsets.len () + 1;
|
|
||||||
unsigned entry_size = use_short_loca ? 2 : 4;
|
|
||||||
char *loca_prime_data = (char *) hb_calloc (entry_size, num_offsets);
|
|
||||||
|
|
||||||
if (unlikely (!loca_prime_data)) return false;
|
|
||||||
|
|
||||||
DEBUG_MSG (SUBSET, nullptr, "loca entry_size %d num_offsets %d size %d",
|
|
||||||
entry_size, num_offsets, entry_size * num_offsets);
|
|
||||||
|
|
||||||
if (use_short_loca)
|
|
||||||
_write_loca (padded_offsets, true, hb_array ((HBUINT16 *) loca_prime_data, num_offsets));
|
|
||||||
else
|
|
||||||
_write_loca (padded_offsets, false, hb_array ((HBUINT32 *) loca_prime_data, num_offsets));
|
|
||||||
|
|
||||||
hb_blob_t *loca_blob = hb_blob_create (loca_prime_data,
|
|
||||||
entry_size * num_offsets,
|
|
||||||
HB_MEMORY_MODE_WRITABLE,
|
|
||||||
loca_prime_data,
|
|
||||||
hb_free);
|
|
||||||
|
|
||||||
bool result = plan->add_table (HB_OT_TAG_loca, loca_blob)
|
|
||||||
&& _add_head_and_set_loca_version (plan, use_short_loca);
|
|
||||||
|
|
||||||
hb_blob_destroy (loca_blob);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename IteratorIn, typename IteratorOut,
|
|
||||||
hb_requires (hb_is_source_of (IteratorIn, unsigned int)),
|
|
||||||
hb_requires (hb_is_sink_of (IteratorOut, unsigned))>
|
|
||||||
static void
|
|
||||||
_write_loca (IteratorIn it, bool short_offsets, IteratorOut dest)
|
|
||||||
{
|
|
||||||
unsigned right_shift = short_offsets ? 1 : 0;
|
|
||||||
unsigned int offset = 0;
|
|
||||||
dest << 0;
|
|
||||||
+ it
|
|
||||||
| hb_map ([=, &offset] (unsigned int padded_size)
|
|
||||||
{
|
|
||||||
offset += padded_size;
|
|
||||||
DEBUG_MSG (SUBSET, nullptr, "loca entry offset %d", offset);
|
|
||||||
return offset >> right_shift;
|
|
||||||
})
|
|
||||||
| hb_sink (dest)
|
|
||||||
;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* requires source of SubsetGlyph complains the identifier isn't declared */
|
/* requires source of SubsetGlyph complains the identifier isn't declared */
|
||||||
template <typename Iterator>
|
template <typename Iterator>
|
||||||
bool serialize (hb_serialize_context_t *c,
|
bool serialize (hb_serialize_context_t *c,
|
||||||
|
@ -145,29 +94,11 @@ struct glyf
|
||||||
|
|
||||||
|
|
||||||
if (unlikely (c->serializer->in_error ())) return_trace (false);
|
if (unlikely (c->serializer->in_error ())) return_trace (false);
|
||||||
return_trace (c->serializer->check_success (_add_loca_and_head (c->plan,
|
return_trace (c->serializer->check_success (glyf_impl::_add_loca_and_head (c->plan,
|
||||||
padded_offsets,
|
padded_offsets,
|
||||||
use_short_loca)));
|
use_short_loca)));
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
|
||||||
_add_head_and_set_loca_version (hb_subset_plan_t *plan, bool use_short_loca)
|
|
||||||
{
|
|
||||||
hb_blob_t *head_blob = hb_sanitize_context_t ().reference_table<head> (plan->source);
|
|
||||||
hb_blob_t *head_prime_blob = hb_blob_copy_writable_or_fail (head_blob);
|
|
||||||
hb_blob_destroy (head_blob);
|
|
||||||
|
|
||||||
if (unlikely (!head_prime_blob))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
head *head_prime = (head *) hb_blob_get_data_writable (head_prime_blob, nullptr);
|
|
||||||
head_prime->indexToLocFormat = use_short_loca ? 0 : 1;
|
|
||||||
bool success = plan->add_table (HB_OT_TAG_head, head_prime_blob);
|
|
||||||
|
|
||||||
hb_blob_destroy (head_prime_blob);
|
|
||||||
return success;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
_populate_subset_glyphs (const hb_subset_plan_t *plan,
|
_populate_subset_glyphs (const hb_subset_plan_t *plan,
|
||||||
hb_vector_t<glyf_impl::SubsetGlyph> *glyphs /* OUT */) const;
|
hb_vector_t<glyf_impl::SubsetGlyph> *glyphs /* OUT */) const;
|
||||||
|
|
|
@ -93,6 +93,7 @@ hb_base_sources = files(
|
||||||
'hb-ot-layout-gpos-table.hh',
|
'hb-ot-layout-gpos-table.hh',
|
||||||
'hb-ot-layout-gsub-table.hh',
|
'hb-ot-layout-gsub-table.hh',
|
||||||
'OT/glyf/glyf.hh',
|
'OT/glyf/glyf.hh',
|
||||||
|
'OT/glyf/glyf-helpers.hh',
|
||||||
'OT/glyf/loca.hh',
|
'OT/glyf/loca.hh',
|
||||||
'OT/glyf/path-builder.hh',
|
'OT/glyf/path-builder.hh',
|
||||||
'OT/glyf/Glyph.hh',
|
'OT/glyf/Glyph.hh',
|
||||||
|
|
Loading…
Reference in New Issue