diff options
author | Gregory Heytings <gregory@heytings.org> | 2022-10-30 17:00:35 +0100 |
---|---|---|
committer | Gregory Heytings <gregory@heytings.org> | 2022-10-30 17:00:35 +0100 |
commit | aef803d6c3d61004f15d0bc82fa7bf9952302312 (patch) | |
tree | 087c444f788cda27006ddc066ad430f62f5ac02a /src/editfns.c | |
parent | 3bf19c417fd39766ee9c7a793c9faadd3bd88478 (diff) | |
parent | 3fa4cca3d244f51e471e7779c934278731fc21e9 (diff) | |
download | emacs-aef803d6c3d61004f15d0bc82fa7bf9952302312.tar.gz emacs-aef803d6c3d61004f15d0bc82fa7bf9952302312.tar.bz2 emacs-aef803d6c3d61004f15d0bc82fa7bf9952302312.zip |
Merge master into feature/improved-locked-narrowing.
Diffstat (limited to 'src/editfns.c')
-rw-r--r-- | src/editfns.c | 78 |
1 files changed, 27 insertions, 51 deletions
diff --git a/src/editfns.c b/src/editfns.c index 8018065568c..c7cc63d8d3e 100644 --- a/src/editfns.c +++ b/src/editfns.c @@ -1,6 +1,6 @@ /* Lisp functions pertaining to editing. -*- coding: utf-8 -*- -Copyright (C) 1985-1987, 1989, 1993-2022 Free Software Foundation, Inc. +Copyright (C) 1985-2022 Free Software Foundation, Inc. This file is part of GNU Emacs. @@ -265,51 +265,20 @@ If you set the marker not to point anywhere, the buffer will have no mark. */) /* Find all the overlays in the current buffer that touch position POS. Return the number found, and store them in a vector in VEC - of length LEN. */ + of length LEN. + + Note: this can return overlays that do not touch POS. The caller + should filter these out. */ static ptrdiff_t -overlays_around (EMACS_INT pos, Lisp_Object *vec, ptrdiff_t len) +overlays_around (ptrdiff_t pos, Lisp_Object *vec, ptrdiff_t len) { - ptrdiff_t idx = 0; - - for (struct Lisp_Overlay *tail = current_buffer->overlays_before; - tail; tail = tail->next) - { - Lisp_Object overlay = make_lisp_ptr (tail, Lisp_Vectorlike); - Lisp_Object end = OVERLAY_END (overlay); - ptrdiff_t endpos = OVERLAY_POSITION (end); - if (endpos < pos) - break; - Lisp_Object start = OVERLAY_START (overlay); - ptrdiff_t startpos = OVERLAY_POSITION (start); - if (startpos <= pos) - { - if (idx < len) - vec[idx] = overlay; - /* Keep counting overlays even if we can't return them all. */ - idx++; - } - } - - for (struct Lisp_Overlay *tail = current_buffer->overlays_after; - tail; tail = tail->next) - { - Lisp_Object overlay = make_lisp_ptr (tail, Lisp_Vectorlike); - Lisp_Object start = OVERLAY_START (overlay); - ptrdiff_t startpos = OVERLAY_POSITION (start); - if (pos < startpos) - break; - Lisp_Object end = OVERLAY_END (overlay); - ptrdiff_t endpos = OVERLAY_POSITION (end); - if (pos <= endpos) - { - if (idx < len) - vec[idx] = overlay; - idx++; - } - } - - return idx; + /* Find all potentially rear-advance overlays at (POS - 1). Find + all overlays at POS, so end at (POS + 1). Find even empty + overlays, which due to the way 'overlays-in' works implies that + we might also fetch empty overlays starting at (POS + 1). */ + return overlays_in (pos - 1, pos + 1, false, &vec, &len, + true, false, NULL); } DEFUN ("get-pos-property", Fget_pos_property, Sget_pos_property, 2, 3, 0, @@ -369,11 +338,12 @@ at POSITION. */) if (!NILP (tem)) { /* Check the overlay is indeed active at point. */ - Lisp_Object start = OVERLAY_START (ol), finish = OVERLAY_END (ol); - if ((OVERLAY_POSITION (start) == posn - && XMARKER (start)->insertion_type == 1) - || (OVERLAY_POSITION (finish) == posn - && XMARKER (finish)->insertion_type == 0)) + if ((OVERLAY_START (ol) == posn + && OVERLAY_FRONT_ADVANCE_P (ol)) + || (OVERLAY_END (ol) == posn + && ! OVERLAY_REAR_ADVANCE_P (ol)) + || OVERLAY_START (ol) > posn + || OVERLAY_END (ol) < posn) ; /* The overlay will not cover a char inserted at point. */ else { @@ -3597,8 +3567,15 @@ styled_format (ptrdiff_t nargs, Lisp_Object *args, bool message) || float_conversion || conversion == 'i' || conversion == 'o' || conversion == 'x' || conversion == 'X')) - error ("Invalid format operation %%%c", - STRING_CHAR ((unsigned char *) format - 1)); + { + unsigned char *p = (unsigned char *) format - 1; + if (multibyte_format) + error ("Invalid format operation %%%c", STRING_CHAR (p)); + else + error (*p <= 127 ? "Invalid format operation %%%c" + : "Invalid format operation char #o%03o", + *p); + } else if (! (FIXNUMP (arg) || ((BIGNUMP (arg) || FLOATP (arg)) && conversion != 'c'))) error ("Format specifier doesn't match argument type"); @@ -4565,7 +4542,6 @@ ring. */) transpose_markers (start1, end1, start2, end2, start1_byte, start1_byte + len1_byte, start2_byte, start2_byte + len2_byte); - fix_start_end_in_overlays (start1, end2); } else { |