From: Zach Riggle <zachriggle@gmail.com>
To: Daniel Shahaf <d.s@daniel.shahaf.name>,
Bart Schaefer <schaefer@brasslantern.com>
Cc: "Lawrence Velázquez" <larryv@zsh.org>, "Zsh Users" <zsh-users@zsh.org>
Subject: Re: Odd behavior with various (q) array modifiers and non-printable characters (backspace, newline)
Date: Tue, 19 Oct 2021 14:17:48 -0500 [thread overview]
Message-ID: <CAMP9c5kLJnSzowD9hNo2LQOnVKqDhQ1=3Zy=wfYeb5iEAn+5yw@mail.gmail.com> (raw)
In-Reply-To: <20210814155252.GG11391@tarpaulin.shahaf.local2>
[-- Attachment #1: Type: text/plain, Size: 1827 bytes --]
Apologies for resurrecting this thread, but I wanted to revisit and thank
everybody for the help.
I ran into some issues where my
print-a-$-and-then-the-minally-quoted-version-of-this-array-of-scalars when
dealing with regex, due to "builtin echo" treating '\bfoo bar\b'
incorrectly.
I attempted a variety of things to fix the problem, but going back through
this thread really helped a bunch. I had written additional code that
relied in builtin echo. "command echo" and the issue is resolved.
On Sat, Aug 14, 2021 at 10:52 AM Daniel Shahaf <d.s@daniel.shahaf.name>
wrote:
> Lawrence Velázquez wrote on Wed, Aug 11, 2021 at 17:42:09 -0400:
> > On Wed, Aug 11, 2021, at 5:16 PM, Bart Schaefer wrote:
> > > You need to stop testing things with "echo". The "echo" builtin
> > > interprets some backslash escapes itself, which will confuse you about
> > > what the quoting options have done.
> > >
> > > Repeat all your tests instead with
> > > printf "%s\n" ${(q)...}
> > > and so on, and come back if you still have questions.
> >
> > Additionally, \b and \n are not interpreted in double quotes, so
> > your initial data does not actually contain BS or NL characters.
> ⋮
> > As per the QUOTING section of zshmisc(1):
> >
> > Inside double quotes (""), parameter and command substitution
> > occur, and `\' quotes the characters `\', ``', `"', `$',
> > and the first character of $histchars (default `!').
>
> There are third-party plugins that implement syntax highlighting at the
> prompt (I happen to co-maintain one such plugin). Those plugins are
> aware of the quoted docs section, so on input such as
> .
> % foo "bar \n \\ \x"
> .
> they will correctly highlight only the «\\» as an escape sequence, and
> everything else as literals.
>
[-- Attachment #2: Type: text/html, Size: 2399 bytes --]
next prev parent reply other threads:[~2021-10-19 19:18 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-08-11 20:29 Zach Riggle
2021-08-11 21:16 ` Bart Schaefer
2021-08-11 21:42 ` Lawrence Velázquez
2021-08-11 23:25 ` Zach Riggle
2021-08-12 0:22 ` Bart Schaefer
2021-08-12 0:34 ` Lawrence Velázquez
2021-08-12 13:34 ` Ray Andrews
2021-08-12 0:36 ` Lawrence Velázquez
2021-08-14 15:52 ` Daniel Shahaf
2021-10-19 19:17 ` Zach Riggle [this message]
2021-10-21 14:24 ` Daniel Shahaf
2021-10-21 15:23 ` Bart Schaefer
2021-08-11 21:27 ` Bart Schaefer
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='CAMP9c5kLJnSzowD9hNo2LQOnVKqDhQ1=3Zy=wfYeb5iEAn+5yw@mail.gmail.com' \
--to=zachriggle@gmail.com \
--cc=d.s@daniel.shahaf.name \
--cc=larryv@zsh.org \
--cc=schaefer@brasslantern.com \
--cc=zsh-users@zsh.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.vuxu.org/mirror/zsh/
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 NNTP newsgroup(s).