[HarfBuzz] harfbuzz: Branch 'master'
Behdad Esfahbod
behdad at kemper.freedesktop.org
Sun Mar 11 19:39:25 UTC 2018
src/hb-ot-color-sbix-table.hh | 70 ++++++++++++++++++++++--------------------
1 file changed, 37 insertions(+), 33 deletions(-)
New commits:
commit fb0f3e3767b488651f13978c1fd8651aefdd6b83
Author: Behdad Esfahbod <behdad at behdad.org>
Date: Sun Mar 11 20:38:40 2018 +0100
[sbix] Clean up
diff --git a/src/hb-ot-color-sbix-table.hh b/src/hb-ot-color-sbix-table.hh
index 5f6a0ecb..c0d8f9b3 100644
--- a/src/hb-ot-color-sbix-table.hh
+++ b/src/hb-ot-color-sbix-table.hh
@@ -34,33 +34,43 @@ namespace OT {
struct SBIXGlyph
{
- friend struct sbix;
-
- protected:
- HBINT16 originOffsetX;
- HBINT16 originOffsetY;
- unsigned char tag[4];
- HBUINT8 data[VAR];
+ HBINT16 xOffset; /* The horizontal (x-axis) offset from the left
+ * edge of the graphic to the glyph’s origin.
+ * That is, the x-coordinate of the point on the
+ * baseline at the left edge of the glyph. */
+ HBINT16 yOffset; /* The vertical (y-axis) offset from the bottom
+ * edge of the graphic to the glyph’s origin.
+ * That is, the y-coordinate of the point on the
+ * baseline at the left edge of the glyph. */
+ Tag graphicType; /* Indicates the format of the embedded graphic
+ * data: one of 'jpg ', 'png ' or 'tiff', or the
+ * special format 'dupe'. */
+ HBUINT8 data[VAR]; /* The actual embedded graphic data. The total
+ * length is inferred from sequential entries in
+ * the glyphDataOffsets array and the fixed size
+ * (8 bytes) of the preceding fields. */
public:
- DEFINE_SIZE_STATIC (9);
+ DEFINE_SIZE_ARRAY (8, data);
};
-struct ImageTable
+struct SBIXStrike
{
- friend struct sbix;
-
inline bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
return_trace (c->check_struct (this) &&
- c->check_array (imageOffsetsZ, sizeof (HBUINT32), c->num_glyphs) &&
- c->check_range (this, imageOffsetsZ[c->num_glyphs]));
+ c->check_array (imageOffsetsZ,
+ sizeof (HBUINT32),
+ 1 + c->num_glyphs));
}
+ HBUINT16 ppem; /* The PPEM size for which this strike was designed. */
+ HBUINT16 resolution; /* The device pixel density (in PPI) for which this
+ * strike was designed. (E.g., 96 PPI, 192 PPI.) */
protected:
- HBUINT16 ppem;
- HBUINT16 resolution;
LOffsetTo<SBIXGlyph> imageOffsetsZ[VAR]; // VAR=maxp.numGlyphs + 1
+ /* Offset from the beginning of the strike data header
+ * to bitmap data for an individual glyph ID. */
public:
DEFINE_SIZE_STATIC (8);
};
@@ -87,40 +97,34 @@ struct sbix
inline bool sanitize (hb_sanitize_context_t *c) const
{
TRACE_SANITIZE (this);
- if (!(c->check_struct (this) && imageTables.sanitize (c, this)))
- return_trace (false);
-
- for (unsigned int i = 0; i < imageTables.len; ++i)
- if (!(imageTables[i].sanitize (c, this)))
- return_trace (false);
-
- // dump (c->num_glyphs, 8);
-
- return_trace (true);
+ return_trace (c->check_struct (this) && strikes.sanitize (c, this));
}
// inline void dump (unsigned int num_glyphs, unsigned int group) const
// {
- // const ImageTable &imageTable = imageTables[group](this);
+ // const SBIXStrike &strike = strikes[group](this);
// for (unsigned int i = 0; i < num_glyphs; ++i)
- // if (imageTable.imageOffsetsZ[i + 1] - imageTable.imageOffsetsZ[i] > 0)
+ // if (strike.imageOffsetsZ[i + 1] - strike.imageOffsetsZ[i] > 0)
// {
- // const SBIXGlyph &sbixGlyph = imageTable.imageOffsetsZ[i]((const void *) &imageTable);
+ // const SBIXGlyph &sbixGlyph = strike.imageOffsetsZ[i]((const void *) &strike);
// char outName[255];
// sprintf (outName, "out/%d-%d.png", group, i);
// FILE *f = fopen (outName, "wb");
// fwrite (sbixGlyph.data, 1,
- // imageTable.imageOffsetsZ[i + 1] - imageTable.imageOffsetsZ[i] - 8, f);
+ // strike.imageOffsetsZ[i + 1] - strike.imageOffsetsZ[i] - 8, f);
// fclose (f);
// }
// }
protected:
- HBUINT16 version;
- HBUINT16 flags;
- ArrayOf<LOffsetTo<ImageTable>, HBUINT32> imageTables;
+ HBUINT16 version; /* Table version number — set to 1 */
+ HBUINT16 flags; /* Bit 0: Set to 1. Bit 1: Draw outlines.
+ * Bits 2 to 15: reserved (set to 0). */
+ ArrayOf<LOffsetTo<SBIXStrike>, HBUINT32>
+ strikes; /* Offsets from the beginning of the 'sbix'
+ * table to data for each individual bitmap strike. */
public:
- DEFINE_SIZE_ARRAY (8, imageTables);
+ DEFINE_SIZE_ARRAY (8, strikes);
};
} /* namespace OT */
More information about the HarfBuzz
mailing list