Explicitly track whether the buffer has positions
This commit is contained in:
parent
314b460d8a
commit
314905d754
|
@ -76,7 +76,8 @@ struct _hb_buffer_t {
|
||||||
|
|
||||||
unsigned int allocated;
|
unsigned int allocated;
|
||||||
|
|
||||||
hb_bool_t have_output; /* weather we have an output buffer going on */
|
hb_bool_t have_output; /* whether we have an output buffer going on */
|
||||||
|
hb_bool_t have_positions; /* whether we have positions */
|
||||||
unsigned int in_length;
|
unsigned int in_length;
|
||||||
unsigned int out_length;
|
unsigned int out_length;
|
||||||
unsigned int in_pos;
|
unsigned int in_pos;
|
||||||
|
|
|
@ -177,6 +177,7 @@ void
|
||||||
hb_buffer_clear (hb_buffer_t *buffer)
|
hb_buffer_clear (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
buffer->have_output = FALSE;
|
buffer->have_output = FALSE;
|
||||||
|
buffer->have_positions = FALSE;
|
||||||
buffer->in_length = 0;
|
buffer->in_length = 0;
|
||||||
buffer->out_length = 0;
|
buffer->out_length = 0;
|
||||||
buffer->in_pos = 0;
|
buffer->in_pos = 0;
|
||||||
|
@ -241,6 +242,7 @@ void
|
||||||
_hb_buffer_clear_output (hb_buffer_t *buffer)
|
_hb_buffer_clear_output (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
buffer->have_output = TRUE;
|
buffer->have_output = TRUE;
|
||||||
|
buffer->have_positions = FALSE;
|
||||||
buffer->out_length = 0;
|
buffer->out_length = 0;
|
||||||
buffer->out_pos = 0;
|
buffer->out_pos = 0;
|
||||||
buffer->out_string = buffer->in_string;
|
buffer->out_string = buffer->in_string;
|
||||||
|
@ -251,6 +253,7 @@ hb_buffer_clear_positions (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
_hb_buffer_clear_output (buffer);
|
_hb_buffer_clear_output (buffer);
|
||||||
buffer->have_output = FALSE;
|
buffer->have_output = FALSE;
|
||||||
|
buffer->have_positions = TRUE;
|
||||||
|
|
||||||
if (HB_UNLIKELY (!buffer->positions))
|
if (HB_UNLIKELY (!buffer->positions))
|
||||||
{
|
{
|
||||||
|
@ -420,23 +423,21 @@ _hb_buffer_add_output_glyph (hb_buffer_t *buffer,
|
||||||
void
|
void
|
||||||
_hb_buffer_next_glyph (hb_buffer_t *buffer)
|
_hb_buffer_next_glyph (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (!buffer->have_output)
|
if (buffer->have_output)
|
||||||
{
|
{
|
||||||
buffer->in_pos++;
|
if (buffer->out_string != buffer->in_string)
|
||||||
return;
|
{
|
||||||
}
|
hb_buffer_ensure (buffer, buffer->out_pos + 1);
|
||||||
|
buffer->out_string[buffer->out_pos] = buffer->in_string[buffer->in_pos];
|
||||||
|
}
|
||||||
|
else if (buffer->out_pos != buffer->in_pos)
|
||||||
|
buffer->out_string[buffer->out_pos] = buffer->in_string[buffer->in_pos];
|
||||||
|
|
||||||
if (buffer->out_string != buffer->in_string)
|
buffer->out_pos++;
|
||||||
{
|
buffer->out_length = buffer->out_pos;
|
||||||
hb_buffer_ensure (buffer, buffer->out_pos + 1);
|
|
||||||
buffer->out_string[buffer->out_pos] = buffer->in_string[buffer->in_pos];
|
|
||||||
}
|
}
|
||||||
else if (buffer->out_pos != buffer->in_pos)
|
|
||||||
buffer->out_string[buffer->out_pos] = buffer->in_string[buffer->in_pos];
|
|
||||||
|
|
||||||
buffer->in_pos++;
|
buffer->in_pos++;
|
||||||
buffer->out_pos++;
|
|
||||||
buffer->out_length = buffer->out_pos;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -470,7 +471,7 @@ hb_buffer_get_glyph_infos (hb_buffer_t *buffer)
|
||||||
hb_glyph_position_t *
|
hb_glyph_position_t *
|
||||||
hb_buffer_get_glyph_positions (hb_buffer_t *buffer)
|
hb_buffer_get_glyph_positions (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (buffer->have_output || (buffer->in_length && !buffer->positions))
|
if (!buffer->have_positions)
|
||||||
hb_buffer_clear_positions (buffer);
|
hb_buffer_clear_positions (buffer);
|
||||||
|
|
||||||
return (hb_glyph_position_t *) buffer->positions;
|
return (hb_glyph_position_t *) buffer->positions;
|
||||||
|
|
Loading…
Reference in New Issue