diff options
author | hubertf <hubertf> | 2000-02-14 02:07:08 +0000 |
---|---|---|
committer | hubertf <hubertf> | 2000-02-14 02:07:08 +0000 |
commit | 062df0707ef1d754ebf7e395b41e142f7b413e6d (patch) | |
tree | 5821b2704988718cb4f74b697c77c2c776a3c108 /pkgtools/pkg_tarup | |
parent | f5dc4c985c5cc8f2671fef5d3b8aa9a043635283 (diff) | |
download | pkgsrc-062df0707ef1d754ebf7e395b41e142f7b413e6d.tar.gz |
Script to tar up an already instaled package.
Diffstat (limited to 'pkgtools/pkg_tarup')
-rw-r--r-- | pkgtools/pkg_tarup/Makefile | 21 | ||||
-rw-r--r-- | pkgtools/pkg_tarup/files/pkg_tarup | 104 | ||||
-rw-r--r-- | pkgtools/pkg_tarup/pkg/COMMENT | 1 | ||||
-rw-r--r-- | pkgtools/pkg_tarup/pkg/DESCR | 14 | ||||
-rw-r--r-- | pkgtools/pkg_tarup/pkg/PLIST | 2 |
5 files changed, 142 insertions, 0 deletions
diff --git a/pkgtools/pkg_tarup/Makefile b/pkgtools/pkg_tarup/Makefile new file mode 100644 index 00000000000..9252227dab1 --- /dev/null +++ b/pkgtools/pkg_tarup/Makefile @@ -0,0 +1,21 @@ +# $NetBSD: Makefile,v 1.1.1.1 2000/02/14 02:07:08 hubertf Exp $ +# + +DISTNAME= pkg_tarup-1.0 +CATEGORIES= pkgtools +MASTER_SITES= # empty +DISTFILES= # empty + +MAINTAINER= hubertf@netbsd.org + +WRKSRC= ${WRKDIR} +NO_CHECKSUM= yes +NO_PATCH= yes +NO_CONFIGURE= yes +NO_BUILD= yes +NO_MTREE= yes + +do-install: + ${INSTALL_SCRIPT} ${FILESDIR}/pkg_tarup ${PREFIX}/bin + +.include "../../mk/bsd.pkg.mk" diff --git a/pkgtools/pkg_tarup/files/pkg_tarup b/pkgtools/pkg_tarup/files/pkg_tarup new file mode 100644 index 00000000000..0522d5ead55 --- /dev/null +++ b/pkgtools/pkg_tarup/files/pkg_tarup @@ -0,0 +1,104 @@ +#!/bin/sh +# $Id: pkg_tarup,v 1.1.1.1 2000/02/14 02:07:13 hubertf Exp $ +# +# Tar up installed package +# +# (c) Copyright 2000 Hubert Feyrer <hubert@feyrer.de> +# + +PKG_DBDIR=${PKG_DBDIR:-/var/db/pkg} +PKGREPOSITORY=${PKGREPOSITORY:-/tmp} +PKG_SUFX=${PKG_SUFX:-tgz} + +PKG="$1" +rPKG="`pkg_info -e \"$PKG\"`" + +if [ "$PKG" = "" -o "$rPKG" = "" -o -f "${PKG_DBDIR}/${rPKG}" ] +then + echo Usage: $0 installed_pkg + exit 1 +fi + +PKG=$rPKG +echo "Taring up $PKG" + + +check_and_add() { + opt="$1" + file="$2" + + if [ x"$opt" = x"" -o x"$file" = x"" ]; then + echo Usage: check_and_add -opt +FILE + exit 1 + fi + + if [ -f "$file" ] + then + PKG_ARGS="${PKG_ARGS} ${opt} ${file}" + fi +} + +check_and_add -c ${PKG_DBDIR}/${PKG}/+COMMENT +check_and_add -d ${PKG_DBDIR}/${PKG}/+DESC +check_and_add -b ${PKG_DBDIR}/${PKG}/+BUILD_VERSION +check_and_add -B ${PKG_DBDIR}/${PKG}/+BUILD_INFO +check_and_add -s ${PKG_DBDIR}/${PKG}/+SIZE_PKG +check_and_add -S ${PKG_DBDIR}/${PKG}/+SIZE_ALL +check_and_add -i ${PKG_DBDIR}/${PKG}/+INSTALL #NOTYET# +check_and_add -k ${PKG_DBDIR}/${PKG}/+DEINSTALL +check_and_add -r ${PKG_DBDIR}/${PKG}/+REQUIRE +check_and_add -D ${PKG_DBDIR}/${PKG}/+DISPLAY +check_and_add -m ${PKG_DBDIR}/${PKG}/+MTREE #NOTYET# + +PLIST=/tmp/+CONTENTS.$$ +sed -n \ + -e '/^@comment MD5:/d' \ + -e '/^@cwd \.$/,$d' \ + -e '/\$NetBSD/,$p' \ + <${PKG_DBDIR}/${PKG}/+CONTENTS >$PLIST + +# Duplicate first @cwd (work around pkg_create "feature" ...) +grep '^@cwd' $PLIST | head -1 >$PLIST.1 +if [ -s ${PLIST}.1 ] +then + sed \ + -e "/`cat ${PLIST}.1 | sed 's,/,\\\\/,g'`/r${PLIST}.1" \ + <${PLIST} >${PLIST}.2 + mv ${PLIST}.2 ${PLIST} +fi +rm ${PLIST}.1 + +# echo ----- +# cat $PLIST +# echo ----- +# exit 0 + +# Just for kicks ... +# pkg_admin check "${PKG}" + +pkg_create \ + ${PKG_ARGS} \ + -v \ + -f ${PLIST} \ + -l \ + -p "`pkg_info -qp ${PKG} | head -1 | awk '{ print $2 }'`" \ + -P "`pkg_info -qf ${PKG} | grep ^@pkgdep | awk '{ print $2 }'`" \ + -C "`pkg_info -qf ${PKG} | grep ^@pkgcfl | awk '{ print $2 }'`" \ + ${PKGREPOSITORY}/${PKG}.${PKG_SUFX} + +rm -f ${PLIST} +exit 0 + + + +mtree file considerations: + - keeping uncompressed mtree file adds ~10% too size of /var/db/pkg + - could gzip file, space saving: 5kb->850b (plus some intelligence to + uncompress them when needed) + - not keeping mtree file results in pkgs w/o mtree file (but should work) + +integration: + - how/where? I'd prefer not to have yet another pkg_* utility flying + around, integration into pkg_admin would be nice. But how merge a + shell script into a C executable? + diff --git a/pkgtools/pkg_tarup/pkg/COMMENT b/pkgtools/pkg_tarup/pkg/COMMENT new file mode 100644 index 00000000000..75e10537fa5 --- /dev/null +++ b/pkgtools/pkg_tarup/pkg/COMMENT @@ -0,0 +1 @@ +Generates binary package from installed pkg diff --git a/pkgtools/pkg_tarup/pkg/DESCR b/pkgtools/pkg_tarup/pkg/DESCR new file mode 100644 index 00000000000..5338c058499 --- /dev/null +++ b/pkgtools/pkg_tarup/pkg/DESCR @@ -0,0 +1,14 @@ +Script to tar up an already instaled package. + +Now my question is, how can we include this? I'd prefer to have it +available from pkg_admin, but that is C, and the other is a script - +rewrite in C? + +The Script has still two problems, as the INSTALL and MTREE files are +removed after a pkg_add/make install. The INSTALL file isn't a problem to +keep, but the MTREE file will lead to a ~10% increase in space needed for +/var/db/pkg which I'm not sure we should do, esp. as the files are almost +always the same again. (On my notebook with ~250 installed pkgs, the size +increasement would be from 8.8MB to 10MB). + +Send your thoughts to me <hubertf@netbsd.org> ! diff --git a/pkgtools/pkg_tarup/pkg/PLIST b/pkgtools/pkg_tarup/pkg/PLIST new file mode 100644 index 00000000000..5585207048f --- /dev/null +++ b/pkgtools/pkg_tarup/pkg/PLIST @@ -0,0 +1,2 @@ +@comment $NetBSD: PLIST,v 1.1.1.1 2000/02/14 02:07:11 hubertf Exp $ +bin/pkg_tarup |