The following message is a courtesy copy of an article
that has been posted to comp.unix.shell as well.

>>>>> Arnt Karlsen <a...@c2i.net> writes:
>>>>> On Fri, 16 Sep 2011 00:17:47 +0700, Ivan wrote:

        [Cross-posting to comp.unix.shell for no good reason at all.]

 >> Whitespace is not a problem as long as one remembers to double-quote
 >> Shell $ubstitutions, like:

 >> for i in a b c ; do

 > ..or, e.g.: for i in $(ls /path/to/files/*.txt ) ; do

        No, it isn't whitespace-tolerant, as the result of the unescaped
        $()-substitution is subject to IFS-splitting.  The correct form
        would be:

    for i in /path/to/files/*.txt ; do something ; done 

        Consider, e. g.:

$ ls -1 
a
b c
$ (for x in $(ls *) ; do echo ."$x". ; done) 
.a.
.b.
.c.
$ 

        Moreover, ls(1) is an extra here; the command above requests the
        Shell to search for all the .txt filenames in /path/to/files/,
        then the filenames are passed to ls(1), which is supposed to
        pass them back to the shell unaltered.  There, ls(1) may
        essentially behave the same as, say, $ echo, or $ printf %s\\n.

        This is somewhat akin to UUoC, as in:

$ cat < "$file" | grep something 

        vs. simply:

$ grep something < "$file" 

        Or it may not.  Consider that one of the .txt-filenames refers
        to a directory, like:

$ ls -1RF 
.:
a
b c
d/

./d:
x y
$ (for x in $(ls *) ; do echo ."$x". ; done) 
.a.
.b.
.c.
.d:.
.x.
.y.
$ 

        Note that the above has ‘x’ set to ‘d:’, ‘x’ and ‘y’, neither of
        whose belong to the current directory.

        (NB: the term “path” is also considered obsolete by GNU when
        speaking of “whole names”, as opposed to “search paths”, such
        as, e. g., "$PATH" or "$CDPATH".  In particular, GNU find(1)
        states that -wholename is preferred to -path.)

 >>   txt2pdf -input "${i}.txt" -out "${i}.pdf"
 >> done

 > ..disclaimer: I've only used the alleged obsolete back-tick way. ;o)

        The backticks are harder to both nest and mix with other Shell
        substitutions and escapes.  Consider, e. g.:

$ echo \\\" 
\"
$ 

        To put the stdout of the command above into a Shell variable, we
        may use either the $()-substitution:

$ x=$(echo \\\") ; echo "$y" 
\"
$ 

        or the backticks:

$ y=`echo \\\\\\"` ; echo "$y" 
\"
$ 

        Now, can you explain why the backslashes above have to be
        doubled in the latter case?

-- 
FSF associate member #7257


--
To UNSUBSCRIBE, email to debian-user-requ...@lists.debian.org
with a subject of "unsubscribe". Trouble? Contact listmas...@lists.debian.org
Archive: http://lists.debian.org/86fwjtp3qr....@gray.siamics.net

Reply via email to