diff options
author | agc <agc@pkgsrc.org> | 2002-03-04 11:56:54 +0000 |
---|---|---|
committer | agc <agc@pkgsrc.org> | 2002-03-04 11:56:54 +0000 |
commit | 9e721c102575339fa160c8f2d1f955cb2eafcd37 (patch) | |
tree | 4d0690b4b083f6b303749dd9330d502cab31dcef | |
parent | 27eb7cc25770bba750699efbd35f101609b1a663 (diff) | |
download | pkgsrc-9e721c102575339fa160c8f2d1f955cb2eafcd37.tar.gz |
Add two new EXPERIMENTAL targets:
replace - this target updates a package in place, fixing up references
to and from other packages to the updated package.
undo-replace - undoes all the work of the previous replace operation.
For this target to work, the ${WRKDIR} must be preserved.
The replace target first makes a binary package of the existing
installed package, then a copy of the +REQUIRED_BY file is taken, if
it exists, and then the existing package is deleted. The new package
is installed, and the preserved +REQUIRED_BY file is copied back into
place, using its contents to modify the +CONTENTS files of all the
packages which require it. The undo-replace shares code with the
replace target, and does the same operation, but in reverse.
Warnings are displayed when either of these targets is used, since
they are experimental targets right now.
-rw-r--r-- | mk/bsd.pkg.mk | 69 |
1 files changed, 68 insertions, 1 deletions
diff --git a/mk/bsd.pkg.mk b/mk/bsd.pkg.mk index 6276abf0c6b..c44f86dbf8e 100644 --- a/mk/bsd.pkg.mk +++ b/mk/bsd.pkg.mk @@ -1,4 +1,4 @@ -# $NetBSD: bsd.pkg.mk,v 1.938 2002/03/04 11:47:25 seb Exp $ +# $NetBSD: bsd.pkg.mk,v 1.939 2002/03/04 11:56:54 agc Exp $ # # This file is in the public domain. # @@ -2332,6 +2332,14 @@ install: uptodate-pkgtools build ${INSTALL_COOKIE} package: uptodate-pkgtools install ${PACKAGE_COOKIE} .endif +.if !target(replace) +replace: uptodate-pkgtools build real-replace +.endif + +.if !target(undo-replace) +undo-replace: uptodate-pkgtools real-undo-replace +.endif + ${EXTRACT_COOKIE}: ${_PKG_SILENT}${_PKG_DEBUG}cd ${.CURDIR} && ${MAKE} ${MAKEFLAGS} real-extract DEPENDS_TARGET=${DEPENDS_TARGET} ${PATCH_COOKIE}: @@ -2379,6 +2387,8 @@ real-configure: configure-message pre-configure do-configure post-configure conf real-build: build-message pre-build do-build post-build build-cookie real-install: do-su-install real-package: do-su-package +real-replace: do-su-replace +real-undo-replace: do-su-undo-replace _SU_TARGET= \ if [ `${ID} -u` = 0 ]; then \ @@ -2427,6 +2437,20 @@ do-su-package: action="package"; \ ${_SU_TARGET} +do-su-replace: + @${ECHO_MSG} "${_PKGSRC_IN}> Replacing ${PKGNAME}" + ${_PKG_SILENT}${_PKG_DEBUG} \ + realtarget="real-su-replace"; \ + action="replace"; \ + ${_SU_TARGET} + +do-su-undo-replace: + @${ECHO_MSG} "${_PKGSRC_IN}> Undoing Replacement of ${PKGNAME}" + ${_PKG_SILENT}${_PKG_DEBUG} \ + realtarget="real-su-undo-replace"; \ + action="undo-replace"; \ + ${_SU_TARGET} + # Empty pre-* and post-* targets .for name in fetch extract patch configure build install-script install package @@ -2636,6 +2660,49 @@ tarup: ${LN} -s ../All/${PKGNAME}${PKG_SUFX}; \ done +# shared code for replace and undo-replace +_REPLACE= \ + if [ -f ${PKG_DBDIR}/$$oldpkgname/+REQUIRED_BY ]; then \ + ${MV} ${PKG_DBDIR}/$$oldpkgname/+REQUIRED_BY ${WRKDIR}/.req; \ + fi; \ + ${MAKE} deinstall; \ + $$replace_action; \ + if [ -f ${WRKDIR}/.req ]; then \ + ${MV} ${WRKDIR}/.req ${PKG_DBDIR}/$$newpkgname/+REQUIRED_BY; \ + for pkg in `${CAT} ${PKG_DBDIR}/$$newpkgname/+REQUIRED_BY`; do \ + ${SETENV} NEWPKGNAME=$$newpkgname \ + ${AWK} '/^@pkgdep '$$oldpkgname'/ { print "@pkgdep " ENVIRON["NEWPKGNAME"]; next } { print }' \ + < ${PKG_DBDIR}/$$pkg/+CONTENTS > ${PKG_DBDIR}/$$pkg/+CONTENTS.$$$$ && \ + ${MV} ${PKG_DBDIR}/$$pkg/+CONTENTS.$$$$ ${PKG_DBDIR}/$$pkg/+CONTENTS; \ + done; \ + fi + +# replace a package in place - not for the faint-hearted +real-su-replace: + ${_PKG_SILENT}${_PKG_DEBUG} \ + ${ECHO_MSG} "*** WARNING - experimental target - data loss may be experienced ***"; \ + pkg_tarup ${PKGBASE} || (${ECHO} "Can't pkg_tarup ${PKGBASE}"; exit 1); \ + oldpkgname=`${PKG_INFO} -e ${PKGBASE}`; \ + newpkgname=${PKGNAME}; \ + ${ECHO} "$$oldpkgname" > ${WRKDIR}/.replace; \ + replace_action="${MAKE} install"; \ + ${_REPLACE} + +# undo the replacement of a package - not for the faint-hearted either +real-su-undo-replace: + ${_PKG_SILENT}${_PKG_DEBUG} \ + if [ ! -f ${WRKDIR}/.replace ]; then \ + ${ECHO_MSG} "No replacement to undo"; \ + exit 1; \ + fi; \ + ${ECHO_MSG} "*** WARNING - experimental target - data loss may be experienced ***"; \ + pkg_tarup ${PKGBASE} || (${ECHO} "Can't pkg_tarup ${PKGBASE}"; exit 1); \ + oldpkgname=${PKGNAME}; \ + newpkgname=`${CAT} ${WRKDIR}/.replace`; \ + replace_action="${SETENV} ${PKG_ADD} ${PKGREPOSITORY}/$$newpkgname${PKG_SUFX}"; \ + ${_REPLACE}; \ + ${RM} ${WRKDIR}/.replace + # This is for the use of sites which store distfiles which others may # fetch - only fetch the distfile if it is allowed to be # re-distributed freely |