Here's a #bash pop quiz.
-
@vwbusguy The guy who runs the indently.io Python YouTube channel posts little quizzes like this one quite often.
They're like little nucleation points for getting me started down some rabbit hole (as was your poll).
-
Space Catitude 🚀replied to Scott Williams 🐧 last edited by
I really don't do bash scripting much, but typing this into the shell actually gives me:
bash: [[1]]: command not found
-
Scott Williams 🐧replied to Space Catitude 🚀 last edited by
@TerryHancock You need a space after [[ and before ]] . It's a bash-ism shorthand for the test command.
-
@jbowen
Back when I was on Twitter, I used to do bash quizzes regularly after I was inspired by someone that did it with python. -
Gonzalo Nemmi :runbsd:replied to Gonzalo Nemmi :runbsd: last edited by
@vwbusguy ok, so .. now with time on my hands I understand that I can confirm that my previous assumption was correct, that is to say, that the ' && echo "true" ' will only execute if the previous command ( a test in this case ) didn't fail and returned with an exit status of "0".
The same applies to while and if. The value tested by the while and if commands is the "exit status" of the last simple command following the "while" or "if".
-
Scott Williams 🐧replied to Scott Williams 🐧 last edited by
In C based languages, 1 is truthy, but in bash 0 is truthy. However, in this case, the same result happens whether or not it's a 0 or a 1 because without any expression, bash will treat it as a string test which returns true for any non-zero length string.
#4 is the correct answer.
Shout out to @fedops for getting it right first in the comments!
-
Scott Williams 🐧replied to Jonathan Lamothe last edited by
Scott Williams 🐧 (@[email protected])
Content warning: The answer
Mastodon (mastodon.online)
-
Fabio Valentinireplied to Scott Williams 🐧 last edited by
@vwbusguy thanks - one more reason for why I think bash is cursed
-
Scott Williams 🐧replied to Fabio Valentini last edited by
@decathorpe They're all cursed.
-
R.L. Dane :Debian: :OpenBSD: 🍵replied to Fabio Valentini last edited by
Disagree. The whole point of the
[[ ]]
syntax is to examine and compare strings (and also filenames). There's no expectation of numerical or boolean analysis.Now, if you said that bash is cursed because of the string substitution syntax, I'm with you on that one. Its horrifying.
-
Scott Williams 🐧replied to R.L. Dane :Debian: :OpenBSD: 🍵 last edited by [email protected]
@rl_dane @decathorpe I disagree. If you `man test` you'll see that numerical analysis is indeed supported and I use it regularly as a way to evaluate timestamps (converting to epoch seconds and using gt, lt, etc).
Here's an example of where I use it for both boolean and numerical analysis:
Calculates a new serial for a bind zone SOA. Assumes single zone per file.
Calculates a new serial for a bind zone SOA. Assumes single zone per file. - calculate_new_bind_serial.sh
Gist (gist.github.com)
-
R.L. Dane :Debian: :OpenBSD: 🍵replied to Scott Williams 🐧 last edited by
But
test
is analogous to[ ]
, not[[ ]]
. -
Scott Williams 🐧replied to R.L. Dane :Debian: :OpenBSD: 🍵 last edited by [email protected]
@rl_dane @decathorpe [[ supports everything [ does. [[ is the bash-ism where [ is POSIX, and test in bash is a built-in, IIRC. None of this negates what I said in my previous post.
-
R.L. Dane :Debian: :OpenBSD: 🍵replied to Scott Williams 🐧 last edited by
My understanding is that
test
|[ ]
was branched off into[[ ]]
for string/filename analysis/comparison, and(( ))
for numerical operations.[[ ]]
does seem to retain the legacy-gt
|-lt
operators oftest
|[ ]
, which is kinda cursed, admittedly. -
Scott Williams 🐧replied to R.L. Dane :Debian: :OpenBSD: 🍵 last edited by
@rl_dane @decathorpe No, what [[ adds is stuff like && and || for and/or logic and using ! for negation. It supports the same evals as test, and I should also note that "test", [, [[ are built-ins for bash, so it's not actually calling the test binary in a script unless you give the full path to it.
-
DHeadshot's Altreplied to R.L. Dane :Debian: :OpenBSD: 🍵 last edited by
@rl_dane
I just use `test` directly for everything as it makes more sense, so the above would be `test ! -z 1 && echo "true" || echo "false"`, which is actually readable!
@vwbusguy @decathorpe -
Scott Williams 🐧replied to DHeadshot's Alt last edited by [email protected]
@ddlyh @rl_dane @decathorpe test -n would be the equivalent one in this case.