Page MenuHomeFreeBSD

Remove an unneeded 'tail -n 1' from a pipeline
ClosedPublic

Authored by lidl on Mar 4 2019, 2:44 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Mar 30, 4:46 PM
Unknown Object (File)
Mon, Mar 30, 12:00 PM
Unknown Object (File)
Fri, Mar 27, 2:13 AM
Unknown Object (File)
Thu, Mar 26, 11:15 PM
Unknown Object (File)
Thu, Mar 26, 1:58 PM
Unknown Object (File)
Sat, Mar 21, 11:44 PM
Unknown Object (File)
Tue, Mar 17, 6:07 AM
Unknown Object (File)
Fri, Mar 13, 7:59 AM

Details

Summary

When piping to awk, it's almost always an anti-pattern to use 'grep' first.

When not in a pipeline, sometimes it is faster to use tail, as awk must process all the lines, and won't 'seek'. In a pipeline, both must process all lines, so we might as well skip the extra process creation and just use awk for all the processing.

Test Plan

Verify that the output between:

zpool list -v $rootdev | tail -n 1 | awk '{print $1}'

and

zpool list -v $rootdev | awk 'END {print $1}'

Are the same on all my systems. The output is the same.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable