From d94647e2cd187bf4a4c8fb1c0c15c3d23c1293ac Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Tue, 3 Nov 2009 16:35:10 -0500 Subject: [PATCH] Add ICU glue --- configure.ac | 8 +- src/Makefile.am | 23 ++++- src/hb-icu.c | 221 ++++++++++++++++++++++++++++++++++++++++++++++++ src/hb-icu.h | 41 +++++++++ 4 files changed, 288 insertions(+), 5 deletions(-) create mode 100644 src/hb-icu.c create mode 100644 src/hb-icu.h diff --git a/configure.ac b/configure.ac index 59b0ca8c2..754fd47e4 100644 --- a/configure.ac +++ b/configure.ac @@ -23,10 +23,16 @@ dnl ========================================================================== PKG_CHECK_MODULES(GLIB, glib-2.0, have_glib=true, have_glib=false) if $have_glib; then - AC_DEFINE(HAVE_GLIB, 1, [Have FreeType 2 library]) + AC_DEFINE(HAVE_GLIB, 1, [Have glib2 library]) fi AM_CONDITIONAL(HAVE_GLIB, $have_glib) +PKG_CHECK_MODULES(ICU, icu, have_icu=true, have_icu=false) +if $have_icu; then + AC_DEFINE(HAVE_ICU, 1, [Have ICU library]) +fi +AM_CONDITIONAL(HAVE_ICU, $have_icu) + PKG_CHECK_MODULES(FREETYPE, freetype2, have_freetype=true, have_freetype=false) if $have_freetype; then AC_DEFINE(HAVE_FREETYPE, 1, [Have FreeType 2 library]) diff --git a/src/Makefile.am b/src/Makefile.am index 90f368e88..4eff29381 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -7,6 +7,8 @@ NULL = lib_LTLIBRARIES = libharfbuzz.la +HBCFLAGS = +HBLIBS = HBSOURCES = \ hb-blob.c \ hb-buffer.c \ @@ -46,6 +48,8 @@ HBHEADERS += \ $(NULL) if HAVE_GLIB +HBCFLAGS += $(GLIB_CFLAGS) +HBLIBS += $(GLIB_LIBS) HBSOURCES += \ hb-glib.c \ $(NULL) @@ -54,18 +58,29 @@ HBHEADERS += \ $(NULL) endif +if HAVE_ICU +HBCFLAGS += $(ICU_CFLAGS) +HBLIBS += $(ICU_LIBS) +HBSOURCES += \ + hb-icu.c \ + $(NULL) +HBHEADERS += \ + hb-icu.h \ + $(NULL) +endif + CXXLINK = $(LINK) libharfbuzz_la_SOURCES = $(HBSOURCES) $(HBHEADERS) -libharfbuzz_la_CPPFLAGS = $(GLIB_CFLAGS) -libharfbuzz_la_LIBADD = $(GLIB_LIBS) +libharfbuzz_la_CPPFLAGS = $(HBCFLAGS) +libharfbuzz_la_LIBADD = $(HBLIBS) pkginclude_HEADERS = $(HBHEADERS) noinst_PROGRAMS = main main_SOURCES = main.cc -main_CPPFLAGS = $(GLIB_CFLAGS) -main_LDADD = libharfbuzz.la $(GLIB_LIBS) +main_CPPFLAGS = $(HBCFLAGS) +main_LDADD = libharfbuzz.la $(HBLIBS) TESTS = \ check-libstdc++.sh \ diff --git a/src/hb-icu.c b/src/hb-icu.c new file mode 100644 index 000000000..2b28aa157 --- /dev/null +++ b/src/hb-icu.c @@ -0,0 +1,221 @@ +/* + * Copyright (C) 2009 Red Hat, Inc. + * Copyright (C) 2009 Keith Stribley + * + * 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-icu.h" + +#include "hb-unicode-private.h" + +#include +#include + +static hb_codepoint_t hb_icu_get_mirroring (hb_codepoint_t unicode) { return u_charMirror(unicode); } +static unsigned int hb_icu_get_combining_class (hb_codepoint_t unicode) { return u_getCombiningClass (unicode); } + +static unsigned int +hb_icu_get_eastasian_width (hb_codepoint_t unicode) +{ + switch (u_getIntPropertyValue(unicode, UCHAR_EAST_ASIAN_WIDTH)) + { + case U_EA_WIDE: + case U_EA_FULLWIDTH: + return 2; + case U_EA_NEUTRAL: + case U_EA_AMBIGUOUS: + case U_EA_HALFWIDTH: + case U_EA_NARROW: + return 1; + } + return 1; +} + +static hb_category_t +hb_icu_get_general_category (hb_codepoint_t unicode) +{ + switch (u_getIntPropertyValue(unicode, UCHAR_GENERAL_CATEGORY)) + { + case U_UNASSIGNED: return HB_CATEGORY_UNASSIGNED; + + case U_UPPERCASE_LETTER: return HB_CATEGORY_UPPERCASE_LETTER; /* Lu */ + case U_LOWERCASE_LETTER: return HB_CATEGORY_LOWERCASE_LETTER; /* Ll */ + case U_TITLECASE_LETTER: return HB_CATEGORY_TITLECASE_LETTER; /* Lt */ + case U_MODIFIER_LETTER: return HB_CATEGORY_MODIFIER_LETTER; /* Lm */ + case U_OTHER_LETTER: return HB_CATEGORY_OTHER_LETTER; /* Lo */ + + case U_NON_SPACING_MARK: return HB_CATEGORY_NON_SPACING_MARK; /* Mn */ + case U_ENCLOSING_MARK: return HB_CATEGORY_ENCLOSING_MARK; /* Me */ + case U_COMBINING_SPACING_MARK: return HB_CATEGORY_COMBINING_MARK; /* Mc */ + + case U_DECIMAL_DIGIT_NUMBER: return HB_CATEGORY_DECIMAL_NUMBER; /* Nd */ + case U_LETTER_NUMBER: return HB_CATEGORY_LETTER_NUMBER; /* Nl */ + case U_OTHER_NUMBER: return HB_CATEGORY_OTHER_NUMBER; /* No */ + + case U_SPACE_SEPARATOR: return HB_CATEGORY_SPACE_SEPARATOR; /* Zs */ + case U_LINE_SEPARATOR: return HB_CATEGORY_LINE_SEPARATOR; /* Zl */ + case U_PARAGRAPH_SEPARATOR: return HB_CATEGORY_PARAGRAPH_SEPARATOR; /* Zp */ + + case U_CONTROL_CHAR: return HB_CATEGORY_CONTROL; /* Cc */ + case U_FORMAT_CHAR: return HB_CATEGORY_FORMAT; /* Cf */ + case U_PRIVATE_USE_CHAR: return HB_CATEGORY_PRIVATE_USE; /* Co */ + case U_SURROGATE: return HB_CATEGORY_SURROGATE; /* Cs */ + + + case U_DASH_PUNCTUATION: return HB_CATEGORY_DASH_PUNCTUATION; /* Pd */ + case U_START_PUNCTUATION: return HB_CATEGORY_OPEN_PUNCTUATION; /* Ps */ + case U_END_PUNCTUATION: return HB_CATEGORY_CLOSE_PUNCTUATION; /* Pe */ + case U_CONNECTOR_PUNCTUATION: return HB_CATEGORY_CONNECT_PUNCTUATION; /* Pc */ + case U_OTHER_PUNCTUATION: return HB_CATEGORY_OTHER_PUNCTUATION; /* Po */ + + case U_MATH_SYMBOL: return HB_CATEGORY_MATH_SYMBOL; /* Sm */ + case U_CURRENCY_SYMBOL: return HB_CATEGORY_CURRENCY_SYMBOL; /* Sc */ + case U_MODIFIER_SYMBOL: return HB_CATEGORY_MODIFIER_SYMBOL; /* Sk */ + case U_OTHER_SYMBOL: return HB_CATEGORY_OTHER_SYMBOL; /* So */ + + case U_INITIAL_PUNCTUATION: return HB_CATEGORY_INITIAL_PUNCTUATION; /* Pi */ + case U_FINAL_PUNCTUATION: return HB_CATEGORY_FINAL_PUNCTUATION; /* Pf */ + } + + return HB_CATEGORY_UNASSIGNED; +} + +static hb_script_t +hb_icu_get_script (hb_codepoint_t unicode) +{ + UErrorCode status = U_ZERO_ERROR; + UScriptCode scriptCode = uscript_getScript(unicode, &status); + switch ((int) scriptCode) + { +#define MATCH_SCRIPT(C) case USCRIPT_##C: return HB_SCRIPT_##C + MATCH_SCRIPT (INVALID_CODE); + MATCH_SCRIPT (COMMON); /* Zyyy */ + MATCH_SCRIPT (INHERITED); /* Qaai */ + MATCH_SCRIPT (ARABIC); /* Arab */ + MATCH_SCRIPT (ARMENIAN); /* Armn */ + MATCH_SCRIPT (BENGALI); /* Beng */ + MATCH_SCRIPT (BOPOMOFO); /* Bopo */ + MATCH_SCRIPT (CHEROKEE); /* Cher */ + MATCH_SCRIPT (COPTIC); /* Qaac */ + MATCH_SCRIPT (CYRILLIC); /* Cyrl (Cyrs) */ + MATCH_SCRIPT (DESERET); /* Dsrt */ + MATCH_SCRIPT (DEVANAGARI); /* Deva */ + MATCH_SCRIPT (ETHIOPIC); /* Ethi */ + MATCH_SCRIPT (GEORGIAN); /* Geor (Geon); Geoa) */ + MATCH_SCRIPT (GOTHIC); /* Goth */ + MATCH_SCRIPT (GREEK); /* Grek */ + MATCH_SCRIPT (GUJARATI); /* Gujr */ + MATCH_SCRIPT (GURMUKHI); /* Guru */ + MATCH_SCRIPT (HAN); /* Hani */ + MATCH_SCRIPT (HANGUL); /* Hang */ + MATCH_SCRIPT (HEBREW); /* Hebr */ + MATCH_SCRIPT (HIRAGANA); /* Hira */ + MATCH_SCRIPT (KANNADA); /* Knda */ + MATCH_SCRIPT (KATAKANA); /* Kana */ + MATCH_SCRIPT (KHMER); /* Khmr */ + MATCH_SCRIPT (LAO); /* Laoo */ + MATCH_SCRIPT (LATIN); /* Latn (Latf); Latg) */ + MATCH_SCRIPT (MALAYALAM); /* Mlym */ + MATCH_SCRIPT (MONGOLIAN); /* Mong */ + MATCH_SCRIPT (MYANMAR); /* Mymr */ + MATCH_SCRIPT (OGHAM); /* Ogam */ + MATCH_SCRIPT (OLD_ITALIC); /* Ital */ + MATCH_SCRIPT (ORIYA); /* Orya */ + MATCH_SCRIPT (RUNIC); /* Runr */ + MATCH_SCRIPT (SINHALA); /* Sinh */ + MATCH_SCRIPT (SYRIAC); /* Syrc (Syrj, Syrn); Syre) */ + MATCH_SCRIPT (TAMIL); /* Taml */ + MATCH_SCRIPT (TELUGU); /* Telu */ + MATCH_SCRIPT (THAANA); /* Thaa */ + MATCH_SCRIPT (THAI); /* Thai */ + MATCH_SCRIPT (TIBETAN); /* Tibt */ + MATCH_SCRIPT (CANADIAN_ABORIGINAL);/* Cans */ + MATCH_SCRIPT (YI); /* Yiii */ + MATCH_SCRIPT (TAGALOG); /* Tglg */ + MATCH_SCRIPT (HANUNOO); /* Hano */ + MATCH_SCRIPT (BUHID); /* Buhd */ + MATCH_SCRIPT (TAGBANWA); /* Tagb */ + + /* Unicode-4.0 additions */ + MATCH_SCRIPT (BRAILLE); /* Brai */ + MATCH_SCRIPT (CYPRIOT); /* Cprt */ + MATCH_SCRIPT (LIMBU); /* Limb */ + MATCH_SCRIPT (OSMANYA); /* Osma */ + MATCH_SCRIPT (SHAVIAN); /* Shaw */ + MATCH_SCRIPT (LINEAR_B); /* Linb */ + MATCH_SCRIPT (TAI_LE); /* Tale */ + MATCH_SCRIPT (UGARITIC); /* Ugar */ + + /* Unicode-4.1 additions */ + MATCH_SCRIPT (NEW_TAI_LUE); /* Talu */ + MATCH_SCRIPT (BUGINESE); /* Bugi */ + MATCH_SCRIPT (GLAGOLITIC); /* Glag */ + MATCH_SCRIPT (TIFINAGH); /* Tfng */ + MATCH_SCRIPT (SYLOTI_NAGRI); /* Sylo */ + MATCH_SCRIPT (OLD_PERSIAN); /* Xpeo */ + MATCH_SCRIPT (KHAROSHTHI); /* Khar */ + + /* Unicode-5.0 additions */ + MATCH_SCRIPT (UNKNOWN); /* Zzzz */ + MATCH_SCRIPT (BALINESE); /* Bali */ + MATCH_SCRIPT (CUNEIFORM); /* Xsux */ + MATCH_SCRIPT (PHOENICIAN); /* Phnx */ + MATCH_SCRIPT (PHAGS_PA); /* Phag */ + MATCH_SCRIPT (NKO); /* Nkoo */ + + /* Unicode-5.1 additions */ + MATCH_SCRIPT (KAYAH_LI); /* Kali */ + MATCH_SCRIPT (LEPCHA); /* Lepc */ + MATCH_SCRIPT (REJANG); /* Rjng */ + MATCH_SCRIPT (SUNDANESE); /* Sund */ + MATCH_SCRIPT (SAURASHTRA); /* Saur */ + MATCH_SCRIPT (CHAM); /* Cham */ + MATCH_SCRIPT (OL_CHIKI); /* Olck */ + MATCH_SCRIPT (VAI); /* Vaii */ + MATCH_SCRIPT (CARIAN); /* Cari */ + MATCH_SCRIPT (LYCIAN); /* Lyci */ + MATCH_SCRIPT (LYDIAN); /* Lydi */ + } + return HB_SCRIPT_UNKNOWN; +} + +static hb_unicode_funcs_t icu_ufuncs = { + HB_REFERENCE_COUNT_INVALID, /* ref_count */ + + TRUE, /* immutable */ + + hb_icu_get_general_category, + hb_icu_get_combining_class, + hb_icu_get_mirroring, + hb_icu_get_script, + hb_icu_get_eastasian_width +}; + +hb_unicode_funcs_t * +hb_icu_get_unicode_funcs (void) +{ + return &icu_ufuncs; +} diff --git a/src/hb-icu.h b/src/hb-icu.h new file mode 100644 index 000000000..91fb0da32 --- /dev/null +++ b/src/hb-icu.h @@ -0,0 +1,41 @@ +/* + * 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_ICU_H +#define HB_ICU_H + +#include "hb.h" + +#include "hb-unicode.h" + +HB_BEGIN_DECLS + +hb_unicode_funcs_t * +hb_icu_get_unicode_funcs (void); + +HB_END_DECLS + +#endif /* HB_ICU_H */