Mercurial > hg > xemacs-beta
diff src/insdel.c @ 5879:77d7b77909c2
Move extents.c to working in byte positions only; fix a bug, extent_detach()
src/ChangeLog addition:
2015-03-27 Aidan Kehoe <kehoea@parhasard.net>
Fix a small bug, extent_detach(); minimise needless char-byte
conversion, extents.c, sticking to byte positions in general in
this file.
* extents.c:
* extents.c (signal_single_extent_changed):
Pass byte endpoints to
gutter_extent_signal_changed_region_maybe(),
buffer_extent_signal_changed_region().
* extents.c (extent_detach):
Call signal_extent_changed() correctly, pass both extent endpoints
rather than just the byte and character variants of the start.
* extents.c (struct report_extent_modification_closure):
Do this in terms of byte positions.
* extents.c (report_extent_modification_mapper):
Use byte positions, only converting to characters when we are
definitely calling Lisp.
* extents.c (report_extent_modification):
Use byte positions in this API, move the byte-char conversion to
our callers, simplifying extents.c (it all now works in byte
positions).
* extents.h:
Update report_extent_modification's prototype.
* gutter.c (gutter_extent_signal_changed_region_maybe):
Use byte positions here, avoids needless byte-char conversion.
* gutter.h:
Update the prototype here.
* insdel.c:
* insdel.c (buffer_extent_signal_changed_region):
Implement this in terms of byte positions.
* insdel.c (signal_before_change):
* insdel.c (signal_after_change):
Call report_extent_modification() with byte positions, doing the
char->byte conversion here rather than leaving it to extents.c.
* insdel.h:
* insdel.h (struct each_buffer_change_data):
The extent unchanged info now describes bytecounts.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Fri, 27 Mar 2015 23:39:49 +0000 |
parents | 65d65b52d608 |
children |
line wrap: on
line diff
--- a/src/insdel.c Thu Mar 26 20:47:12 2015 -0400 +++ b/src/insdel.c Fri Mar 27 23:39:49 2015 +0000 @@ -570,15 +570,15 @@ } void -buffer_extent_signal_changed_region (struct buffer *buf, Charbpos start, - Charbpos end) +buffer_extent_signal_changed_region (struct buffer *buf, Bytebpos start, + Bytebpos end) { if (buf->changes->begin_extent_unchanged < 0 || - buf->changes->begin_extent_unchanged > start - BUF_BEG (buf)) - buf->changes->begin_extent_unchanged = start - BUF_BEG (buf); + buf->changes->begin_extent_unchanged > start - BYTE_BUF_BEG (buf)) + buf->changes->begin_extent_unchanged = start - BYTE_BUF_BEG (buf); if (buf->changes->end_extent_unchanged < 0 || - buf->changes->end_extent_unchanged > BUF_Z (buf) - end) - buf->changes->end_extent_unchanged = BUF_Z (buf) - end; + buf->changes->end_extent_unchanged > BYTE_BUF_Z (buf) - end) + buf->changes->end_extent_unchanged = BYTE_BUF_Z (buf) - end; } void @@ -837,10 +837,16 @@ if (end < BUF_BEGV (buf)) end = BUF_BEGV (buf); if (end > BUF_ZV (buf)) end = BUF_ZV (buf); - MAP_INDIRECT_BUFFERS (buf, mbuf, bufcons) - { - report_extent_modification (wrap_buffer (mbuf), start, end, 0); - } + { + Bytexpos byte_start = charbpos_to_bytebpos (buf, start); + Bytexpos byte_end = charbpos_to_bytebpos (buf, end); + + MAP_INDIRECT_BUFFERS (buf, mbuf, bufcons) + { + report_extent_modification (wrap_buffer (mbuf), byte_start, + byte_end, 0); + } + } unbind_to (speccount); /* Only now do we indicate that the before-change-functions have @@ -930,12 +936,17 @@ if (orig_end < BUF_BEGV (buf)) orig_end = BUF_BEGV (buf); if (orig_end > BUF_ZV (buf)) orig_end = BUF_ZV (buf); - MAP_INDIRECT_BUFFERS (buf, mbuf, bufcons) - { - buffer = wrap_buffer (mbuf); - report_extent_modification (buffer, start, new_end, 1); - } - unbind_to (speccount); /* sets inside_change_hook back to 0 */ + { + Bytexpos byte_start = charbpos_to_bytebpos (buf, start); + Bytexpos byte_new_end = charbpos_to_bytebpos (buf, new_end); + + MAP_INDIRECT_BUFFERS (buf, mbuf, bufcons) + { + buffer = wrap_buffer (mbuf); + report_extent_modification (buffer, byte_start, byte_new_end, 1); + } + unbind_to (speccount); /* sets inside_change_hook back to 0 */ + } } }