Groups | Search | Server Info | Keyboard shortcuts | Login | Register
Groups > gnu.bash.bug > #11250
| From | Chet Ramey <chet.ramey@case.edu> |
|---|---|
| Newsgroups | gnu.bash.bug |
| Subject | Re: extra \1 in declare -p |
| Date | 2015-07-22 08:45 -0400 |
| Message-ID | <mailman.7257.1437569153.904.bug-bash@gnu.org> (permalink) |
| References | <CAAZkfoKirh-7ZOV329tnzr-6HJN1paNFhVVE4g04xzs-nEeQFQ@mail.gmail.com> |
On 7/20/15 2:23 PM, isabella parakiss wrote:
> Hi, about this bug:
> http://lists.gnu.org/archive/html/bug-bash/2003-03/msg00093.html
>
> The fix was to add this in lib/sh/shquote.c
> else if (c == CTLESC || c == CTLNUL)
> *r++ = CTLESC;
>
> I think the fix it was applied twice, it should only check this in the
> prompt string, right?
>
>
> Now declare -p produces output that can't be eval'ed.
>
> $ var=$'x\1y\177z'; declare -p var | sed -n l
> declare -- var="x\001\001y\001\177z"$
>
>
> Removing lines 151-152 (from the 4.4 alpha branch) seems to fix this.
> The duplicate code keeps checking the prompt in lines 297-298.
> (${var@P} is expanded by that part so it should be fine...)
> I hope it won't cause other problems.
Thanks, this looks like a good fix. I'll check other uses of sh_double_quote.
Chet
--
``The lyf so short, the craft so long to lerne.'' - Chaucer
``Ars longa, vita brevis'' - Hippocrates
Chet Ramey, ITS, CWRU chet@case.edu http://cnswww.cns.cwru.edu/~chet/
Back to gnu.bash.bug | Previous | Next | Find similar
Re: extra \1 in declare -p Chet Ramey <chet.ramey@case.edu> - 2015-07-22 08:45 -0400
csiph-web