Groups | Search | Server Info | Keyboard shortcuts | Login | Register


Groups > gnu.bash.bug > #11250

Re: extra \1 in declare -p

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>

Show all headers | View raw


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


Thread

Re: extra \1 in declare -p Chet Ramey <chet.ramey@case.edu> - 2015-07-22 08:45 -0400

csiph-web