[vte/wip/egmont/bidi: 15/87] fribidi_get_mirror_char
- From: Egmont Koblinger <egmontkob src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vte/wip/egmont/bidi: 15/87] fribidi_get_mirror_char
- Date: Tue, 9 Apr 2019 09:09:48 +0000 (UTC)
commit ee03df160f0c43e3290f19158588f214e6dffccc
Author: Egmont Koblinger <egmont gmail com>
Date: Mon Aug 20 14:19:06 2018 +0200
fribidi_get_mirror_char
src/vtedraw.cc | 12 ++++++++++++
1 file changed, 12 insertions(+)
---
diff --git a/src/vtedraw.cc b/src/vtedraw.cc
index 7e52cfe2..c3f9b7ff 100644
--- a/src/vtedraw.cc
+++ b/src/vtedraw.cc
@@ -26,6 +26,10 @@
#include <glib.h>
#include <gtk/gtk.h>
+#ifdef WITH_FRIBIDI
+#include <fribidi.h>
+#endif
+
#include "vtedraw.hh"
#include "vtedefines.hh"
#include "debug.h"
@@ -1475,7 +1479,15 @@ _vte_draw_text_internal (struct _vte_draw *draw,
if (G_UNLIKELY (requests[i].mirror)) {
// FIXME what if 'c' is actually a real vteunistr?
+#ifdef WITH_FRIBIDI
+ /* Prefer the FriBidi variant as that's more likely
+ * to be in sync with the rest of our BiDi stuff. */
+ fribidi_get_mirror_char (c, &c);
+#else
+ /* Fall back to glib, so that we still get mirrored
+ * characters in explicit RTL mode. */
g_unichar_get_mirror_char (c, &c);
+#endif
}
struct unistr_info *uinfo = font_info_get_unistr_info (font, c);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]