summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjschauma <jschauma>2006-11-19 03:06:26 +0000
committerjschauma <jschauma>2006-11-19 03:06:26 +0000
commit728f33e197c50bbdae9987baa54c23b137f57eb7 (patch)
tree956bca69aecad989975f3ff997b0777fe1de7d8e
parent741281e240e6d0e0b61425cfbbb0d22c9a8802eb (diff)
downloadpkgsrc-728f33e197c50bbdae9987baa54c23b137f57eb7.tar.gz
nuke two Useless Use of Wc and let awk do the legwork. This saves us
two forks per package.
-rw-r--r--mk/bulk/build14
1 files changed, 8 insertions, 6 deletions
diff --git a/mk/bulk/build b/mk/bulk/build
index 1fb7fd9ba07..25311e5d34f 100644
--- a/mk/bulk/build
+++ b/mk/bulk/build
@@ -1,5 +1,5 @@
-#!/bin/sh
-# $NetBSD: build,v 1.94 2006/02/11 21:44:16 rillig Exp $
+#!/bin/sh
+# $NetBSD: build,v 1.95 2006/11/19 03:06:26 jschauma Exp $
#
# Copyright (c) 1999, 2000 Hubert Feyrer <hubertf@NetBSD.org>
@@ -90,7 +90,7 @@ die() {
# For more sophisticated output, you may use all the variables that this
# example function uses.
post_filter_cmd() {
- ${SED} "s;^;`date '+%Y/%m/%d %H:%M:%S'` ${built}/${tot}=${percent} ${pkgdir} @ ${MACHINE_ARCH}> ;g"
+ ${SED} "s;^;`date '+%Y/%m/%d %H:%M:%S'` ${percent} ${pkgdir} @ ${MACHINE_ARCH}> ;g"
}
@@ -361,14 +361,16 @@ echo "build> Starting actual build using the order specified in $ORDERFILE..."
# make sure we have something to grep in in the build loop
touch "${main_buildlog}" || die "Cannot write to ${main_buildlog}."
-tot=`wc -l "${ORDERFILE}" | ${AWK} '{print $1}'`
+tot=`${AWK} 'END { print NR }' "${ORDERFILE}"`
for pkgdir in `cat "${ORDERFILE}"`
do
if ${GREP} -q "^${pkgdir}\$" "${main_buildlog}"; then
: "skip this package"
else
- built=`wc -l "${main_buildlog}" | ${AWK} '{print $1}'`
- percent=`echo $built $tot | ${AWK} '{printf("%4.1f%%",$1*100/$2);}'`
+ percent=`${AWK} -v tot="${tot}" '
+ END {
+ printf("%d/%d=%4.1f%%", NR, tot, NR*100/tot);
+ }' "${main_buildlog}"`
( cd "${pkgsrc_dir}/${pkgdir}" \
&& ${NICE_LEVEL} ${BMAKE} USE_BULK_CACHE=yes "${target}" \
$makeargs </dev/null | post_filter_cmd