Bug 150324 - [MAINTAINER-UPDATE] ports-mgmt/bpkg: update to 2.1
Summary: [MAINTAINER-UPDATE] ports-mgmt/bpkg: update to 2.1
Status: Closed FIXED
Alias: None
Product: Ports & Packages
Classification: Unclassified
Component: Individual Port(s) (show other bugs)
Version: Latest
Hardware: Any Any
: Normal Affects Only Me
Assignee: Baptiste Daroussin
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2010-09-06 13:20 UTC by Andy Kosela
Modified: 2010-09-15 09:50 UTC (History)
1 user (show)

See Also:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Andy Kosela 2010-09-06 13:20:08 UTC
- Update to 2.1

 * major new release
 * most functions has been rewritten for speed and efficiency
 * -S deprecated
 * -I switched with -i
 * search improvements (using INDEX)
 * overall code clean-up

Generated with FreeBSD Port Tools 0.99

Fix: 

--
Andy Kosela
akosela@andykosela.com--Yjkzd1kSU3k1WUMmU63pGhV7nN3ux7t1s0n1Ebxo5Br9V9DR
Content-Type: text/plain; name="bpkg-2.1.patch"
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment; filename="bpkg-2.1.patch"

diff -ruN --exclude=CVS /usr/ports/ports-mgmt/bpkg/Makefile /usr/home/akosela/bpkg/Makefile
--- /usr/ports/ports-mgmt/bpkg/Makefile	2010-02-04 05:03:44.000000000 +0100
+++ /usr/home/akosela/bpkg/Makefile	2010-09-02 14:03:31.000000000 +0200
@@ -2,13 +2,13 @@
 # Date created:				24 June 2007
 # Whom:					Andy Kosela <akosela@andykosela.com>
 #
-# $FreeBSD: ports/ports-mgmt/bpkg/Makefile,v 1.25 2010/02/04 04:03:44 pgollucci Exp $
+# $FreeBSD: ports/ports-mgmt/bpkg/Makefile,v 1.24 2009/12/26 18:02:32 miwi Exp $
 #
 # This port is self contained in the files directory.
 #
 
 PORTNAME=	bpkg
-PORTVERSION=	2.0.10
+PORTVERSION=	2.1
 CATEGORIES=	ports-mgmt
 MASTER_SITES=	# none
 DISTFILES=	# none
diff -ruN --exclude=CVS /usr/ports/ports-mgmt/bpkg/files/bpkg.8 /usr/home/akosela/bpkg/files/bpkg.8
--- /usr/ports/ports-mgmt/bpkg/files/bpkg.8	2010-02-04 05:03:44.000000000 +0100
+++ /usr/home/akosela/bpkg/files/bpkg.8	2010-09-02 18:22:28.000000000 +0200
@@ -25,7 +25,7 @@
 .\" SUCH DAMAGE.
 .\"
 .\"
-.Dd January 31, 2010
+.Dd September 2, 2010
 .Dt BPKG 8
 .Os
 .Sh NAME
@@ -33,7 +33,7 @@
 .Nd a simple tool for displaying information about ports.
 .Sh SYNOPSIS
 .Nm
-.Op Fl abDdeFfgIijkLMmOopQqrSswz
+.Op Fl abDdeFfgIijkLMmOopQqrswz
 .Ar pkg-name ...
 .Nm
 .Op Fl BCchltvZ
@@ -75,9 +75,9 @@
 .It Fl h
 display help.  [no arguments]
 .It Fl i
-display info about the port (priority - installed ports).
+display short description of the port (priority -- installed ports).
 .It Fl I
-display short info about the port (priority - installed ports).
+display info about the port.
 .It Fl j
 search the ports tree according to ports' descriptions.
 .It Fl k
@@ -95,7 +95,7 @@
 .It Fl o
 display config OPTIONS for the specified port.
 .It Fl p
-search the ports tree and display short info about the port.
+search the ports tree and display short info about each port.
 .It Fl Q
 display the latest available package in the FreeBSD repository.  
 [-STABLE]
@@ -104,8 +104,6 @@
 [-RELEASE]
 .It Fl r
 show the list of all port's dependencies.
-.It Fl S
-search the ports tree and display info about the port.
 .It Fl s
 show the total size occupied by files installed within the port.
 .It Fl t
@@ -123,16 +121,15 @@
 .Sh EXIT STATUS
 .Ex -std
 .Sh EXAMPLES
-The following is an example of a typical usage
-of the
+The following is an example of a typical usage of the
 .Nm
 command:
 .Pp
 .Dl "$ bpkg -i foo" 
 .Pp
-Display info about port foo.
+Display short description about port foo.
 .Pp
-.Dl "$ bpkg -S 'foo[0-9]+$'"
+.Dl "$ bpkg -p foo$"
 .Pp
 Display all ports matching the regular expression.
 .Pp
@@ -142,7 +139,7 @@
 .Pp
 .Dl "$ bpkg -b 'foo bar'"
 .Pp
-Create backup packages of foo and bar in /var/tmp/bpkg/ directory.
+Create backup packages of foo and bar in /var/tmp/bpkg directory.
 .Sh SEE ALSO
 .Xr pkg_add 1 ,
 .Xr pkg_create 1 ,
diff -ruN --exclude=CVS /usr/ports/ports-mgmt/bpkg/files/bpkg.sh.in /usr/home/akosela/bpkg/files/bpkg.sh.in
--- /usr/ports/ports-mgmt/bpkg/files/bpkg.sh.in	2010-02-04 05:03:44.000000000 +0100
+++ /usr/home/akosela/bpkg/files/bpkg.sh.in	2010-09-03 16:46:11.000000000 +0200
@@ -1,5 +1,5 @@
 #!/bin/sh
-# $FreeBSD: ports/ports-mgmt/bpkg/files/bpkg.sh.in,v 1.24 2010/02/04 04:03:44 pgollucci Exp $
+# $FreeBSD: ports/ports-mgmt/bpkg/files/bpkg.sh.in,v 1.23 2009/12/26 18:02:32 miwi Exp $
 
 #  Copyright (c) 2007-2010 Andy Kosela <akosela@andykosela.com>
 #  All rights reserved.
@@ -21,7 +21,7 @@
 #  CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 #  EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 #  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
-#  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 
+#  PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 #  OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 #  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 #  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
@@ -43,28 +43,54 @@
 	fi
 }
 
-#######################################################################
+check_index()
+{
+	local re
+
+	re=`uname -r | cut -d. -f1`
+	if [ -e /usr/ports/INDEX-$re ]; then
+		return 0
+	else
+		root
+		echo "Downloading INDEX file..."
+		(cd /usr && /usr/bin/cvs -Q -f -z3 -R \
+		    -d:pserver:anoncvs@anoncvs.fr.freebsd.org:/home/ncvs \
+		    checkout -A -T -P -l ports)
+		(cd /usr/ports && /usr/bin/cvs -Q -f -z3 -R \
+		    -d:pserver:anoncvs@anoncvs.fr.freebsd.org:/home/ncvs \
+		    update -A -T -P -d Mk Templates Tools ;
+		make fetchindex)
+		return 0
+	fi
+}
+
+info_fn()
+{
+	info=`pkg_info | grep $e | cut -d' ' -f1`
+}
+
+########################################################################
 # Start of main functions
 
 pkg_info-xI()
 {
-	local e info pwd i
+	local e info pwd i re
+	re=`uname -r | cut -d. -f1`
 
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d/ -f5`
+		info_fn
 	
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e | \
-			grep -w Path | cut -d/ -f4,5`
-		    echo -e "\033[33m*** not installed ***\033[0m"
-		    for i in $pwd; do
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep COMMENT | cut -d= -f2`"
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			echo "*** not installed ***"
+			for i in $pwd; do
+				echo "$i: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|' | cut -d'|' -f4`"
+			done
 		else
-		    echo -e "\033[33m*** installed ***\033[0m"
-		    pkg_info -I $info 
+			echo "*** installed ***"
+			pkg_info -I $info
 		fi
 	done
 	exit 0
@@ -72,97 +98,73 @@
 
 pkg_info-xL()
 {
-	local e info i
+	local i
 
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-
-		if [ ! -z "$info" ]; then
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info -L `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-		    done	
-		else
-		    echo "bpkg: no installed ports match $e"
-		fi
-	done
+	i=`pkg_info -xL $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
 	exit 0
 }
 
 pkg_inf()
 {
-	echo -e "\033[33m*** installed ***\033[0m"
-	pkg_info 
-	echo "*`pkg_info | wc -l` ports installed      *"
+	pkg_info
+	echo "`pkg_info | wc -l` ports installed"
 	exit 0
 }
 
 pkg_info-xs()
 {
-	local e info i
+	local i
 
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-
-		if [ ! -z "$info" ]; then
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info -s `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5` 
-		    done	
-		else
-		    echo "bpkg: no installed ports match $e"
-		fi
-	done
+	i=`pkg_info -xs $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
 	exit 0
 }
 
 pkg_info-xr()
 {
-	local e info pwd i
+	local e info pwd i re
+	re=`uname -r | cut -d. -f1`
 
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 	
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep -w Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep -w COMMENT | cut -d= -f2`"
-			echo ""
-			echo "Information in ports for `echo $i | \
-			    cut -d/ -f2`:"
-			echo ""
-			cd /usr/ports && make search path=/$i$ | \
-			    grep .*-deps
-			echo ""
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				echo "*** not installed ***"
+				echo "$i: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|' | cut -d'|' -f4`"
+				echo "Information in ports for `echo $i |
+				    cut -d/ -f2`:"
+				echo "B-deps: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|'/ | cut -d'|' -f8`"
+				echo "R-deps: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|'/ | cut -d'|' -f9`"
+				echo ""
+			done
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			echo "Information in ports for $i:"
-			echo ""
-			cd /usr/ports && make search path=/$i$ | \
-			    grep .*-deps
-			echo ""
-			pkg_info -rR `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-		    done
+			echo "*** installed ***"
+			pkg_info -xrR $info
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				echo "Information in ports for $i:"
+				echo "B-deps: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|'/ | cut -d'|' -f8`"
+				echo "R-deps: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|'/ | cut -d'|' -f9`"
+				echo ""
+			done
 		fi
 	done
 	exit 0
@@ -170,57 +172,40 @@
 
 pkg_info-xg()
 {
-	local e info i
-
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+	local i
 
-		if [ ! -z "$info" ]; then
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info -g `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5` 
-			done	
-		else
-		    echo "bpkg: no installed ports match $e"
-		fi
-	done
+	i=`pkg_info -xg $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
 	exit 0
 }
 
+
 pkg_info-xf()
 {
-	local e info pwd i
+	local e info pwd i re
+	re=`uname -r | cut -d. -f1`
 
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 	
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep -w Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep -w COMMENT | cut -d= -f2`"
-			echo ""
-			echo "Packing list:"
-			cat /usr/ports/$i/pkg-plist
-			echo ""
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			echo "*** not installed ***"
+			for i in $pwd; do
+				echo "$i: `cat /usr/ports/INDEX-$re |
+				    grep /$i'|' | cut -d'|' -f4`"
+				echo "Packing list:"
+				[ -d /usr/ports/$i ] &&
+				    cat /usr/ports/$i/pkg-plist
+				echo ""
+			done
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info -f `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-		    done
+			pkg_info -f $info
 		fi
 	done
 	exit 0
@@ -228,131 +213,92 @@
 
 pkg_info-xk()
 {
-	local e info i
+	local i
 
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-
-		if [ ! -z "$info" ]; then
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info -k `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5` 
-		    done	
-		else
-		    echo "bpkg: no installed ports match $e"
-		fi
-	done
+	i=`pkg_info -xk $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
 	exit 0
 }
 
 pkg_info-xD()
 {
-	local e info i
+	local i
 
-        for e in $pkg; do
-                info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-                
-                if [ ! -z "$info" ]; then
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`"
-			echo ""
-			pkg_info -D `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-		    done 
-                else
-		    echo "bpkg: no installed ports match $e"
-                fi
-        done
-        exit 0
+	i=`pkg_info -xD $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
+	exit 0
 }
 
 pkg_info-x()
 {
-	local e info pwd i
+	local i
 
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-	
-		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep -w Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep -w COMMENT | cut -d= -f2`"
-			echo ""
-			echo "Description:"
-			echo "`cat /usr/ports/$i/pkg-descr`"
-			echo ""
-		    done
-		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			pkg_info `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-		    done
-		fi
-	done
+	i=`pkg_info -x $pkg 2>/dev/null`
+	if [ -z "$i" ]; then
+		echo "bpkg: no installed ports match pattern(s)"
+		exit 1
+	fi
+	echo "$i"
 	exit 0
 }
 
 pkg_ver()
 {
-	echo -e "\033[33m*** installed ***\033[0m"
 	pkg_version -Iv
-	echo "*`pkg_info | wc -l` ports installed      *"
 	exit 0
 }
 
 pkg_path()
 {
-	local pwd e
+	local e pwd i re
+	re=`uname -r | cut -d. -f1`
 
-	pwd=`cd /usr/ports && make search path=/$pkg | grep -w Path | \
-	    cut -d/ -f4,5`
-	for e in $pwd; do
-		echo "$e" ; cat /usr/ports/$e/Makefile | \
-		    grep -w COMMENT | cut -d= -f2
+	for e in $pkg; do
+		pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+		    cut -d'|' -f2 | cut -d/ -f4,5`
+		for i in $pwd; do
+			echo "$i: `cat /usr/ports/INDEX-$re |
+			    grep /$i'|' | cut -d'|' -f4`"
+		done
 	done
 	exit 0
 }
 
 pkg_makefile()
 {
-	local pwd
+	local pwd re
+	re=`uname -r | cut -d. -f1`
 
-	pwd=`cd /usr/ports && make search path=/$pkg$ | grep -w Path | \
-	    sed -n 1p | cut -d/ -f4,5`
-	[ -z "$pwd" ] && echo "bpkg: can't find the port in /usr/ports/"
+	pwd=`cat /usr/ports/INDEX-$re | grep /$pkg'|'/ | sed -n 1p |
+	    cut -d'|' -f2`
+	[ -z "$pwd" ] &&
+	    echo "bpkg: can't find the port in /usr/ports/" && exit 0
 
-	less /usr/ports/$pwd/Makefile 2>/dev/null
+	[ -d $pwd ] && less $pwd/Makefile 2>/dev/null
 	exit 0
 }
 
 pkg_distinfo()
 {
-	local pwd e
+	local pwd e re
+	re=`uname -r | cut -d. -f1`
 
-	pwd=`cd /usr/ports && make search path=/$pkg$ | grep -w Path | \
-	    sed -n 1p | cut -d/ -f4,5`
+	pwd=`cat /usr/ports/INDEX-$re | grep /$pkg'|'/ | sed -n 1p |
+	    cut -d'|' -f2`
 	[ -z "$pwd" ] && echo "bpkg: can't find the port in /usr/ports/"
 
-	for e in `cat /usr/ports/$pwd/distinfo 2>/dev/null | \
-	    grep SIZE | cut -d'=' -f2`; do
-		echo "`cat /usr/ports/$pwd/distinfo | grep $e | \
-		    sed 's/SIZE// ; s/(// ; s/)//' | \
+	for e in `cat $pwd/distinfo 2>/dev/null | grep SIZE |
+	    cut -d'=' -f2`; do
+		echo "`cat $pwd/distinfo | grep $e |
+		    sed 's/SIZE// ; s/(// ; s/)//' |
 		    cut -d' ' -f2` `convert $e`"
 	done
 	exit 0
@@ -360,37 +306,10 @@
 
 make_search()
 {
-	local e info pwd i
-
-	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
-		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e | \
-			grep -w Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			cd /usr/ports && make search path=/$i$
-		    done
-		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo ""
-			cd /usr/ports && make search path=/$i$
-		    done
-		fi
-	done
-	exit 0
-}
-
-make_search_S()
-{
 	local e
 
 	for e in $pkg; do
-		cd /usr/ports && make search path=/$e
+		cd /usr/ports && make search path=/$e$
 	done
 	exit 0
 }
@@ -418,18 +337,19 @@
 	sed -i '' s/[0-9][0-9].*/*/ /tmp/bpkg.tmp
 
 	echo "ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-release/Latest/"
+	echo "Loading data..."
 	ftp -4Va ftp://ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-release/Latest/ < /tmp/bpkg.tmp > /tmp/bpkg1.tmp
 	ftp -4Va ftp://ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-release/All/ < /tmp/bpkg.tmp > /tmp/bpkg2.tmp
 
 	n=1
 	for e in `cat /tmp/bpkg1.tmp | awk '{print $9}' | cut -d. -f1`
 	do
-		size_pkg=`cat /tmp/bpkg1.tmp | sed '/^[A-Z]/d' | \
+		size_pkg=`cat /tmp/bpkg1.tmp | sed '/^[A-Z]/d' |
 		    sed -n ${n}p | awk '{print $11}' | cut -d/ -f3`
-		size=`cat /tmp/bpkg2.tmp | grep $size_pkg | \
+		size=`cat /tmp/bpkg2.tmp | grep $size_pkg |
 		    awk '{print $5}'`
-		mtime=`cat /tmp/bpkg2.tmp | grep $size_pkg | \
-		    awk '{print $6, $7, $8}'` 
+		mtime=`cat /tmp/bpkg2.tmp | grep $size_pkg |
+		    awk '{print $6, $7, $8}'`
 		echo "$e -> $size_pkg `convert $size` [$mtime]"
 		n=`expr $n + 1`
 	done
@@ -450,18 +370,19 @@
 	sed -i '' s/[0-9][0-9].*/*/ /tmp/bpkg.tmp
 
 	echo "ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-stable/Latest/"
+	echo "Loading data..."
 	ftp -4Va ftp://ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-stable/Latest/ < /tmp/bpkg.tmp > /tmp/bpkg1.tmp
 	ftp -4Va ftp://ftp.freebsd.org/pub/FreeBSD/ports/$arch/packages-$sys-stable/All/ < /tmp/bpkg.tmp > /tmp/bpkg2.tmp
 
 	n=1
 	for e in `cat /tmp/bpkg1.tmp | awk '{print $9}' | cut -d. -f1`
 	do
-		size_pkg=`cat /tmp/bpkg1.tmp | sed '/^[A-Z]/d' | \
+		size_pkg=`cat /tmp/bpkg1.tmp | sed '/^[A-Z]/d' |
 		    sed -n ${n}p | awk '{print $11}' | cut -d/ -f3`
-		size=`cat /tmp/bpkg2.tmp | grep $size_pkg | \
+		size=`cat /tmp/bpkg2.tmp | grep $size_pkg |
 		    awk '{print $5}'`
-		mtime=`cat /tmp/bpkg2.tmp | grep $size_pkg | \
-		    awk '{print $6, $7, $8}'` 
+		mtime=`cat /tmp/bpkg2.tmp | grep $size_pkg |
+		    awk '{print $6, $7, $8}'`
 		echo "$e -> $size_pkg `convert $size` [$mtime]"
 		n=`expr $n + 1`
 	done
@@ -482,7 +403,7 @@
 {
 	root
 	echo "Cleaning /usr/ports/distfiles/* and /usr/ports/*/*/work/"
-	rm -rf /usr/ports/distfiles/* 1>/dev/null 2>&1 
+	rm -rf /usr/ports/distfiles/* 1>/dev/null 2>&1
 	rm -rf /usr/ports/*/*/work/ 1>/dev/null 2>&1
 	echo "Done."
 	exit 0
@@ -490,10 +411,10 @@
 
 pkg_which-()
 {
-	grep "$pkg"$ /var/db/pkg/*/+CONTENTS | \
-	    awk -F 'pkg/' '{ print $2 }' | \
-	    sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ; 
-	    s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
+	grep "$pkg"$ /var/db/pkg/*/+CONTENTS |
+	    awk -F 'pkg/' '{ print $2 }' |
+	    sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
+	    s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' |
 	    awk -F: '{ print $1 ":\t" $2 }'
 	exit 0
 }
@@ -510,7 +431,7 @@
 		exit 0
 	fi
 
-	pkg_install=`pkg_info -xoQ ^$pkg | cut -d: -f1 | \
+	pkg_install=`pkg_info -xoQ ^$pkg | cut -d: -f1 |
 	    awk '{ORS=" " ;print}'`
 	echo "Creating backup package(s) "$pkg_install"in /var/tmp/bpkg/"
 	[ ! -d /var/tmp/bpkg/ ] && mkdir /var/tmp/bpkg/
@@ -541,52 +462,51 @@
 }
 
 pkg_time()
-{ 
-	/bin/ls -lUTt /var/db/pkg/ | awk -F' ' '{ print $6, $7, $8, \
-	    $9, $10 }' | cut -d/ -f1,5
-	echo "*`pkg_info | wc -l` ports installed      *"
+{
+	/bin/ls -lUTt /var/db/pkg/ | grep -v total |
+	    awk -F' ' '{ print $6, $7, $8, $9, "\t" $10 }' |
+	    cut -d/ -f1,5
 	exit 0
 }
 
 make_showc()
 {
-	local e info pwd i key
+	local e info pwd i key re
+	re=`uname -r | cut -d. -f1`
 
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
+
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep COMMENT | cut -d= -f2`"
-			echo -n \
-			"Do you want to display config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make showconfig-recursive ;;
-			    *) cd /usr/ports/$i && make showconfig ;; 
-			esac
-			echo ""
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				echo "*** not installed ***"
+				echo "$i: `cat /usr/ports/$i/Makefile |
+				    grep COMMENT | cut -d= -f2`"
+				echo -n "Do you want to display config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i &&
+				    make showconfig-recursive ;;
+				*) cd /usr/ports/$i && make showconfig ;
+				esac
+				echo ""
+			done
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo -n \
-			"Do you want to display config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make showconfig-recursive ;;
-			    *) cd /usr/ports/$i && make showconfig ;; 
-			esac
-			echo ""
-		    done
+			for i in $info; do
+				echo "*** installed ***"
+				pkg_info -xI $i
+				echo -n \
+				"Do you want to display config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i && \
+				    make showconfig-recursive ;;
+				*) cd /usr/ports/$i && make showconfig ;;
+				esac
+				echo ""
+			done
 		fi
 	done
 	exit 0
@@ -594,45 +514,44 @@
 
 make_rmc()
 {
-	local e info pwd i key
+	local e info pwd i key re
 
 	root
+	re=`uname -r | cut -d. -f1`
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 	
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep COMMENT | cut -d= -f2`"
-			echo -n \
-			"Do you want to remove config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make rmconfig-recursive ;;
-			    *) cd /usr/ports/$i && make rmconfig ;; 
-			esac
-			echo ""
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				echo "*** not installed ***"
+				echo "$i: `cat /usr/ports/$i/Makefile |
+				    grep COMMENT | cut -d= -f2`"
+				echo -n \
+				"Do you want to remove config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i && \
+				    make rmconfig-recursive ;;
+				*) cd /usr/ports/$i && make rmconfig ;;
+				esac
+				echo ""
+			done
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo -n \
-			"Do you want to remove config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make rmconfig-recursive ;;
-			    *) cd /usr/ports/$i && make rmconfig ;; 
-			esac
-			echo ""
-		    done
+			for i in $info; do
+				echo "*** installed ***"
+				pkg_info -xI $i
+				echo -n \
+				"Do you want to remove config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i &&
+				    make rmconfig-recursive ;;
+				*) cd /usr/ports/$i && make rmconfig ;;
+				esac
+				echo ""
+			done
 		fi
 	done
 	exit 0
@@ -640,45 +559,44 @@
 
 make_config()
 {
-	local e info pwd i key
+	local e info pwd i key re
 
 	root
+	re=`uname -r | cut -d. -f1`
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e.* | \
-			grep Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			echo -e "\033[33m*** not installed ***\033[0m"
-			echo "$i: `cat /usr/ports/$i/Makefile | \
-			    grep COMMENT | cut -d= -f2`"
-			echo -n \
-			"Do you want to set config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make config-recursive ;;
-			    *) cd /usr/ports/$i && make config ;; 
-			esac
-			echo ""
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				echo "*** not installed ***"
+				echo "$i: `cat /usr/ports/$i/Makefile |
+				    grep COMMENT | cut -d= -f2`"
+				echo -n \
+				"Do you want to set config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i &&
+				    make config-recursive ;;
+				*) cd /usr/ports/$i && make config ;;
+				esac
+				echo ""
+			done
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
-			echo -n \
-			"Do you want to set config options recursively? [n] "
-			read key
-			case $key in
-			    y) cd /usr/ports/$i && \
-				make config-recursive ;;
-			    *) cd /usr/ports/$i && make config ;; 
-			esac
-			echo ""
-		    done
+			for i in $info; do
+				echo "*** installed ***"
+				pkg_info -xI $i
+				echo -n \
+				"Do you want to set config options recursively? [n] "
+				read key
+				case $key in
+				y) cd /usr/ports/$i &&
+				    make config-recursive ;;
+				*) cd /usr/ports/$i && make config ;;
+				esac
+				echo ""
+			done
 		fi
 	done
 	exit 0
@@ -688,14 +606,14 @@
 {
 	local browser pwd
 
-	browser=`ls /usr/local/bin/w3m 2>/dev/null || \
-	    ls /usr/local/bin/lynx 2>/dev/null || \
+	browser=`ls /usr/local/bin/w3m 2>/dev/null ||
+	    ls /usr/local/bin/lynx 2>/dev/null ||
 	    ls /usr/local/bin/links 2>/dev/null`
 	if [ -z "$browser" ]; then
 		echo "bpkg: text WWW browser required"
 	else
 		echo "Loading..."
-		pwd=`cd /usr/ports && make search path=/$pkg | \
+		pwd=`cd /usr/ports && make search path=/$pkg |
 		    grep -w Path | sed -n 1p | cut -d/ -f4,5`
 		$browser http://www.freshports.org/$pwd
 	fi
@@ -704,26 +622,26 @@
 
 show_work()
 {
-	local e info pwd i
+	local e info pwd i re
 
-	if [ ! -x /usr/local/sbin/portmaster ]; then 
+	if [ ! -x /usr/local/sbin/portmaster ]; then
 		echo "bpkg: you don't have portmaster installed.  Exiting."
 		exit 1
 	fi
 
+	re=`uname -r | cut -d. -f1`
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 		if [ -z "$info" ]; then
-		    pwd=`cd /usr/ports && make search path=/$e | \
-			grep -w Path | cut -d/ -f4,5`
-		    for i in $pwd; do
-			/usr/local/sbin/portmaster --show-work $i
-		    done
+			pwd=`cat /usr/ports/INDEX-$re | grep /$e.*'|'/ |
+			    cut -d'|' -f2 | cut -d/ -f4,5`
+			for i in $pwd; do
+				/usr/local/sbin/portmaster --show-work $i
+			done
 		else
-		    for i in $info; do
-			/usr/local/sbin/portmaster --show-work $i
-		    done
+			for i in $info; do
+				/usr/local/sbin/portmaster --show-work $i
+			done
 		fi
 	done
 	exit 0
@@ -731,30 +649,25 @@
 
 make_ldd()
 {
-	local e info i pkg bin o
+	local e info i pkg bin o origin
 
 	for e in $pkg; do
-		info=`grep $e /var/db/pkg/*/+CONTENTS | \
-		    grep -w ORIGIN | cut -d: -f3`
+		info_fn
 	
 		if [ -z "$info" ]; then
-		    echo "bpkg: no installed ports match $e"
+			echo "bpkg: no installed ports match $e"
 		else
-		    for i in $info; do
-			echo -e "\033[33m*** installed ***\033[0m"
-			echo "$i: `grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`" 
+			echo "*** installed ***"
+			pkg_info -xI $info
 			echo ""
 			echo "List of dynamic object dependencies:"
-			pkg=`grep $i /var/db/pkg/*/+CONTENTS | \
-			    grep -w ORIGIN | cut -d/ -f5`
-			bin=`pkg_info -L $pkg | \
+			bin=`pkg_info -L $info |
 			    awk '/\/usr\/local\/bin/ \
-			    /\/usr\/local\/sbin/ /usr\/local\/libexec/'`
+			    /\/usr\/local\/sbin/ \
+			    /usr\/local\/libexec/'`
 			for o in $bin; do
-			    /usr/bin/ldd -a $o
+				/usr/bin/ldd -a $o
 			done
-		    done
 		fi
 	done
 	exit 0
@@ -762,296 +675,43 @@
 
 make_ldd_all()
 {
+	root
 	local e libs i
 
-	echo ""
 	echo "List of all missing dynamic object dependencies:"
 
-	for e in `/bin/ls -l /bin/ 2>/dev/null | awk -F' ' '{print $9}'`
-	do 
-		libs=`/usr/bin/ldd -a /bin/$e 2>/dev/null | grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
+	find /bin 2>/dev/null > /tmp/ldd_all
+	find /sbin 2>/dev/null >> /tmp/ldd_all
+	find /usr/bin 2>/dev/null >> /tmp/ldd_all
+	find /usr/sbin 2>/dev/null >> /tmp/ldd_all
+	find /usr/libexec 2>/dev/null >> /tmp/ldd_all
+	find /usr/local/bin 2>/dev/null >> /tmp/ldd_all
+	find /usr/local/sbin 2>/dev/null >> /tmp/ldd_all
+	find /usr/local/libexec 2>/dev/null >> /tmp/ldd_all
 
-	for e in `/bin/ls -l /sbin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do
-		libs=`/usr/bin/ldd -a /sbin/$e 2>/dev/null | grep found`
+	for e in `cat /tmp/ldd_all`; do
+		libs=`/usr/bin/ldd -a $e 2>/dev/null | grep found`
 		if [ ! -z "$libs" ]; then
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/bin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do
-		libs=`/usr/bin/ldd -a /usr/bin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
+			grep "$e"$ /var/db/pkg/*/+CONTENTS |
+			    awk -F 'pkg/' '{ print $2 }' |
 			    sed '/@dirrm/ d ; /@unexec/ d ;
 			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
+			    s/:@comment .*ORIGIN//g' |
 			    awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/games/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/games/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/libexec/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/libexec/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/sbin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/sbin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/local/bin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/local/bin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/local/libexec/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/local/libexec/$e \
-		    2>/dev/null | grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/local/sbin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/local/sbin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/X11R6/bin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/X11R6/bin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/X11R6/libexec/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/X11R6/libexec/$e \
-		    2>/dev/null | grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
-		    echo ""
-		fi
-	done
-
-	for e in `/bin/ls -l /usr/X11R6/sbin/ 2>/dev/null | \
-	    awk -F' ' '{print $9}'`; do 
-		libs=`/usr/bin/ldd -a /usr/X11R6/sbin/$e 2>/dev/null | \
-		    grep found`
-		if [ ! -z "$libs" ]; then 
-		    grep "$e"$ /var/db/pkg/*/+CONTENTS | \
-			awk -F 'pkg/' '{ print $2 }' | \
-			sed '/@dirrm/ d ; /@unexec/ d ; /@comment/ d ;
-			s/\/+CONTENTS//g ; s/:@comment .*ORIGIN//g' | \
-			awk -F: '{ print $1 ":\t" $2 }'
-		    echo "$libs"
-		    for i in `echo $libs | cut -d' ' -f1 | \
-			cut -d. -f1,2`; do
-			grep "$i". /var/db/pkg/*/+CONTENTS | \
-			    awk -F 'pkg/' '{ print $2 }' | \
-			    sed '/@dirrm/ d ; /@unexec/ d ;
-			    /@comment/ d ; s/\/+CONTENTS//g ;
-			    s/:@comment .*ORIGIN//g' | \
-			    awk -F: '{ print $2 "\t [" $1 "]" }'
-		    done
+			echo "$libs"
+			for i in `echo $libs | cut -d' ' -f1 |
+			    cut -d. -f1,2`; do
+				grep "$i". /var/db/pkg/*/+CONTENTS |
+				    awk -F 'pkg/' '{ print $2 }' |
+				    sed '/@dirrm/ d ; /@unexec/ d ;
+				    /@comment/ d ; s/\/+CONTENTS//g ;
+				    s/:@comment .*ORIGIN//g' |
+				    awk -F: '{ print $2 "\t [" $1 "]" }'
+			done
+			echo ""
 		fi
 	done
+	rm /tmp/ldd_all
 	exit 0
 }
 
@@ -1059,7 +719,7 @@
 {
 	local kilo kiloint mega megaint giga gigaint
 
-	kilo=`echo "scale=1; $1/1024" | bc` 
+	kilo=`echo "scale=1; $1/1024" | bc`
 	kiloint=`echo "$1/1024" | bc`
 
 	mega=`echo "scale=1; $kilo/1024" | bc`
@@ -1081,10 +741,10 @@
 
 help()
 {
-	echo "bpkg version `pkg_info -xI bpkg | cut -d- -f2 | \
+	echo "bpkg version `pkg_info -xI bpkg | cut -d- -f2 |
 	    cut -d' ' -f1`"
 	echo ""
-	echo "Usage: bpkg [-abDdeFfgIijkLMmOopQqrSswz] pkg-name ..."
+	echo "Usage: bpkg [-abDdeFfgIijkLMmOopQqrswz] pkg-name ..."
 	echo "       bpkg [-BCchltvZ]"
 	echo ""
 	echo "Please see the bpkg(8) man page for more information"
@@ -1092,33 +752,42 @@
 }
 
 # End of functions
-#######################################################################
+########################################################################
 
-while 
-getopts a:b:D:d:e:F:f:g:I:i:j:k:L:M:m:O:o:p:Q:q:r:S:s:w:z:BCchltvZ opts
+while
+getopts a:b:D:d:e:F:f:g:I:i:j:k:L:M:m:O:o:p:Q:q:r:s:w:z:BCchltvZ opts
 do
 	case $opts in
 		a) pkg=$OPTARG
+		   check_index
 		   show_work ;;
 		b) pkg=$OPTARG
 		   pkg_backup ;;
 		D) pkg=$OPTARG
+		   check_index
 		   pkg_distinfo ;;
 		d) pkg=$OPTARG
+		   check_index
 		   pkg_info-x ;;
 		e) pkg=$OPTARG
+		   check_index
 		   make_config ;;
 		F) pkg=$OPTARG
+		   check_index
 		   pkg_freshports ;;
 		f) pkg=$OPTARG
+		   check_index
 		   pkg_info-xf ;;
 		g) pkg=$OPTARG
 		   pkg_info-xg ;;
 		I) pkg=$OPTARG
-		   pkg_info-xI ;;
-		i) pkg=$OPTARG
+		   check_index
 		   make_search ;;
+		i) pkg=$OPTARG
+		   check_index
+		   pkg_info-xI ;;
 		j) pkg=$OPTARG
+		   check_index
 		   make_search_info ;;
 		k) pkg=$OPTARG
 		   pkg_info-xk ;;
@@ -1127,21 +796,24 @@
 		M) pkg=$OPTARG
 		   pkg_info-xD ;;
 		m) pkg=$OPTARG
+		   check_index
 		   pkg_makefile ;;
 		O) pkg=$OPTARG
+		   check_index
 		   make_rmc ;;
 		o) pkg=$OPTARG
+		   check_index
 		   make_showc ;;
 		p) pkg=$OPTARG
+		   check_index
 		   pkg_path ;;
 		Q) pkg=$OPTARG
 		   pkg_latestftp ;;
 		q) pkg=$OPTARG
 		   pkg_ftp ;;
 		r) pkg=$OPTARG
+		   check_index
 		   pkg_info-xr ;;
-		S) pkg=$OPTARG
-		   make_search_S ;;
 		s) pkg=$OPTARG
 		   pkg_info-xs ;;
 		w) pkg=$OPTARG
Comment 1 Baptiste Daroussin freebsd_committer freebsd_triage 2010-09-06 17:57:53 UTC
Responsible Changed
From-To: freebsd-ports-bugs->bapt

I'll take it.
Comment 2 Baptiste Daroussin freebsd_committer freebsd_triage 2010-09-06 18:00:13 UTC
State Changed
From-To: open->closed

Committed. Thanks!
Comment 3 dfilter service freebsd_committer freebsd_triage 2010-09-15 09:42:00 UTC
bapt        2010-09-15 08:41:55 UTC

  FreeBSD ports repository

  Modified files:
    ports-mgmt/bpkg      Makefile 
    ports-mgmt/bpkg/files bpkg.8 bpkg.sh.in 
  Log:
  - Update to 2.1
  
  * major new release
  * most functions has been rewritten for speed and efficiency
  * -S deprecated
  * -I switched with -i
  * search improvements (using INDEX)
  * overall code clean-up
  
  PR:             ports/150324
  Submitted by:   Andy Kosela <akosela _at_ andykosela.com> (maintainer)
  
  Revision  Changes    Path
  1.26      +1 -1      ports/ports-mgmt/bpkg/Makefile
  1.19      +9 -12     ports/ports-mgmt/bpkg/files/bpkg.8
  1.25      +343 -671  ports/ports-mgmt/bpkg/files/bpkg.sh.in
_______________________________________________
cvs-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/cvs-all
To unsubscribe, send any mail to "cvs-all-unsubscribe@freebsd.org"