]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix assertion failure when displaying stretch glyphs under linum-mode.
authorEli Zaretskii <eliz@gnu.org>
Wed, 21 Sep 2011 08:13:18 +0000 (04:13 -0400)
committerEli Zaretskii <eliz@gnu.org>
Wed, 21 Sep 2011 08:13:18 +0000 (04:13 -0400)
 src/xdisp.c (pop_it): Allow it->object that is a cons cell to pass
 the xassert test.
 src/dispextern.h (struct it): Update the comment documenting what
 can it->OBJECT be.

src/ChangeLog
src/dispextern.h
src/xdisp.c

index 17b53216e8377538621a0b378a5320df9933f3de..dff41f1dbbfc06d1d248da5bae9f57cb7527144c 100644 (file)
@@ -1,3 +1,11 @@
+2011-09-21  Eli Zaretskii  <eliz@gnu.org>
+
+       * xdisp.c (pop_it): Allow it->object that is a cons cell to pass
+       the xassert test.
+
+       * dispextern.h (struct it): Update the comment documenting what
+       can it->OBJECT be.
+
 2011-09-20  Eli Zaretskii  <eliz@gnu.org>
 
        * xdisp.c (set_cursor_from_row): If the row ends in a newline from
index 65284121588a3ace640fd257bb8505c2d43c6d4d..3c157371ef37a969d9f06f83739b9a52ada8fb02 100644 (file)
@@ -2398,9 +2398,19 @@ struct it
   Lisp_Object font_height;
 
   /* Object and position where the current display element came from.
-     Object can be a Lisp string in case the current display element
-     comes from an overlay string, or it is buffer.  It may also be nil
-     during mode-line update.  Position is a position in object.  */
+     Object is normally the buffer which is being rendered, but it can
+     also be a Lisp string in case the current display element comes
+     from an overlay string or from a display string (before- or
+     after-string).  It may also be nil when a C string is being
+     rendered, e.g., during mode-line or header-line update.  It can
+     also be a cons cell of the form `(space ...)', when we produce a
+     stretch glyph from a `display' specification.  Finally, it can be
+     a zero-valued Lisp integer, but only temporarily, when we are
+     producing special glyphs for display purposes, like truncation
+     and continuation glyphs, or blanks that extend each line to the
+     edge of the window on a TTY.
+
+     Position is the current iterator position in object.  */
   Lisp_Object object;
   struct text_pos position;
 
index 3505d18d502af1250746d963851ca89b2596a859..0d870671c696d7995476cb62549709989900e362 100644 (file)
@@ -5459,7 +5459,8 @@ pop_it (struct it *it)
                && IT_BYTEPOS (*it) == it->bidi_it.bytepos)
               || (STRINGP (it->object)
                   && IT_STRING_CHARPOS (*it) == it->bidi_it.charpos
-                  && IT_STRING_BYTEPOS (*it) == it->bidi_it.bytepos));
+                  && IT_STRING_BYTEPOS (*it) == it->bidi_it.bytepos)
+              || (CONSP (it->object) && it->method == GET_FROM_STRETCH));
     }
 }