harfbuzz/src/hb-ot-shape-normalize.cc

95 lines
2.5 KiB
C++
Raw Normal View History

2011-07-21 06:51:18 +02:00
/*
* Copyright © 2011 Google, Inc.
*
* This is part of HarfBuzz, a text shaping library.
*
* Permission is hereby granted, without written agreement and without
* license or royalty fees, to use, copy, modify, and distribute this
* software and its documentation for any purpose, provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software.
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*
* Google Author(s): Behdad Esfahbod
*/
#include "hb-ot-shape-private.hh"
HB_BEGIN_DECLS
2011-07-21 17:31:08 +02:00
static bool
get_glyph (hb_ot_shape_context_t *c, unsigned int i)
2011-07-21 06:51:18 +02:00
{
hb_buffer_t *b = c->buffer;
hb_codepoint_t glyph;
2011-07-21 06:51:18 +02:00
return hb_font_get_glyph (c->font, b->info[i].codepoint, 0, &glyph);
2011-07-21 17:31:08 +02:00
}
2011-07-21 18:16:45 +02:00
static bool
decompose_single_char_cluster (hb_ot_shape_context_t *c,
unsigned int i)
{
return FALSE;
}
2011-07-21 17:31:08 +02:00
static bool
handle_single_char_cluster (hb_ot_shape_context_t *c,
unsigned int i)
{
2011-07-21 18:16:45 +02:00
/* If the single char is supported by the font, we're good. */
2011-07-21 17:31:08 +02:00
if (get_glyph (c, i))
return FALSE;
2011-07-21 06:51:18 +02:00
/* Decompose */
2011-07-21 18:16:45 +02:00
return decompose_single_char_cluster (c, i);
2011-07-21 06:51:18 +02:00
}
2011-07-21 17:31:08 +02:00
static bool
2011-07-21 06:51:18 +02:00
handle_multi_char_cluster (hb_ot_shape_context_t *c,
2011-07-21 18:16:45 +02:00
unsigned int start,
2011-07-21 06:51:18 +02:00
unsigned int end)
{
/* If there's a variation-selector, give-up, it's just too hard. */
2011-07-21 18:16:45 +02:00
for (unsigned int i = start; i < end; i++)
if (unlikely (is_variation_selector (c->buffer->info[i].codepoint)))
return FALSE;
2011-07-21 17:31:08 +02:00
return FALSE;
2011-07-21 06:51:18 +02:00
}
2011-07-21 17:31:08 +02:00
bool
2011-07-21 06:51:18 +02:00
_hb_normalize (hb_ot_shape_context_t *c)
{
hb_buffer_t *b = c->buffer;
2011-07-21 17:31:08 +02:00
bool changed = FALSE;
2011-07-21 06:51:18 +02:00
unsigned int count = b->len;
for (unsigned int i = 0; i < count;) {
unsigned int end;
for (end = i + 1; end < count; end++)
if (b->info[i].cluster != b->info[end].cluster)
break;
if (i + 1 == end)
2011-07-21 17:31:08 +02:00
changed |= handle_single_char_cluster (c, i);
2011-07-21 06:51:18 +02:00
else
2011-07-21 17:31:08 +02:00
changed |= handle_multi_char_cluster (c, i, end);
2011-07-21 06:51:18 +02:00
i = end;
}
2011-07-21 17:31:08 +02:00
return changed;
2011-07-21 06:51:18 +02:00
}
HB_END_DECLS