# HG changeset patch # User Stefan Monnier # Date 1125348568 0 # Node ID c37b7f6542ec5d0e7ec73fe7d7f5748a3f065e4b # Parent aefa34357e063fe9b85311ae25f6efc46effd4af (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. diff -r aefa34357e06 -r c37b7f6542ec src/ChangeLog --- 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 + + * 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 * emacs.c (USAGE1): Fix the description of the -Q option. +2005-08-26 Stefan Monnier + + * xdisp.c (pos_visible_p): Yet another int/Lisp_Object mixup (YAILOM). + 2005-08-26 Kim F. Storm * 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. diff -r aefa34357e06 -r c37b7f6542ec src/syntax.c --- 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