[HB] Remove last dependence on the old code base!
This commit is contained in:
parent
5c0adce1cc
commit
3015c41751
|
@ -28,79 +28,79 @@
|
||||||
#ifndef HB_BUFFER_PRIVATE_H
|
#ifndef HB_BUFFER_PRIVATE_H
|
||||||
#define HB_BUFFER_PRIVATE_H
|
#define HB_BUFFER_PRIVATE_H
|
||||||
|
|
||||||
#include "harfbuzz-impl.h"
|
#include "hb-private.h"
|
||||||
#include "hb-buffer.h"
|
#include "hb-buffer.h"
|
||||||
|
|
||||||
HB_BEGIN_HEADER
|
HB_BEGIN_DECLS();
|
||||||
|
|
||||||
#define HB_GLYPH_PROPERTY_UNKNOWN 0xFFFF
|
#define HB_GLYPH_PROPERTY_UNKNOWN 0xFFFF
|
||||||
|
|
||||||
HB_INTERNAL void
|
HB_INTERNAL void
|
||||||
_hb_buffer_swap( HB_Buffer buffer );
|
_hb_buffer_swap (hb_buffer_t *buffer);
|
||||||
|
|
||||||
HB_INTERNAL void
|
HB_INTERNAL void
|
||||||
_hb_buffer_clear_output( HB_Buffer buffer );
|
_hb_buffer_clear_output (hb_buffer_t *buffer);
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_clear_positions( HB_Buffer buffer );
|
_hb_buffer_clear_positions (hb_buffer_t *buffer);
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyphs( HB_Buffer buffer,
|
_hb_buffer_add_output_glyphs (hb_buffer_t *buffer,
|
||||||
HB_UShort num_in,
|
unsigned int num_in,
|
||||||
HB_UShort num_out,
|
unsigned int num_out,
|
||||||
HB_UShort *glyph_data,
|
unsigned short *glyph_data,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID );
|
unsigned short ligID);
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyph ( HB_Buffer buffer,
|
_hb_buffer_add_output_glyph (hb_buffer_t *buffer,
|
||||||
HB_UInt glyph_index,
|
hb_codepoint_t glyph_index,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID );
|
unsigned short ligID);
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_next_glyph ( HB_Buffer buffer );
|
_hb_buffer_next_glyph (hb_buffer_t *buffer);
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_replace_glyph ( HB_Buffer buffer,
|
_hb_buffer_replace_glyph (hb_buffer_t *buffer,
|
||||||
HB_UInt glyph_index );
|
hb_codepoint_t glyph_index);
|
||||||
|
|
||||||
HB_INTERNAL HB_UShort
|
HB_INTERNAL unsigned short
|
||||||
_hb_buffer_allocate_ligid( HB_Buffer buffer );
|
_hb_buffer_allocate_ligid (hb_buffer_t *buffer);
|
||||||
|
|
||||||
|
|
||||||
/* convenience macros */
|
/* convenience macros */
|
||||||
|
|
||||||
#define IN_GLYPH( pos ) (buffer->in_string[(pos)].gindex)
|
#define IN_GLYPH(pos) (buffer->in_string[(pos)].gindex)
|
||||||
#define IN_ITEM( pos ) (&buffer->in_string[(pos)])
|
#define IN_ITEM(pos) (&buffer->in_string[(pos)])
|
||||||
#define IN_CURGLYPH() (buffer->in_string[buffer->in_pos].gindex)
|
#define IN_CURGLYPH() (buffer->in_string[buffer->in_pos].gindex)
|
||||||
#define IN_CURITEM() (&buffer->in_string[buffer->in_pos])
|
#define IN_CURITEM() (&buffer->in_string[buffer->in_pos])
|
||||||
#define IN_PROPERTIES( pos ) (buffer->in_string[(pos)].properties)
|
#define IN_PROPERTIES(pos) (buffer->in_string[(pos)].properties)
|
||||||
#define IN_LIGID( pos ) (buffer->in_string[(pos)].ligID)
|
#define IN_LIGID(pos) (buffer->in_string[(pos)].ligID)
|
||||||
#define IN_COMPONENT( pos ) (buffer->in_string[(pos)].component)
|
#define IN_COMPONENT(pos) (buffer->in_string[(pos)].component)
|
||||||
#define POSITION( pos ) (&buffer->positions[(pos)])
|
#define POSITION(pos) (&buffer->positions[(pos)])
|
||||||
#define CURPOSITION() (&buffer->positions[buffer->in_pos])
|
#define CURPOSITION() (&buffer->positions[buffer->in_pos])
|
||||||
#define OUT_GLYPH( pos ) (buffer->out_string[(pos)].gindex)
|
#define OUT_GLYPH(pos) (buffer->out_string[(pos)].gindex)
|
||||||
#define OUT_ITEM( pos ) (&buffer->out_string[(pos)])
|
#define OUT_ITEM(pos) (&buffer->out_string[(pos)])
|
||||||
|
|
||||||
#define CHECK_Property( layout, index, flags, properties ) \
|
#define CHECK_Property (layout, index, flags, properties) \
|
||||||
({unsigned int _p; error = _hb_ot_layout_check_glyph_property((layout), (index), (flags), (&_p)) \
|
({unsigned int _p; error = _hb_ot_layout_check_glyph_property((layout), (index), (flags), (&_p)) \
|
||||||
? HB_Err_Ok : HB_Err_Not_Covered, *(properties) = _p; error;})
|
? HB_Err_Ok : HB_Err_Not_Covered, *(properties) = _p; error;})
|
||||||
|
|
||||||
#define ADD_String( buffer, num_in, num_out, glyph_data, component, ligID ) \
|
#define ADD_String (buffer, num_in, num_out, glyph_data, component, ligID) \
|
||||||
( ( error = _hb_buffer_add_output_glyphs( (buffer), \
|
((error = _hb_buffer_add_output_glyphs ((buffer), \
|
||||||
(num_in), (num_out), \
|
(num_in), (num_out), \
|
||||||
(glyph_data), (component), (ligID) \
|
(glyph_data), (component), (ligID) \
|
||||||
) ) != HB_Err_Ok )
|
)) != HB_Err_Ok)
|
||||||
#define ADD_Glyph( buffer, glyph_index, component, ligID ) \
|
#define ADD_Glyph (buffer, glyph_index, component, ligID) \
|
||||||
( ( error = _hb_buffer_add_output_glyph( (buffer), \
|
((error = _hb_buffer_add_output_glyph ((buffer), \
|
||||||
(glyph_index), (component), (ligID) \
|
(glyph_index), (component), (ligID) \
|
||||||
) ) != HB_Err_Ok )
|
)) != HB_Err_Ok)
|
||||||
#define REPLACE_Glyph( buffer, glyph_index ) \
|
#define REPLACE_Glyph (buffer, glyph_index) \
|
||||||
( ( error = _hb_buffer_replace_glyph( (buffer), (glyph_index) ) ) != HB_Err_Ok )
|
((error = _hb_buffer_replace_glyph ((buffer), (glyph_index))) != HB_Err_Ok)
|
||||||
#define COPY_Glyph( buffer ) \
|
#define COPY_Glyph (buffer) \
|
||||||
( (error = _hb_buffer_next_glyph ( buffer ) ) != HB_Err_Ok )
|
((error = _hb_buffer_next_glyph (buffer)) != HB_Err_Ok)
|
||||||
|
|
||||||
HB_END_HEADER
|
HB_END_DECLS();
|
||||||
|
|
||||||
#endif /* HB_BUFFER_PRIVATE_H */
|
#endif /* HB_BUFFER_PRIVATE_H */
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
* Red Hat Author(s): Owen Taylor, Behdad Esfahbod
|
* Red Hat Author(s): Owen Taylor, Behdad Esfahbod
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "harfbuzz-impl.h"
|
|
||||||
#include "hb-buffer-private.h"
|
#include "hb-buffer-private.h"
|
||||||
|
|
||||||
/* Here is how the buffer works internally:
|
/* Here is how the buffer works internally:
|
||||||
|
@ -61,7 +60,7 @@
|
||||||
hb_buffer_ensure (hb_buffer_t *buffer,
|
hb_buffer_ensure (hb_buffer_t *buffer,
|
||||||
unsigned int size)
|
unsigned int size)
|
||||||
{
|
{
|
||||||
HB_UInt new_allocated = buffer->allocated;
|
unsigned int new_allocated = buffer->allocated;
|
||||||
/* XXX err handling */
|
/* XXX err handling */
|
||||||
|
|
||||||
if (size > new_allocated)
|
if (size > new_allocated)
|
||||||
|
@ -152,10 +151,10 @@ hb_buffer_clear (HB_Buffer buffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
hb_buffer_add_glyph (HB_Buffer buffer,
|
hb_buffer_add_glyph (hb_buffer_t *buffer,
|
||||||
HB_UInt glyph_index,
|
hb_codepoint_t glyph_index,
|
||||||
HB_UInt properties,
|
unsigned int properties,
|
||||||
HB_UInt cluster)
|
unsigned int cluster)
|
||||||
{
|
{
|
||||||
HB_Error error;
|
HB_Error error;
|
||||||
HB_GlyphItem glyph;
|
HB_GlyphItem glyph;
|
||||||
|
@ -241,17 +240,17 @@ _hb_buffer_swap (HB_Buffer buffer)
|
||||||
The cluster value for the glyph at position buffer->in_pos is used
|
The cluster value for the glyph at position buffer->in_pos is used
|
||||||
for all replacement glyphs */
|
for all replacement glyphs */
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyphs (HB_Buffer buffer,
|
_hb_buffer_add_output_glyphs (hb_buffer_t *buffer,
|
||||||
HB_UShort num_in,
|
unsigned int num_in,
|
||||||
HB_UShort num_out,
|
unsigned int num_out,
|
||||||
HB_UShort *glyph_data,
|
unsigned short *glyph_data,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID)
|
unsigned short ligID)
|
||||||
{
|
{
|
||||||
HB_Error error;
|
HB_Error error;
|
||||||
HB_UShort i;
|
unsigned int i;
|
||||||
HB_UInt properties;
|
unsigned int properties;
|
||||||
HB_UInt cluster;
|
unsigned int cluster;
|
||||||
|
|
||||||
hb_buffer_ensure (buffer, buffer->out_pos + num_out);
|
hb_buffer_ensure (buffer, buffer->out_pos + num_out);
|
||||||
|
|
||||||
|
@ -290,12 +289,12 @@ _hb_buffer_add_output_glyphs (HB_Buffer buffer,
|
||||||
}
|
}
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyph (HB_Buffer buffer,
|
_hb_buffer_add_output_glyph (hb_buffer_t *buffer,
|
||||||
HB_UInt glyph_index,
|
hb_codepoint_t glyph_index,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID)
|
unsigned short ligID)
|
||||||
{
|
{
|
||||||
HB_UShort glyph_data = glyph_index;
|
unsigned short glyph_data = glyph_index;
|
||||||
|
|
||||||
return _hb_buffer_add_output_glyphs (buffer, 1, 1,
|
return _hb_buffer_add_output_glyphs (buffer, 1, 1,
|
||||||
&glyph_data, component, ligID);
|
&glyph_data, component, ligID);
|
||||||
|
@ -321,8 +320,8 @@ _hb_buffer_next_glyph (HB_Buffer buffer)
|
||||||
}
|
}
|
||||||
|
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_replace_glyph (HB_Buffer buffer,
|
_hb_buffer_replace_glyph (hb_buffer_t *buffer,
|
||||||
HB_UInt glyph_index)
|
hb_codepoint_t glyph_index)
|
||||||
{
|
{
|
||||||
if (!buffer->separate_out)
|
if (!buffer->separate_out)
|
||||||
{
|
{
|
||||||
|
@ -340,8 +339,8 @@ _hb_buffer_replace_glyph (HB_Buffer buffer,
|
||||||
return HB_Err_Ok;
|
return HB_Err_Ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
HB_INTERNAL HB_UShort
|
HB_INTERNAL unsigned short
|
||||||
_hb_buffer_allocate_ligid (HB_Buffer buffer)
|
_hb_buffer_allocate_ligid (hb_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
return ++buffer->max_ligID;
|
return ++buffer->max_ligID;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,9 +29,6 @@
|
||||||
|
|
||||||
#include "hb-ot-layout-gsubgpos-private.h"
|
#include "hb-ot-layout-gsubgpos-private.h"
|
||||||
|
|
||||||
/* XXX */
|
|
||||||
#include "harfbuzz-impl.h"
|
|
||||||
|
|
||||||
|
|
||||||
/* Shared Tables: ValueRecord, Anchor Table, and MarkArray */
|
/* Shared Tables: ValueRecord, Anchor Table, and MarkArray */
|
||||||
|
|
||||||
|
@ -670,7 +667,7 @@ struct CursivePosFormat1
|
||||||
|
|
||||||
struct hb_ot_layout_t::gpos_info_t *gpi = &layout->gpos_info;
|
struct hb_ot_layout_t::gpos_info_t *gpi = &layout->gpos_info;
|
||||||
hb_codepoint_t last_pos = gpi->last;
|
hb_codepoint_t last_pos = gpi->last;
|
||||||
gpi->last = 0xFFFF;
|
gpi->last = HB_OT_GPOS_NO_LAST;
|
||||||
|
|
||||||
/* We don't handle mark glyphs here. */
|
/* We don't handle mark glyphs here. */
|
||||||
if (property == HB_OT_LAYOUT_GLYPH_CLASS_MARK)
|
if (property == HB_OT_LAYOUT_GLYPH_CLASS_MARK)
|
||||||
|
@ -684,7 +681,7 @@ struct CursivePosFormat1
|
||||||
|
|
||||||
hb_position_t entry_x, entry_y, exit_x, exit_y;
|
hb_position_t entry_x, entry_y, exit_x, exit_y;
|
||||||
|
|
||||||
if (last_pos == 0xFFFF || !record.entryAnchor)
|
if (last_pos == HB_OT_GPOS_NO_LAST || !record.entryAnchor)
|
||||||
goto end;
|
goto end;
|
||||||
|
|
||||||
(this+record.entryAnchor).get_anchor (layout, IN_CURGLYPH (), &entry_x, &entry_y);
|
(this+record.entryAnchor).get_anchor (layout, IN_CURGLYPH (), &entry_x, &entry_y);
|
||||||
|
@ -1180,7 +1177,7 @@ struct PosLookup : Lookup
|
||||||
if (HB_UNLIKELY (!buffer->in_length))
|
if (HB_UNLIKELY (!buffer->in_length))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
layout->gpos_info.last = 0xFFFF; /* no last valid glyph for cursive pos. */
|
layout->gpos_info.last = HB_OT_GPOS_NO_LAST; /* no last valid glyph for cursive pos. */
|
||||||
|
|
||||||
buffer->in_pos = 0;
|
buffer->in_pos = 0;
|
||||||
while (buffer->in_pos < buffer->in_length)
|
while (buffer->in_pos < buffer->in_length)
|
||||||
|
@ -1196,7 +1193,7 @@ struct PosLookup : Lookup
|
||||||
done = false;
|
done = false;
|
||||||
/* Contrary to properties defined in GDEF, user-defined properties
|
/* Contrary to properties defined in GDEF, user-defined properties
|
||||||
will always stop a possible cursive positioning. */
|
will always stop a possible cursive positioning. */
|
||||||
layout->gpos_info.last = 0xFFFF;
|
layout->gpos_info.last = HB_OT_GPOS_NO_LAST;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!done)
|
if (!done)
|
||||||
|
|
|
@ -30,14 +30,14 @@
|
||||||
#include "hb-ot-layout-gsubgpos-private.h"
|
#include "hb-ot-layout-gsubgpos-private.h"
|
||||||
|
|
||||||
/* XXX */
|
/* XXX */
|
||||||
#include "harfbuzz-impl.h"
|
#include "hb-buffer-private.h"
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyph_ids( HB_Buffer buffer,
|
_hb_buffer_add_output_glyph_ids (hb_buffer_t *buffer,
|
||||||
HB_UShort num_in,
|
unsigned int num_in,
|
||||||
HB_UShort num_out,
|
unsigned int num_out,
|
||||||
const GlyphID *glyph_data,
|
const GlyphID *glyph_data,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID );
|
unsigned short ligID);
|
||||||
|
|
||||||
|
|
||||||
struct SingleSubstFormat1
|
struct SingleSubstFormat1
|
||||||
|
|
|
@ -597,17 +597,17 @@ hb_buffer_duplicate_out_buffer( HB_Buffer buffer )
|
||||||
|
|
||||||
/* XXX */
|
/* XXX */
|
||||||
HB_INTERNAL HB_Error
|
HB_INTERNAL HB_Error
|
||||||
_hb_buffer_add_output_glyph_ids( HB_Buffer buffer,
|
_hb_buffer_add_output_glyph_ids (hb_buffer_t *buffer,
|
||||||
HB_UShort num_in,
|
unsigned int num_in,
|
||||||
HB_UShort num_out,
|
unsigned int num_out,
|
||||||
const GlyphID *glyph_data,
|
const GlyphID *glyph_data,
|
||||||
HB_UShort component,
|
unsigned short component,
|
||||||
HB_UShort ligID )
|
unsigned short ligID)
|
||||||
{
|
{
|
||||||
HB_Error error;
|
HB_Error error;
|
||||||
HB_UShort i;
|
unsigned int i;
|
||||||
HB_UInt properties;
|
unsigned int properties;
|
||||||
HB_UInt cluster;
|
unsigned int cluster;
|
||||||
|
|
||||||
hb_buffer_ensure( buffer, buffer->out_pos + num_out );
|
hb_buffer_ensure( buffer, buffer->out_pos + num_out );
|
||||||
/* XXX */
|
/* XXX */
|
||||||
|
|
Loading…
Reference in New Issue