/*
 * Copyright © 2022  Behdad Esfahbod
 *
 *  This is part of HarfBuzz, a text shaping library.
 *
 * Permission is hereby granted, without written agreement and without
 * license or royalty fees, to use, copy, modify, and distribute this
 * software and its documentation for any purpose, provided that the
 * above copyright notice and the following two paragraphs appear in
 * all copies of this software.
 *
 * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
 * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
 * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
 * DAMAGE.
 *
 * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
 * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
 * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
 */

#include "hb-test.h"

#include <hb.h>

static void
test_maxp_and_hmtx (void)
{
  hb_face_t *face;
  hb_font_t *font;

  const char maxp_data[] = "\x00\x00\x50\x00" // version
			   "\x00\x05" // numGlyphs
			   ;
  const char loca_data[18] = "";
  const char hhea_data[36] =
    "\x00\x01\x00\x00" /* FixedVersion<>version;	 * 0x00010000u for version 1.0. */
    "\x02\x00" /* FWORD		ascender;	 * Typographic ascent. */
    "\x00\x10" /* FWORD		descender;	 * Typographic descent. */
    "\x00\x00" /* FWORD		lineGap;	 * Typographic line gap. */
    "\x00\x00" /* UFWORD	advanceMax;	 * Maximum advance width/height value in metrics table. */
    "\x00\x00" /* FWORD		minLeadingBearing;  * Minimum left/top sidebearing value in metrics table. */
    "\x00\x00" /* FWORD		minTrailingBearing;  * Minimum right/bottom sidebearing value; */
    "\x01\x00" /* FWORD		maxExtent;	 * horizontal: Max(lsb + (xMax - xMin)), */
    "\x00\x00" /* HBINT16	caretSlopeRise;	 * Used to calculate the slope of the,*/
    "\x00\x00" /* HBINT16	caretSlopeRun;	 * 0 for vertical caret, 1 for horizontal. */
    "\x00\x00" /* HBINT16	caretOffset;	 * The amount by which a slanted */
    "\x00\x00" /* HBINT16	reserved1;	 * Set to 0. */
    "\x00\x00" /* HBINT16	reserved2;	 * Set to 0. */
    "\x00\x00" /* HBINT16	reserved3;	 * Set to 0. */
    "\x00\x00" /* HBINT16	reserved4;	 * Set to 0. */
    "\x00\x00" /* HBINT16	metricDataFormat; * 0 for current format. */
    "\x00\x02" /* HBUINT16	numberOfLongMetrics;  * Number of LongMetric entries in metric table. */
    ;
  const char hmtx_data[18] =
    "\x00\x01\x00\x02"	/* glyph 0 advance lsb */
    "\x00\x03\x00\x04"	/* glyph 1 advance lsb */
    "\x00\x05"		/* glyph 2         lsb */
    "\x00\x06"		/* glyph 3         lsb */
    "\x00\x07"		/* glyph 4         lsb */
    "\x00\x08"		/* glyph 5 advance */
    "\x00\x09"		/* glyph 6 advance */
    ;

  face = hb_face_builder_create ();
  HB_FACE_ADD_TABLE (face, "maxp", maxp_data);
  HB_FACE_ADD_TABLE (face, "loca", loca_data);
  HB_FACE_ADD_TABLE (face, "hhea", hhea_data);
  HB_FACE_ADD_TABLE (face, "hmtx", hmtx_data);
  font = hb_font_create (face);
  hb_face_destroy (face);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 0), ==, 1);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 1), ==, 3);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 2), ==, 3);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 3), ==, 3);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 4), ==, 3);
#ifndef HB_NO_BEYOND_64K
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 5), ==, 8);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 6), ==, 9);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 7), ==, 9);
#endif
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 8), ==, 0);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font, 9), ==, 0);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font,10), ==, 0);
  g_assert_cmpuint (hb_font_get_glyph_h_advance (font,11), ==, 0);
  hb_font_destroy (font);
}


int
main (int argc, char **argv)
{
  hb_test_init (&argc, &argv);

  hb_test_add (test_maxp_and_hmtx);

  return hb_test_run();
}