tweak FETCH_PACKAGES: do not fetch all multi-packages to satisfy a

dependency, but only the ones actually required.
If we end up needing to rebuild them from source, then change back
to _internal-package-only, so that we benefit from the whole build
and get all packages again.
This commit is contained in:
espie 2007-06-16 09:57:03 +00:00
parent c71a5ac01c
commit 343aff0c83

View File

@ -1,6 +1,6 @@
#-*- mode: Makefile; tab-width: 4; -*- #-*- mode: Makefile; tab-width: 4; -*-
# ex:ts=4 sw=4 filetype=make: # ex:ts=4 sw=4 filetype=make:
# $OpenBSD: bsd.port.mk,v 1.903 2007/06/04 12:15:09 espie Exp $ # $OpenBSD: bsd.port.mk,v 1.904 2007/06/16 09:57:03 espie Exp $
# $FreeBSD: bsd.port.mk,v 1.264 1996/12/25 02:27:44 imp Exp $ # $FreeBSD: bsd.port.mk,v 1.264 1996/12/25 02:27:44 imp Exp $
# $NetBSD: bsd.port.mk,v 1.62 1998/04/09 12:47:02 hubertf Exp $ # $NetBSD: bsd.port.mk,v 1.62 1998/04/09 12:47:02 hubertf Exp $
# #
@ -1377,7 +1377,7 @@ ${_PACKAGE_COOKIE${_S}}:
@f=${_CACHE_REPO}/${_PKGFILE${_S}}; \ @f=${_CACHE_REPO}/${_PKGFILE${_S}}; \
cd ${.CURDIR} && ${MAKE} $$f && \ cd ${.CURDIR} && ${MAKE} $$f && \
{ ln $$f $@ 2>/dev/null || cp -p $$f $@ ; } || \ { ln $$f $@ 2>/dev/null || cp -p $$f $@ ; } || \
cd ${.CURDIR} && ${MAKE} _TRIED_FETCHING_${_PACKAGE_COOKIE${_S}}=Yes $@ cd ${.CURDIR} && ${MAKE} _TRIED_FETCHING_${_PACKAGE_COOKIE${_S}}=Yes _internal-package-only
. else . else
@cd ${.CURDIR} && exec ${MAKE} ${_PACKAGE_COOKIE_DEPS} @cd ${.CURDIR} && exec ${MAKE} ${_PACKAGE_COOKIE_DEPS}
. if target(pre-package) . if target(pre-package)
@ -1412,7 +1412,11 @@ ${_PACKAGE_COOKIE${_S}}:
# The real install # The real install
${_INSTALL_COOKIE${_S}}: ${_INSTALL_COOKIE${_S}}:
. if ${FETCH_PACKAGES:L} == "yes"
@cd ${.CURDIR} && exec ${MAKE} subpackage
. else
@cd ${.CURDIR} && exec ${MAKE} package @cd ${.CURDIR} && exec ${MAKE} package
. endif
@cd ${.CURDIR} && SUBPACKAGE=${_S} DEPENDS_TARGET=install \ @cd ${.CURDIR} && SUBPACKAGE=${_S} DEPENDS_TARGET=install \
exec ${MAKE} _internal-run-depends _internal-runlib-depends \ exec ${MAKE} _internal-run-depends _internal-runlib-depends \
_internal-runwantlib-depends _internal-runwantlib-depends