summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEli Zaretskii <eliz@gnu.org>2013-06-09 19:37:22 +0300
committerEli Zaretskii <eliz@gnu.org>2013-06-09 19:37:22 +0300
commit52fab9c9b8d690de6e8754995c0027767d356146 (patch)
treef7ab231ad82c10ccb14c8be8abf51fbda1cee1ec /src
parentbf77e2305f392b966805fb7b080570911468709b (diff)
downloademacs-52fab9c9b8d690de6e8754995c0027767d356146.tar.gz
Fix bug #14575 with window-specific overlays with line-prefix or wrap-prefix.
src/xdisp.c (get_it_property): If it->object is a buffer, pass to get-char-property the window that is being rendered, instead of the buffer, to support window-specific overlays.
Diffstat (limited to 'src')
-rw-r--r--src/ChangeLog6
-rw-r--r--src/xdisp.c13
2 files changed, 14 insertions, 5 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index cf5a8c0ee1e..06b738e5043 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,9 @@
+2013-06-09 Eli Zaretskii <eliz@gnu.org>
+
+ * xdisp.c (get_it_property): If it->object is a buffer, pass to
+ get-char-property the window that is being rendered, instead of
+ the buffer, to support window-specific overlays. (Bug#14575)
+
2013-06-08 Eli Zaretskii <eliz@gnu.org>
* bidi.c (bidi_fetch_char): Accept additional argument, the window
diff --git a/src/xdisp.c b/src/xdisp.c
index 5ec72407191..2097929128b 100644
--- a/src/xdisp.c
+++ b/src/xdisp.c
@@ -18971,16 +18971,19 @@ push_prefix_prop (struct it *it, Lisp_Object prop)
static Lisp_Object
get_it_property (struct it *it, Lisp_Object prop)
{
- Lisp_Object position;
+ Lisp_Object position, object = it->object;
- if (STRINGP (it->object))
+ if (STRINGP (object))
position = make_number (IT_STRING_CHARPOS (*it));
- else if (BUFFERP (it->object))
- position = make_number (IT_CHARPOS (*it));
+ else if (BUFFERP (object))
+ {
+ position = make_number (IT_CHARPOS (*it));
+ XSETWINDOW (object, it->w);
+ }
else
return Qnil;
- return Fget_char_property (position, prop, it->object);
+ return Fget_char_property (position, prop, object);
}
/* See if there's a line- or wrap-prefix, and if so, push it on IT. */