diff options
author | Eli Zaretskii <eliz@gnu.org> | 2010-08-18 19:42:06 +0300 |
---|---|---|
committer | Eli Zaretskii <eliz@gnu.org> | 2010-08-18 19:42:06 +0300 |
commit | 9335210608653cef7a111d096dcfacd7bd87682a (patch) | |
tree | 4b2d8db0f1d851f9dc890793d214613fc75ad228 | |
parent | b5ba2d6f9bdd21771f5dbad663396eef2ec057c8 (diff) | |
download | emacs-9335210608653cef7a111d096dcfacd7bd87682a.tar.gz |
Fix display of bar cursor on right-to-left text.
xterm.c (x_draw_bar_cursor):
w32term.c (x_draw_bar_cursor): If the character under cursor is
R2L, draw the bar cursor on its right rather than on its left.
-rw-r--r-- | src/ChangeLog | 6 | ||||
-rw-r--r-- | src/w32term.c | 5 | ||||
-rw-r--r-- | src/xterm.c | 5 |
3 files changed, 16 insertions, 0 deletions
diff --git a/src/ChangeLog b/src/ChangeLog index 45cccea1ebb..4033a424aed 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,9 @@ +2010-08-18 Eli Zaretskii <eliz@gnu.org> + + * xterm.c (x_draw_bar_cursor): + * w32term.c (x_draw_bar_cursor): If the character under cursor is + R2L, draw the bar cursor on its right rather than on its left. + 2010-08-18 Stefan Monnier <monnier@iro.umontreal.ca> * eval.c (Fdefmacro): Only obey one declaration. diff --git a/src/w32term.c b/src/w32term.c index 947ed5c9d44..992538e0e88 100644 --- a/src/w32term.c +++ b/src/w32term.c @@ -4897,6 +4897,11 @@ x_draw_bar_cursor (struct window *w, struct glyph_row *row, w->phys_cursor_width = width; + /* If the character under cursor is R2L, draw the bar cursor + on the right of its glyph, rather than on the left. */ + if ((cursor_glyph->resolved_level & 1) != 0) + x += cursor_glyph->pixel_width - width; + w32_fill_area (f, hdc, cursor_color, x, WINDOW_TO_FRAME_PIXEL_Y (w, w->phys_cursor.y), width, row->height); diff --git a/src/xterm.c b/src/xterm.c index 4325fb3d991..420c5ccc7fd 100644 --- a/src/xterm.c +++ b/src/xterm.c @@ -7158,6 +7158,11 @@ x_draw_bar_cursor (struct window *w, struct glyph_row *row, int width, enum text w->phys_cursor_width = width; + /* If the character under cursor is R2L, draw the bar cursor + on the right of its glyph, rather than on the left. */ + if ((cursor_glyph->resolved_level & 1) != 0) + x += cursor_glyph->pixel_width - width; + XFillRectangle (dpy, window, gc, WINDOW_TEXT_TO_FRAME_PIXEL_X (w, w->phys_cursor.x), WINDOW_TO_FRAME_PIXEL_Y (w, w->phys_cursor.y), |