diff options
author | Raph Levien <raph@google.com> | 2012-10-30 15:58:57 -0700 |
---|---|---|
committer | Raph Levien <raph@google.com> | 2012-10-30 15:58:57 -0700 |
commit | c12e37c1ce6c98018ea28cb0e09302297f1a33b3 (patch) | |
tree | 9792c1b5ef0e5f509276bc76b65a74e8588ab62d | |
parent | f17ec8a5508a16f99566c65bfebf634319c88196 (diff) | |
download | skia-c12e37c1ce6c98018ea28cb0e09302297f1a33b3.tar.gz |
Changes to Skia to support Harfbuzz NG
This version of the patch supports both old and new Harfbuzz (the former
is still needed for WebView).
Change-Id: Id438a5dd7f9fe4a7deca3cb6fb8521eb757b10e4
-rw-r--r-- | include/ports/SkTypeface_android.h | 4 | ||||
-rw-r--r-- | src/ports/SkFontHost_android.cpp | 90 |
2 files changed, 59 insertions, 35 deletions
diff --git a/include/ports/SkTypeface_android.h b/include/ports/SkTypeface_android.h index c3eb3d16bb..7e9204d91c 100644 --- a/include/ports/SkTypeface_android.h +++ b/include/ports/SkTypeface_android.h @@ -13,6 +13,7 @@ #include "SkPaint.h" #include "../harfbuzz/src/harfbuzz-shaper.h" +#include "../harfbuzz_ng/src/hb.h" /** * Return a new typeface for a fallback script. If the script is @@ -23,6 +24,9 @@ * @return reference to the matching typeface. Caller must call * unref() when they are done. */ +SK_API SkTypeface* SkCreateTypefaceForScriptNG(hb_script_t script, SkTypeface::Style style, + SkPaint::FontVariant fontVariant = SkPaint::kDefault_Variant); + SK_API SkTypeface* SkCreateTypefaceForScript(HB_Script script, SkTypeface::Style style, SkPaint::FontVariant fontVariant = SkPaint::kDefault_Variant); diff --git a/src/ports/SkFontHost_android.cpp b/src/ports/SkFontHost_android.cpp index dddadd0a98..bfd1dac661 100644 --- a/src/ports/SkFontHost_android.cpp +++ b/src/ports/SkFontHost_android.cpp @@ -1118,50 +1118,64 @@ static SkFontID findFontIDForChar(SkUnichar uni, SkTypeface::Style style, } struct HB_UnicodeMapping { - HB_Script script; + // TODO: when the WebView no longer needs harfbuzz_old, remove + HB_Script script_old; + hb_script_t script; const SkUnichar unicode; }; /* * The following scripts are not complex fonts and we do not expect them to be parsed by this table - * HB_Script_Common, - * HB_Script_Greek, - * HB_Script_Cyrillic, - * HB_Script_Hangul - * HB_Script_Inherited + * HB_SCRIPT_COMMON, + * HB_SCRIPT_GREEK, + * HB_SCRIPT_CYRILLIC, + * HB_SCRIPT_HANGUL + * HB_SCRIPT_INHERITED */ -static HB_UnicodeMapping HB_UnicodeMappingArray[] { - {HB_Script_Armenian, 0x0531}, - {HB_Script_Hebrew, 0x0591}, - {HB_Script_Arabic, 0x0600}, - {HB_Script_Syriac, 0x0710}, - {HB_Script_Thaana, 0x0780}, - {HB_Script_Nko, 0x07C0}, - {HB_Script_Devanagari, 0x0901}, - {HB_Script_Bengali, 0x0981}, - {HB_Script_Gurmukhi, 0x0A10}, - {HB_Script_Gujarati, 0x0A90}, - {HB_Script_Oriya, 0x0B10}, - {HB_Script_Tamil, 0x0B82}, - {HB_Script_Telugu, 0x0C10}, - {HB_Script_Kannada, 0x0C90}, - {HB_Script_Malayalam, 0x0D10}, - {HB_Script_Sinhala, 0x0D90}, - {HB_Script_Thai, 0x0E01}, - {HB_Script_Lao, 0x0E81}, - {HB_Script_Tibetan, 0x0F00}, - {HB_Script_Myanmar, 0x1000}, - {HB_Script_Georgian, 0x10A0}, +static HB_UnicodeMapping HB_UnicodeMappingArray[] = { + {HB_Script_Armenian, HB_SCRIPT_ARMENIAN, 0x0531}, + {HB_Script_Hebrew, HB_SCRIPT_HEBREW, 0x0591}, + {HB_Script_Arabic, HB_SCRIPT_ARABIC, 0x0600}, + {HB_Script_Syriac, HB_SCRIPT_SYRIAC, 0x0710}, + {HB_Script_Thaana, HB_SCRIPT_THAANA, 0x0780}, + {HB_Script_Nko, HB_SCRIPT_NKO, 0x07C0}, + {HB_Script_Devanagari, HB_SCRIPT_DEVANAGARI, 0x0901}, + {HB_Script_Bengali, HB_SCRIPT_BENGALI, 0x0981}, + {HB_Script_Gurmukhi, HB_SCRIPT_GURMUKHI, 0x0A10}, + {HB_Script_Gujarati, HB_SCRIPT_GUJARATI, 0x0A90}, + {HB_Script_Oriya, HB_SCRIPT_ORIYA, 0x0B10}, + {HB_Script_Tamil, HB_SCRIPT_TAMIL, 0x0B82}, + {HB_Script_Telugu, HB_SCRIPT_TELUGU, 0x0C10}, + {HB_Script_Kannada, HB_SCRIPT_KANNADA, 0x0C90}, + {HB_Script_Malayalam, HB_SCRIPT_MALAYALAM, 0x0D10}, + {HB_Script_Sinhala, HB_SCRIPT_SINHALA, 0x0D90}, + {HB_Script_Thai, HB_SCRIPT_THAI, 0x0E01}, + {HB_Script_Lao, HB_SCRIPT_LAO, 0x0E81}, + {HB_Script_Tibetan, HB_SCRIPT_TIBETAN, 0x0F00}, + {HB_Script_Myanmar, HB_SCRIPT_MYANMAR, 0x1000}, + {HB_Script_Georgian, HB_SCRIPT_GEORGIAN, 0x10A0}, // we don't currently support HB_Script_Ethiopic, it is a placeholder for an upstream merge - //{HB_Script_Ethiopic, 0x1200}, - {HB_Script_Ogham, 0x1680}, - {HB_Script_Runic, 0x16A0}, - {HB_Script_Khmer, 0x1780}, + //{HB_Script_Ethiopic, HB_SCRIPT_ETHIOPIC, 0x1200}, + {HB_Script_Ogham, HB_SCRIPT_OGHAM, 0x1680}, + {HB_Script_Runic, HB_SCRIPT_RUNIC, 0x16A0}, + {HB_Script_Khmer, HB_SCRIPT_KHMER, 0x1780}, }; +static hb_script_t getHBScriptFromHBScriptOld(HB_Script script_old) { + hb_script_t script = HB_SCRIPT_INVALID; + int numSupportedFonts = sizeof(HB_UnicodeMappingArray) / sizeof(HB_UnicodeMapping); + for (int i = 0; i < numSupportedFonts; i++) { + if (script_old == HB_UnicodeMappingArray[i].script_old) { + script = HB_UnicodeMappingArray[i].script; + break; + } + } + return script; +} + // returns 0 for "Not Found" -static SkUnichar getUnicodeFromHBScript(HB_Script script) { +static SkUnichar getUnicodeFromHBScript(hb_script_t script) { SkUnichar unichar = 0; int numSupportedFonts = sizeof(HB_UnicodeMappingArray) / sizeof(HB_UnicodeMapping); for (int i = 0; i < numSupportedFonts; i++) { @@ -1174,7 +1188,7 @@ static SkUnichar getUnicodeFromHBScript(HB_Script script) { } struct TypefaceLookupStruct { - HB_Script script; + hb_script_t script; SkTypeface::Style style; SkPaint::FontVariant fontVariant; SkTypeface* typeface; @@ -1197,7 +1211,7 @@ static int typefaceLookupCompare(const TypefaceLookupStruct& first, return 0; } -SK_API SkTypeface* SkCreateTypefaceForScript(HB_Script script, SkTypeface::Style style, +SK_API SkTypeface* SkCreateTypefaceForScriptNG(hb_script_t script, SkTypeface::Style style, SkPaint::FontVariant fontVariant) { SkTypeface* retTypeface = NULL; @@ -1229,3 +1243,9 @@ SK_API SkTypeface* SkCreateTypefaceForScript(HB_Script script, SkTypeface::Style SkSafeRef(retTypeface); return retTypeface; } + +SK_API SkTypeface* SkCreateTypefaceForScript(HB_Script script, SkTypeface::Style style, + SkPaint::FontVariant fontVariant) { + return SkCreateTypefaceForScriptNG(getHBScriptFromHBScriptOld(script), style, fontVariant); +} + |