From: Eli Zaretskii Date: Mon, 15 Aug 2011 08:16:09 +0000 (+0300) Subject: Support RLE/RLO/LRE/LRO for determining paragraph direction. X-Git-Tag: emacs-pretest-24.0.90~104^2~124^2~49 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=324133141121953a2bad19b6734401dd52d83726;p=emacs.git Support RLE/RLO/LRE/LRO for determining paragraph direction. src/bidi.c (bidi_paragraph_init): Support zero value of bidi_ignore_explicit_marks_for_paragraph_level. --- diff --git a/src/ChangeLog b/src/ChangeLog index 628875f7ae6..fa94aed1383 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,8 @@ 2011-08-15 Eli Zaretskii + * bidi.c (bidi_paragraph_init): Support zero value of + bidi_ignore_explicit_marks_for_paragraph_level. + * xdisp.c (move_it_in_display_line_to): Don't reset pixel coordinates of the iterator when restoring from ppos_it. (Bug#9296) diff --git a/src/bidi.c b/src/bidi.c index 2879198ce31..383553f6d91 100644 --- a/src/bidi.c +++ b/src/bidi.c @@ -79,6 +79,11 @@ typedef enum { STRONG } bidi_category_t; +/* UAX#9 says to search only for L, AL, or R types of characters, and + ignore RLE, RLO, LRE, and LRO, when determining the base paragraph + level. Yudit indeed ignores them. This variable is therefore set + by default to ignore them, but setting it to zero will take them + into account. */ extern int bidi_ignore_explicit_marks_for_paragraph_level EXTERNALLY_VISIBLE; int bidi_ignore_explicit_marks_for_paragraph_level = 1; @@ -1178,10 +1183,6 @@ bidi_paragraph_init (bidi_dir_t dir, struct bidi_it *bidi_it, int no_default_p) type = bidi_get_type (ch, NEUTRAL_DIR); for (pos += nchars, bytepos += ch_len; - /* NOTE: UAX#9 says to search only for L, AL, or R types - of characters, and ignore RLE, RLO, LRE, and LRO. - However, I'm not sure it makes sense to omit those 4; - should try with and without that to see the effect. */ (bidi_get_category (type) != STRONG) || (bidi_ignore_explicit_marks_for_paragraph_level && (type == RLE || type == RLO @@ -1206,9 +1207,13 @@ bidi_paragraph_init (bidi_dir_t dir, struct bidi_it *bidi_it, int no_default_p) pos += nchars; bytepos += ch_len; } - if (type == STRONG_R || type == STRONG_AL) /* P3 */ + if ((type == STRONG_R || type == STRONG_AL) /* P3 */ + || (!bidi_ignore_explicit_marks_for_paragraph_level + && (type == RLO || type == RLE))) bidi_it->paragraph_dir = R2L; - else if (type == STRONG_L) + else if (type == STRONG_L + || (!bidi_ignore_explicit_marks_for_paragraph_level + && (type == LRO || type == LRE))) bidi_it->paragraph_dir = L2R; if (!string_p && no_default_p && bidi_it->paragraph_dir == NEUTRAL_DIR)