]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix display of bar cursor on right-to-left text.
authorEli Zaretskii <eliz@gnu.org>
Wed, 18 Aug 2010 16:42:06 +0000 (19:42 +0300)
committerEli Zaretskii <eliz@gnu.org>
Wed, 18 Aug 2010 16:42:06 +0000 (19:42 +0300)
 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.

src/ChangeLog
src/w32term.c
src/xterm.c

index 45cccea1ebb0ea837db15fe80171641cf0c1d776..4033a424aed4dfaac0e0b014ddebc79352ce135b 100644 (file)
@@ -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.
index 947ed5c9d4409097d445d6248fee9510b98ff341..992538e0e880c0a978ea0cb2f75e8a3d884320e0 100644 (file)
@@ -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);
index 4325fb3d9918153de14d522286cf7a6437d718cc..420c5ccc7fd099f00289568791e6003d3b9bf4da 100644 (file)
@@ -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),