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)
Thu, May 23, 7:50 AM
Unknown Object (File)
Tue, May 14, 8:32 AM
Unknown Object (File)
Thu, May 9, 6:56 AM
Unknown Object (File)
Apr 29 2024, 4:20 PM
Unknown Object (File)
Apr 25 2024, 7:49 AM
Unknown Object (File)
Apr 20 2024, 2:10 AM
Unknown Object (File)
Apr 19 2024, 6:38 AM
Unknown Object (File)
Jan 23 2024, 9:41 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