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 fed167dec3beffbbb61260d27152368ebd190999..8b775fbbd6e21c8e083b46c7ace5b7c5ddd37ce0 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 (C) 2010 Google, Inc. |
+ * Copyright © 2010,2011 Google, Inc. |
* |
* This is part of HarfBuzz, a text shaping library. |
* |
@@ -27,26 +27,114 @@ |
#ifndef HB_OT_SHAPE_COMPLEX_PRIVATE_HH |
#define HB_OT_SHAPE_COMPLEX_PRIVATE_HH |
-#include "hb-private.h" |
+#include "hb-private.hh" |
-#include "hb-ot-shape-private.hh" |
+#include "hb-ot-map-private.hh" |
-HB_BEGIN_DECLS |
+/* 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) */ |
+ |
+/* 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 HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS \ |
+ HB_COMPLEX_SHAPER_IMPLEMENT (default) /* should be first */ \ |
+ HB_COMPLEX_SHAPER_IMPLEMENT (arabic) \ |
+ HB_COMPLEX_SHAPER_IMPLEMENT (indic) \ |
+ /* ^--- Add new shapers here */ |
+ |
+enum hb_ot_complex_shaper_t { |
+#define HB_COMPLEX_SHAPER_IMPLEMENT(name) hb_ot_complex_shaper_##name, |
+ HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
+ /* Just here to avoid enum trailing comma: */ |
+ hb_ot_complex_shaper_generic = hb_ot_complex_shaper_default |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
+}; |
+ |
static inline hb_ot_complex_shaper_t |
hb_ot_shape_complex_categorize (const hb_segment_properties_t *props) |
{ |
- switch ((int) props->script) { |
+ switch ((int) props->script) |
+ { |
+ default: |
+ return hb_ot_complex_shaper_default; |
+ |
case HB_SCRIPT_ARABIC: |
- case HB_SCRIPT_NKO: |
- case HB_SCRIPT_SYRIAC: |
case HB_SCRIPT_MANDAIC: |
case HB_SCRIPT_MONGOLIAN: |
+ case HB_SCRIPT_NKO: |
+ case HB_SCRIPT_SYRIAC: |
return hb_ot_complex_shaper_arabic; |
- default: |
- return hb_ot_complex_shaper_none; |
+#if 0 |
+ /* Note: |
+ * |
+ * These disabled scripts are listed in ucd/IndicSyllabicCategory.txt, but according |
+ * to Martin Hosken do not require 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: |
+ case HB_SCRIPT_HANUNOO: |
+ case HB_SCRIPT_MEETEI_MAYEK: |
+ case HB_SCRIPT_SAURASHTRA: |
+ |
+ /* Simple */ |
+ case HB_SCRIPT_KAYAH_LI: |
+ case HB_SCRIPT_LAO: |
+ case HB_SCRIPT_LIMBU: |
+ case HB_SCRIPT_PHAGS_PA: |
+ case HB_SCRIPT_SYLOTI_NAGRI: |
+ case HB_SCRIPT_TAGALOG: |
+ case HB_SCRIPT_TAGBANWA: |
+ case HB_SCRIPT_TAI_LE: |
+ case HB_SCRIPT_TAI_VIET: |
+ case HB_SCRIPT_THAI: |
+ case HB_SCRIPT_TIBETAN: |
+ |
+ /* May need Indic treatment in the future? */ |
+ case HB_SCRIPT_MYANMAR: |
+#endif |
+ |
+ case HB_SCRIPT_BALINESE: |
+ 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_SINHALA: |
+ case HB_SCRIPT_SUNDANESE: |
+ case HB_SCRIPT_TAI_THAM: |
+ case HB_SCRIPT_TAMIL: |
+ case HB_SCRIPT_TELUGU: |
+ return hb_ot_complex_shaper_indic; |
+ |
+ /* ^--- Add new shapers here */ |
} |
} |
@@ -57,18 +145,53 @@ hb_ot_shape_complex_categorize (const hb_segment_properties_t *props) |
* |
* Called during shape_plan(). |
* |
- * Shapers should use plan->map to add their features. |
+ * Shapers should use map to add their features and callbacks. |
*/ |
-HB_INTERNAL void _hb_ot_shape_complex_collect_features_arabic (hb_ot_shape_plan_t *plan, const hb_segment_properties_t *props); |
+typedef void hb_ot_shape_complex_collect_features_func_t (hb_ot_map_builder_t *map, const hb_segment_properties_t *props); |
+#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
+ HB_INTERNAL hb_ot_shape_complex_collect_features_func_t _hb_ot_shape_complex_collect_features_##name; |
+ HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
static inline void |
-hb_ot_shape_complex_collect_features (hb_ot_shape_plan_t *plan, |
+hb_ot_shape_complex_collect_features (hb_ot_complex_shaper_t shaper, |
+ hb_ot_map_builder_t *map, |
const hb_segment_properties_t *props) |
{ |
- switch (plan->shaper) { |
- case hb_ot_complex_shaper_arabic: _hb_ot_shape_complex_collect_features_arabic (plan, props); return; |
- case hb_ot_complex_shaper_none: default: return; |
+ switch (shaper) { |
+ default: |
+#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
+ case hb_ot_complex_shaper_##name: _hb_ot_shape_complex_collect_features_##name (map, props); return; |
+ HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
+ } |
+} |
+ |
+ |
+/* |
+ * prefer_decomposed() |
+ * |
+ * 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); |
+#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
+ HB_INTERNAL hb_ot_shape_complex_prefer_decomposed_func_t _hb_ot_shape_complex_prefer_decomposed_##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) |
+{ |
+ switch (shaper) { |
+ default: |
+#define HB_COMPLEX_SHAPER_IMPLEMENT(name) \ |
+ case hb_ot_complex_shaper_##name: return _hb_ot_shape_complex_prefer_decomposed_##name (); |
+ HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
} |
} |
@@ -77,21 +200,29 @@ hb_ot_shape_complex_collect_features (hb_ot_shape_plan_t *plan, |
* |
* Called during shape_execute(). |
* |
- * Shapers should use c->plan.map to get feature masks and set on buffer. |
+ * Shapers should use map to get feature masks and set on buffer. |
*/ |
-HB_INTERNAL void _hb_ot_shape_complex_setup_masks_arabic (hb_ot_shape_context_t *c); |
+typedef void hb_ot_shape_complex_setup_masks_func_t (hb_ot_map_t *map, hb_buffer_t *buffer); |
+#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 |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
static inline void |
-hb_ot_shape_complex_setup_masks (hb_ot_shape_context_t *c) |
+hb_ot_shape_complex_setup_masks (hb_ot_complex_shaper_t shaper, |
+ hb_ot_map_t *map, |
+ hb_buffer_t *buffer) |
{ |
- switch (c->plan->shaper) { |
- case hb_ot_complex_shaper_arabic: _hb_ot_shape_complex_setup_masks_arabic (c); return; |
- case hb_ot_complex_shaper_none: default: return; |
+ 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; |
+ HB_COMPLEX_SHAPERS_IMPLEMENT_SHAPERS |
+#undef HB_COMPLEX_SHAPER_IMPLEMENT |
} |
} |
-HB_END_DECLS |
#endif /* HB_OT_SHAPE_COMPLEX_PRIVATE_HH */ |