summaryrefslogtreecommitdiff
path: root/mk
diff options
context:
space:
mode:
authorjwise <jwise>2001-01-29 01:56:51 +0000
committerjwise <jwise>2001-01-29 01:56:51 +0000
commit487ecf0132ca31804bc1a84dc6735e734ef1d9ce (patch)
tree7ff1357239f0f2f7ed9fc6680305337093f8edcd /mk
parent3ee78b86bf5ebf8228f36e38f01037525d57fd89 (diff)
downloadpkgsrc-487ecf0132ca31804bc1a84dc6735e734ef1d9ce.tar.gz
As per discussion on tech-pkg, correct behavior of `make package' in the
case where DESTDIR is set. Previously, if DESTDIR was set when a pkg was installed, $DESTDIR/var/db/pkg/+CONTENT would get `@cwd $DESTDIR/$PREFIX', as would the +CONTENT archived in the binary package. The first is correct, the second is not. Now, @cwd in the +CONTENT recorded in the binary package gets $PREFIX (no $DESTDIR). This allows binary packages built into a DESTDIR to be installed on a real system. The @cwd in the installed PKG_DBDIR ($DESTDIR/var/db/pkg) remains the same. In addition, the full path ($DESTDIR/$PREFIX) is recorded in @src in the binary package's +CONTENT, for reference purposes. This patch is the same as that posted to tech-pkg, except that variable names have been clarified as suggested by hubertf.
Diffstat (limited to 'mk')
-rw-r--r--mk/bsd.pkg.mk32
1 files changed, 18 insertions, 14 deletions
diff --git a/mk/bsd.pkg.mk b/mk/bsd.pkg.mk
index 532c62c464d..9d35c868de9 100644
--- a/mk/bsd.pkg.mk
+++ b/mk/bsd.pkg.mk
@@ -1,4 +1,4 @@
-# $NetBSD: bsd.pkg.mk,v 1.652 2001/01/28 18:53:58 dmcmahill Exp $
+# $NetBSD: bsd.pkg.mk,v 1.653 2001/01/29 01:56:51 jwise Exp $
#
# This file is in the public domain.
#
@@ -701,27 +701,31 @@ BUILD_INFO_FILE= ${WRKDIR}/.build_info
SIZE_PKG_FILE= ${WRKDIR}/.SizePkg
SIZE_ALL_FILE= ${WRKDIR}/.SizeAll
-.ifndef PKG_ARGS
-PKG_ARGS= -v -c ${COMMENT} -d ${DESCR} -f ${PLIST} -l
-PKG_ARGS+= -b ${BUILD_VERSION_FILE} -B ${BUILD_INFO_FILE}
-PKG_ARGS+= -s ${SIZE_PKG_FILE} -S ${SIZE_ALL_FILE}
-PKG_ARGS+= -p ${PREFIX} -P "`${MAKE} ${MAKEFLAGS} run-depends-list PACKAGE_DEPENDS_QUICK=true|sort -u`"
+.ifndef PKG_ARGS_COMMON
+PKG_ARGS_COMMON= -v -c ${COMMENT} -d ${DESCR} -f ${PLIST} -l
+PKG_ARGS_COMMON+= -b ${BUILD_VERSION_FILE} -B ${BUILD_INFO_FILE}
+PKG_ARGS_COMMON+= -s ${SIZE_PKG_FILE} -S ${SIZE_ALL_FILE}
+PKG_ARGS_COMMON+= -P "`${MAKE} ${MAKEFLAGS} run-depends-list PACKAGE_DEPENDS_QUICK=true|sort -u`"
.ifdef CONFLICTS
-PKG_ARGS+= -C "${CONFLICTS}"
+PKG_ARGS_COMMON+= -C "${CONFLICTS}"
.endif
.ifdef INSTALL_FILE
-PKG_ARGS+= -i ${INSTALL_FILE}
+PKG_ARGS_COMMON+= -i ${INSTALL_FILE}
.endif
.ifdef DEINSTALL_FILE
-PKG_ARGS+= -k ${DEINSTALL_FILE}
+PKG_ARGS_COMMON+= -k ${DEINSTALL_FILE}
.endif
.ifdef MESSAGE_FILE
-PKG_ARGS+= -D ${MESSAGE_FILE}
+PKG_ARGS_COMMON+= -D ${MESSAGE_FILE}
.endif
.ifndef NO_MTREE
-PKG_ARGS+= -m ${MTREE_FILE}
+PKG_ARGS_COMMON+= -m ${MTREE_FILE}
.endif
-.endif # !PKG_ARGS
+
+PKG_ARGS_INSTALL= -p ${PREFIX} ${PKG_ARGS_COMMON}
+PKG_ARGS_BINPKG= -p ${PREFIX:C/^${DESTDIR}//} -L ${PREFIX} ${PKG_ARGS_COMMON}
+.endif # !PKG_ARGS_COMMON
+
PKG_SUFX?= .tgz
#PKG_SUFX?= .tbz # bzip2(1) pkgs
# where pkg_add records its dirty deeds.
@@ -1558,7 +1562,7 @@ do-package: ${PLIST} ${DESCR}
exit 1; \
fi; \
fi; \
- if ${PKG_CREATE} ${PKG_ARGS} ${PKGFILE}; then \
+ if ${PKG_CREATE} ${PKG_ARGS_BINPKG} ${PKGFILE}; then \
${MAKE} ${MAKEFLAGS} package-links; \
else \
${MAKE} ${MAKEFLAGS} delete-package; \
@@ -3190,7 +3194,7 @@ fake-pkg: ${PLIST} ${DESCR}
if [ ! -d ${PKG_DBDIR}/${PKGNAME} ]; then \
${ECHO_MSG} "${_PKGSRC_IN}> Registering installation for ${PKGNAME}"; \
${MKDIR} ${PKG_DBDIR}/${PKGNAME}; \
- ${PKG_CREATE} ${PKG_ARGS} -O ${PKGFILE} > ${PKG_DBDIR}/${PKGNAME}/+CONTENTS; \
+ ${PKG_CREATE} ${PKG_ARGS_INSTALL} -O ${PKGFILE} > ${PKG_DBDIR}/${PKGNAME}/+CONTENTS; \
${CP} ${DESCR} ${PKG_DBDIR}/${PKGNAME}/+DESC; \
${CP} ${COMMENT} ${PKG_DBDIR}/${PKGNAME}/+COMMENT; \
${CP} ${BUILD_VERSION_FILE} ${PKG_DBDIR}/${PKGNAME}/+BUILD_VERSION; \