unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Alan Mackenzie <acm@muc.de>
To: Andreas Schwab <schwab@linux-m68k.org>
Cc: emacs-devel@gnu.org
Subject: Re: buffer-string considered as a Bad Thing.
Date: Tue, 4 Jun 2024 20:51:51 +0000	[thread overview]
Message-ID: <Zl9-Z201PL_FBZFr@ACM> (raw)
In-Reply-To: <878qzk8nkz.fsf@igel.home>

Hello, Andreas.

On Tue, Jun 04, 2024 at 22:22:52 +0200, Andreas Schwab wrote:
> On Jun 04 2024, Alan Mackenzie wrote:

> > As an example, in pp, the function pp-to-string does this.  To see the
> > effect, try

> >     M-: (pp "foo \"bar\" baz")

> > ..  This gets printed correctly to the temporary buffer  *temp* as:

> >     "foo \"bar\" baz" ;; (a 13 character string)

> > , but buffer-string wrongly converts those literal characters to

> >     "foo \\\"bar\\\" baz" ;; (a 15 character string)

> That's not what I get.

> ELISP> (pp-to-string "foo \"bar\" baz")
> "\"foo \\\"bar\\\" baz\""

> This string correctly represents the contents of the buffer.

That may well be, but the contents of that buffer don't reflect the
contents of the original string which was printed by pp.  This string
contained no backslash characters.  The output string contains two of
them.

pp-to-string prints (in the sense of read-eval-print loop) its argument
to the buffer.  To get that argument back from the buffer, it needs to be
_read_, not merely copied.

Did you consider my two suggestions for fixing this?  If so, what did you
think of them?

> -- 
> Andreas Schwab, schwab@linux-m68k.org
> GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
> "And now for something completely different."

-- 
Alan Mackenzie (Nuremberg, Germany).



  reply	other threads:[~2024-06-04 20:51 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-06-04 19:05 buffer-string considered as a Bad Thing Alan Mackenzie
2024-06-04 20:22 ` Andreas Schwab
2024-06-04 20:51   ` Alan Mackenzie [this message]
2024-06-04 21:24     ` Andreas Schwab

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

  List information: https://www.gnu.org/software/emacs/

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

  git send-email \
    --in-reply-to=Zl9-Z201PL_FBZFr@ACM \
    --to=acm@muc.de \
    --cc=emacs-devel@gnu.org \
    --cc=schwab@linux-m68k.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 public inbox

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

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).