4610
Comment: Initial version
|
3735
mammamia; http://www.diyalcohol.com/viewtopic.php?p=258016#258016 buy prozac; http://genekeysministries.com/index.php?topic=1111.0 prozac uk; http://www.dinero-ya.info/modules.php?name=Forums&file=vie
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
#pragma section-numbers 2 = Bash Pitfalls = [[TableOfContents]] == for i in `ls *.mp3` == One of the most common mistakes ["BASH"] programmers make is to write a loop like this: {{{ for i in `ls *.mp3`; do # Wrong! some command $i # Wrong! done }}} This breaks when the user has a file with a space in its name. Why? Because the output of the `ls *.mp3` command substitution undergoes word splitting. Assuming we have a file named {{{01 - Don't Eat the Yellow Snow.mp3}}} in the current directory, the {{{for}}} loop will iterate over each word in the resulting file name (namely: "01", "-", "Don't", "Eat", and so on). You can't double-quote the substitution either: {{{ for i in "`ls *.mp3`"; do # Wrong! ... }}} This causes the entire output of the {{{ls}}} command to be treated as a single word, and instead of iterating over each file name in the output list, the loop will only execute ''once'', with {{{i}}} taking on a value which is the concatenation of all the file names (with spaces between them). In addition to this, the use of {{{ls}}} is just plain unnecessary. It's an external command, which simply isn't needed to do the job. So, what's the right way to do it? {{{ for i in *.mp3; do # Right! some command "$i" done }}} Let Bash expand the list of filenames for you. The expansion will ''not'' be subject to word splitting. Each filename that's matched by the {{{*.mp3}}} pattern will be treated as a separate word and, the loop will iterate once per file name. The astute reader will notice the double quotes in the second line. This leads to our second common pitfall. == cp $file $target == What's wrong with the command shown above? Well, nothing, '''if'' you happen to know in advance that {{{$file}}} and {{{$target}}} have no white space in them. But if you don't know that in advance, or if you're paranoid, or if you're just trying to develop good habits, then you should quote your variable references to ''avoid'' having them undergo word splitting. {{{ mv "$file" "$target" }}} Without the double quotes, you'll get a command like {{{mv 01 - Don't Eat the Yellow Snow.mp3 /mnt/usb}}} and then you'll get errors like {{{mv: cannot stat `01': No such file or directory}}}. With the double quotes, all's well. == [ $foo = "bar" ] == This is really the same as the previous pitfall, but I repeat it because it's ''so'' important. In the example above, the quotes are in the wrong place. You do ''not'' need to quote a string literal in bash. But you ''should'' quote your variables if you aren't sure whether they could contain white space. {{{ [ "$foo" = bar ] # Right! }}} Another way you could write this in bash involves the {{{[[}}} keyword, which extends and embraces the old {{{test}}} command (also known as {{{[}}}). {{{ [[ $foo = bar ]] # Also right! }}} You don't need to quote variable references within {{{[[ ]]}}} because they don't undergo word splitting in that context. On the other hand, quoting them won't hurt anything either. == [ "$foo" = bar && "$bar" = foo ] == You can't use {{{&&}}} inside the old {{{test}}} (or {{{[}}}) command. The Bash parser sees {{{&&}}} outside of {{{[[ ]]}}} or {{{(( ))}}} and breaks your command into ''two'' commands, before and after the {{{&&}}}. Use one of these instead: {{{ [ "$foo" = bar -a "$bar" = foo ] # Right! [ "$foo" = bar ] && [ "$bar" = foo ] # Also right! [[ $foo = bar && $bar = foo ]] # Also right! }}} == [[ $foo > 7 ]] == The {{{[[ ]]}}} operator is ''not'' used for an ArithmeticExpression. It's used for strings only. If you want to do a numeric comparison against the constant 7, you must use {{{(( ))}}} instead: {{{ ((foo > 7)) # Right! }}} == grep foo bar | while read line; do ((count++)); done == The code above looks OK at first glance, doesn't it? Sure, it's just a poor implementation of {{{grep -c}}}, but it's intended as a simplistic example. So why doesn't it work? The variable {{{count}}} will be unchanged after the loop terminates, much to the surprise of Bash developers everywhere. The reason this code does not work as expected is because each command in a pipeline is executed in a separate subshell. The changes to the {{{count}}} variable within the loop's subshell aren't reflected within the parent shell (the script in which the code occurs). For solutions to this, please see [wiki:Self:BashFaq#faq24 Bash FAQ #24]. |
mammamia; http://www.diyalcohol.com/viewtopic.php?p=258016#258016 buy prozac; http://genekeysministries.com/index.php?topic=1111.0 prozac uk; http://www.dinero-ya.info/modules.php?name=Forums&file=viewtopic&p=517915#517915 buy cheap prozac online; http://www.grantnewsnetwork.com/portal/modules.php?name=Forums&file=viewtopic&p=350231&sid=2e27fb80500c10cf8cc9923d86c9f5ee#350231 prozac generic; http://www.desiyell.com/phpbb/viewtopic.php?p=64176#64176 purchase prozac; http://leadmarket.com/forum/viewtopic.php?p=113382#113382 prozac; http://www.viibs.hostingarcade.com/BB/viewtopic.php?p=21967#21967 buy cheap prozac; http://forum.clubmix-project.com/index.php?topic=2685.0 prozac; http://www.venturecapitalnewsnetwork.com/forum/index.php?topic=1816.0 buy prozac; http://leadmarket.com/forum/viewtopic.php?p=113376#113376 cheap prozac usa; http://sharpmeadow.se/phpBBnew//viewtopic.php?p=32249#32249 buy generic prozac; http://www.desiyell.com/phpbb/viewtopic.php?p=64179#64179 prozac; http://www.strikeengine.com/yourforum/viewtopic.php?p=1890#1890 prozac; http://www.lc.camcom.it/agora_innovazione/forum/viewtopic.php?p=20988#20988 prozac; http://v100.vspring.com/phpBB2//viewtopic.php?p=35984#35984 prozac cheap; http://cubic.lnxnt.org/trolloc_forum/viewtopic.php?p=24709#24709 prozac order; http://gluaiseacht.nologic.org/phpBB2/viewtopic.php?p=39463#39463 cheap prozac online; http://www.vgwf.net/showthread.php?p=102054#post102054 buy cheap prozac; http://forum.mobile-centers.com/showthread.php?p=109126#post109126 prozac; http://www.dnac.org/ece///////viewtopic.php?p=25103#25103 buy prozac online; http://www.viibs.hostingarcade.com/BB/viewtopic.php?p=21970#21970 buy prozac; http://gofishgreatlakes.com/fishingforums/index.php?topic=23567.0 buy prozac; http://fubarbreaks.co.uk/fubarbreaks/viewtopic.php?p=166235#166235 prozac; http://bluedogdemocrats.us/Forum/index.php?topic=2621.0 generic prozac; http://www.rolroyce.com/foros/viewtopic.php?p=34472#34472 prozac; http://spacesbloggers.com/forum/viewtopic.php?p=5778#5778 online prozac; http://www.essexandsuffolksquash.co.uk/phpBB/viewtopic.php?p=385209#385209 prozac online; http://foro.fisi-acm.info/index.php?topic=1675.0 prozac; http://www.rolroyce.com/foros/viewtopic.php?p=34477#34477 prozac; http://provagilda.helloweb.eu/viewtopic.php?p=42108#42108 prozac; http://www.venturecapitalnewsnetwork.com/forum/index.php?topic=1815.0 purchase generic prozac online; http://www.bike.co.uk/forum/showthread.php?p=191822#post191822 prozac; http://country2.com/foro/viewtopic.php?p=77284#77284 prozac purchase; http://www.strikeengine.com/yourforum/viewtopic.php?p=1889#1889 prozac; http://docevidarestaurante.com/forum/viewtopic.php?p=43658#43658 order prozac; http://www.resolvequery.com/forum/viewtopic.php?p=182671#182671 prozac; http://ignition500.com/forum/viewtopic.php?p=10203#10203 prozac online; http://memorybooknook.com/MBNforum/index.php?topic=1463.0 prozac order; http://www.planet-domination.com/modules.php?name=Forums&file=viewtopic&p=172515#172515 prozac; http://memorybooknook.com/MBNforum/index.php?topic=1462.0 online prozac buy; http://www.resolvequery.com/forum/viewtopic.php?p=182667#182667 prozac online purchase; http://gofishgreatlakes.com/fishingforums/index.php?topic=23568.0 prozac; http://www.javateak.co.uk/logcabins/viewtopic.php?p=6823#6823 prozac; http://www.sandiegohealthdirectory.com/forum/viewtopic.php?p=19986#19986 purchase cheap prozac; http://cubic.lnxnt.org/trolloc_forum/viewtopic.php?p=24710#24710 generic prozac; http://iuda.haos.ro/viewtopic.php?p=1910#1910 prozac; http://sandiegohealthdirectory.com/forum/viewtopic.php?p=19989#19989 prozac uk; http://ignition500.com/forum/viewtopic.php?p=10208#10208 order cheap prozac; |
mammamia; http://www.diyalcohol.com/viewtopic.php?p=258016#258016 buy prozac; http://genekeysministries.com/index.php?topic=1111.0 prozac uk; http://www.dinero-ya.info/modules.php?name=Forums&file=viewtopic&p=517915#517915 buy cheap prozac online; http://www.grantnewsnetwork.com/portal/modules.php?name=Forums&file=viewtopic&p=350231&sid=2e27fb80500c10cf8cc9923d86c9f5ee#350231 prozac generic; http://www.desiyell.com/phpbb/viewtopic.php?p=64176#64176 purchase prozac; http://leadmarket.com/forum/viewtopic.php?p=113382#113382 prozac; http://www.viibs.hostingarcade.com/BB/viewtopic.php?p=21967#21967 buy cheap prozac; http://forum.clubmix-project.com/index.php?topic=2685.0 prozac; http://www.venturecapitalnewsnetwork.com/forum/index.php?topic=1816.0 buy prozac; http://leadmarket.com/forum/viewtopic.php?p=113376#113376 cheap prozac usa; http://sharpmeadow.se/phpBBnew//viewtopic.php?p=32249#32249 buy generic prozac; http://www.desiyell.com/phpbb/viewtopic.php?p=64179#64179 prozac; http://www.strikeengine.com/yourforum/viewtopic.php?p=1890#1890 prozac; http://www.lc.camcom.it/agora_innovazione/forum/viewtopic.php?p=20988#20988 prozac; http://v100.vspring.com/phpBB2//viewtopic.php?p=35984#35984 prozac cheap; http://cubic.lnxnt.org/trolloc_forum/viewtopic.php?p=24709#24709 prozac order; http://gluaiseacht.nologic.org/phpBB2/viewtopic.php?p=39463#39463 cheap prozac online; http://www.vgwf.net/showthread.php?p=102054#post102054 buy cheap prozac; http://forum.mobile-centers.com/showthread.php?p=109126#post109126 prozac; http://www.dnac.org/ece///////viewtopic.php?p=25103#25103 buy prozac online; http://www.viibs.hostingarcade.com/BB/viewtopic.php?p=21970#21970 buy prozac; http://gofishgreatlakes.com/fishingforums/index.php?topic=23567.0 buy prozac; http://fubarbreaks.co.uk/fubarbreaks/viewtopic.php?p=166235#166235 prozac; http://bluedogdemocrats.us/Forum/index.php?topic=2621.0 generic prozac; http://www.rolroyce.com/foros/viewtopic.php?p=34472#34472 prozac; http://spacesbloggers.com/forum/viewtopic.php?p=5778#5778 online prozac; http://www.essexandsuffolksquash.co.uk/phpBB/viewtopic.php?p=385209#385209 prozac online; http://foro.fisi-acm.info/index.php?topic=1675.0 prozac; http://www.rolroyce.com/foros/viewtopic.php?p=34477#34477 prozac; http://provagilda.helloweb.eu/viewtopic.php?p=42108#42108 prozac; http://www.venturecapitalnewsnetwork.com/forum/index.php?topic=1815.0 purchase generic prozac online; http://www.bike.co.uk/forum/showthread.php?p=191822#post191822 prozac; http://country2.com/foro/viewtopic.php?p=77284#77284 prozac purchase; http://www.strikeengine.com/yourforum/viewtopic.php?p=1889#1889 prozac; http://docevidarestaurante.com/forum/viewtopic.php?p=43658#43658 order prozac; http://www.resolvequery.com/forum/viewtopic.php?p=182671#182671 prozac; http://ignition500.com/forum/viewtopic.php?p=10203#10203 prozac online; http://memorybooknook.com/MBNforum/index.php?topic=1463.0 prozac order; http://www.planet-domination.com/modules.php?name=Forums&file=viewtopic&p=172515#172515 prozac; http://memorybooknook.com/MBNforum/index.php?topic=1462.0 online prozac buy; http://www.resolvequery.com/forum/viewtopic.php?p=182667#182667 prozac online purchase; http://gofishgreatlakes.com/fishingforums/index.php?topic=23568.0 prozac; http://www.javateak.co.uk/logcabins/viewtopic.php?p=6823#6823 prozac; http://www.sandiegohealthdirectory.com/forum/viewtopic.php?p=19986#19986 purchase cheap prozac; http://cubic.lnxnt.org/trolloc_forum/viewtopic.php?p=24710#24710 generic prozac; http://iuda.haos.ro/viewtopic.php?p=1910#1910 prozac; http://sandiegohealthdirectory.com/forum/viewtopic.php?p=19989#19989 prozac uk; http://ignition500.com/forum/viewtopic.php?p=10208#10208 order cheap prozac;