]> git.eshelyaron.com Git - emacs.git/commitdiff
* nsterm.m (ns_draw_window_cursor): Draw BAR_CURSOR correct for R2L.
authorJan D <jan.h.d@swipnet.se>
Sun, 29 Aug 2010 10:30:45 +0000 (12:30 +0200)
committerJan D <jan.h.d@swipnet.se>
Sun, 29 Aug 2010 10:30:45 +0000 (12:30 +0200)
src/ChangeLog
src/nsterm.m

index 8a3714bcf0dcbf6f271ef0db9a3131d8f20cfda8..b58557a944e8871c9ece4d5964e54084ac426fc4 100644 (file)
@@ -1,3 +1,7 @@
+2010-08-29  Jan Djärv  <jan.h.d@swipnet.se>
+
+       * nsterm.m (ns_draw_window_cursor): Draw BAR_CURSOR correct for R2L.
+
 2010-08-26  Kenichi Handa  <handa@m17n.org>
 
        * xdisp.c (compute_stop_pos): Pay attention to bidi scan direction
index 2eb84607562184c5fbb91712ec8727b30daf8f42..f0efb948ab9a50af580a3e06cec4fcb237dd74a8 100644 (file)
@@ -2251,6 +2251,11 @@ ns_draw_window_cursor (struct window *w, struct glyph_row *glyph_row,
   struct frame *f = WINDOW_XFRAME (w);
   struct glyph *phys_cursor_glyph;
   int overspill;
+  struct glyph *cursor_glyph;
+
+  /* If cursor is out of bounds, don't draw garbage.  This can happen
+     in mini-buffer windows when switching between echo area glyphs
+     and mini-buffer.  */
 
   NSTRACE (dumpcursor);
 //fprintf(stderr, "drawcursor (%d,%d) activep = %d\tonp = %d\tc_type = %d\twidth = %d\n",x,y, active_p,on_p,cursor_type,cursor_width);
@@ -2328,6 +2333,13 @@ ns_draw_window_cursor (struct window *w, struct glyph_row *glyph_row,
     case BAR_CURSOR:
       s = r;
       s.size.width = min (cursor_width, 2); //FIXME(see above)
+
+      /* If the character under cursor is R2L, draw the bar cursor
+         on the right of its glyph, rather than on the left.  */
+      cursor_glyph = get_phys_cursor_glyph (w);
+      if ((cursor_glyph->resolved_level & 1) != 0)
+        s.origin.x += cursor_glyph->pixel_width - s.size.width;
+
       NSRectFill (s);
       break;
     }