Mercurial > emacs
changeset 65215:c37b7f6542ec
(update_syntax_table): Properly reproduce the special +1
setting of e_property at the end of the buffer when bumping into the
INTERVALS_AT_ONCE limit.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Mon, 29 Aug 2005 20:49:28 +0000 |
parents | aefa34357e06 |
children | 262bf19addb4 |
files | src/ChangeLog src/syntax.c |
diffstat | 2 files changed, 22 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/src/ChangeLog Mon Aug 29 20:49:01 2005 +0000 +++ b/src/ChangeLog Mon Aug 29 20:49:28 2005 +0000 @@ -1,7 +1,17 @@ +2005-08-29 Stefan Monnier <monnier@iro.umontreal.ca> + + * syntax.c (update_syntax_table): Properly reproduce the special +1 + setting of e_property at the end of the buffer when bumping into the + INTERVALS_AT_ONCE limit. + 2005-08-27 Eli Zaretskii <eliz@gnu.org> * emacs.c (USAGE1): Fix the description of the -Q option. +2005-08-26 Stefan Monnier <monnier@iro.umontreal.ca> + + * xdisp.c (pos_visible_p): Yet another int/Lisp_Object mixup (YAILOM). + 2005-08-26 Kim F. Storm <storm@cua.dk> * xdisp.c (resize_mini_window): Fix 2005-08-20 change. @@ -12,8 +22,8 @@ * keyboard.c (kbd_buffer_get_event) [MAC_OS]: Make events for ICONIFY/DEICONIFY_EVENT. - * macterm.c (mac_copy_area, mac_copy_area_with_mask): Restore - background color. + * macterm.c (mac_copy_area, mac_copy_area_with_mask): + Restore background color. (mac_handle_visibility_change): New function. (x_make_frame_invisible, x_iconify_frame) (XTread_socket) [!USE_CARBON_EVENTS]: Use it.
--- a/src/syntax.c Mon Aug 29 20:49:01 2005 +0000 +++ b/src/syntax.c Mon Aug 29 20:49:28 2005 +0000 @@ -133,7 +133,7 @@ { Lisp_Object tmp_table; int cnt = 0, invalidate = 1; - INTERVAL i, oldi; + INTERVAL i; if (init) { @@ -164,7 +164,7 @@ gl_state.e_property = INTERVAL_LAST_POS (i) - gl_state.offset; goto update; } - oldi = i = count > 0 ? gl_state.forward_i : gl_state.backward_i; + i = count > 0 ? gl_state.forward_i : gl_state.backward_i; /* We are guaranteed to be called with CHARPOS either in i, or further off. */ @@ -249,7 +249,8 @@ } else { - gl_state.b_property = i->position + LENGTH (i) - gl_state.offset; + gl_state.b_property + = i->position + LENGTH (i) - gl_state.offset; gl_state.backward_i = i; } return; @@ -258,7 +259,12 @@ { if (count > 0) { - gl_state.e_property = i->position + LENGTH (i) - gl_state.offset; + gl_state.e_property + = i->position + LENGTH (i) - gl_state.offset + /* e_property at EOB is not set to ZV but to ZV+1, so that + we can do INC(from);UPDATE_SYNTAX_TABLE_FORWARD without + having to check eob between the two. */ + + (NULL_INTERVAL_P (next_interval (i)) ? 1 : 0); gl_state.forward_i = i; } else