diff options
author | Adam Spragg <adam@spra.gg> | 2022-04-04 15:02:37 +0100 |
---|---|---|
committer | Adam Spragg <adam@spra.gg> | 2022-04-04 15:02:37 +0100 |
commit | e69d9645d4525f288a8e2b8a99b2abe582ea92cc (patch) | |
tree | 32d2411ceacde1d6d426c46a682c97ce9ed62b7a /adu-download.service | |
parent | 1e1e75f0d5c6e6bfbf67b36266aa97edc7fb8bf1 (diff) |
Fix upgrade count when there are no upgrades
There's a difference between
cmd | wc -l
and
x="$(cmd)"; echo "$x" | wc -l
in that the assignment in the latter removes a trailing newline **if one
exists**, but the "echo" always adds one. This means that if `cmd`
produces no output, the former has 0 lines, and the latter has 1 (empty)
line.
I've not found an easy way to fix this in a way that `wc` can tell the
difference between an empty line and a non-empty one, so I had to find a
separate way to count non-empty lines.
I did try `echo "$x" | grep . | wc -l`, but `shellcheck` complains with
[SC2126](https://github.com/koalaman/shellcheck/wiki/SC2126). The
suggested alternative, `echo "$x" | grep -c .`, causes a failure on
empty inputs (i.e. when there are no upgrades) because `grep` exits with
a failure status if no lines are selected.
My options were then to go with `grep | wc` and silence the warning, or
do `grep -c | cat` to mask the `grep` failure (again). Given that they
both have the same number of commands in the pipe, but `cat` is probably
*slightly* cheaper than `wc`, and the `cat` version doesn't require
adding a `shellcheck`-silencing comment, let's go with that.
Diffstat (limited to 'adu-download.service')
0 files changed, 0 insertions, 0 deletions