all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Stephen Berman <stephen.berman@gmx.net>
To: Heime <heimeborgia@protonmail.com>
Cc: Heime via Users list for the GNU Emacs text editor
	<help-gnu-emacs@gnu.org>
Subject: Re: insert gives args out of range
Date: Fri, 16 Aug 2024 17:34:22 +0200	[thread overview]
Message-ID: <875xs0mqgx.fsf@gmx.net> (raw)
In-Reply-To: <1LrMW6VZOGaiPZeu9oQzAEzURNe5DSG4qEIpTAcMJIYlF_Ror7Qi4fwKLeEtID86cPFTghDDGsf78h3ngmTMitZ_kbjiPZ2L_COpl5uJRFc=@protonmail.com> (Heime's message of "Fri, 16 Aug 2024 15:21:12 +0000")

On Fri, 16 Aug 2024 15:21:12 +0000 Heime <heimeborgia@protonmail.com> wrote:

> On Saturday, August 17th, 2024 at 3:16 AM, Stephen Berman
> <stephen.berman@gmx.net> wrote:
>
>> On Fri, 16 Aug 2024 15:09:55 +0000 Heime heimeborgia@protonmail.com wrote:
>>
>> > On Saturday, August 17th, 2024 at 3:01 AM, Heime
>> > heimeborgia@protonmail.com wrote:
>> >
>> > > On Saturday, August 17th, 2024 at 12:26 AM, Stephen Berman
>> > > stephen.berman@gmx.net wrote:
>> > >
>> > > > On Fri, 16 Aug 2024 12:10:48 +0000 Heime heimeborgia@protonmail.com wrote:
>> > > >
>> > > > > On Saturday, August 17th, 2024 at 12:03 AM, Heime
>> > > > > heimeborgia@protonmail.com wrote:
>> > > > >
>> > > > > > On Friday, August 16th, 2024 at 11:51 PM, Stephen Berman
>> > > > > > stephen.berman@gmx.net wrote:
>> > > > > >
>> > > > > > > On Fri, 16 Aug 2024 10:59:09 +0000 Heime
>> > > > > > > heimeborgia@protonmail.com wrote:
>> > > > > > >
>> > > > > > > > On Friday, August 16th, 2024 at 10:20 PM, Heime
>> > > > > > > > heimeborgia@protonmail.com wrote:
>> > > > > > > >
>> > > > > > > > > On Friday, August 16th, 2024 at 9:54 PM, Stephen Berman
>> > > > > > > > > stephen.berman@gmx.net wrote:
>> > > > > > > > >
>> > > > > > > > > > On Fri, 16 Aug 2024 09:24:23 +0000 Heime
>> > > > > > > > > > heimeborgia@protonmail.com wrote:
>> > > > > > > > > >
>> > > > > > > > > > > I want to display text starting from "(defun" up to the
>> > > > > > > > > > > second blank
>> > > > > > > > > > > line that is encountered.
>> > > > > > > > > > >
>> > > > > > > > > > > But with this code I get
>> > > > > > > > > > >
>> > > > > > > > > > > insert: Args out of range: #<buffer Defun Sections>, 2706, 2804
>> > > > > > > > > > >
>> > > > > > > > > > > (defun display-text ()
>> > > > > > > > > > > "Display the text between a line starting with '(defun' and
>> > > > > > > > > > > the second
>> > > > > > > > > > > blank line."
>> > > > > > > > > > > (interactive)
>> > > > > > > > > > > (let ((output-buffer (get-buffer-create "Defun Sections")))
>> > > > > > > > > > > (with-current-buffer output-buffer
>> > > > > > > > > > > (erase-buffer)) ;; Clear previous contents
>> > > > > > > > > > > (save-excursion
>> > > > > > > > > > > (goto-char (point-min))
>> > > > > > > > > > > (while (re-search-forward "^(defun" nil t)
>> > > > > > > > > > > (let ((start (match-beginning 0))
>> > > > > > > > > > > (blank-lines 0)
>> > > > > > > > > > > end)
>> > > > > > > > > > > ;; Move forward to find the second blank line
>> > > > > > > > > > > (while (and (< blank-lines 2)
>> > > > > > > > > > > (re-search-forward "^\\s-*$" nil t))
>> > > > > > > > > > > (setq blank-lines (1+ blank-lines)))
>> > > > > > > > > > > (setq end (point))
>> > > > > > > > > > > ;; Ensure the range is valid before inserting
>> > > > > > > > > > > (when (> end start)
>> > > > > > > > > > > (with-current-buffer output-buffer
>> > > > > > > > > > > (insert (buffer-substring-no-properties start end) "\n"))))))
>> > > > > > > > > > > ;; Display the output buffer
>> > > > > > > > > > > (display-buffer output-buffer)))
>> > > > > > > > > >
>> > > > > > > > > > You've set `start' and` end' in a different buffer than
>> > > > > > > > > > output-buffer
>> > > > > > > > > > but you're invoking buffer-substring-no-properties with these
>> > > > > > > > > > values in
>> > > > > > > > > > output-buffer, which you've erased, so those values are not in
>> > > > > > > > > > the range
>> > > > > > > > > > of possible values in output-buffer. Try let-binding the
>> > > > > > > > > > result of
>> > > > > > > > > > invoking buffer-substring-no-properties before the second
>> > > > > > > > > > invocation of
>> > > > > > > > > > with-current-buffer.
>> > > > > > > > > >
>> > > > > > > > > > Steve Berman
>> > > > > > > >
>> > > > > > > > I updated as suggested. Although I get the output, the search
>> > > > > > > > stops on
>> > > > > > > > the first
>> > > > > > > > blank line rather than on the second blank line.
>> > > > > > >
>> > > > > > > Consider a buffer "test" with the following content (two blank lines
>> > > > > > > between the defuns):
>> > > > > > >
>> > > > > > > ;;;;;;;;;;;;;
>> > > > > > >
>> > > > > > > (defun f1 ()
>> > > > > > > (ignore))
>> > > > > > >
>> > > > > > > (defun f2 ()
>> > > > > > > (ignore))
>> > > > > > > ;;;;;;;;;;;;;
>> > > > > > >
>> > > > > > > When you call `display-text' in "test", the first evaluation of the
>> > > > > > > sexp (re-search-forward "^\\s-*$" nil t) moves point to the first blank
>> > > > > > > line below the first defun. Where is point after the second evaluation
>> > > > > > > of that sexp? - Steve Berman
>> > > > > >
>> > > > > > It is still at the beginning of the first blank line.
>> > > > >
>> > > > > I do not understand why this happens. Because (point) after
>> > > > > re-search-forward should give me the position at the beginning of the
>> > > > > second blank line that is encountered.
>> > > >
>> > > > The sexp (re-search-forward "^\\s-*$" nil t) succeeds if it find a line
>> > > > containing only zero or more whitespace characters and moves point to
>> > > > the end of the match. If point is on a blank line, the search succeeds,
>> > > > but since the beginning and end of the match coincide, point does not
>> > > > move. If you want point to move, your code needs to accommodate this
>> > > > case. - Steve Berman
>> > >
>> > > Have printed start and end just after (setq end (point))
>> > >
>> > > (message "Start: %d, End: %d" start end)
>> > >
>> > > And the values for start and end are different.
>>
>>
>> `start' holds the value of the beginning of the match for "^(defun", but
>> your problem arises when searching for "^\\s-*$"; you'll see it if you
>> change the message to this:
>>
>> (message "Start: %d, End: %d" (match-beginning 0) (match-end 0))
>>
>> > When the first blank is reached, point moves to that blank, the next search
>> > keeps point at the same place rather than moving to the next blank line.
>>
>>
>> For the reason I explained above. - Steve Berman
>
> I have solved the problem by adding (forward-line 1) after setting blank-lines
>
>           (while (and (< blank-lines 2)
>                       (re-search-forward "^\\s-*$" nil t))
>             (setq blank-lines (1+ blank-lines))
>             ;; Move point forward to avoid re-matching the same blank line
>             (forward-line 1))
>
> Could this fail on some circumstances ?

Depends on what you consider failure: with the buffer "*test*" I gave as
an example above, output-buffer contains not just two but three empty
lines between the two defuns, and not just one but two empty lines at
the end; is that what you want?

Steve Berman



  reply	other threads:[~2024-08-16 15:34 UTC|newest]

Thread overview: 18+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-08-16  9:24 insert gives args out of range Heime
2024-08-16  9:54 ` Stephen Berman
2024-08-16 10:20   ` Heime
2024-08-16 10:59     ` Heime
2024-08-16 11:51       ` Stephen Berman
2024-08-16 12:03         ` Heime
2024-08-16 12:10           ` Heime
2024-08-16 12:26             ` Stephen Berman
2024-08-16 15:01               ` Heime
2024-08-16 15:09                 ` Heime
2024-08-16 15:16                   ` Stephen Berman
2024-08-16 15:21                     ` Heime
2024-08-16 15:34                       ` Stephen Berman [this message]
2024-08-16 17:32                         ` Heime
2024-08-16 21:29                           ` Stephen Berman
2024-08-16 21:47                             ` Heime
2024-08-16 22:26                               ` Stephen Berman
2024-08-17  9:47                                 ` Heime

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=875xs0mqgx.fsf@gmx.net \
    --to=stephen.berman@gmx.net \
    --cc=heimeborgia@protonmail.com \
    --cc=help-gnu-emacs@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.