Start ft glue
authorBehdad Esfahbod <behdad@behdad.org>
Tue, 3 Nov 2009 23:34:20 +0000 (18:34 -0500)
committerBehdad Esfahbod <behdad@behdad.org>
Tue, 3 Nov 2009 23:34:20 +0000 (18:34 -0500)
TODO
src/Makefile.am
src/hb-font-private.h
src/hb-font.cc
src/hb-font.h
src/hb-ft.c [new file with mode: 0644]
src/hb-ft.h [new file with mode: 0644]
src/hb-glib.h
src/hb-icu.h
src/hb.h

diff --git a/TODO b/TODO
index f11dbeb..efcee6a 100644 (file)
--- a/TODO
+++ b/TODO
@@ -7,6 +7,3 @@ hb-ot:
 - Rename hb_internal_glyph_info_t to hb_ot_glyph_info_t
 - Add query API for aalt-like features
 - HB_OT_LAYOUT_GLYPH_CLASS_BASE_GLYPH vs LookupType::... mess
-
-hb-ft:
-- Add hb_ft_create_face()?
index 4eff293..34f4162 100644 (file)
@@ -49,7 +49,7 @@ HBHEADERS += \
 
 if HAVE_GLIB
 HBCFLAGS += $(GLIB_CFLAGS)
-HBLIBS += $(GLIB_LIBS)
+HBLIBS   += $(GLIB_LIBS)
 HBSOURCES += \
        hb-glib.c \
        $(NULL)
@@ -60,7 +60,7 @@ endif
 
 if HAVE_ICU
 HBCFLAGS += $(ICU_CFLAGS)
-HBLIBS += $(ICU_LIBS)
+HBLIBS   += $(ICU_LIBS)
 HBSOURCES += \
        hb-icu.c \
        $(NULL)
@@ -69,8 +69,18 @@ HBHEADERS += \
        $(NULL)
 endif
 
-CXXLINK = $(LINK)
+if HAVE_FREETYPE
+HBCFLAGS += $(FREETYPE_CFLAGS)
+HBLIBS   += $(FREETYPE_LIBS)
+HBSOURCES += \
+       hb-ft.c \
+       $(NULL)
+HBHEADERS += \
+       hb-ft.h \
+       $(NULL)
+endif
 
+CXXLINK = $(LINK)
 libharfbuzz_la_SOURCES = $(HBSOURCES) $(HBHEADERS)
 libharfbuzz_la_CPPFLAGS = $(HBCFLAGS)
 libharfbuzz_la_LIBADD = $(HBLIBS)
index 79de5e4..3d695d7 100644 (file)
@@ -84,7 +84,9 @@ struct _hb_font_t {
   unsigned int x_ppem;
   unsigned int y_ppem;
 
-  hb_font_funcs_t *klass;
+  hb_font_funcs_t   *klass;
+  hb_destroy_func_t  destroy;
+  void              *user_data;
 };
 
 
index 4865baa..3108f52 100644 (file)
@@ -232,7 +232,9 @@ static hb_font_t _hb_font_nil = {
   0, /* x_ppem */
   0, /* y_ppem */
 
-  NULL /* klass */
+  NULL, /* klass */
+  NULL, /* destroy */
+  NULL  /* user_data */
 };
 
 hb_font_t *
@@ -264,20 +266,29 @@ hb_font_destroy (hb_font_t *font)
   HB_OBJECT_DO_DESTROY (font);
 
   hb_font_funcs_destroy (font->klass);
+  if (font->destroy)
+    font->destroy (font->user_data);
 
   free (font);
 }
 
 void
-hb_font_set_funcs (hb_font_t       *font,
-                  hb_font_funcs_t *klass)
+hb_font_set_funcs (hb_font_t         *font,
+                  hb_font_funcs_t   *klass,
+                  hb_destroy_func_t  destroy,
+                  void              *user_data)
 {
   if (HB_OBJECT_IS_INERT (font))
     return;
 
+  if (font->destroy)
+    font->destroy (font->user_data);
+
   hb_font_funcs_reference (klass);
   hb_font_funcs_destroy (font->klass);
   font->klass = klass;
+  font->destroy = destroy;
+  font->user_data = user_data;
 }
 
 void
index 5bce0d4..153279f 100644 (file)
@@ -150,8 +150,10 @@ void
 hb_font_destroy (hb_font_t *font);
 
 void
-hb_font_set_funcs (hb_font_t       *font,
-                  hb_font_funcs_t *klass);
+hb_font_set_funcs (hb_font_t         *font,
+                  hb_font_funcs_t   *klass,
+                  hb_destroy_func_t  destroy,
+                  void              *user_data);
 
 hb_font_funcs_t *
 hb_font_get_funcs (hb_font_t       *font);
diff --git a/src/hb-ft.c b/src/hb-ft.c
new file mode 100644 (file)
index 0000000..38f7c44
--- /dev/null
@@ -0,0 +1,192 @@
+/*
+ * Copyright (C) 2009  Red Hat, Inc.
+ * Copyright (C) 2009  Keith Stribley <devel@thanlwinsoft.org>
+ *
+ *  This is part of HarfBuzz, an OpenType Layout engine 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.
+ *
+ * Red Hat Author(s): Behdad Esfahbod
+ */
+
+#include "hb-private.h"
+
+#include "hb-ft.h"
+
+#include "hb-font-private.h"
+
+#include FT_TRUETYPE_TABLES_H
+
+#if 0
+extern hb_codepoint_t hb_GetGlyph(hb_font_t *font, hb_face_t *face, const void *user_data,
+                            hb_codepoint_t unicode, hb_codepoint_t variant_selector)
+{
+    FT_Face fcFace = (FT_Face)user_data;
+    return FT_Get_Char_Index(fcFace, unicode);
+}
+
+extern hb_bool_t hb_GetContourPoint(hb_font_t *font, hb_face_t *face, const void *user_data,
+                               hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y)
+{
+    unsigned int point = 0; /* TODO this should be in API */
+    int load_flags = FT_LOAD_DEFAULT;
+
+    FT_Face fcFace = (FT_Face)user_data;
+    if (FT_Load_Glyph(fcFace, glyph, load_flags))
+        return 0;
+
+    if (fcFace->glyph->format != ft_glyph_format_outline)
+        return 0;
+
+    unsigned int nPoints = fcFace->glyph->outline.n_points;
+    if (!(nPoints))
+        return 0;
+
+    if (point > nPoints)
+        return 0;
+
+    *x = fcFace->glyph->outline.points[point].x;
+    *y = fcFace->glyph->outline.points[point].y;
+
+    return 1;
+}
+
+extern void hb_GetGlyphMetrics(hb_font_t *font, hb_face_t *face, const void *user_data,
+                          hb_codepoint_t glyph, hb_glyph_metrics_t *metrics)
+{
+    int load_flags = FT_LOAD_DEFAULT;
+    FT_Face fcFace = (FT_Face)user_data;
+
+    metrics->x = metrics->y = 0;
+       metrics->x_offset = metrics->y_offset = 0;
+    if (FT_Load_Glyph(fcFace, glyph, load_flags))
+    {
+        metrics->width = metrics->height = 0;
+    }
+    else
+    {
+        metrics->width = fcFace->glyph->metrics.width;
+        metrics->height = fcFace->glyph->metrics.height;
+               metrics->x_offset = fcFace->glyph->advance.x;
+               metrics->y_offset = fcFace->glyph->advance.y;
+    }
+}
+
+extern hb_position_t hb_GetKerning(hb_font_t *font, hb_face_t *face, const void *user_data,
+                             hb_codepoint_t first_glyph, hb_codepoint_t second_glyph)
+{
+    FT_Face fcFace = (FT_Face)user_data;
+    FT_Vector aKerning;
+    if (FT_Get_Kerning(fcFace, first_glyph, second_glyph, FT_KERNING_DEFAULT,
+                       &aKerning))
+    {
+        return 0;
+    }
+    return aKerning.x;
+}
+#endif
+
+static hb_font_funcs_t ft_ffuncs = {
+  HB_REFERENCE_COUNT_INVALID, /* ref_count */
+
+  TRUE, /* immutable */
+
+#if 0
+  hb_ft_get_glyph,
+  hb_ft_get_contour_point,
+  hb_ft_get_glyph_metrics,
+  hb_ft_get_kerning
+#endif
+};
+
+hb_font_funcs_t *
+hb_ft_get_font_funcs (void)
+{
+  return &ft_ffuncs;
+}
+
+
+static hb_blob_t *
+_get_table  (hb_tag_t tag, void *user_data)
+{
+  FT_Face ft_face = (FT_Face) user_data;
+  FT_Byte *buffer;
+  FT_ULong  length = 0;
+  FT_Error error;
+
+  error = FT_Load_Sfnt_Table (ft_face, tag, 0, NULL, &length);
+  if (error)
+    return hb_blob_create_empty ();
+
+  buffer = malloc (length);
+  if (buffer == NULL)
+    return hb_blob_create_empty ();
+
+  error = FT_Load_Sfnt_Table (ft_face, tag, 0, buffer, &length);
+  if (error)
+    return hb_blob_create_empty ();
+
+  return hb_blob_create ((const char *) buffer, length,
+                        HB_MEMORY_MODE_WRITABLE,
+                        free, buffer);
+}
+
+
+hb_face_t *
+hb_ft_face_create (FT_Face           ft_face,
+                  hb_destroy_func_t destroy)
+{
+  hb_face_t *face;
+
+  if (ft_face->stream->base != NULL) {
+    hb_blob_t *blob;
+
+    blob = hb_blob_create ((const char *) ft_face->stream->base,
+                          (unsigned int) ft_face->stream->size,
+                          HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE,
+                          destroy, ft_face);
+    face = hb_face_create_for_data (blob, ft_face->face_index);
+    hb_blob_destroy (blob);
+  } else {
+    face = hb_face_create_for_tables (_get_table, destroy, ft_face);
+  }
+
+  return face;
+}
+
+
+hb_font_t *
+hb_ft_font_create (FT_Face           ft_face,
+                  hb_destroy_func_t destroy)
+{
+  hb_font_t *font;
+
+  font = hb_font_create ();
+  hb_font_set_funcs (font,
+                    hb_ft_get_font_funcs (),
+                    destroy, ft_face);
+  hb_font_set_scale (font,
+                    ft_face->size->metrics.x_scale,
+                    ft_face->size->metrics.y_scale);
+  hb_font_set_ppem (font,
+                   ft_face->size->metrics.x_ppem,
+                   ft_face->size->metrics.y_ppem);
+
+  return font;
+}
diff --git a/src/hb-ft.h b/src/hb-ft.h
new file mode 100644 (file)
index 0000000..e6a4f86
--- /dev/null
@@ -0,0 +1,52 @@
+/*
+ * Copyright (C) 2009  Red Hat, Inc.
+ *
+ *  This is part of HarfBuzz, an OpenType Layout engine 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.
+ *
+ * Red Hat Author(s): Behdad Esfahbod
+ */
+
+#ifndef HB_FT_H
+#define HB_FT_H
+
+#include "hb.h"
+
+#include "hb-font.h"
+
+#include <ft2build.h>
+#include FT_FREETYPE_H
+
+HB_BEGIN_DECLS
+
+hb_font_funcs_t *
+hb_ft_get_font_funcs (void);
+
+hb_face_t *
+hb_ft_face_create (FT_Face           ft_face,
+                  hb_destroy_func_t destroy);
+
+hb_font_t *
+hb_ft_font_create (FT_Face           ft_face,
+                  hb_destroy_func_t destroy);
+
+HB_END_DECLS
+
+#endif /* HB_FT_H */
index 6c94993..d7b9c15 100644 (file)
@@ -29,8 +29,6 @@
 
 #include "hb.h"
 
-#include "hb-unicode.h"
-
 HB_BEGIN_DECLS
 
 hb_unicode_funcs_t *
index 91fb0da..ca8031c 100644 (file)
@@ -29,8 +29,6 @@
 
 #include "hb.h"
 
-#include "hb-unicode.h"
-
 HB_BEGIN_DECLS
 
 hb_unicode_funcs_t *
index a948e13..a1b70bd 100644 (file)
--- a/src/hb.h
+++ b/src/hb.h
 #ifndef HB_H
 #define HB_H
 
-#include "hb-common.h"
 #include "hb-blob.h"
 #include "hb-buffer.h"
+#include "hb-common.h"
 #include "hb-font.h"
+#include "hb-shape.h"
+#include "hb-unicode.h"
 
 #endif /* HB_H */