Index: third_party/harfbuzz-ng/src/hb-ot-shape-complex-private.hh |
diff --git a/third_party/harfbuzz-ng/src/hb-ot-shape-complex-private.hh b/third_party/harfbuzz-ng/src/hb-ot-shape-complex-private.hh |
index 8b775fbbd6e21c8e083b46c7ace5b7c5ddd37ce0..ba962b5919715d2c3c9ffe5b68c54379e1f3e08e 100644 |
--- a/third_party/harfbuzz-ng/src/hb-ot-shape-complex-private.hh |
+++ b/third_party/harfbuzz-ng/src/hb-ot-shape-complex-private.hh |
@@ -1,5 +1,5 @@ |
/* |
- * Copyright © 2010,2011 Google, Inc. |
+ * Copyright © 2010,2011,2012 Google, Inc. |
* |
* This is part of HarfBuzz, a text shaping library. |
* |
@@ -30,26 +30,31 @@ |
#include "hb-private.hh" |
#include "hb-ot-map-private.hh" |
+#include "hb-ot-shape-normalize-private.hh" |
/* buffer var allocations, used during the entire shaping process */ |
-#define general_category() var1.u8[0] /* unicode general_category (hb_unicode_general_category_t) */ |
-#define combining_class() var1.u8[1] /* unicode combining_class (uint8_t) */ |
+#define unicode_props0() var1.u8[0] |
+#define unicode_props1() var1.u8[1] |
+ |
+/* buffer var allocations, used during the GSUB/GPOS processing */ |
+#define props_cache() var1.u16[1] /* GSUB/GPOS glyph_props cache */ |
+#define syllable() var2.u8[0] /* GSUB/GPOS shaping boundaries */ |
+#define lig_props() var2.u8[1] /* GSUB/GPOS ligature tracking */ |
/* buffer var allocations, used by complex shapers */ |
-#define complex_var_persistent_u8_0() var2.u8[0] |
-#define complex_var_persistent_u8_1() var2.u8[1] |
-#define complex_var_persistent_u16() var2.u16[0] |
-#define complex_var_temporary_u8_0() var2.u8[2] |
-#define complex_var_temporary_u8_1() var2.u8[3] |
-#define complex_var_temporary_u16() var2.u16[1] |
+#define complex_var_persistent_u8_0() var2.u8[2] |
+#define complex_var_persistent_u8_1() var2.u8[3] |
+#define complex_var_temporary_u8() var2.u8[0] |
#define HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS \ |
HB_COMPLEX_SHAPER_IMPLEMENT (default) /* should be first */ \ |
HB_COMPLEX_SHAPER_IMPLEMENT (arabic) \ |
+ HB_COMPLEX_SHAPER_IMPLEMENT (hangul) \ |
HB_COMPLEX_SHAPER_IMPLEMENT (indic) \ |
+ HB_COMPLEX_SHAPER_IMPLEMENT (thai) \ |
/* ^--- Add new shapers here */ |
enum hb_ot_complex_shaper_t { |
@@ -63,78 +68,152 @@ enum hb_ot_complex_shaper_t { |
static inline hb_ot_complex_shaper_t |
hb_ot_shape_complex_categorize (const hb_segment_properties_t *props) |
{ |
- switch ((int) props->script) |
+ switch ((hb_tag_t) props->script) |
{ |
default: |
return hb_ot_complex_shaper_default; |
+ |
+ /* Unicode-1.1 additions */ |
case HB_SCRIPT_ARABIC: |
- case HB_SCRIPT_MANDAIC: |
case HB_SCRIPT_MONGOLIAN: |
- case HB_SCRIPT_NKO: |
case HB_SCRIPT_SYRIAC: |
+ |
+ /* Unicode-5.0 additions */ |
+ case HB_SCRIPT_NKO: |
+ |
+ /* Unicode-6.0 additions */ |
+ case HB_SCRIPT_MANDAIC: |
+ |
return hb_ot_complex_shaper_arabic; |
+ |
+ /* Unicode-1.1 additions */ |
+ case HB_SCRIPT_HANGUL: |
+ |
+ return hb_ot_complex_shaper_hangul; |
+ |
+ |
+ /* Unicode-1.1 additions */ |
+ case HB_SCRIPT_THAI: |
+ case HB_SCRIPT_LAO: |
+ |
+ return hb_ot_complex_shaper_thai; |
+ |
+ |
+ |
+ /* ^--- Add new shapers here */ |
+ |
+ |
#if 0 |
/* Note: |
* |
* These disabled scripts are listed in ucd/IndicSyllabicCategory.txt, but according |
- * to Martin Hosken do not require complex shaping. |
+ * to Martin Hosken and Jonathan Kew do not require complex shaping. |
+ * |
+ * TODO We should automate figuring out which scripts do not need complex shaping |
* |
* TODO We currently keep data for these scripts in our indic table. Need to fix the |
* generator to not do that. |
*/ |
+ |
/* Simple? */ |
- case HB_SCRIPT_BATAK: |
- case HB_SCRIPT_BRAHMI: |
+ |
+ /* Unicode-3.2 additions */ |
+ case HB_SCRIPT_BUHID: |
case HB_SCRIPT_HANUNOO: |
- case HB_SCRIPT_MEETEI_MAYEK: |
+ |
+ /* Unicode-5.1 additions */ |
case HB_SCRIPT_SAURASHTRA: |
+ /* Unicode-5.2 additions */ |
+ case HB_SCRIPT_MEETEI_MAYEK: |
+ |
+ /* Unicode-6.0 additions */ |
+ case HB_SCRIPT_BATAK: |
+ case HB_SCRIPT_BRAHMI: |
+ |
+ |
/* Simple */ |
- case HB_SCRIPT_KAYAH_LI: |
+ |
+ /* Unicode-1.1 additions */ |
+ /* These have their own shaper now. */ |
case HB_SCRIPT_LAO: |
- case HB_SCRIPT_LIMBU: |
- case HB_SCRIPT_PHAGS_PA: |
- case HB_SCRIPT_SYLOTI_NAGRI: |
+ case HB_SCRIPT_THAI: |
+ |
+ /* Unicode-2.0 additions */ |
+ case HB_SCRIPT_TIBETAN: |
+ |
+ /* Unicode-3.2 additions */ |
case HB_SCRIPT_TAGALOG: |
case HB_SCRIPT_TAGBANWA: |
+ |
+ /* Unicode-4.0 additions */ |
+ case HB_SCRIPT_LIMBU: |
case HB_SCRIPT_TAI_LE: |
+ |
+ /* Unicode-4.1 additions */ |
+ case HB_SCRIPT_SYLOTI_NAGRI: |
+ |
+ /* Unicode-5.0 additions */ |
+ case HB_SCRIPT_PHAGS_PA: |
+ |
+ /* Unicode-5.1 additions */ |
+ case HB_SCRIPT_KAYAH_LI: |
+ |
+ /* Unicode-5.2 additions */ |
case HB_SCRIPT_TAI_VIET: |
- case HB_SCRIPT_THAI: |
- case HB_SCRIPT_TIBETAN: |
+ |
/* May need Indic treatment in the future? */ |
+ |
+ /* Unicode-3.0 additions */ |
case HB_SCRIPT_MYANMAR: |
+ |
+ |
#endif |
- case HB_SCRIPT_BALINESE: |
+ /* Unicode-1.1 additions */ |
case HB_SCRIPT_BENGALI: |
- case HB_SCRIPT_BUGINESE: |
- case HB_SCRIPT_BUHID: |
- case HB_SCRIPT_CHAM: |
case HB_SCRIPT_DEVANAGARI: |
case HB_SCRIPT_GUJARATI: |
case HB_SCRIPT_GURMUKHI: |
- case HB_SCRIPT_JAVANESE: |
- case HB_SCRIPT_KAITHI: |
case HB_SCRIPT_KANNADA: |
- case HB_SCRIPT_KHAROSHTHI: |
- case HB_SCRIPT_KHMER: |
- case HB_SCRIPT_LEPCHA: |
case HB_SCRIPT_MALAYALAM: |
- case HB_SCRIPT_NEW_TAI_LUE: |
case HB_SCRIPT_ORIYA: |
- case HB_SCRIPT_REJANG: |
+ case HB_SCRIPT_TAMIL: |
+ case HB_SCRIPT_TELUGU: |
+ |
+ /* Unicode-3.0 additions */ |
+ case HB_SCRIPT_KHMER: |
case HB_SCRIPT_SINHALA: |
+ |
+ /* Unicode-4.1 additions */ |
+ case HB_SCRIPT_BUGINESE: |
+ case HB_SCRIPT_KHAROSHTHI: |
+ case HB_SCRIPT_NEW_TAI_LUE: |
+ |
+ /* Unicode-5.0 additions */ |
+ case HB_SCRIPT_BALINESE: |
+ |
+ /* Unicode-5.1 additions */ |
+ case HB_SCRIPT_CHAM: |
+ case HB_SCRIPT_LEPCHA: |
+ case HB_SCRIPT_REJANG: |
case HB_SCRIPT_SUNDANESE: |
+ |
+ /* Unicode-5.2 additions */ |
+ case HB_SCRIPT_JAVANESE: |
+ case HB_SCRIPT_KAITHI: |
case HB_SCRIPT_TAI_THAM: |
- case HB_SCRIPT_TAMIL: |
- case HB_SCRIPT_TELUGU: |
- return hb_ot_complex_shaper_indic; |
- /* ^--- Add new shapers here */ |
+ /* Unicode-6.1 additions */ |
+ case HB_SCRIPT_CHAKMA: |
+ case HB_SCRIPT_SHARADA: |
+ case HB_SCRIPT_TAKRI: |
+ |
+ return hb_ot_complex_shaper_indic; |
} |
} |
@@ -170,26 +249,26 @@ hb_ot_shape_complex_collect_features (hb_ot_complex_shaper_t shaper, |
/* |
- * prefer_decomposed() |
+ * normalization_preference() |
* |
* Called during shape_execute(). |
* |
* Shapers should return TRUE if it prefers decomposed (NFD) input rather than precomposed (NFC). |
*/ |
-typedef bool hb_ot_shape_complex_prefer_decomposed_func_t (void); |
+typedef hb_ot_shape_normalization_mode_t hb_ot_shape_complex_normalization_preference_func_t (void); |
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
- HB_INTERNAL hb_ot_shape_complex_prefer_decomposed_func_t _hb_ot_shape_complex_prefer_decomposed_##name; |
+ HB_INTERNAL hb_ot_shape_complex_normalization_preference_func_t _hb_ot_shape_complex_normalization_preference_##name; |
HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
#undef HB_COMPLEX_SHAPER_IMPLEMENT |
-static inline bool |
-hb_ot_shape_complex_prefer_decomposed (hb_ot_complex_shaper_t shaper) |
+static inline hb_ot_shape_normalization_mode_t |
+hb_ot_shape_complex_normalization_preference (hb_ot_complex_shaper_t shaper) |
{ |
switch (shaper) { |
default: |
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
- case hb_ot_complex_shaper_##name: return _hb_ot_shape_complex_prefer_decomposed_##name (); |
+ case hb_ot_complex_shaper_##name: return _hb_ot_shape_complex_normalization_preference_##name (); |
HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
#undef HB_COMPLEX_SHAPER_IMPLEMENT |
} |
@@ -203,7 +282,7 @@ hb_ot_shape_complex_prefer_decomposed (hb_ot_complex_shaper_t shaper) |
* Shapers should use map to get feature masks and set on buffer. |
*/ |
-typedef void hb_ot_shape_complex_setup_masks_func_t (hb_ot_map_t *map, hb_buffer_t *buffer); |
+typedef void hb_ot_shape_complex_setup_masks_func_t (hb_ot_map_t *map, hb_buffer_t *buffer, hb_font_t *font); |
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
HB_INTERNAL hb_ot_shape_complex_setup_masks_func_t _hb_ot_shape_complex_setup_masks_##name; |
HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
@@ -212,12 +291,13 @@ typedef void hb_ot_shape_complex_setup_masks_func_t (hb_ot_map_t *map, hb_buffer |
static inline void |
hb_ot_shape_complex_setup_masks (hb_ot_complex_shaper_t shaper, |
hb_ot_map_t *map, |
- hb_buffer_t *buffer) |
+ hb_buffer_t *buffer, |
+ hb_font_t *font) |
{ |
switch (shaper) { |
default: |
#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
- case hb_ot_complex_shaper_##name: _hb_ot_shape_complex_setup_masks_##name (map, buffer); return; |
+ case hb_ot_complex_shaper_##name: _hb_ot_shape_complex_setup_masks_##name (map, buffer, font); return; |
HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
#undef HB_COMPLEX_SHAPER_IMPLEMENT |
} |