a special way just before the sweep phase, and after stripping
some of its elements that are not needed any more. */
- if (buffer->overlays)
- {
- struct interval_node *node;
- buffer_overlay_iter_start (buffer, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
-
- while ((node = buffer_overlay_iter_next (buffer)))
- mark_overlay (XOVERLAY (node->data));
- buffer_overlay_iter_finish (buffer);
- }
+ struct interval_node *node;
+ buffer_overlay_iter_start (buffer, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
+ while ((node = buffer_overlay_iter_next (buffer)))
+ mark_overlay (XOVERLAY (node->data));
+ buffer_overlay_iter_finish (buffer);
/* If this is an indirect buffer, mark its base buffer. */
if (buffer->base_buffer && !VECTOR_MARKED_P (buffer->base_buffer))
copy_overlays (struct buffer *from, struct buffer *to)
{
eassert (to && ! to->overlays);
-
struct interval_node *node;
- if (! from->overlays)
- return;
-
buffer_overlay_iter_start (from, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
-
while ((node = buffer_overlay_iter_next (from)))
{
Lisp_Object ov = node->data;
{
struct interval_node *node;
- if (buffer->overlays)
- {
- buffer_overlay_iter_start (buffer, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
- while ((node = buffer_overlay_iter_next (buffer)))
- XOVERLAY (node->data)->buffer = other;
- buffer_overlay_iter_finish (buffer);
- }
- if (other->overlays)
- {
- buffer_overlay_iter_start (other, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
- while ((node = buffer_overlay_iter_next (other)))
- XOVERLAY (node->data)->buffer = buffer;
- buffer_overlay_iter_finish (other);
- }
+ buffer_overlay_iter_start (buffer, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
+ while ((node = buffer_overlay_iter_next (buffer)))
+ XOVERLAY (node->data)->buffer = other;
+ buffer_overlay_iter_finish (buffer);
+
+ buffer_overlay_iter_start (other, PTRDIFF_MIN, PTRDIFF_MAX, ITREE_ASCENDING);
+ while ((node = buffer_overlay_iter_next (other)))
+ XOVERLAY (node->data)->buffer = buffer;
+ buffer_overlay_iter_finish (other);
+
/* Swap the interval trees. */
void *tmp = buffer->overlays;
buffer->overlays = other->overlays;
ptrdiff_t len = *len_ptr;
ptrdiff_t next = ZV;
Lisp_Object *vec = *vec_ptr;
-
struct interval_node *node;
- if (! current_buffer->overlays)
- return idx;
-
buffer_overlay_iter_start (current_buffer, beg,
/* Find empty OV at Z ? */
(end >= Z && empty) ? Z + 1 : ZV,
ptrdiff_t next = ZV;
struct interval_node *node;
- if (! current_buffer->overlays)
- return next;
-
buffer_overlay_iter_start (current_buffer, pos, ZV, ITREE_ASCENDING);
while ((node = buffer_overlay_iter_next (current_buffer)))
{
struct interval_node *node;
ptrdiff_t prev = BEGV;
- if (! current_buffer->overlays)
- return prev;
-
buffer_overlay_iter_start (current_buffer, BEGV, pos, ITREE_DESCENDING);
while ((node = buffer_overlay_iter_next (current_buffer)))
{
struct interval_node *node;
bool result = false;
- if (! current_buffer->overlays)
- return false;
-
/* We need to find overlays ending in pos, as well as empty ones at
pos. */
buffer_overlay_iter_start (current_buffer,
(void)
{
Lisp_Object overlays = Qnil;
+ struct interval_node *node;
- if (current_buffer->overlays)
- {
- struct interval_node *node;
+ buffer_overlay_iter_start (current_buffer, BEG, Z, ITREE_DESCENDING);
+ while ((node = buffer_overlay_iter_next (current_buffer)))
+ overlays = Fcons (node->data, overlays);
+ buffer_overlay_iter_finish (current_buffer);
- buffer_overlay_iter_start (current_buffer, BEG, Z, ITREE_DESCENDING);
- while ((node = buffer_overlay_iter_next (current_buffer)))
- overlays = Fcons (node->data, overlays);
- buffer_overlay_iter_finish (current_buffer);
- }
return Fcons (overlays, Qnil);
}
void
evaporate_overlays (ptrdiff_t pos)
{
- Lisp_Object hit_list;
+ Lisp_Object hit_list = Qnil;
struct interval_node *node;
- if (! current_buffer->overlays)
- return;
-
- hit_list = Qnil;
buffer_overlay_iter_start (current_buffer, pos, pos, ITREE_ASCENDING);
-
while ((node = buffer_overlay_iter_next (current_buffer)))
{
if (node->end == pos
hit_list = Fcons (node->data, hit_list);
}
buffer_overlay_iter_finish (current_buffer);
+
for (; CONSP (hit_list); hit_list = XCDR (hit_list))
Fdelete_overlay (XCAR (hit_list));
}
} \
while (false)
- if (current_buffer->overlays)
- {
- buffer_overlay_iter_start (current_buffer,
- charpos - 1, charpos + 1, ITREE_DESCENDING);
- /* Process overlays. */
- while ((node = buffer_overlay_iter_next (current_buffer)))
- {
- overlay = node->data;
- eassert (OVERLAYP (overlay));
- start = node->begin;
- end = node->end;
-
- /* Skip this overlay if it doesn't start or end at IT's current
- position. */
- if (end != charpos && start != charpos)
- continue;
-
- /* Skip this overlay if it doesn't apply to IT->w. */
- window = Foverlay_get (overlay, Qwindow);
- if (WINDOWP (window) && XWINDOW (window) != it->w)
- continue;
-
- /* If the text ``under'' the overlay is invisible, both before-
- and after-strings from this overlay are visible; start and
- end position are indistinguishable. */
- invisible = Foverlay_get (overlay, Qinvisible);
- invis = TEXT_PROP_MEANS_INVISIBLE (invisible);
-
- /* If overlay has a non-empty before-string, record it. */
- if ((start == charpos || (end == charpos && invis != 0))
- && (str = Foverlay_get (overlay, Qbefore_string), STRINGP (str))
- && SCHARS (str))
- RECORD_OVERLAY_STRING (overlay, str, false);
-
- /* If overlay has a non-empty after-string, record it. */
- if ((end == charpos || (start == charpos && invis != 0))
- && (str = Foverlay_get (overlay, Qafter_string), STRINGP (str))
- && SCHARS (str))
- RECORD_OVERLAY_STRING (overlay, str, true);
- }
- buffer_overlay_iter_finish (current_buffer);
- }
+
+ buffer_overlay_iter_start (current_buffer,
+ charpos - 1, charpos + 1, ITREE_DESCENDING);
+ /* Process overlays. */
+ while ((node = buffer_overlay_iter_next (current_buffer)))
+ {
+ overlay = node->data;
+ eassert (OVERLAYP (overlay));
+ start = node->begin;
+ end = node->end;
+
+ /* Skip this overlay if it doesn't start or end at IT's current
+ position. */
+ if (end != charpos && start != charpos)
+ continue;
+
+ /* Skip this overlay if it doesn't apply to IT->w. */
+ window = Foverlay_get (overlay, Qwindow);
+ if (WINDOWP (window) && XWINDOW (window) != it->w)
+ continue;
+
+ /* If the text ``under'' the overlay is invisible, both before-
+ and after-strings from this overlay are visible; start and
+ end position are indistinguishable. */
+ invisible = Foverlay_get (overlay, Qinvisible);
+ invis = TEXT_PROP_MEANS_INVISIBLE (invisible);
+
+ /* If overlay has a non-empty before-string, record it. */
+ if ((start == charpos || (end == charpos && invis != 0))
+ && (str = Foverlay_get (overlay, Qbefore_string), STRINGP (str))
+ && SCHARS (str))
+ RECORD_OVERLAY_STRING (overlay, str, false);
+
+ /* If overlay has a non-empty after-string, record it. */
+ if ((end == charpos || (start == charpos && invis != 0))
+ && (str = Foverlay_get (overlay, Qafter_string), STRINGP (str))
+ && SCHARS (str))
+ RECORD_OVERLAY_STRING (overlay, str, true);
+ }
+ buffer_overlay_iter_finish (current_buffer);
#undef RECORD_OVERLAY_STRING