Blame src/hb-ot-cbdt-table.hh

Packit 874993
/*
Packit 874993
 * Copyright © 2016  Google, Inc.
Packit 874993
 *
Packit 874993
 *  This is part of HarfBuzz, a text shaping library.
Packit 874993
 *
Packit 874993
 * Permission is hereby granted, without written agreement and without
Packit 874993
 * license or royalty fees, to use, copy, modify, and distribute this
Packit 874993
 * software and its documentation for any purpose, provided that the
Packit 874993
 * above copyright notice and the following two paragraphs appear in
Packit 874993
 * all copies of this software.
Packit 874993
 *
Packit 874993
 * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
Packit 874993
 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
Packit 874993
 * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
Packit 874993
 * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
Packit 874993
 * DAMAGE.
Packit 874993
 *
Packit 874993
 * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
Packit 874993
 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
Packit 874993
 * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
Packit 874993
 * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
Packit 874993
 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
Packit 874993
 *
Packit 874993
 * Google Author(s): Seigo Nonaka
Packit 874993
 */
Packit 874993
Packit 874993
#ifndef HB_OT_CBDT_TABLE_HH
Packit 874993
#define HB_OT_CBDT_TABLE_HH
Packit 874993
Packit 874993
#include "hb-open-type-private.hh"
Packit 874993
Packit 874993
namespace OT {
Packit 874993
Packit 874993
struct SmallGlyphMetrics
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this));
Packit 874993
  }
Packit 874993
Packit 874993
  inline void get_extents (hb_glyph_extents_t *extents) const
Packit 874993
  {
Packit 874993
    extents->x_bearing = bearingX;
Packit 874993
    extents->y_bearing = bearingY;
Packit 874993
    extents->width = width;
Packit 874993
    extents->height = -height;
Packit 874993
  }
Packit 874993
Packit 874993
  BYTE height;
Packit 874993
  BYTE width;
Packit 874993
  CHAR bearingX;
Packit 874993
  CHAR bearingY;
Packit 874993
  BYTE advance;
Packit 874993
Packit 874993
  DEFINE_SIZE_STATIC(5);
Packit 874993
};
Packit 874993
Packit 874993
struct BigGlyphMetrics : SmallGlyphMetrics
Packit 874993
{
Packit 874993
  CHAR vertBearingX;
Packit 874993
  CHAR vertBearingY;
Packit 874993
  BYTE vertAdvance;
Packit 874993
Packit 874993
  DEFINE_SIZE_STATIC(8);
Packit 874993
};
Packit 874993
Packit 874993
struct SBitLineMetrics
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this));
Packit 874993
  }
Packit 874993
Packit 874993
  CHAR ascender;
Packit 874993
  CHAR decender;
Packit 874993
  BYTE widthMax;
Packit 874993
  CHAR caretSlopeNumerator;
Packit 874993
  CHAR caretSlopeDenominator;
Packit 874993
  CHAR caretOffset;
Packit 874993
  CHAR minOriginSB;
Packit 874993
  CHAR minAdvanceSB;
Packit 874993
  CHAR maxBeforeBL;
Packit 874993
  CHAR minAfterBL;
Packit 874993
  CHAR padding1;
Packit 874993
  CHAR padding2;
Packit 874993
Packit 874993
  DEFINE_SIZE_STATIC(12);
Packit 874993
};
Packit 874993
Packit 874993
Packit 874993
/*
Packit 874993
 * Index Subtables.
Packit 874993
 */
Packit 874993
Packit 874993
struct IndexSubtableHeader
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this));
Packit 874993
  }
Packit 874993
Packit 874993
  USHORT indexFormat;
Packit 874993
  USHORT imageFormat;
Packit 874993
  ULONG imageDataOffset;
Packit 874993
Packit 874993
  DEFINE_SIZE_STATIC(8);
Packit 874993
};
Packit 874993
Packit 874993
template <typename OffsetType>
Packit 874993
struct IndexSubtableFormat1Or3
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c, unsigned int glyph_count) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this) &&
Packit 874993
		  c->check_array (offsetArrayZ, offsetArrayZ[0].static_size, glyph_count + 1));
Packit 874993
  }
Packit 874993
Packit 874993
  bool get_image_data (unsigned int idx,
Packit 874993
		       unsigned int *offset,
Packit 874993
		       unsigned int *length) const
Packit 874993
  {
Packit 874993
    if (unlikely (offsetArrayZ[idx + 1] <= offsetArrayZ[idx]))
Packit 874993
      return false;
Packit 874993
Packit 874993
    *offset = header.imageDataOffset + offsetArrayZ[idx];
Packit 874993
    *length = offsetArrayZ[idx + 1] - offsetArrayZ[idx];
Packit 874993
    return true;
Packit 874993
  }
Packit 874993
Packit 874993
  IndexSubtableHeader header;
Packit 874993
  Offset<OffsetType> offsetArrayZ[VAR];
Packit 874993
Packit 874993
  DEFINE_SIZE_ARRAY(8, offsetArrayZ);
Packit 874993
};
Packit 874993
Packit 874993
struct IndexSubtableFormat1 : IndexSubtableFormat1Or3<ULONG> {};
Packit 874993
struct IndexSubtableFormat3 : IndexSubtableFormat1Or3<USHORT> {};
Packit 874993
Packit 874993
struct IndexSubtable
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c, unsigned int glyph_count) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    if (!u.header.sanitize (c)) return_trace (false);
Packit 874993
    switch (u.header.indexFormat) {
Packit 874993
    case 1: return_trace (u.format1.sanitize (c, glyph_count));
Packit 874993
    case 3: return_trace (u.format3.sanitize (c, glyph_count));
Packit 874993
    default:return_trace (true);
Packit 874993
    }
Packit 874993
  }
Packit 874993
Packit 874993
  inline bool get_extents (hb_glyph_extents_t *extents) const
Packit 874993
  {
Packit 874993
    switch (u.header.indexFormat) {
Packit 874993
    case 2: case 5: /* TODO */
Packit 874993
    case 1: case 3: case 4: /* Variable-metrics formats do not have metrics here. */
Packit 874993
    default:return (false);
Packit 874993
    }
Packit 874993
  }
Packit 874993
Packit 874993
  bool get_image_data (unsigned int idx,
Packit 874993
		       unsigned int *offset,
Packit 874993
		       unsigned int *length,
Packit 874993
		       unsigned int *format) const
Packit 874993
  {
Packit 874993
    *format = u.header.imageFormat;
Packit 874993
    switch (u.header.indexFormat) {
Packit 874993
    case 1: return u.format1.get_image_data (idx, offset, length);
Packit 874993
    case 3: return u.format3.get_image_data (idx, offset, length);
Packit 874993
    default: return false;
Packit 874993
    }
Packit 874993
  }
Packit 874993
Packit 874993
  protected:
Packit 874993
  union {
Packit 874993
  IndexSubtableHeader	header;
Packit 874993
  IndexSubtableFormat1	format1;
Packit 874993
  IndexSubtableFormat3	format3;
Packit 874993
  /* TODO: Format 2, 4, 5. */
Packit 874993
  } u;
Packit 874993
  public:
Packit 874993
  DEFINE_SIZE_UNION (8, header);
Packit 874993
};
Packit 874993
Packit 874993
struct IndexSubtableRecord
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c, const void *base) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this) &&
Packit 874993
		  firstGlyphIndex <= lastGlyphIndex &&
Packit 874993
		  offsetToSubtable.sanitize (c, this, lastGlyphIndex - firstGlyphIndex + 1));
Packit 874993
  }
Packit 874993
Packit 874993
  inline bool get_extents (hb_glyph_extents_t *extents) const
Packit 874993
  {
Packit 874993
    return (this+offsetToSubtable).get_extents (extents);
Packit 874993
  }
Packit 874993
Packit 874993
  bool get_image_data (unsigned int gid,
Packit 874993
		       unsigned int *offset,
Packit 874993
		       unsigned int *length,
Packit 874993
		       unsigned int *format) const
Packit 874993
  {
Packit 874993
    if (gid < firstGlyphIndex || gid > lastGlyphIndex)
Packit 874993
    {
Packit 874993
      return false;
Packit 874993
    }
Packit 874993
    return (this+offsetToSubtable).get_image_data (gid - firstGlyphIndex,
Packit 874993
						   offset, length, format);
Packit 874993
  }
Packit 874993
Packit 874993
  USHORT firstGlyphIndex;
Packit 874993
  USHORT lastGlyphIndex;
Packit 874993
  LOffsetTo<IndexSubtable> offsetToSubtable;
Packit 874993
Packit 874993
  DEFINE_SIZE_STATIC(8);
Packit 874993
};
Packit 874993
Packit 874993
struct IndexSubtableArray
Packit 874993
{
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c, unsigned int count) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    if (unlikely (!c->check_array (&indexSubtablesZ, indexSubtablesZ[0].static_size, count)))
Packit 874993
      return_trace (false);
Packit 874993
    for (unsigned int i = 0; i < count; i++)
Packit 874993
      if (unlikely (!indexSubtablesZ[i].sanitize (c, this)))
Packit 874993
	return_trace (false);
Packit 874993
    return_trace (true);
Packit 874993
  }
Packit 874993
Packit 874993
  public:
Packit 874993
  const IndexSubtableRecord* find_table (hb_codepoint_t glyph, unsigned int numTables) const
Packit 874993
  {
Packit 874993
    for (unsigned int i = 0; i < numTables; ++i)
Packit 874993
    {
Packit 874993
      unsigned int firstGlyphIndex = indexSubtablesZ[i].firstGlyphIndex;
Packit 874993
      unsigned int lastGlyphIndex = indexSubtablesZ[i].lastGlyphIndex;
Packit 874993
      if (firstGlyphIndex <= glyph && glyph <= lastGlyphIndex) {
Packit 874993
        return &indexSubtablesZ[i];
Packit 874993
      }
Packit 874993
    }
Packit 874993
    return NULL;
Packit 874993
  }
Packit 874993
Packit 874993
  protected:
Packit 874993
  IndexSubtableRecord indexSubtablesZ[VAR];
Packit 874993
Packit 874993
  public:
Packit 874993
  DEFINE_SIZE_ARRAY(0, indexSubtablesZ);
Packit 874993
};
Packit 874993
Packit 874993
struct BitmapSizeTable
Packit 874993
{
Packit 874993
  friend struct CBLC;
Packit 874993
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c, const void *base) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this) &&
Packit 874993
		  indexSubtableArrayOffset.sanitize (c, base, numberOfIndexSubtables) &&
Packit 874993
		  c->check_range (&(base+indexSubtableArrayOffset), indexTablesSize) &&
Packit 874993
		  horizontal.sanitize (c) &&
Packit 874993
		  vertical.sanitize (c));
Packit 874993
  }
Packit 874993
Packit 874993
  const IndexSubtableRecord *find_table (hb_codepoint_t glyph, const void *base) const
Packit 874993
  {
Packit 874993
    return (base+indexSubtableArrayOffset).find_table (glyph, numberOfIndexSubtables);
Packit 874993
  }
Packit 874993
Packit 874993
  protected:
Packit 874993
  LOffsetTo<IndexSubtableArray> indexSubtableArrayOffset;
Packit 874993
  ULONG indexTablesSize;
Packit 874993
  ULONG numberOfIndexSubtables;
Packit 874993
  ULONG colorRef;
Packit 874993
  SBitLineMetrics horizontal;
Packit 874993
  SBitLineMetrics vertical;
Packit 874993
  USHORT startGlyphIndex;
Packit 874993
  USHORT endGlyphIndex;
Packit 874993
  BYTE ppemX;
Packit 874993
  BYTE ppemY;
Packit 874993
  BYTE bitDepth;
Packit 874993
  CHAR flags;
Packit 874993
Packit 874993
public:
Packit 874993
  DEFINE_SIZE_STATIC(48);
Packit 874993
};
Packit 874993
Packit 874993
Packit 874993
/*
Packit 874993
 * Glyph Bitmap Data Formats.
Packit 874993
 */
Packit 874993
Packit 874993
struct GlyphBitmapDataFormat17
Packit 874993
{
Packit 874993
  SmallGlyphMetrics glyphMetrics;
Packit 874993
  ULONG dataLen;
Packit 874993
  BYTE dataZ[VAR];
Packit 874993
Packit 874993
  DEFINE_SIZE_ARRAY(9, dataZ);
Packit 874993
};
Packit 874993
Packit 874993
Packit 874993
/*
Packit 874993
 * CBLC -- Color Bitmap Location Table
Packit 874993
 */
Packit 874993
Packit 874993
#define HB_OT_TAG_CBLC HB_TAG('C','B','L','C')
Packit 874993
Packit 874993
struct CBLC
Packit 874993
{
Packit 874993
  static const hb_tag_t tableTag = HB_OT_TAG_CBLC;
Packit 874993
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this) &&
Packit 874993
		  likely (version.major == 2 || version.major == 3) &&
Packit 874993
		  sizeTables.sanitize (c, this));
Packit 874993
  }
Packit 874993
Packit 874993
  public:
Packit 874993
  const IndexSubtableRecord *find_table (hb_codepoint_t glyph,
Packit 874993
					 unsigned int *x_ppem, unsigned int *y_ppem) const
Packit 874993
  {
Packit 874993
    /* TODO: Make it possible to select strike. */
Packit 874993
Packit 874993
    unsigned int count = sizeTables.len;
Packit 874993
    for (uint32_t i = 0; i < count; ++i)
Packit 874993
    {
Packit 874993
      unsigned int startGlyphIndex = sizeTables.array[i].startGlyphIndex;
Packit 874993
      unsigned int endGlyphIndex = sizeTables.array[i].endGlyphIndex;
Packit 874993
      if (startGlyphIndex <= glyph && glyph <= endGlyphIndex)
Packit 874993
      {
Packit 874993
	*x_ppem = sizeTables[i].ppemX;
Packit 874993
	*y_ppem = sizeTables[i].ppemY;
Packit 874993
	return sizeTables[i].find_table (glyph, this);
Packit 874993
      }
Packit 874993
    }
Packit 874993
Packit 874993
    return NULL;
Packit 874993
  }
Packit 874993
Packit 874993
  protected:
Packit 874993
  FixedVersion<>		version;
Packit 874993
  LArrayOf<BitmapSizeTable>	sizeTables;
Packit 874993
Packit 874993
  public:
Packit 874993
  DEFINE_SIZE_ARRAY(8, sizeTables);
Packit 874993
};
Packit 874993
Packit 874993
/*
Packit 874993
 * CBDT -- Color Bitmap Data Table
Packit 874993
 */
Packit 874993
#define HB_OT_TAG_CBDT HB_TAG('C','B','D','T')
Packit 874993
Packit 874993
struct CBDT
Packit 874993
{
Packit 874993
  static const hb_tag_t tableTag = HB_OT_TAG_CBDT;
Packit 874993
Packit 874993
  inline bool sanitize (hb_sanitize_context_t *c) const
Packit 874993
  {
Packit 874993
    TRACE_SANITIZE (this);
Packit 874993
    return_trace (c->check_struct (this) &&
Packit 874993
		  likely (version.major == 2 || version.major == 3));
Packit 874993
  }
Packit 874993
Packit 874993
  protected:
Packit 874993
  FixedVersion<>version;
Packit 874993
  BYTE dataZ[VAR];
Packit 874993
Packit 874993
  public:
Packit 874993
  DEFINE_SIZE_ARRAY(4, dataZ);
Packit 874993
};
Packit 874993
Packit 874993
} /* namespace OT */
Packit 874993
Packit 874993
#endif /* HB_OT_CBDT_TABLE_HH */