pango.glyph_item_iter

Module for [GlyphItemIter] class

Types 1

A [pango.glyph_item_iter.GlyphItemIter] is an iterator over the clusters in a [pango.glyph_item.GlyphItem].

The forward direction of the iterator is the logical direction of text. That is, with increasing @start_index and @start_char values. If @glyph_item is right-to-left (that is, if glyph_item->item->analysis.level is odd), then @start_glyph decreases as the iterator moves forward. Moreover, in right-to-left cases, @start_glyph is greater than @end_glyph.

An iterator should be initialized using either [pango.glyph_item_iter.GlyphItemIter.initStart] or [pango.glyph_item_iter.GlyphItemIter.initEnd], for forward and backward iteration respectively, and walked over using any desired mixture of [pango.glyph_item_iter.GlyphItemIter.nextCluster] and [pango.glyph_item_iter.GlyphItemIter.prevCluster].

A common idiom for doing a forward iteration over the clusters is:

PangoGlyphItemIter cluster_iter;
gboolean have_cluster;

for (have_cluster = pango_glyph_item_iter_init_start (&cluster_iter,
                                                     glyph_item, text);
    have_cluster;
    have_cluster = pango_glyph_item_iter_next_cluster (&cluster_iter))
{
 ...
}

Note that @text is the start of the text for layout, which is then indexed by glyph_item->item->offset to get to the text of @glyph_item. The @start_index and @end_index values can directly index into @text. The @start_glyph, @end_glyph, @start_char, and @end_char values however are zero-based for the @glyph_item. For each cluster, the item pointed at by the start variables is included in the cluster while the one pointed at by end variables is not.

None of the members of a [pango.glyph_item_iter.GlyphItemIter] should be modified manually.

Methods
void * _cPtr(Flag!"Dup" dup = No.Dup)
GType _gType() @property
GlyphItemIter self()Returns `this`, for use in `with` statements.
void glyphItem(pango.glyph_item.GlyphItem propval) @property
string text() @property
void text(string propval) @property
int startGlyph() @property
void startGlyph(int propval) @property
int startIndex() @property
void startIndex(int propval) @property
int startChar() @property
void startChar(int propval) @property
int endGlyph() @property
void endGlyph(int propval) @property
int endIndex() @property
void endIndex(int propval) @property
int endChar() @property
void endChar(int propval) @property
pango.glyph_item_iter.GlyphItemIter copy()Make a shallow copy of an existing [pango.glyphitemiter.GlyphItemIter] structure. Returns: the newly allocated [pango.glyphitemiter.GlyphItemIter]
bool initEnd(pango.glyph_item.GlyphItem glyphItem, string text)Initializes a [pango.glyphitemiter.GlyphItemIter] structure to point to the last cluster in a glyph item.
bool initStart(pango.glyph_item.GlyphItem glyphItem, string text)Initializes a [pango.glyphitemiter.GlyphItemIter] structure to point to the first cluster in a glyph item.
bool nextCluster()Advances the iterator to the next cluster in the glyph item.
bool prevCluster()Moves the iterator to the preceding cluster in the glyph item. See [pango.glyphitemiter.GlyphItemIter] for details of cluster orders. Returns: true if the iterator was moved, false if we were alrea...
Constructors
this(pango.glyph_item.GlyphItem glyphItem = pango.glyph_item.GlyphItem.init, string text = string.init, int startGlyph = int.init, int startIndex = int.init, int startChar = int.init, int endGlyph = int.init, int endIndex = int.init, int endChar = int.init)Create a `glyphitemiter.GlyphItemIter` boxed type. Params: glyphItem = text = startGlyph = startIndex = startChar = endGlyph = endIndex = endChar =
this(void * ptr, Flag!"Take" take)