This runs autoreconf (or a command of your choice, like autogen.sh) at the gen stage. It implies "gnu". ok espie@
3569 lines
102 KiB
Makefile
3569 lines
102 KiB
Makefile
#-*- mode: Makefile; tab-width: 4; -*-
|
|
# ex:ts=4 sw=4 filetype=make:
|
|
# $OpenBSD: bsd.port.mk,v 1.1466 2019/05/14 14:59:56 naddy Exp $
|
|
#
|
|
# bsd.port.mk - 940820 Jordan K. Hubbard.
|
|
# This file is in the public domain.
|
|
|
|
# Each port has a MAINTAINER, which is the email address(es) of the person(s)
|
|
# to contact if you have questions/suggestions about that specific port.
|
|
# To obtain that address, just type
|
|
# make show=MAINTAINER
|
|
# in the specific port's directory.
|
|
#
|
|
# The ports@openbsd.org address is the `default' MAINTAINER (the generic
|
|
# OpenBSD ports mailing-list).
|
|
|
|
|
|
# The definitive source of documentation to this file's user-visible parts
|
|
# is bsd.port.mk(5).
|
|
#
|
|
# Any variable or target starting with an underscore (e.g., _DEPEND_ECHO)
|
|
# is internal to bsd.port.mk, not part of the user's API, and liable to
|
|
# change without notice.
|
|
#
|
|
# a few experimental variables are voluntarily NOT documented
|
|
# PARALLEL_BUILD, PARALLEL_INSTALL, DANGEROUS, GLOBAL_DEPENDS_CACHE
|
|
#
|
|
# Enquiries as to the bsd.port.mk framework should usually be directed
|
|
# to ports@openbsd.org.
|
|
|
|
# Sequence for "all" is: fetch checksum prepare extract patch configure build
|
|
#
|
|
# Please read the comments in the targets section below, you
|
|
# should be able to use the pre-* or post-* targets (which
|
|
# are available for every stage except checksum) or provide
|
|
# an overriding do-* target to do pretty much anything you
|
|
# want.
|
|
#
|
|
# For historical reasons, the distpatch target is a subtarget of patch.
|
|
# If you provide a do-patch, you MUST call distpatch explicitly.
|
|
# The sequence of hooks actually run is:
|
|
#
|
|
# pre-patch `real distpatch' post-distpatch `real patch' post-patch
|
|
#
|
|
|
|
#
|
|
# tests and variable definitions come first, THEN targets
|
|
#
|
|
.if ${.MAKEFLAGS:MFLAVOR=*}
|
|
ERRORS += "Fatal: Use 'env FLAVOR=${FLAVOR} ${MAKE}' instead."
|
|
.endif
|
|
.if ${.MAKEFLAGS:MSUBPACKAGE=*}
|
|
ERRORS += "Fatal: Use 'env SUBPACKAGE=${SUBPACKAGE} ${MAKE}' instead."
|
|
.endif
|
|
|
|
.for f v in bsd.port.mk _BSD_PORT_MK bsd.port.subdir.mk _BSD_PORT_SUBDIR_MK
|
|
. if defined($v)
|
|
ERRORS += "Fatal: inclusion of bsd.port.mk from $f"
|
|
. endif
|
|
.endfor
|
|
|
|
# hook to allow scripts to query bsd.port.mk without having a valid port
|
|
.if defined(DUMMY_PACKAGE)
|
|
COMMENT ?= dummy
|
|
CATEGORIES ?= dummy
|
|
PKGPATH ?= dummy/a
|
|
DISTNAME ?= dummy
|
|
PERMIT_PACKAGE_CDROM ?= Yes
|
|
IGNORE ?= Yes
|
|
_MAKEFILE_INC_DONE ?= Yes
|
|
ECHO_MSG ?= :
|
|
.endif
|
|
|
|
# include guard so that other parts don't include this twice
|
|
_BSD_PORT_MK = Done
|
|
|
|
# User settings
|
|
FETCH_PACKAGES ?= No
|
|
CLEANDEPENDS ?= No
|
|
BULK ?= Auto
|
|
WRKDIR_LINKNAME ?=
|
|
|
|
USE_MFS ?= No
|
|
WRKOBJDIR ?= ${PORTSDIR}/pobj
|
|
WRKOBJDIR_MFS ?= /tmp/pobj
|
|
FAKEOBJDIR ?=
|
|
UPDATE_PLIST_ARGS ?=
|
|
UPDATE_PLIST_OPTS ?=
|
|
|
|
BULK_TARGETS ?=
|
|
BULK_DO ?=
|
|
CHECK_LIB_DEPENDS ?= No
|
|
FORCE_UPDATE ?= No
|
|
DPB ?= All Fetch Test
|
|
PREPARE_CHECK_ONLY ?= No
|
|
_SHSCRIPT = sh ${PORTSDIR}/infrastructure/bin
|
|
DPB_PROPERTIES ?=
|
|
|
|
# bsd.own.mk overrides
|
|
BINMODE = 755
|
|
NONBINMODE = 644
|
|
|
|
# All variables relevant to the port's description (see dump-vars)
|
|
_ALL_VARIABLES = BUILD_DEPENDS IS_INTERACTIVE \
|
|
SUBPACKAGE FLAVOR BUILD_PACKAGES DPB_PROPERTIES \
|
|
MULTI_PACKAGES
|
|
# and stuff needing to be MULTI_PACKAGE'd
|
|
_ALL_VARIABLES_INDEXED = FULLPKGNAME RUN_DEPENDS LIB_DEPENDS IGNORE
|
|
_ALL_VARIABLES_PER_ARCH =
|
|
|
|
# consumers of (dump-vars) include sqlports generation and dpb
|
|
# dpb doesn't need everything, those are speed optimizations
|
|
.if ${DPB:L:Mfetch} || ${DPB:L:Mall}
|
|
_ALL_VARIABLES += DISTFILES PATCHFILES SUPDISTFILES DIST_SUBDIR MASTER_SITES \
|
|
MASTER_SITES0 MASTER_SITES1 MASTER_SITES2 MASTER_SITES3 MASTER_SITES4 \
|
|
MASTER_SITES5 MASTER_SITES6 MASTER_SITES7 MASTER_SITES8 MASTER_SITES9 \
|
|
CHECKSUM_FILE FETCH_MANUALLY MISSING_FILES \
|
|
PERMIT_DISTFILES_FTP
|
|
.endif
|
|
.if ${DPB:L:Mtest} || ${DPB:L:Mall}
|
|
_ALL_VARIABLES += NO_TEST TEST_IS_INTERACTIVE TEST_DEPENDS
|
|
.endif
|
|
.if ${DPB:L:Mall}
|
|
_ALL_VARIABLES += HOMEPAGE DISTNAME \
|
|
BROKEN COMES_WITH \
|
|
USE_GMAKE USE_GROFF MODULES FLAVORS \
|
|
NO_BUILD PSEUDO_FLAVORS \
|
|
CONFIGURE_STYLE USE_LIBTOOL SEPARATE_BUILD \
|
|
SHARED_LIBS TARGETS PSEUDO_FLAVOR \
|
|
MAINTAINER AUTOCONF_VERSION AUTOMAKE_VERSION CONFIGURE_ARGS \
|
|
GH_ACCOUNT GH_COMMIT GH_PROJECT GH_TAGNAME PORTROACH \
|
|
PORTROACH_COMMENT MAKEFILE_LIST USE_LLD USE_WXNEEDED COMPILER \
|
|
COMPILER_LANGS COMPILER_LINKS SUBST_VARS UPDATE_PLIST_ARGS \
|
|
PKGPATHS
|
|
_ALL_VARIABLES_PER_ARCH += BROKEN
|
|
# and stuff needing to be MULTI_PACKAGE'd
|
|
_ALL_VARIABLES_INDEXED += COMMENT PKGNAME \
|
|
ONLY_FOR_ARCHS NOT_FOR_ARCHS PKGSPEC PKGSTEM PREFIX \
|
|
PERMIT_PACKAGE_FTP PERMIT_PACKAGE_CDROM WANTLIB CATEGORIES DESCR \
|
|
EPOCH REVISION STATIC_PLIST PKG_ARCH
|
|
.endif
|
|
|
|
PATCH_CHECK_ONLY ?= No
|
|
EDIT_PATCHES ?= Yes
|
|
REFETCH ?= false
|
|
PORTROACH ?=
|
|
|
|
# Global path locations.
|
|
PORTSDIR ?= /usr/ports
|
|
X11BASE ?= /usr/X11R6
|
|
VARBASE ?= /var
|
|
DISTDIR ?= ${PORTSDIR}/distfiles
|
|
BULK_COOKIES_DIR ?= ${PORTSDIR}/bulk/${MACHINE_ARCH}
|
|
UPDATE_COOKIES_DIR ?= ${PORTSDIR}/update/${MACHINE_ARCH}
|
|
|
|
PLIST_REPOSITORY ?= ${PORTSDIR}/plist
|
|
.if !empty(PLIST_REPOSITORY)
|
|
PLIST_DB ?= ${PLIST_REPOSITORY}/${MACHINE_ARCH}
|
|
.endif
|
|
PACKAGE_REPOSITORY ?= ${PORTSDIR}/packages
|
|
|
|
FIX_EXTRACT_PERMISSIONS ?= No
|
|
|
|
.if !exists(${X11BASE}/man/mandoc.db)
|
|
. if exists(${X11BASE}/man/whatis.db)
|
|
ERRORS += "Your X11/system is not current"
|
|
. else
|
|
ERRORS += "Fatal: building ports requires correctly installed X11"
|
|
. endif
|
|
.endif
|
|
|
|
# stuff common to bsd.port.mk and bsd.port.subdir.mk
|
|
# (determination of PKGPATH and various shell fragments:
|
|
# flavor determination, dependency caching behavior...)
|
|
.include "${PORTSDIR}/infrastructure/mk/pkgpath.mk"
|
|
|
|
.if ${USE_MFS:L} == "yes"
|
|
WRKOBJDIR_${PKGPATH} ?= ${WRKOBJDIR_MFS}
|
|
.else
|
|
WRKOBJDIR_${PKGPATH} ?= ${WRKOBJDIR}
|
|
.endif
|
|
FAKEOBJDIR_${PKGPATH} ?= ${FAKEOBJDIR}
|
|
|
|
BULK_${PKGPATH} ?= ${BULK}
|
|
BULK_TARGETS_${PKGPATH} ?= ${BULK_TARGETS}
|
|
BULK_DO_${PKGPATH} ?= ${BULK_DO}
|
|
CLEANDEPENDS_${PKGPATH} ?= ${CLEANDEPENDS}
|
|
|
|
# Commands and command settings.
|
|
PKG_DBDIR ?= /var/db/pkg
|
|
|
|
PROGRESS_METER ?= Yes
|
|
.if ${PROGRESS_METER:L} == "yes"
|
|
_PROGRESS = -m
|
|
.else
|
|
_PROGRESS =
|
|
.endif
|
|
|
|
FETCH_CMD ?= /usr/bin/ftp -V ${_PROGRESS} -C
|
|
|
|
# switch for fetching each distfile: avoid warnings for missing
|
|
# distinfo and wrong size when running makesum
|
|
_MAKESUM ?= false
|
|
|
|
PKG_TMPDIR ?= /var/tmp
|
|
|
|
PKG_ADD ?= /usr/sbin/pkg_add
|
|
PKG_INFO ?= /usr/sbin/pkg_info
|
|
PKG_CREATE ?= /usr/sbin/pkg_create
|
|
PKG_DELETE ?= /usr/sbin/pkg_delete
|
|
|
|
_PKG_ADD = ${PKG_ADD} ${_PROGRESS} -I
|
|
_PKG_CREATE = ${PKG_CREATE} ${_PROGRESS}
|
|
_SUDO_PKG_ADD_LOCAL = TRUSTED_PKG_PATH=${_PKG_REPO} ${SUDO} ${_PKG_ADD}
|
|
_PKG_DELETE = ${PKG_DELETE} ${_PROGRESS}
|
|
|
|
.if defined(PKG_PATH)
|
|
_PKG_PATH = ${PKG_PATH}
|
|
.else
|
|
_PKG_PATH = installpath
|
|
.endif
|
|
|
|
.if !defined(_ARCH_DEFINES_INCLUDED)
|
|
_ARCH_DEFINES_INCLUDED = Done
|
|
. include "${PORTSDIR}/infrastructure/mk/arch-defines.mk"
|
|
.endif
|
|
|
|
.if !defined(_MAKEFILE_INC_DONE)
|
|
. if exists(${.CURDIR}/../Makefile.inc)
|
|
_MAKEFILE_INC_DONE = Yes
|
|
. include "${.CURDIR}/../Makefile.inc"
|
|
. endif
|
|
.endif
|
|
|
|
|
|
# XXX clean may be set in stone on the cmdline, so we need to define _clean
|
|
# instead, if not already set while recursing
|
|
_clean ?= ${clean}
|
|
.if empty(_clean) || ${_clean} == "depends"
|
|
_clean += work
|
|
.endif
|
|
.if ${_clean:Mall}
|
|
_clean += work build packages plist
|
|
.endif
|
|
.if ${CLEANDEPENDS_${PKGPATH}:L} == "yes"
|
|
_clean += depends
|
|
.endif
|
|
.if ${_clean:Mwork} || ${_clean:Mbuild}
|
|
_clean += fake
|
|
.endif
|
|
.if ${_clean:Mforce}
|
|
_clean += -f
|
|
.endif
|
|
|
|
_okay_words = depends work fake -f flavors dist install sub packages package \
|
|
bulk force plist build all
|
|
.for _w in ${_clean}
|
|
. if !${_okay_words:M${_w}}
|
|
ERRORS += "Fatal: unknown clean command: ${_w}\n(not in ${_okay_words})"
|
|
. endif
|
|
.endfor
|
|
|
|
# Used to build wrapper scripts to run compilers, appended by compiler MODULES
|
|
COMPILER_LINKS ?=
|
|
|
|
# MODULES support
|
|
# reserved name spaces: for module=NAME, modname*, _modname* variables and
|
|
# targets.
|
|
|
|
# These variables must be defined before modules
|
|
CONFIGURE_STYLE ?=
|
|
NO_DEPENDS ?= No
|
|
NO_BUILD ?= No
|
|
NO_TEST ?= No
|
|
INSTALL_TARGET ?= install
|
|
USE_GROFF ?= No
|
|
|
|
.if !defined(_ARCH_DEFINES_INCLUDED)
|
|
_ARCH_DEFINES_INCLUDED = Done
|
|
. include "${PORTSDIR}/infrastructure/mk/arch-defines.mk"
|
|
.endif
|
|
|
|
.if ${CONFIGURE_STYLE:L:Mautoconf} || ${CONFIGURE_STYLE:L:Mautoreconf}
|
|
. if !${CONFIGURE_STYLE:L:Mgnu}
|
|
CONFIGURE_STYLE += gnu
|
|
. endif
|
|
.endif
|
|
|
|
.if ${CONFIGURE_STYLE:L:Mmodbuild}
|
|
. if !${CONFIGURE_STYLE:L:Mperl}
|
|
CONFIGURE_STYLE += perl
|
|
. endif
|
|
.endif
|
|
|
|
.for _i in perl gnu imake
|
|
. if ${CONFIGURE_STYLE:L:M${_i}}
|
|
MODULES += ${_i}
|
|
. endif
|
|
.endfor
|
|
|
|
MODULES ?=
|
|
.if !empty(MODULES) || !empty(COMPILER)
|
|
_MODULES_DONE =
|
|
. include "${PORTSDIR}/infrastructure/mk/modules.port.mk"
|
|
.endif
|
|
|
|
# this only happens if we exit modules without having ever gone
|
|
# thru compiler.port.mk
|
|
COMPILER ?= base-clang base-gcc gcc3
|
|
COMPILER_LANGS ?= c c++
|
|
.if ${PROPERTIES:Mclang}
|
|
CHOSEN_COMPILER ?= base-clang
|
|
.elif ${PROPERTIES:Mgcc4}
|
|
CHOSEN_COMPILER ?= base-gcc
|
|
.else
|
|
CHOSEN_COMPILER ?= gcc3
|
|
.endif
|
|
COMPILER_LIBCXX ?= ${LIBCXX}
|
|
|
|
###
|
|
### Variable setup that can happen after modules
|
|
###
|
|
|
|
.for v in PKGREPOSITORY PKGREPOSITORYBASE CDROM_PACKAGES FTP_PACKAGES \
|
|
SED_PLIST IGNORE_FILES NO_REGRESS REGRESS_IS_INTERACTIVE REGRESS_DEPENDS \
|
|
PERMIT_DISTFILES_CDROM
|
|
. if defined($v)
|
|
ERRORS += "Fatal: Variable $v is obsolete, see bsd.port.mk(5)"
|
|
. endif
|
|
.endfor
|
|
|
|
.if !empty(BUILD_DEPENDS:Mdevel/automake/*)
|
|
DPB_PROPERTIES += noconfigurejunk
|
|
.endif
|
|
|
|
.for t in pre-fetch do-fetch post-fetch pre-package do-package post-package
|
|
. if target($t)
|
|
ERRORS += "Fatal: you're not allowed to override $t"
|
|
. endif
|
|
.endfor
|
|
|
|
|
|
# some introspection
|
|
TARGETS =
|
|
.for _t in extract patch distpatch configure build fake install
|
|
. for _s in pre do post
|
|
. if target(${_s}-${_t})
|
|
TARGETS += ${_s}-${_t}
|
|
. endif
|
|
. endfor
|
|
.endfor
|
|
.for _t in post-extract post-patch gen pre-configure configure pre-fake post-install
|
|
. for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_${_t})
|
|
TARGETS += MOD${_m}_${_t}
|
|
. endif
|
|
. endfor
|
|
.endfor
|
|
|
|
SEPARATE_BUILD ?= No
|
|
|
|
DIST_SUBDIR ?=
|
|
|
|
.if !empty(DIST_SUBDIR)
|
|
FULLDISTDIR ?= ${DISTDIR}/${DIST_SUBDIR}
|
|
.else
|
|
FULLDISTDIR ?= ${DISTDIR}
|
|
.endif
|
|
|
|
PATCHDIR ?= ${.CURDIR}/patches
|
|
PATCH_LIST ?= patch-*
|
|
FILESDIR ?= ${.CURDIR}/files
|
|
PKGDIR ?= ${.CURDIR}/pkg
|
|
|
|
PREFIX ?= ${LOCALBASE}
|
|
TRUEPREFIX ?= ${PREFIX}
|
|
DESTDIRNAME ?= DESTDIR
|
|
DESTDIR ?= ${WRKINST}
|
|
|
|
MAKE_FLAGS ?=
|
|
FAKE_FLAGS ?=
|
|
LIBTOOL_FLAGS ?=
|
|
|
|
# User choice, consider read-only from a given port
|
|
BASESYSCONFDIR ?= /etc
|
|
# where configuration files should actually go
|
|
SYSCONFDIR ?= ${BASESYSCONFDIR}
|
|
|
|
# User choice, consider read-only from a given port
|
|
BASELOCALSTATEDIR ?= ${VARBASE}
|
|
# Defaut localstatedir for gnu ports
|
|
LOCALSTATEDIR ?= ${BASELOCALSTATEDIR}
|
|
|
|
RCDIR ?= /etc/rc.d
|
|
USE_WXNEEDED ?= No
|
|
.if ${USE_WXNEEDED:L} == "yes"
|
|
_WXNEEDED_FLAGS = -z wxneeded
|
|
.endif
|
|
USE_GMAKE ?= No
|
|
.if ${USE_GMAKE:L} == "yes"
|
|
BUILD_DEPENDS += devel/gmake
|
|
MAKE_PROGRAM = ${GMAKE}
|
|
CONFIGURE_ENV += MAKE=${MAKE_PROGRAM}
|
|
.else
|
|
MAKE_PROGRAM = ${MAKE}
|
|
.endif
|
|
# Even if a port does not actually use libtool, defaulting to Yes does no
|
|
# harm since there is a libtool in the base system.
|
|
USE_LIBTOOL ?= Yes
|
|
_lt_libs =
|
|
.if ${USE_LIBTOOL:L} != "no"
|
|
. if ${USE_LIBTOOL:L} == "gnu"
|
|
LIBTOOL ?= ${LOCALBASE}/bin/libtool
|
|
BUILD_DEPENDS += devel/libtool
|
|
. else
|
|
LIBTOOL ?= /usr/bin/libtool
|
|
MAKE_ENV += PORTSDIR="${PORTSDIR}"
|
|
. endif
|
|
# Massage into an intermediate variable because python does
|
|
# not parse variables with trailing spaces properly and adds
|
|
# a bogus "" argument.
|
|
_LIBTOOL = ${LIBTOOL}
|
|
.if !empty(LIBTOOL_FLAGS)
|
|
_LIBTOOL += "${LIBTOOL_FLAGS}"
|
|
.endif
|
|
CONFIGURE_ENV += LIBTOOL="${_LIBTOOL}" ${_lt_libs}
|
|
MAKE_ENV += LIBTOOL="${_LIBTOOL}" ${_lt_libs}
|
|
MAKE_FLAGS += LIBTOOL="${_LIBTOOL}" ${_lt_libs}
|
|
.endif
|
|
# log for the SHARED_LIBS override
|
|
MAKE_FLAGS += SHARED_LIBS_LOG=${WRKBUILD}/shared_libs.log
|
|
USE_CCACHE ?= No
|
|
NO_CCACHE ?= No
|
|
CCACHE_ENV ?=
|
|
.if ${USE_CCACHE:L} == "yes" && ${NO_CCACHE:L} == "no" && ${NO_BUILD:L} == "no"
|
|
CCACHE_DIR ?= ${WRKOBJDIR_${PKGPATH}}/.ccache
|
|
MAKE_ENV += CCACHE_DIR=${CCACHE_DIR} ${CCACHE_ENV}
|
|
CONFIGURE_ENV += CCACHE_DIR=${CCACHE_DIR}
|
|
BUILD_DEPENDS += devel/ccache
|
|
COMPILER_WRAPPER = ccache
|
|
.endif
|
|
|
|
# by default, installation (fake) does not need -jN.
|
|
ALL_FAKE_FLAGS= ${MAKE_FLAGS:N-j[0-9]*} ${DESTDIRNAME}=${WRKINST} ${FAKE_FLAGS}
|
|
|
|
.if ${LOCALBASE:L} != "/usr/local"
|
|
_PKG_ADD += -L ${LOCALBASE}
|
|
.endif
|
|
|
|
# XXX this stuff is not production-ready, because there are too many bugs in
|
|
# parallel make yet. MAKE_JOBS>1 is known to work on a few ports and used
|
|
# sparingly by dpb (DPB_PROPERTIES=parallel) for obvious gains.
|
|
#
|
|
PARALLEL_BUILD ?= Yes
|
|
PARALLEL_INSTALL ?= ${PARALLEL_BUILD}
|
|
MAKE_JOBS ?= 1
|
|
|
|
.if ${MAKE_JOBS} != 1
|
|
. if ${PARALLEL_BUILD:L} == "yes"
|
|
MAKE_FLAGS += -j${MAKE_JOBS}
|
|
. endif
|
|
. if ${PARALLEL_INSTALL:L} == "yes"
|
|
ALL_FAKE_FLAGS += -j${MAKE_JOBS}
|
|
. endif
|
|
.endif
|
|
|
|
# Here comes the part that sets BUILD_PACKAGES and various IGNORE* up.
|
|
.if !defined(_BSD_PORT_ARCH_MK_INCLUDED)
|
|
. include "${PORTSDIR}/infrastructure/mk/bsd.port.arch.mk"
|
|
.endif
|
|
|
|
.for _S in ${MULTI_PACKAGES}
|
|
PERMIT_PACKAGE_CDROM${_S} ?= ${PERMIT_PACKAGE_CDROM}
|
|
. if defined(PERMIT_PACKAGE_FTP)
|
|
PERMIT_PACKAGE_FTP${_S} ?= ${PERMIT_PACKAGE_FTP}
|
|
. endif
|
|
. if defined(PERMIT_PACKAGE_CDROM${_S}) && ${PERMIT_PACKAGE_CDROM${_S}:L} == "yes"
|
|
PERMIT_PACKAGE_FTP${_S} ?= Yes
|
|
. endif
|
|
. if !defined(PERMIT_PACKAGE_CDROM${_S}) || !defined(PERMIT_PACKAGE_FTP${_S})
|
|
ERRORS += "The licensing info for ${FULLPKGNAME${_S}} is incomplete."
|
|
_BAD_LICENSING = Yes
|
|
. endif
|
|
.endfor
|
|
|
|
.if defined(PERMIT_PACKAGE_CDROM) && ${PERMIT_PACKAGE_CDROM:L} == "yes"
|
|
PERMIT_PACKAGE_FTP ?= Yes
|
|
PERMIT_DISTFILES_FTP ?= Yes
|
|
.elif defined(PERMIT_PACKAGE_FTP) && ${PERMIT_PACKAGE_FTP:L} == "yes"
|
|
PERMIT_DISTFILES_FTP ?= Yes
|
|
.endif
|
|
|
|
.if !defined(PERMIT_PACKAGE_CDROM) || !defined(PERMIT_PACKAGE_FTP) || \
|
|
!defined(PERMIT_DISTFILES_FTP)
|
|
ERRORS += "The licensing info for ${FULLPKGNAME} is incomplete."
|
|
_BAD_LICENSING = Yes
|
|
.endif
|
|
|
|
.if defined(_BAD_LICENSING)
|
|
ERRORS += "Please notify the OpenBSD port maintainer:"
|
|
ERRORS += " ${MAINTAINER}"
|
|
PERMIT_PACKAGE_CDROM = No
|
|
PERMIT_PACKAGE_FTP = No
|
|
PERMIT_DISTFILES_FTP = No
|
|
. for _S in ${MULTI_PACKAGES}
|
|
PERMIT_PACKAGE_CDROM${_S} = No
|
|
PERMIT_PACKAGE_FTP${_S} = No
|
|
. endfor
|
|
.endif
|
|
|
|
.if ${MACHINE_ARCH} != ${ARCH}
|
|
PKG_ARCH ?= ${MACHINE_ARCH},${ARCH}
|
|
.else
|
|
PKG_ARCH ?= ${MACHINE_ARCH}
|
|
.endif
|
|
|
|
REVISION ?=
|
|
EPOCH ?=
|
|
|
|
.for _s in ${MULTI_PACKAGES}
|
|
REVISION${_s} ?= ${REVISION}
|
|
EPOCH${_s} ?= ${EPOCH}
|
|
.endfor
|
|
|
|
FLAVOR ?=
|
|
FLAVORS ?=
|
|
PSEUDO_FLAVORS ?=
|
|
FLAVORS += ${PSEUDO_FLAVORS}
|
|
|
|
.if !empty(FLAVORS:Mtest) && empty(FLAVOR:Mtest)
|
|
NO_TEST = Yes
|
|
.endif
|
|
|
|
.if empty(SUBPACKAGE)
|
|
ERRORS += "Fatal: empty SUBPACKAGE is invalid."
|
|
.else
|
|
. for _i in ${SUBPACKAGE}
|
|
. if empty(MULTI_PACKAGES:M${_i})
|
|
ERRORS += "Fatal: Subpackage ${SUBPACKAGE} does not exist."
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
.if !empty(MULTI_PACKAGES:N-*)
|
|
ERRORS += "Fatal: SUBPACKAGES should always begin with -: ${MULTI_PACKAGES:N-*}."
|
|
.endif
|
|
|
|
# Build FLAVOR_EXT, checking that no flavors are misspelled
|
|
FLAVOR_EXT :=
|
|
BASE_PKGPATH := ${PKGPATH}
|
|
# _FLAVOR_EXT2 is used internally for working directories.
|
|
# It encodes flavors and pseudo-flavors.
|
|
_FLAVOR_EXT2 :=
|
|
BUILD_PKGPATH := ${PKGPATH}
|
|
_PKG_ARGS = -u ${PORTSDIR}/infrastructure/db/user.list
|
|
.if !empty(PLIST_DB)
|
|
_PKG_ARGS += -DHISTORY_DIR=${PLIST_DB}/history
|
|
.endif
|
|
_README_DIR = ${LOCALBASE}/share/doc/pkg-readmes
|
|
|
|
PSEUDO_FLAVOR =
|
|
# (applies only to PLIST for now)
|
|
.if !empty(FLAVORS)
|
|
. for _i in ${FLAVORS}
|
|
. if empty(FLAVOR:M${_i})
|
|
_PKG_ARGS += -D${_i}=0
|
|
. else
|
|
_FLAVOR_EXT2 := ${_FLAVOR_EXT2}-${_i}
|
|
BUILD_PKGPATH := ${BUILD_PKGPATH},${_i}
|
|
. if empty(PSEUDO_FLAVORS:M${_i})
|
|
FLAVOR_EXT := ${FLAVOR_EXT}-${_i}
|
|
BASE_PKGPATH := ${BASE_PKGPATH},${_i}
|
|
. else
|
|
PSEUDO_FLAVOR := ${PSEUDO_FLAVOR},${_i}
|
|
. endif
|
|
_PKG_ARGS += -D${_i}=1
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
.if !${BUILD_PKGPATH:M*,*}
|
|
BUILD_PKGPATH := ${BUILD_PKGPATH},
|
|
.endif
|
|
|
|
.if !empty(FLAVORS:M[0-9]*)
|
|
ERRORS += "Fatal: flavor should never start with a digit"
|
|
.endif
|
|
|
|
.if !empty(FLAVOR)
|
|
. if !empty(FLAVORS)
|
|
. for _i in ${FLAVOR}
|
|
. if empty(FLAVORS:M${_i})
|
|
ERRORS += "Fatal: Unknown flavor: ${_i}"
|
|
ERRORS += " (Possible flavors are: ${FLAVORS})."
|
|
. endif
|
|
. endfor
|
|
. else
|
|
ERRORS += "Fatal: Unknown flavor(s) ${FLAVOR}"
|
|
ERRORS += " (No flavors for this port)."
|
|
. endif
|
|
.endif
|
|
|
|
.if ${USE_GROFF:L} == "yes"
|
|
BUILD_DEPENDS += textproc/groff>=1.21
|
|
_PKG_ARGS += -DUSE_GROFF=1
|
|
.endif
|
|
|
|
# github related variables
|
|
GH_TAGNAME ?=
|
|
GH_COMMIT ?=
|
|
GH_ACCOUNT ?=
|
|
GH_PROJECT ?=
|
|
|
|
.if !empty(GH_PROJECT) && !empty(GH_TAGNAME)
|
|
DISTNAME ?= ${GH_PROJECT}-${GH_TAGNAME:C/^v//}
|
|
.endif
|
|
|
|
PKGNAME ?= ${DISTNAME}
|
|
FULLPKGNAME ?= ${PKGNAME}${FLAVOR_EXT}
|
|
_MASTER ?=
|
|
_FETCH_RECURSE_HELPER ?= No
|
|
_DEPENDENCY_STACK ?=
|
|
|
|
.if ${MULTI_PACKAGES} == "-"
|
|
# XXX "parse" FULLPKGNAME: is there a flavor after the version number
|
|
. if ${FULLPKGNAME:M*-[0-9]*-*}
|
|
. if !empty(REVISION)
|
|
# XXX simplest way is to alter FULLPKGNAME in place, even though := is evil...
|
|
FULLPKGNAME := ${FULLPKGNAME:C/-([0-9][^-]*)-/-\1p${REVISION}-/}
|
|
. endif
|
|
. if !empty(EPOCH)
|
|
FULLPKGNAME := ${FULLPKGNAME:C/-([0-9][^-]*)-/-\1v${EPOCH}-/}
|
|
. endif
|
|
. else
|
|
. if !empty(REVISION)
|
|
FULLPKGNAME := ${FULLPKGNAME}p${REVISION}
|
|
. endif
|
|
. if !empty(EPOCH)
|
|
FULLPKGNAME := ${FULLPKGNAME}v${EPOCH}
|
|
. endif
|
|
. endif
|
|
PKGSPEC ?= ${FULLPKGNAME:C/-[0-9].*/-*/}
|
|
PKGSPEC- = ${PKGSPEC}
|
|
FULLPKGNAME- = ${FULLPKGNAME}
|
|
PKGSTEM ?= ${FULLPKGNAME:C/-[0-9].*//}
|
|
PKGSTEM- = ${PKGSTEM}
|
|
.else
|
|
. for _s in ${MULTI_PACKAGES}
|
|
. if defined(FULLPKGNAME${_s})
|
|
. if !defined(FULLPKGPATH${_s}) && "${FLAVORS}" != " ${PSEUDO_FLAVORS}"
|
|
ERRORS += "Warning: FULLPKGNAME${_s} defined but no FULLPKGPATH${_s}"
|
|
. endif
|
|
. else
|
|
. if defined(PKGNAME${_s})
|
|
FULLPKGNAME${_s} = ${PKGNAME${_s}}${FLAVOR_EXT}
|
|
. else
|
|
FULLPKGNAME${_s} = ${PKGNAME}${_s}${FLAVOR_EXT}
|
|
. endif
|
|
. endif
|
|
# XXX see comments above for !MULTI_PACKAGES case
|
|
. if ${FULLPKGNAME${_s}:M*-[0-9]*-*}
|
|
. if !empty(REVISION${_s})
|
|
FULLPKGNAME${_s} := ${FULLPKGNAME${_s}:C/-([0-9][^-]*)-/-\1p${REVISION${_s}}-/}
|
|
. endif
|
|
. if !empty(EPOCH${_s})
|
|
FULLPKGNAME${_s} := ${FULLPKGNAME${_s}:C/-([0-9][^-]*)-/-\1v${EPOCH${_s}}-/}
|
|
. endif
|
|
. else
|
|
. if !empty(REVISION${_s})
|
|
FULLPKGNAME${_s} := ${FULLPKGNAME${_s}}p${REVISION${_s}}
|
|
. endif
|
|
. if !empty(EPOCH${_s})
|
|
FULLPKGNAME${_s} := ${FULLPKGNAME${_s}}v${EPOCH${_s}}
|
|
. endif
|
|
. endif
|
|
PKGSPEC${_s} ?= ${FULLPKGNAME${_s}:C/-[0-9].*/-*/}
|
|
PKGSTEM${_s} ?= ${FULLPKGNAME${_s}:C/-[0-9].*//}
|
|
. endfor
|
|
.endif
|
|
|
|
_WRKDIR_COOKIE = ${WRKDIR}/.extract_started
|
|
_EXTRACT_COOKIE = ${WRKDIR}/.extract_done
|
|
_PATCH_COOKIE = ${WRKDIR}/.patch_done
|
|
_DISTPATCH_COOKIE = ${WRKDIR}/.distpatch_done
|
|
_PREPATCH_COOKIE = ${WRKDIR}/.prepatch_done
|
|
_GEN_COOKIE = ${WRKDIR}/.gen_done
|
|
_BULK_COOKIE = ${BULK_COOKIES_DIR}/${FULLPKGNAME}
|
|
_FAKE_COOKIE = ${WRKINST}/.fake_done
|
|
_INSTALL_PRE_COOKIE = ${WRKINST}/.install_started
|
|
_UPDATE_COOKIES =
|
|
_FUPDATE_COOKIES =
|
|
_INSTALL_COOKIES =
|
|
.for _S in ${BUILD_PACKAGES}
|
|
. if !empty(UPDATE_COOKIES_DIR)
|
|
_UPDATE_COOKIE${_S} = ${UPDATE_COOKIES_DIR}/${FULLPKGNAME${_S}}
|
|
_FUPDATE_COOKIE${_S} = ${UPDATE_COOKIES_DIR}/F${FULLPKGNAME${_S}}
|
|
. else
|
|
_UPDATE_COOKIE${_S} = ${WRKDIR}/.update_${FULLPKGNAME${_S}}
|
|
_FUPDATE_COOKIE${_S} = ${WRKDIR}/.fupdate_${FULLPKGNAME${_S}}
|
|
. endif
|
|
_INSTALL_COOKIE${_S} = ${PKG_DBDIR}/${FULLPKGNAME${_S}}/+CONTENTS
|
|
_UPDATE_COOKIES += ${_UPDATE_COOKIE${_S}}
|
|
_FUPDATE_COOKIES += ${_FUPDATE_COOKIE${_S}}
|
|
_INSTALL_COOKIES += ${_INSTALL_COOKIE${_S}}
|
|
.endfor
|
|
.if ${SEPARATE_BUILD:L} != "no"
|
|
_CONFIGURE_COOKIE = ${WRKBUILD}/.configure_done
|
|
_BUILD_COOKIE = ${WRKBUILD}/.build_done
|
|
_TEST_COOKIE = ${WRKBUILD}/.test_done
|
|
.else
|
|
_CONFIGURE_COOKIE = ${WRKDIR}/.configure_done
|
|
_BUILD_COOKIE = ${WRKDIR}/.build_done
|
|
_TEST_COOKIE = ${WRKDIR}/.test_done
|
|
.endif
|
|
|
|
_TS_COOKIE = ${WRKDIR}/.check-wrkdir_stamp
|
|
|
|
_ALL_COOKIES = ${_EXTRACT_COOKIE} ${_PATCH_COOKIE} ${_GEN_COOKIE} \
|
|
${_CONFIGURE_COOKIE} \
|
|
${_INSTALL_PRE_COOKIE} ${_BUILD_COOKIE} ${_TEST_COOKIE} \
|
|
${_PACKAGE_COOKIES} ${_CACHE_PACKAGE_COOKIES} \
|
|
${_DISTPATCH_COOKIE} ${_PREPATCH_COOKIE} ${_FAKE_COOKIE} \
|
|
${_TS_COOKIE} \
|
|
${_WRKDIR_COOKIE} ${_DEPBUILD_COOKIES} \
|
|
${_DEPRUN_COOKIES} ${_DEPTEST_COOKIES} ${_UPDATE_COOKIES} \
|
|
${_DEPBUILDLIB_COOKIES} ${_DEPRUNLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE} ${_DEPRUNWANTLIB_COOKIE} ${_DEPLIBSPECS_COOKIES}
|
|
|
|
_MAKE_COOKIE = /usr/bin/touch
|
|
_PMAKE_COOKIE = ${_PBUILD} ${_MAKE_COOKIE}
|
|
|
|
GMAKE ?= gmake
|
|
|
|
CHECKSUM_FILE ?= ${.CURDIR}/distinfo
|
|
|
|
# Current digest algorithm
|
|
_CIPHER = sha256
|
|
|
|
PORTPATH ?= ${WRKDIR}/bin:/usr/bin:/bin:/usr/sbin:/sbin:${LOCALBASE}/bin:${X11BASE}/bin
|
|
|
|
# Add any COPTS to CFLAGS. Note: programs that use imake do not
|
|
# use CFLAGS! Also, many (most?) ports hard code CFLAGS, ignoring
|
|
# what we pass in.
|
|
CFLAGS += ${COPTS}
|
|
CXXFLAGS += ${CXXOPTS}
|
|
WARNINGS ?= no
|
|
.if ${WARNINGS:L} == "yes"
|
|
CFLAGS += ${CDIAGFLAGS}
|
|
CXXFLAGS += ${CXXDIAGFLAGS}
|
|
.endif
|
|
|
|
# XXX trick ports into trying to write into / instead of the current user's
|
|
# homedir.
|
|
PORTHOME ?= /${PKGNAME}_writes_to_HOME
|
|
|
|
MAKE_ENV += PATH='${PORTPATH}' PREFIX='${PREFIX}' \
|
|
LOCALBASE='${LOCALBASE}' X11BASE='${X11BASE}' \
|
|
CFLAGS='${CFLAGS:C/ *$//}' \
|
|
TRUEPREFIX='${PREFIX}' ${DESTDIRNAME}='' \
|
|
HOME='${PORTHOME}'
|
|
|
|
DISTORIG ?= .bak.orig
|
|
PATCH ?= /usr/bin/patch
|
|
PATCHORIG ?= .orig
|
|
PATCH_STRIP ?= -p0
|
|
PATCH_DIST_STRIP ?= -p0
|
|
|
|
PATCH_DEBUG ?= Yes
|
|
.if ${PATCH_DEBUG:L} != "no"
|
|
PATCH_ARGS ?= -d ${WRKDIST} -z ${PATCHORIG} -E ${PATCH_STRIP}
|
|
PATCH_DIST_ARGS ?= -z ${DISTORIG} -d ${WRKDIST} -E ${PATCH_DIST_STRIP}
|
|
.else
|
|
PATCH_ARGS ?= -d ${WRKDIST} -z ${PATCHORIG} --forward --quiet -E ${PATCH_STRIP}
|
|
PATCH_DIST_ARGS ?= -z ${DISTORIG} -d ${WRKDIST} --forward --quiet -E \
|
|
${PATCH_DIST_STRIP}
|
|
.endif
|
|
|
|
.if ${PATCH_CHECK_ONLY:L} == "yes"
|
|
PATCH_ARGS += -C
|
|
PATCH_DIST_ARGS += -C
|
|
.endif
|
|
|
|
TAR ?= /bin/tar
|
|
UNZIP ?= unzip
|
|
BZIP2 ?= bzip2
|
|
|
|
.if ${LOCALBASE} != "/usr/local"
|
|
_perl_arch=`perl -e 'use Config; print $$Config{archname}, "\n";'`
|
|
_EXTRA_ENV= \
|
|
PKG_CONFIG_PATH=${LOCALBASE}/share/pkgconfig:${LOCALBASE}/lib/pkgconfig \
|
|
PERL5LIB=${LOCALBASE}/libdata/perl5/site_perl/${_perl_arch}:${LOCALBASE}/libdata/perl5/site_perl
|
|
CONFIGURE_ENV += ${_EXTRA_ENV}
|
|
MAKE_ENV += ${_EXTRA_ENV}
|
|
.endif
|
|
|
|
.if ${PROPERTIES:Mlld}
|
|
USE_LLD ?= Yes
|
|
.else
|
|
USE_LLD ?= No
|
|
.endif
|
|
|
|
.if ${USE_LLD:L} == "yes"
|
|
_LD_PROGRAM = /usr/bin/ld.lld
|
|
. if ! ${PROPERTIES:Mlld}
|
|
_NONDEFAULT_LD = Yes
|
|
. endif
|
|
.else
|
|
_LD_PROGRAM = /usr/bin/ld.bfd
|
|
. if ${PROPERTIES:Mlld}
|
|
_NONDEFAULT_LD = Yes
|
|
. endif
|
|
.endif
|
|
_NONDEFAULT_LD ?= No
|
|
|
|
# setup locations of compilers from the base system or environment variables.
|
|
# MODULES for compilers (gcc4.port.mk, clang.port.mk) also append to this,
|
|
# used to write wrappers to WRKDIR/bin which is at the head of the PATH.
|
|
.if ${PROPERTIES:Mclang}
|
|
. if !${COMPILER_LINKS:Mclang}
|
|
COMPILER_LINKS += clang /usr/bin/clang
|
|
. endif
|
|
. if !${COMPILER_LINKS:Mclang++}
|
|
COMPILER_LINKS += clang++ /usr/bin/clang++
|
|
. endif
|
|
.endif
|
|
.if ! ${COMPILER_LINKS:Mcc}
|
|
. if ${CC} == cc
|
|
# use the full path for cc/c++ to avoid the script executing itself.
|
|
COMPILER_LINKS += cc /usr/bin/cc
|
|
. else
|
|
# handle "make CC=foo".
|
|
COMPILER_LINKS += cc ${CC}
|
|
. endif
|
|
.endif
|
|
.if ! ${COMPILER_LINKS:Mc++}
|
|
. if ${CXX} == c++
|
|
COMPILER_LINKS += c++ /usr/bin/c++
|
|
. else
|
|
COMPILER_LINKS += c++ ${CXX}
|
|
. endif
|
|
.endif
|
|
|
|
|
|
# copy selected info from bsd.own.mk
|
|
MAKE_ENV += COMPILER_VERSION=${COMPILER_VERSION} \
|
|
PICFLAG="${PICFLAG}" \
|
|
BINGRP=bin BINOWN=root BINMODE=${BINMODE} NONBINMODE=${NONBINMODE} \
|
|
DIRMODE=755 \
|
|
INSTALL_COPY=-c INSTALL_STRIP=${INSTALL_STRIP} \
|
|
MANGRP=bin MANOWN=root MANMODE=${MANMODE}
|
|
.if defined(NOPIC)
|
|
MAKE_ENV += NOPIC=${NOPIC}
|
|
.endif
|
|
|
|
|
|
.if !empty(FAKEOBJDIR_${PKGPATH})
|
|
WRKINST ?= ${FAKEOBJDIR_${PKGPATH}}/${PKGNAME}${_FLAVOR_EXT2}
|
|
.else
|
|
WRKINST ?= ${WRKDIR}/fake-${ARCH}${_FLAVOR_EXT2}
|
|
.endif
|
|
|
|
.if ${SEPARATE_BUILD:L:Mflavored}
|
|
_WRKDIR_STEM = ${PKGNAME}
|
|
.else
|
|
_WRKDIR_STEM = ${PKGNAME}${_FLAVOR_EXT2}
|
|
.endif
|
|
|
|
WRKDIR ?= ${WRKOBJDIR_${PKGPATH}}/${_WRKDIR_STEM}
|
|
_WRKDIRS = ${WRKOBJDIR_${PKGPATH}}/${_WRKDIR_STEM}
|
|
_WRKDIRS += ${WRKOBJDIR}/${_WRKDIR_STEM}
|
|
_WRKDIRS += ${WRKOBJDIR_MFS}/${_WRKDIR_STEM}
|
|
|
|
.if !empty(GH_TAGNAME)
|
|
WRKDIST ?= ${WRKDIR}/${GH_PROJECT}-${GH_TAGNAME:C/^v//}
|
|
.elif !empty(GH_COMMIT)
|
|
WRKDIST ?= ${WRKDIR}/${GH_PROJECT}-${GH_COMMIT}
|
|
.else
|
|
. if !defined(DISTNAME)
|
|
WRKDIST ?= ${WRKDIR}
|
|
. else
|
|
WRKDIST ?= ${WRKDIR}/${DISTNAME}
|
|
. endif
|
|
.endif
|
|
|
|
WRKSRC ?= ${WRKDIST}
|
|
|
|
.if ${SEPARATE_BUILD:L} != "no"
|
|
WRKBUILD ?= ${WRKDIR}/build-${MACHINE_ARCH}${_FLAVOR_EXT2}
|
|
.else
|
|
WRKBUILD ?= ${WRKSRC}
|
|
.endif
|
|
WRKCONF ?= ${WRKBUILD}
|
|
|
|
MAKE_FILE ?= Makefile
|
|
ALL_TARGET ?= all
|
|
|
|
FAKE_TARGET ?= ${INSTALL_TARGET}
|
|
|
|
TEST_TARGET ?= test
|
|
TEST_FLAGS ?=
|
|
TEST_ENV ?=
|
|
ALL_TEST_FLAGS = ${MAKE_FLAGS} ${TEST_FLAGS}
|
|
ALL_TEST_ENV = ${MAKE_ENV} ${TEST_ENV}
|
|
TEST_LOGFILE ?= ${WRKDIR}/test.log
|
|
TEST_LOG = | ${_PBUILD} tee ${TEST_LOGFILE}
|
|
IS_INTERACTIVE ?= No
|
|
TEST_IS_INTERACTIVE ?= No
|
|
|
|
.if ${TEST_IS_INTERACTIVE:L} == "x11"
|
|
TEST_ENV += DISPLAY=${DISPLAY} XAUTHORITY=${XAUTHORITY}
|
|
XAUTHORITY ?= ${HOME}/.Xauthority
|
|
.endif
|
|
|
|
_PACKAGE_COOKIE_DEPS=${_FAKE_COOKIE}
|
|
|
|
.for _s in ${BUILD_PACKAGES}
|
|
PKGNAMES += ${FULLPKGNAME${_s}}
|
|
PKGFILES += ${PKGFILE${_s}}
|
|
PKGPATHS += ${FULLPKGPATH${_s}}
|
|
.endfor
|
|
|
|
STATIC_PLIST ?= Yes
|
|
.for _s in ${MULTI_PACKAGES}
|
|
. for _v in PKG_ARCH RUN_DEPENDS WANTLIB LIB_DEPENDS PREFIX CATEGORIES \
|
|
STATIC_PLIST
|
|
${_v}${_s} ?= ${${_v}}
|
|
. endfor
|
|
.endfor
|
|
|
|
.for _s in ${MULTI_PACKAGES}
|
|
. for _v in MESSAGE UNMESSAGE DESCR PLIST
|
|
. if defined(${_v})
|
|
${_v}${_s} ?= ${${_v}}
|
|
. endif
|
|
. endfor
|
|
.endfor
|
|
|
|
_PACKAGE_LINKS =
|
|
NO_ARCH ?= ${MACHINE_ARCH}/no-arch
|
|
_PKG_REPO = ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/
|
|
_TMP_REPO = ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/tmp/
|
|
_CACHE_REPO = ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/cache/
|
|
PKGFILE = ${_PKG_REPO}${_PKGFILE${SUBPACKAGE}}
|
|
|
|
.for _S in ${MULTI_PACKAGES}
|
|
_PKGFILE${_S} = ${FULLPKGNAME${_S}}.tgz
|
|
. if ${PKG_ARCH${_S}} == "*" && ${NO_ARCH} != ${MACHINE_ARCH}/all
|
|
_PACKAGE_COOKIE${_S} = ${PACKAGE_REPOSITORY}/${NO_ARCH}/${_PKGFILE${_S}}
|
|
. else
|
|
_PACKAGE_COOKIE${_S} = ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/${_PKGFILE${_S}}
|
|
. endif
|
|
_CACHE_PACKAGE_COOKIES += ${_CACHE_REPO}${_PKGFILE${_S}}
|
|
.endfor
|
|
|
|
.for _S in ${BUILD_PACKAGES}
|
|
. if ${PKG_ARCH${_S}} == "*" && ${NO_ARCH} != ${MACHINE_ARCH}/all
|
|
_PACKAGE_LINKS += ${MACHINE_ARCH}/all/${_PKGFILE${_S}} ${NO_ARCH}/${_PKGFILE${_S}}
|
|
_PACKAGE_COOKIES${_S} += ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/${_PKGFILE${_S}}
|
|
. endif
|
|
_PACKAGE_COOKIES${_S} += ${_PACKAGE_COOKIE${_S}}
|
|
. if ${PERMIT_PACKAGE_FTP${_S}:L} == "yes"
|
|
_PACKAGE_COOKIES${_S} += ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/ftp/${_PKGFILE${_S}}
|
|
_PACKAGE_LINKS += ${MACHINE_ARCH}/ftp/${_PKGFILE${_S}} ${MACHINE_ARCH}/all/${_PKGFILE${_S}}
|
|
. endif
|
|
. if ${PERMIT_PACKAGE_CDROM${_S}:L} == "yes"
|
|
_PACKAGE_COOKIES${_S} += ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/cdrom/${_PKGFILE${_S}}
|
|
_PACKAGE_LINKS += ${MACHINE_ARCH}/cdrom/${_PKGFILE${_S}} ${MACHINE_ARCH}/all/${_PKGFILE${_S}}
|
|
. endif
|
|
_PACKAGE_COOKIES += ${_PACKAGE_COOKIES${_S}}
|
|
_PACKAGE_COOKIE += ${_PACKAGE_COOKIE${_S}}
|
|
PKGFILE${_S} = ${_PKG_REPO}${_PKGFILE${_S}}
|
|
.endfor
|
|
|
|
.if empty(SUBPACKAGE) || ${SUBPACKAGE} == "-"
|
|
FULLPKGPATH ?= ${PKGPATH}${FLAVOR_EXT:S/-/,/g}
|
|
FULLPKGPATH- = ${FULLPKGPATH}
|
|
_FULLPKGPATH = ${PKGPATH}${_FLAVOR_EXT2:S/-/,/g}
|
|
_ALLPKGPATHS = ${FULLPKGPATH}
|
|
.else
|
|
_ALLPKGPATHS = ${PKGPATH}${FLAVOR_EXT:S/-/,/g}
|
|
. for _S in ${MULTI_PACKAGES}
|
|
FULLPKGPATH${_S} ?= ${PKGPATH},${_S}${FLAVOR_EXT:S/-/,/g}
|
|
_ALLPKGPATHS += ${FULLPKGPATH${_S}}
|
|
. endfor
|
|
FULLPKGPATH = ${FULLPKGPATH${SUBPACKAGE}}
|
|
_FULLPKGPATH = ${PKGPATH},${SUBPACKAGE}${_FLAVOR_EXT2:S/-/,/g}
|
|
.endif
|
|
|
|
_INSTALL ?= ${WRKDIR}/bin/install
|
|
|
|
# A few aliases for *-install targets
|
|
INSTALL_PROGRAM = \
|
|
${_INSTALL} ${INSTALL_COPY} ${INSTALL_STRIP} -m ${BINMODE}
|
|
INSTALL_SCRIPT = \
|
|
${_INSTALL} ${INSTALL_COPY} -m ${BINMODE}
|
|
INSTALL_DATA = \
|
|
${_INSTALL} ${INSTALL_COPY} -m ${SHAREMODE}
|
|
INSTALL_MAN = \
|
|
${_INSTALL} ${INSTALL_COPY} -m ${MANMODE}
|
|
|
|
INSTALL_PROGRAM_DIR = \
|
|
${_INSTALL} -d -m ${DIRMODE}
|
|
INSTALL_SCRIPT_DIR = \
|
|
${INSTALL_PROGRAM_DIR}
|
|
INSTALL_DATA_DIR = \
|
|
${_INSTALL} -d -m ${DIRMODE}
|
|
INSTALL_MAN_DIR = \
|
|
${_INSTALL} -d -m ${DIRMODE}
|
|
|
|
WRKOBJDIR_MODE ?=
|
|
DISTDIR_MODE ?= ${WRKOBJDIR_MODE}
|
|
PACKAGE_REPOSITORY_MODE ?= ${WRKOBJDIR_MODE}
|
|
LOCKDIR_MODE ?= ${WRKOBJDIR_MODE}
|
|
PLISTDIR_MODE ?= ${WRKOBJDIR_MODE}
|
|
|
|
_INSTALL_MACROS = BSD_INSTALL_PROGRAM="${INSTALL_PROGRAM}" \
|
|
BSD_INSTALL_SCRIPT="${INSTALL_SCRIPT}" \
|
|
BSD_INSTALL_DATA="${INSTALL_DATA}" \
|
|
BSD_INSTALL_MAN="${INSTALL_MAN}" \
|
|
BSD_INSTALL_PROGRAM_DIR="${INSTALL_PROGRAM_DIR}" \
|
|
BSD_INSTALL_SCRIPT_DIR="${INSTALL_SCRIPT_DIR}" \
|
|
BSD_INSTALL_DATA_DIR="${INSTALL_DATA_DIR}" \
|
|
BSD_INSTALL_MAN_DIR="${INSTALL_MAN_DIR}"
|
|
MAKE_ENV += ${_INSTALL_MACROS}
|
|
|
|
# setup for libtool
|
|
SHARED_LIBS ?=
|
|
|
|
.for _n _v in ${SHARED_LIBS}
|
|
LIB${_n}_VERSION = ${_v}
|
|
SUBST_VARS += LIB${_n}_VERSION
|
|
_lt_libs += LIB${_n}_LTVERSION='-version-info ${_v:S/./:/}:0'
|
|
_lt_libs += lib${_n:S/+/_/g:S/-/_/g:S/./_/g}_ltversion=${_v}
|
|
.endfor
|
|
|
|
# Create the generic variable substitution list
|
|
SUBST_VARS += ARCH BASE_PKGPATH FLAVOR_EXT FULLPKGNAME HOMEPAGE \
|
|
LOCALBASE LOCALSTATEDIR MACHINE_ARCH MAINTAINER \
|
|
PREFIX RCDIR SYSCONFDIR TRUEPREFIX X11BASE PKGSTEM
|
|
|
|
_PKG_ADD_AUTO ?=
|
|
.if !empty(_DEPENDENCY_STACK)
|
|
_PKG_ADD_AUTO += -a
|
|
.endif
|
|
|
|
_TERM_ENV = PKG_TMPDIR=${PKG_TMPDIR}
|
|
.for _v in TERM TERMCAP ftp_proxy http_proxy
|
|
. if defined(${_v})
|
|
_TERM_ENV += ${_v}=${${_v}:Q}
|
|
. endif
|
|
.endfor
|
|
|
|
# See bsd.lib.mk:162
|
|
.if ${MACHINE_ARCH:Mmips64*}
|
|
_PKG_ARGS += -Dno_mips64=0
|
|
.else
|
|
_PKG_ARGS += -Dno_mips64=1
|
|
.endif
|
|
|
|
_PKG_ARGS += -DFLAVORS=${FLAVOR_EXT:Q}
|
|
_PKG_ARGS += -B ${WRKINST}
|
|
.if ${LOCALBASE} != "/usr/local"
|
|
_PKG_ARGS += -L${LOCALBASE}
|
|
.endif
|
|
|
|
.for _S in ${MULTI_PACKAGES}
|
|
PKG_ARGS${_S} ?= ${PKG_ARGS}
|
|
PKG_ARGS${_S} += ${_PKG_ARGS}
|
|
. for _v in ${SUBST_VARS}
|
|
. if defined(${_v:S/^^//}${_S})
|
|
_substvars${_S} += -D${_v}=${${_v:S/^^//}${_S}:Q}
|
|
. else
|
|
_substvars${_S} += -D${_v}=${${_v:S/^^//}:Q}
|
|
. endif
|
|
. endfor
|
|
|
|
# maybe this will want some more fine-grained variable
|
|
. if "${PKG_ARCH${_S}}" != "*"
|
|
PKG_ARGS${_S} += ${_PKG_ARGS_VERSION}
|
|
. endif
|
|
|
|
PKG_ARGS${_S} += ${_substvars${_S}:N-DTRUEPREFIX=*}
|
|
PKG_ARGS${_S} += -DFULLPKGPATH=${FULLPKGPATH${_S}}
|
|
PKG_ARGS${_S} += -DPERMIT_PACKAGE_CDROM=${PERMIT_PACKAGE_CDROM${_S}:Q}
|
|
PKG_ARGS${_S} += -DPERMIT_PACKAGE_FTP=${PERMIT_PACKAGE_FTP${_S}:Q}
|
|
|
|
SUBST_CMD${_S} = ${_PERLSCRIPT}/pkg_subst ${_substvars${_S}}
|
|
SUBST_CMD${_S} += -i -B ${WRKDIR}
|
|
.endfor
|
|
|
|
SUBST_CMD = ${_PERLSCRIPT}/pkg_subst
|
|
.for _v in ${SUBST_VARS}
|
|
SUBST_CMD += -D${_v}=${${_v:S/^^//}:Q}
|
|
.endfor
|
|
SUBST_CMD += -i -B ${WRKDIR}
|
|
|
|
SUBST_PROGRAM = ${SUBST_CMD} -c -m ${BINMODE}
|
|
SUBST_DATA = ${SUBST_CMD} -c -m ${SHAREMODE}
|
|
SUBST_MAN = ${SUBST_CMD} -c -m ${MANMODE}
|
|
|
|
# XXX
|
|
.if ${MULTI_PACKAGES} == "-"
|
|
PLIST ?= ${PKGDIR}/PLIST
|
|
|
|
. if defined(COMMENT${FLAVOR_EXT})
|
|
_COMMENT = ${COMMENT${FLAVOR_EXT}}
|
|
. elif defined(COMMENT)
|
|
_COMMENT = ${COMMENT}
|
|
. endif
|
|
|
|
. if exists(${PKGDIR}/MESSAGE)
|
|
MESSAGE ?= ${PKGDIR}/MESSAGE
|
|
. endif
|
|
|
|
. if exists(${PKGDIR}/UNMESSAGE)
|
|
UNMESSAGE ?= ${PKGDIR}/UNMESSAGE
|
|
. endif
|
|
|
|
DESCR ?= ${PKGDIR}/DESCR
|
|
|
|
. for _v in PLIST _COMMENT MESSAGE UNMESSAGE DESCR
|
|
. if defined(${_v})
|
|
${_v}- = ${${_v}}
|
|
. endif
|
|
. endfor
|
|
.else
|
|
. for _S in ${MULTI_PACKAGES}
|
|
PLIST${_S} ?= ${PKGDIR}/PLIST${_S}
|
|
|
|
. if defined(COMMENT${_S}${FLAVOR_EXT})
|
|
_COMMENT${_S} = ${COMMENT${_S}${FLAVOR_EXT}}
|
|
. elif defined(COMMENT${_S})
|
|
_COMMENT${_S} = ${COMMENT${_S}}
|
|
. endif
|
|
|
|
. if exists(${PKGDIR}/MESSAGE${_S})
|
|
MESSAGE${_S} ?= ${PKGDIR}/MESSAGE${_S}
|
|
. endif
|
|
|
|
. if exists(${PKGDIR}/UNMESSAGE${_S})
|
|
UNMESSAGE${_S} ?= ${PKGDIR}/UNMESSAGE${_S}
|
|
. endif
|
|
|
|
DESCR${_S} ?= ${PKGDIR}/DESCR${_S}
|
|
|
|
. endfor
|
|
.endif
|
|
|
|
|
|
.for _S in ${MULTI_PACKAGES}
|
|
# Fill out package command, and package dependencies
|
|
PKG_ARGS${_S} += -DCOMMENT=${_COMMENT${_S}:Q} -d ${DESCR${_S}}
|
|
PKG_ARGS${_S} += -f ${PLIST${_S}} -p ${PREFIX${_S}}
|
|
. if defined(MESSAGE${_S}) && !empty(MESSAGE${_S})
|
|
PKG_ARGS${_S} += -M ${MESSAGE${_S}}
|
|
. endif
|
|
. if defined(UNMESSAGE${_S}) && !empty(UNMESSAGE${_S})
|
|
PKG_ARGS${_S} += -U ${UNMESSAGE${_S}}
|
|
. endif
|
|
PKG_ARGS${_S} += -A'${PKG_ARCH${_S}}'
|
|
. if !defined(_COMMENT${_S})
|
|
ERRORS += "Fatal: Missing comment for ${_S:S/^-$/main package/}."
|
|
. endif
|
|
.endfor
|
|
|
|
GZIP ?= -9
|
|
GZIP_CMD ?= /usr/bin/gzip -nf ${GZIP}
|
|
M4 ?= /usr/bin/m4
|
|
STRIP ?= /usr/bin/strip
|
|
|
|
# Autoconf scripts MAY tend to use bison by default otherwise
|
|
YACC ?= yacc
|
|
# XXX ${SETENV} is needed in front of var=value lists whenever the next
|
|
# command is expanded from a variable, as this could be a shell construct
|
|
SETENV ?= /usr/bin/env -i
|
|
|
|
# Used to print all the '===>' style prompts - override this to turn them off.
|
|
ECHO_MSG ?= echo
|
|
|
|
# basic master sites configuration
|
|
|
|
.include "${PORTSDIR}/infrastructure/db/network.conf"
|
|
|
|
.if !empty(GH_ACCOUNT) && !empty(GH_PROJECT)
|
|
. if !empty(GH_COMMIT) && !empty(GH_TAGNAME)
|
|
ERRORS += "Fatal: specifying both GH_TAGNAME and GH_COMMIT is invalid"
|
|
. endif
|
|
. if ${GH_TAGNAME} == master
|
|
ERRORS += "Fatal: using master as GH_TAGNAME is invalid"
|
|
. endif
|
|
MASTER_SITES_GITHUB += \
|
|
https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/archive/${GH_TAGNAME:S/$/\//}
|
|
|
|
MASTER_SITES ?= ${MASTER_SITES_GITHUB}
|
|
HOMEPAGE ?= https://github.com/${GH_ACCOUNT}/${GH_PROJECT}
|
|
.else
|
|
# Empty declarations to avoid "variable XXX is recursive" errors
|
|
MASTER_SITES ?=
|
|
.endif
|
|
|
|
# I guess we're in the master distribution business! :) As we gain mirror
|
|
# sites for distfiles, add them to MASTER_SITE_BACKUP
|
|
|
|
_warn_checksum = :
|
|
.if !empty(MASTER_SITES:M*[^/])
|
|
_warn_checksum += ;echo ">>> MASTER_SITES not ending in /: ${MASTER_SITES:M*[^/]}"
|
|
.endif
|
|
|
|
.for _I in 0 1 2 3 4 5 6 7 8 9
|
|
. if defined(MASTER_SITES${_I})
|
|
. if !empty(MASTER_SITES${_I}:M*[^/])
|
|
_warn_checksum += ;echo ">>> MASTER_SITES${_I} not ending in /: ${MASTER_SITES${_I}:M*[^/]}"
|
|
. endif
|
|
. endif
|
|
.endfor
|
|
|
|
|
|
EXTRACT_SUFX ?= .tar.gz
|
|
|
|
.if !empty(GH_COMMIT)
|
|
DISTFILES ?= ${DISTNAME}-${GH_COMMIT:C/(........).*/\1/}${EXTRACT_SUFX}{${GH_COMMIT}${EXTRACT_SUFX}}
|
|
.else
|
|
. if defined(DISTNAME)
|
|
DISTFILES ?= ${DISTNAME}${EXTRACT_SUFX}
|
|
. endif
|
|
.endif
|
|
|
|
PATCHFILES ?=
|
|
SUPDISTFILES ?=
|
|
|
|
# the following loop "parses" DISTFILES-style files
|
|
# _PATH_x contains filenames with SUBDIR prepended when necessary
|
|
# _LIST_x contains pure filenames
|
|
#
|
|
# _FULL_FETCH_LIST is used for creating all targets later on:
|
|
# say if DISTFILES=filename{url}sufx:0 DIST_SUBDIR=foo/
|
|
# it will expand to foo/filenamesufx filename MASTER_SITES0 urlsufx
|
|
#
|
|
# _FILES is used to de-duplicates names
|
|
# the order matters: DISTFILES PATCHFILES SUPDISTFILES
|
|
# - we never have the same names in DISTFILES and PATCHFILES
|
|
# - SUPDISTFILES has to happen later
|
|
_FILES=
|
|
.for v in DISTFILES PATCHFILES SUPDISTFILES
|
|
. if !empty($v)
|
|
. for e in ${$v}
|
|
. for f m u in ${e:C/:[0-9]$//:C/(.*)\{.*\}(.*)/\1\2/} MASTER_SITES${e:M*\:[0-9]:C/.*:([0-9])/\1/} ${e:C/:[0-9]$//:C/.*\{(.*)\}(.*)/\1\2/}
|
|
. if empty(_FILES:M$f)
|
|
_FILES += $f
|
|
. if empty(DIST_SUBDIR)
|
|
_FULL_FETCH_LIST += $f $f $m $u
|
|
_PATH_$v += $f
|
|
. else
|
|
_FULL_FETCH_LIST += ${DIST_SUBDIR}/$f $f $m $u
|
|
_PATH_$v += ${DIST_SUBDIR}/$f
|
|
. endif
|
|
_LIST_$v += $f
|
|
. endif
|
|
. endfor
|
|
. endfor
|
|
. else
|
|
_PATH_$v =
|
|
_LIST_$v =
|
|
. endif
|
|
.endfor
|
|
_FULL_FETCHLIST ?=
|
|
|
|
CHECKSUMFILES = ${_PATH_DISTFILES} ${_PATH_PATCHFILES}
|
|
MAKESUMFILES = ${CHECKSUMFILES} ${_PATH_SUPDISTFILES}
|
|
|
|
# This is what is actually going to be extracted, and is overridable
|
|
# by the user.
|
|
EXTRACT_ONLY ?= ${_LIST_DISTFILES}
|
|
|
|
PATCH_CASES ?=
|
|
EXTRACT_CASES ?=
|
|
|
|
_LIST_EXTRACTED = ${EXTRACT_ONLY} ${_LIST_PATCHFILES}
|
|
|
|
# okay, time for some guess work
|
|
# this is mostly ad-hoc, we may want to add more PATCH_CASES eventually.
|
|
.if !empty(_LIST_EXTRACTED:M*.zip)
|
|
BUILD_DEPENDS += archivers/unzip
|
|
EXTRACT_CASES += *.zip) \
|
|
${UNZIP} -oq ${FULLDISTDIR}/$$archive -d ${WRKDIR};;
|
|
.endif
|
|
|
|
.if !empty(_LIST_EXTRACTED:M*.xz) || \
|
|
!empty(_LIST_EXTRACTED:M*.lzma)
|
|
BUILD_DEPENDS += archivers/xz
|
|
EXTRACT_CASES += *.tar.xz) \
|
|
xzdec <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
EXTRACT_CASES += *.tar.lzma) \
|
|
lzmadec <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
.endif
|
|
|
|
.if !empty(_LIST_EXTRACTED:M*.tar.lz)
|
|
BUILD_DEPENDS += archivers/lzip/lunzip
|
|
EXTRACT_CASES += *.tar.lz) \
|
|
lunzip <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
PATCH_CASES += *.lz) \
|
|
lunzip <$$patchfile | ${PATCH} ${PATCH_DIST_ARGS};;
|
|
.endif
|
|
|
|
.if !empty(_LIST_EXTRACTED:M*.bz2) || \
|
|
!empty(_LIST_EXTRACTED:M*.tbz2) || \
|
|
!empty(_LIST_EXTRACTED:M*.tbz)
|
|
BUILD_DEPENDS += archivers/bzip2
|
|
EXTRACT_CASES += *.tar.bz2|*.tbz2|*.tbz) \
|
|
${BZIP2} -d <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
PATCH_CASES += *.bz2) \
|
|
${BZIP2} -d <$$patchfile | ${PATCH} ${PATCH_DIST_ARGS};;
|
|
.endif
|
|
|
|
|
|
_PERL_FIX_SHAR ?= perl -ne 'print if $$s || ($$s = m:^\#(\!\s*/bin/sh\s*| This is a shell archive):)'
|
|
|
|
EXTRACT_CASES += *.tar) \
|
|
${TAR} xf ${FULLDISTDIR}/$$archive;;
|
|
EXTRACT_CASES += *.shar.gz|*.shar.Z|*.sh.gz|*.sh.Z) \
|
|
${GZIP_CMD} -d <${FULLDISTDIR}/$$archive | ${_PERL_FIX_SHAR} | /bin/sh;;
|
|
EXTRACT_CASES += *.shar | *.sh) \
|
|
${_PERL_FIX_SHAR} ${FULLDISTDIR}/$$archive | /bin/sh;;
|
|
EXTRACT_CASES += *.tar.gz|*.tgz) \
|
|
${GZIP_CMD} -d <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
EXTRACT_CASES += *.gz) \
|
|
${GZIP_CMD} -d <${FULLDISTDIR}/$$archive >$$(basename $$archive .gz);;
|
|
EXTRACT_CASES += *) \
|
|
${GZIP_CMD} -d <${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
|
|
PATCH_CASES += *.Z|*.gz) \
|
|
${GZIP_CMD} -d <$$patchfile | ${PATCH} ${PATCH_DIST_ARGS};;
|
|
PATCH_CASES += *) \
|
|
${PATCH} ${PATCH_DIST_ARGS} < $$patchfile;;
|
|
|
|
# Documentation
|
|
MAINTAINER ?= The OpenBSD ports mailing-list <ports@openbsd.org>
|
|
.if empty(MAINTAINER)
|
|
ERRORS += "Fatal: defining MAINTAINER to empty is an error"
|
|
.endif
|
|
|
|
.if !defined(CATEGORIES)
|
|
ERRORS += "Fatal: CATEGORIES is mandatory."
|
|
.else
|
|
_badcat = Yes
|
|
. for _i in ${CATEGORIES}
|
|
. if ${_badcat} == "Yes"
|
|
. if ${PKGPATH:M${_i}/*}
|
|
_badcat = No
|
|
. endif
|
|
. endif
|
|
. endfor
|
|
|
|
. if ${_badcat} == "Yes"
|
|
ERRORS += "Fatal: one category in ${CATEGORIES} should match PKGPATH=${PKGPATH}"
|
|
. if ${PKGPATH:N*/*}
|
|
ERRORS += "Fatal: bogus PKGPATH=${PKGPATH} (no subdirectory)"
|
|
. endif
|
|
. endif
|
|
.endif
|
|
|
|
|
|
|
|
CONFIGURE_SCRIPT ?= configure
|
|
.if ${CONFIGURE_SCRIPT:M/*}
|
|
_CONFIGURE_SCRIPT = ${CONFIGURE_SCRIPT}
|
|
.else
|
|
. if ${SEPARATE_BUILD:L} != "no"
|
|
_CONFIGURE_SCRIPT = ${WRKSRC}/${CONFIGURE_SCRIPT}
|
|
. else
|
|
_CONFIGURE_SCRIPT = ./${CONFIGURE_SCRIPT}
|
|
. endif
|
|
.endif
|
|
|
|
CONFIGURE_ENV += PATH=${PORTPATH}
|
|
|
|
FETCH_MANUALLY ?= No
|
|
MISSING_FILES =
|
|
.if ${FETCH_MANUALLY:L} != "no"
|
|
. for _F in ${CHECKSUMFILES}
|
|
. if !exists(${DISTDIR}/${_F})
|
|
MISSING_FILES += ${_F}
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
|
|
################################################################
|
|
# Many ways to disable a port.
|
|
#
|
|
# A lot of them actually occur earlier on, in bsd.port.arch.mk
|
|
#
|
|
# If we're in BATCH mode and the port is interactive, or we're
|
|
# in interactive mode and the port is non-interactive, skip all
|
|
# the important targets. The reason we have two modes is that
|
|
# one might want to leave a build in BATCH mode running
|
|
# overnight, then come back in the morning and do _only_ the
|
|
# interactive ones that required your intervention.
|
|
#
|
|
# Ignore ports that can't be resold if building for a CDROM.
|
|
#
|
|
# Don't build a port if it's broken.
|
|
#
|
|
# Don't build a port if it comes with the base system.
|
|
################################################################
|
|
TRY_BROKEN ?= No
|
|
_IGNORE_TEST ?=
|
|
.if ${TEST_IS_INTERACTIVE:L} != "no" && defined(BATCH)
|
|
_IGNORE_TEST += "has interactive tests"
|
|
.elif ${TEST_IS_INTERACTIVE:L} == "no" && defined(INTERACTIVE)
|
|
_IGNORE_TEST += "does not have interactive tests"
|
|
.endif
|
|
|
|
.if ${IS_INTERACTIVE:L} != "no" && defined(BATCH)
|
|
IGNORE += "is an interactive port"
|
|
.elif !(${IS_INTERACTIVE:L} != "no" || !empty(MISSING_FILES)) && defined(INTERACTIVE)
|
|
IGNORE += "is not an interactive port"
|
|
.endif
|
|
.if !empty(MISSING_FILES) && defined(BATCH)
|
|
_EXTRA_IGNORE += "is an interactive port: missing files"
|
|
.endif
|
|
|
|
.if ${TRY_BROKEN:L} != "yes"
|
|
. if defined(BROKEN-${ARCH})
|
|
IGNORE += "is marked as broken for ${ARCH}: ${BROKEN-${ARCH}:Q}"
|
|
. endif
|
|
. if ${MACHINE_ARCH} != ${ARCH} && defined(BROKEN-${MACHINE_ARCH})
|
|
IGNORE += "is marked as broken for ${MACHINE_ARCH}: ${BROKEN-${MACHINE_ARCH}:Q}"
|
|
. endif
|
|
. if defined(BROKEN)
|
|
IGNORE += "is marked as broken: ${BROKEN:Q}"
|
|
. endif
|
|
.endif
|
|
.if defined(COMES_WITH)
|
|
IGNORE += "-- ${FULLPKGNAME${SUBPACKAGE}:C/-[0-9].*//g} comes with OpenBSD as of release ${COMES_WITH}"
|
|
.endif
|
|
|
|
IGNORE_IS_FATAL ?= "No"
|
|
# XXX even if subpackage is invalid, define this, so that errors come out
|
|
# from ERRORS and not make internals.
|
|
IGNORE${SUBPACKAGE} ?=
|
|
.if (!empty(IGNORE${SUBPACKAGE}) || defined(_EXTRA_IGNORE)) && ${IGNORE_IS_FATAL:L} == "yes"
|
|
ERRORS += "Fatal: can't build"
|
|
ERRORS += ${IGNORE${SUBPACKAGE}} ${_EXTRA_IGNORE}
|
|
.endif
|
|
|
|
_DEPENDS_TARGET ?= install
|
|
|
|
################################################################
|
|
# Dependency checking
|
|
################################################################
|
|
|
|
# Various dependency styles
|
|
_resolve_lib = LOCALBASE=${LOCALBASE} X11BASE=${X11BASE} \
|
|
${_PERLSCRIPT}/port-resolve-lib-helper
|
|
|
|
PKG_CREATE_NO_CHECKS ?= No
|
|
.if ${PKG_CREATE_NO_CHECKS:L} == "yes"
|
|
_pkg_wantlib_args = fake-wantlib-args
|
|
.elif ${PKG_CREATE_NO_CHECKS:L} == "warn"
|
|
_pkg_wantlib_args = wantlib-args
|
|
_check_msg = Warning
|
|
# ignore diff error
|
|
_check_error = || true
|
|
.else
|
|
_pkg_wantlib_args = wantlib-args
|
|
_check_msg = Error
|
|
# let diff error out
|
|
_check_error =
|
|
.endif
|
|
wantlib_args ?= port-wantlib-args
|
|
lib_depends_args ?= lib-depends-args
|
|
|
|
|
|
|
|
.if ${FORCE_UPDATE:L} == "yes" || ${FORCE_UPDATE:L} == "hard"
|
|
_force_update_fragment = { \
|
|
${ECHO_MSG} "===> Verifying update for $$pkg in $$dir"; \
|
|
if ( eval $$toset exec ${MAKE} subupdate ); then \
|
|
${ECHO_MSG} "===> Returning to build of ${FULLPKGNAME${SUBPACKAGE}}${_MASTER}"; \
|
|
else \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1; \
|
|
fi; \
|
|
}
|
|
_PKG_ADD_FORCE = -D update -D updatedepends
|
|
. if ${FORCE_UPDATE:L} == "hard"
|
|
_PKG_ADD_FORCE += -D installed
|
|
. endif
|
|
.else
|
|
_force_update_fragment = :
|
|
_PKG_ADD_FORCE =
|
|
.endif
|
|
|
|
_FULL_PACKAGE_NAME ?= No
|
|
|
|
# We check for dependency syntax errors before rewriting things.
|
|
_CHECK_DEPENDS =
|
|
.for _v in BUILD LIB RUN TEST
|
|
_CHECK_DEPENDS +:= ${${_v}_DEPENDS}
|
|
.endfor
|
|
.for _s in ${MULTI_PACKAGES}
|
|
. for _v in RUN LIB
|
|
_CHECK_DEPENDS +:= ${${_v}_DEPENDS${_s}}
|
|
. endfor
|
|
.endfor
|
|
.if ${_CHECK_DEPENDS:M\:*}
|
|
ERRORS += "Fatal: old style depends ${_CHECK_DEPENDS:M\:*}"
|
|
.endif
|
|
|
|
# the C,...., part basically does this:
|
|
# if the depends contains only pkgpath>=something
|
|
# then we rebuild it as STEM->=something:pkgpath
|
|
|
|
.for _v in BUILD LIB RUN TEST
|
|
${_v}_DEPENDS := ${${_v}_DEPENDS:C,^([^:]+/[^:<=>]+)([<=>][^:]+)$,STEM-\2:\1,}
|
|
.endfor
|
|
.for _v in BUILD TEST
|
|
${_v}_DEPENDS := ${${_v}_DEPENDS:C,^([^:]+/[^:<=>]+)([<=>][^:]+)(:patch|:configure|:build)$,STEM-\2:\1\3,}
|
|
.endfor
|
|
.for _s in ${MULTI_PACKAGES}
|
|
. for _v in RUN LIB
|
|
${_v}_DEPENDS${_s} := ${${_v}_DEPENDS${_s}:C,^([^:]+/[^:<=>]+)([<=>][^:]+)$,STEM-\2:\1,}
|
|
. endfor
|
|
.endfor
|
|
|
|
|
|
_BUILDLIB_DEPENDS =
|
|
_BUILDWANTLIB =
|
|
# strip inter-multi-packages dependencies during building
|
|
.for _path in ${PKGPATH:S,^mystuff/,,}
|
|
. for _s in ${BUILD_PACKAGES}
|
|
_BUILDLIB_DEPENDS += ${LIB_DEPENDS${_s}:N*\:${_path}:N*\:${_path},*:N${_path}:N${_path},*}
|
|
_BUILDWANTLIB += ${WANTLIB${_s}}
|
|
_LIB4${_s} = ${LIB_DEPENDS${_s}:M*\:${_path}} ${LIB_DEPENDS${_s}:M*\:${_path},*} ${LIB_DEPENDS${_s}:M${_path}} ${LIB_DEPENDS${_s}:M${_path},*}
|
|
_LIB4 += ${_LIB4${_s}}
|
|
. endfor
|
|
.endfor
|
|
|
|
# automatically try to determine USE_X11 from wantlib
|
|
USE_X11 ?= No
|
|
.for _lib in X11 GL ICE xcb pixman freetype Xft
|
|
. if ${USE_X11:L} != "yes"
|
|
. for _b in ${_BUILDWANTLIB:C/[>=].*//}
|
|
. if "${_b:M${_lib}}"
|
|
USE_X11 = Yes
|
|
. endif
|
|
. endfor
|
|
. endif
|
|
.endfor
|
|
|
|
.if ${NO_DEPENDS:L} == "no"
|
|
_BUILD_DEPLIST = ${BUILD_DEPENDS}
|
|
_RUN_DEPLIST = ${RUN_DEPENDS${SUBPACKAGE}}
|
|
_TEST_DEPLIST = ${TEST_DEPENDS}
|
|
_BUILDLIB_DEPLIST = ${_BUILDLIB_DEPENDS}
|
|
_RUNLIB_DEPLIST = ${LIB_DEPENDS${SUBPACKAGE}}
|
|
.endif
|
|
|
|
_DEPLIST = ${_BUILD_DEPLIST} ${_RUN_DEPLIST} ${_TEST_DEPLIST} \
|
|
${_BUILDLIB_DEPLIST} ${_RUNLIB_DEPLIST}
|
|
|
|
# compute DEPBUILD_COOKIES and friends
|
|
.for _DEP in BUILD RUN BUILDLIB RUNLIB TEST
|
|
. for _i in ${_${_DEP}_DEPLIST}
|
|
_DEP${_DEP}_COOKIES += ${WRKDIR}/.dep-${_i:C,>=,ge-,g:C,<=,le-,g:C,<,lt-,g:C,>,gt-,g:C,\*,ANY,g:C,[|:/=],-,g}
|
|
. endfor
|
|
_DEP${_DEP}_COOKIES ?=
|
|
.endfor
|
|
|
|
# Normal user-mode targets are PHONY targets, e.g., don't create the
|
|
# corresponding file. However, there is nothing phony about the cookie.
|
|
|
|
MODSIMPLE_configure = \
|
|
cd ${WRKCONF} && ${SETENV} \
|
|
CC="${CC}" ac_cv_path_CC="${CC}" CFLAGS="${CFLAGS:C/ *$//}" \
|
|
CXX="${CXX}" ac_cv_path_CXX="${CXX}" CXXFLAGS="${CXXFLAGS:C/ *$//}" \
|
|
INSTALL="${_INSTALL} -c" \
|
|
ac_given_INSTALL="${_INSTALL} -c" \
|
|
INSTALL_PROGRAM="${INSTALL_PROGRAM}" INSTALL_MAN="${INSTALL_MAN}" \
|
|
INSTALL_SCRIPT="${INSTALL_SCRIPT}" INSTALL_DATA="${INSTALL_DATA}" \
|
|
YACC="${YACC}" \
|
|
${CONFIGURE_ENV} ${_CONFIGURE_SCRIPT} ${CONFIGURE_ARGS}
|
|
|
|
FAKE_SETUP = PATH='${PORTPATH}' TRUEPREFIX=${PREFIX} \
|
|
PREFIX=${WRKINST}${PREFIX} ${DESTDIRNAME}=${WRKINST} \
|
|
FAKELOG=${WRKINST}/.fake_log
|
|
|
|
_CLEANDEPENDS ?= Yes
|
|
|
|
# Internal variables, used by dependencies targets
|
|
# Only keep pkg:dir spec, strip extra target
|
|
|
|
.for _mod in C/:(patch|configure|build)$$//
|
|
_BUILD_DEP2 = ${BUILD_DEPENDS:${_mod}}
|
|
_BUILD_DEP3 = ${BUILD_DEPENDS:${_mod}}
|
|
|
|
_RUN_DEP2 = ${RUN_DEPENDS${SUBPACKAGE}:${_mod}}
|
|
_RUN_DEP3 = ${RUN_DEPENDS${SUBPACKAGE}:${_mod}}
|
|
|
|
_TEST_DEP2 = ${TEST_DEPENDS:${_mod}}
|
|
_TEST_DEP3 = ${_TEST_DEP2}
|
|
|
|
_RUN_DEP2 += ${LIB_DEPENDS${SUBPACKAGE}:${_mod}}
|
|
_LIB_DEP3 = ${LIB_DEPENDS${SUBPACKAGE}}
|
|
|
|
_BUILD_DEP2 += ${_BUILDLIB_DEPENDS:${_mod}}
|
|
|
|
. for _S in ${MULTI_PACKAGES}
|
|
_BUILD_DEP3${_S} = ${_BUILD_DEP3}
|
|
_RUN_DEP3${_S} = ${RUN_DEPENDS${_S}:${_mod}}
|
|
_LIB_DEP3${_S} = ${LIB_DEPENDS${_S}}
|
|
. endfor
|
|
|
|
.endfor
|
|
|
|
_DEPBUILDLIBS = ${_BUILDWANTLIB}
|
|
_DEPRUNLIBS = ${WANTLIB${SUBPACKAGE}}
|
|
|
|
# the _DEP*LIBSPECS_COOKIES are only there to force reevaluation of
|
|
# _DEPBUILDWANTLIB_COOKIE and _DEPRUNWANTLIB_COOKIE when the dependencies
|
|
# change (the list will change, and so the cookie will be regenerated)
|
|
.if ${NO_DEPENDS:L} == "no"
|
|
. for i in ${_DEPBUILDLIBS:C,>=,-ge-,g:C,=,-gt-,g:C,/,-,g}
|
|
_DEPBUILDLIBSPECS_COOKIES += ${WRKDIR}/.spec-$i
|
|
. endfor
|
|
_DEPBUILDWANTLIB_COOKIE = ${WRKDIR}/.buildwantlibs
|
|
. for i in ${_DEPRUNLIBS:C,>=,-ge-,g:C,=,-gt-,g:C,/,-,g}
|
|
_DEPRUNLIBSPECS_COOKIES += ${WRKDIR}/.spec-$i
|
|
. endfor
|
|
_DEPRUNWANTLIB_COOKIE = ${WRKDIR}/.runwantlibs${SUBPACKAGE}
|
|
.else
|
|
_DEPBUILDWANTLIB_COOKIE =
|
|
_DEPRUNWANTLIB_COOKIE =
|
|
.endif
|
|
|
|
_DEPLIBSPECS_COOKIES = ${_DEPBUILDLIBSPECS_COOKIES} ${_DEPRUNLIBSPECS_COOKIES}
|
|
|
|
# strip optional pkgspec, only keep the path
|
|
_BUILD_DEP = ${_BUILD_DEP2:C,^[^:/]*:,,}
|
|
_RUN_DEP = ${_RUN_DEP2:C,^[^:/]*:,,}
|
|
_TEST_DEP = ${_TEST_DEP2:C,^[^:/]*:,,}
|
|
|
|
REORDER_DEPENDENCIES ?=
|
|
ECHO_REORDER ?= :
|
|
|
|
# recheck WRK...
|
|
.for w in WRKDIR WRKDIST WRKSRC WRKCONF WRKBUILD WRKINST DIST_SUBDIR
|
|
. if ${$w:M*/}
|
|
ERRORS += "Fatal: $w ends with a slash"
|
|
. endif
|
|
.endfor
|
|
|
|
# Lock infrastructure:
|
|
# to remove locks handling, define LOCKDIR to an empty value
|
|
LOCKDIR ?= ${WRKOBJDIR}/locks
|
|
|
|
LOCK_CMD ?= ${_PBUILD} ${_PERLSCRIPT}/portlock
|
|
UNLOCK_CMD ?= ${_PBUILD} rm -f
|
|
_LOCKS_HELD ?=
|
|
LOCK_VERBOSE ?= No
|
|
.if !empty(LOCKDIR)
|
|
. if ${LOCK_VERBOSE:L} == "yes"
|
|
_LOCK = echo "Locking $$lock (${BUILD_PKGPATH}) from $@"; ${LOCK_CMD} ${LOCKDIR_MODE} ${LOCKDIR}/$$lock.lock ${BUILD_PKGPATH}
|
|
_UNLOCK = echo "Unlocking $$lock from $@"; ${UNLOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
. else
|
|
_LOCK = ${LOCK_CMD} ${LOCKDIR_MODE} ${LOCKDIR}/$$lock.lock ${BUILD_PKGPATH}
|
|
_UNLOCK = ${UNLOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
. endif
|
|
. if ${SEPARATE_BUILD:L:Mflavored}
|
|
_LOCKNAME = ${FULLPKGNAME}
|
|
. else
|
|
_LOCKNAME = ${PKGNAME}
|
|
. endif
|
|
|
|
. for _i in ${_LOCKNAME}
|
|
. if empty(_LOCKS_HELD:M${_i})
|
|
_DO_LOCK = \
|
|
lock=${_LOCKNAME}; \
|
|
_LOCKS_HELD="${_LOCKS_HELD} ${_LOCKNAME}"; export _LOCKS_HELD; \
|
|
${_SIMPLE_LOCK}
|
|
. endif
|
|
. endfor
|
|
|
|
_SIMPLE_LOCK = \
|
|
${_LOCK}; locked=true; \
|
|
trap 'if $$locked; then ${_UNLOCK}; locked=false; fi' 0; \
|
|
trap 'exit 1' 1 2 3 13 15
|
|
|
|
.endif
|
|
_SIMPLE_LOCK ?= :
|
|
_DO_LOCK ?= :
|
|
|
|
CHECKSUM_PACKAGES ?= No
|
|
_PACKAGE_CHECKSUM_DIR = ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/cksums
|
|
|
|
_do_checksum_package = \
|
|
install -d ${PACKAGE_REPOSITORY_MODE} ${_PACKAGE_CHECKSUM_DIR} && \
|
|
cd ${_TMP_REPO} && \
|
|
cksum -b -a sha256 -- $$pkgname \
|
|
>${_PACKAGE_CHECKSUM_DIR}/$$(basename $$pkgname .tgz).sha256
|
|
|
|
.if ${CHECKSUM_PACKAGES:L} == "yes"
|
|
_checksum_package = ${_do_checksum_package}
|
|
.elif ${CHECKSUM_PACKAGES:L} == "ftp"
|
|
_checksum_package = \
|
|
case $${permit_ftp} in yes) \
|
|
${_do_checksum_package};; \
|
|
esac
|
|
.elif ${CHECKSUM_PACKAGES:L} == "cdrom"
|
|
_checksum_package = \
|
|
case $${permit_cdrom} in yes) \
|
|
${_do_checksum_package};; \
|
|
esac
|
|
.else
|
|
_checksum_package = :
|
|
.endif
|
|
|
|
_size_fragment = perl -e '$$s = (stat $$ARGV[0])[7]; print "SIZE ($$ARGV[1]) = $$s\n";'
|
|
|
|
# commands used all the time
|
|
_lines2list = tr '\012' '\040' | sed -e 's, $$,,'
|
|
|
|
_zap_last_line = sed -e '$$d'
|
|
|
|
_sort_dependencies = tsort -r|${_zap_last_line}
|
|
|
|
_version2stem = sed -e 's,-[0-9].*,,'
|
|
|
|
_grab_libs_from_plist = sed -n -e '/^@lib /{ s///; p; }' \
|
|
-e '/^@file .*\/lib\/lib.*\.a$$/{ s/^@file //; p; }'
|
|
|
|
# used in the following pattern
|
|
# while $(_read_spec); do $(_parse_spec); done
|
|
|
|
_read_spec = IFS=: read pkg subdir target
|
|
_parse_spec = \
|
|
d="$$pkg$${subdir:+:}$$subdir$${target:+:}$$target"; \
|
|
extra_msg="(DEPENDS was $$d) in ${FULLPKGPATH}"; \
|
|
case "X$$pkg" in \
|
|
*/*) target="$$subdir"; subdir="$$pkg"; pkg=;; \
|
|
esac; ${_flavor_fragment}
|
|
|
|
_compute_default = \
|
|
set -f; \
|
|
if set -- $$(eval $$toset exec ${MAKE} _print-metadata); then \
|
|
default=$$1; pkgspec=$$2; pkgpath=$$3; \
|
|
else \
|
|
echo 1>&2 "Problem with dependency $$d"; \
|
|
exit 1; \
|
|
fi; \
|
|
set +f
|
|
|
|
_complete_pkgspec = \
|
|
${_compute_default}; \
|
|
case "X$$pkg" in \
|
|
X) \
|
|
pkg=$$pkgspec;; \
|
|
XSTEM*) \
|
|
stem=$$(echo $$default|${_version2stem}); \
|
|
pkg="$$stem$${pkg\#STEM}";; \
|
|
esac
|
|
|
|
_emit_lib_depends = for i in ${LIB_DEPENDS${SUBPACKAGE}:QL}; do echo "$$i"; done
|
|
_emit_run_depends = for i in ${RUN_DEPENDS${SUBPACKAGE}:QL}; do echo "$$i"; done
|
|
|
|
# computing libraries from the ports tree is expensive, so cache as many of
|
|
# these as we can
|
|
|
|
# XXX assumes it's running under _cache_fragment, either directly, or from
|
|
# a target up there
|
|
|
|
# XXX if we can't move the tmpfile, we remove it, because we've been pre-empted
|
|
# by someone with more rights who created the correct file for us
|
|
_libs2cache = \
|
|
cached_libs=$${_DEPENDS_CACHE}/$$(echo $$subdir|sed -e 's/\//--/g'); \
|
|
if ! test -f $$cached_libs; then \
|
|
t=$$(${_PBUILD} mktemp $${_DEPENDS_CACHE}/tmp.XXXXXXXXXX||exit 1); \
|
|
if eval $$toset ${MAKE} print-plist-libs ${_PREDIR} $$t; \
|
|
then \
|
|
${_PBUILD} chmod 0644 $$t; \
|
|
${_PBUILD} mv $$t $$cached_libs || rm $$t; \
|
|
else \
|
|
echo 1>&2 "Problem with dependency $$subdir"; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
|
|
# is this subdir actually needed as a libs depend ?
|
|
_if_check_needed = \
|
|
${_parse_spec}; \
|
|
${_libs2cache}; \
|
|
if ${_resolve_lib} -needed ${_DEPRUNLIBS:QL} <$$cached_libs
|
|
|
|
# turn a list of found libraries into parameters for pkg_create,
|
|
# zap .a in the meantime
|
|
_show_found = \
|
|
for k in $$found; do \
|
|
case $$k in *.a) ;; \
|
|
*) echo "-W $$k";; \
|
|
esac; \
|
|
done
|
|
|
|
# fairly good approximation of libraries we want
|
|
# XXX this is ksh, be less perfect with pure sh
|
|
_lib=/lib*.{so.+([0-9]).+([0-9]),a}
|
|
|
|
_list_system_libs = \
|
|
for i in /usr/lib${_lib} ${X11BASE}/lib${_lib}; do echo $$i; done
|
|
|
|
_list_port_libs = \
|
|
{ ${MAKE} show-run-depends|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
${_libs2cache}; \
|
|
cat $$cached_libs; \
|
|
done; ${_list_system_libs}; }
|
|
|
|
.if empty(PLIST_DB)
|
|
_register_plist =:
|
|
.else
|
|
_register_plist = ${_PBUILD} install -d ${PLISTDIR_MODE} ${PLIST_DB:S/:/ /g} && ${_PBUILD} ${_PERLSCRIPT}/register-plist ${PLIST_DB}
|
|
.endif
|
|
.if ${CHECK_LIB_DEPENDS:L} == "yes"
|
|
_check_lib_depends = ${_CHECK_LIB_DEPENDS}
|
|
.else
|
|
_check_lib_depends =:
|
|
.endif
|
|
|
|
_CHECK_LIB_DEPENDS = PORTSDIR=${PORTSDIR} ${_PERLSCRIPT}/check-lib-depends
|
|
_CHECK_LIB_DEPENDS += -d ${_PKG_REPO} -B ${WRKINST}
|
|
_CHECK_LIB_DEPENDS += -S COMPILER_LIBCXX="${COMPILER_LIBCXX}"
|
|
_CHECK_LIB_DEPENDS += -S LIBECXX="${LIBECXX}"
|
|
_CHECK_LIB_DEPENDS += -S LIBCXX="${LIBCXX}"
|
|
_CHECK_LIB_DEPENDS += -F pthread
|
|
|
|
.for _s in ${MULTI_PACKAGES}
|
|
. if ${STATIC_PLIST${_s}:L} == "no"
|
|
_register_plist${_s} = :
|
|
. else
|
|
_register_plist${_s} = ${_register_plist}
|
|
. endif
|
|
.endfor
|
|
|
|
# script that can verify permissions and timestamps
|
|
|
|
CHECK_WRKDIR ?= No
|
|
WRKDIR_CHANGES_OKAY += ${_ALL_COOKIES}
|
|
WRKDIR_CHANGES_OKAY += ${WRKBUILD}/_build/runtime_params
|
|
WRKDIR_CHANGES_OKAY += ${WRKBUILD}/.ninja_log
|
|
|
|
.if ${CHECK_WRKDIR:L} == "yes"
|
|
_check_wrkdir = ${_PBUILD} ${_PERLSCRIPT}/check-wrkdir
|
|
.else
|
|
_check_wrkdir = :
|
|
.endif
|
|
|
|
.for wrapper command in install install chown chown chown chgrp
|
|
_wrap_install_commands += ${_PBUILD} install -m ${BINMODE} ${PORTSDIR}/infrastructure/bin/${wrapper}-wrapper /${WRKDIR}/bin/${command};
|
|
.endfor
|
|
|
|
_cat = {cat1,cat2,cat3,cat3f,cat3p,cat4,cat5,cat6,cat7,cat8,cat9,catl,catn}
|
|
_man = ${_cat:S/cat/man/g}
|
|
_treebase = ${WRKINST}${LOCALBASE}
|
|
_nls = ${_treebase}/share/nls
|
|
_FAKE_TREE_LIST = \
|
|
${WRKINST}${BASESYSCONFDIR}/{firmware,rc.d} \
|
|
${_treebase}/bin \
|
|
${_treebase}/include/X11 \
|
|
${_treebase}/info \
|
|
${_treebase}/lib/pkgconfig \
|
|
${_treebase}/lib/X11/app-defaults \
|
|
${_treebase}/libdata/perl5/site_perl \
|
|
${_treebase}/libexec \
|
|
${_treebase}/man/${_cat} \
|
|
${_treebase}/man/${_man} \
|
|
${_treebase}/man/ja_JP.EUC/${_cat} \
|
|
${_treebase}/man/ja_JP.EUC/${_man} \
|
|
${_treebase}/sbin \
|
|
${_treebase}/share/{dict,examples,misc,pkgconfig,skel} \
|
|
${_treebase}/share/doc/pkg-readmes \
|
|
${_nls}/{C,da_DK.ISO_8859-1,de_AT.ISO_8859-1,de_CH.ISO_8859-1} \
|
|
${_nls}/{de_DE.ISO_8859-1,el_GR.ISO_8859-7,en_AU.ISO_8859-1} \
|
|
${_nls}/{en_CA.ISO_8859-1,en_GB.ISO_8859-1,en_US.ISO_8859-1} \
|
|
${_nls}/{es_ES.ISO_8859-1,et_EE.ISO-8859-1,fi_FI.ISO_8859-1} \
|
|
${_nls}/{fr_BE.ISO_8859-1,fr_CA.ISO_8859-1,fr_CH.ISO_8859-1} \
|
|
${_nls}/fr_FR.ISO_8859-1 \
|
|
${_nls}/{hr_HR.ISO_8859-2,is_IS.ISO_8859-1,it_CH.ISO_8859-1} \
|
|
${_nls}/{it_IT.ISO_8859-1,ja_JP.EUC,ko_KR.EUC,lt_LN.ASCII} \
|
|
${_nls}/{lt_LN.ISO_8859-1,lt_LN.ISO_8859-2,nl_BE.ISO_8859-1} \
|
|
${_nls}/{no_NO.ISO_8859-1,pl_PL.ISO_8859-2,pt_PT.ISO_8859-1} \
|
|
${_nls}/{ru_RU.CP866,ru_RU.ISO_8859-5,ru_RU.KOI8-R} \
|
|
${_nls}/{sv_SE.ISO_8859-1,uk_UA.KOI8-U} \
|
|
${WRKINST}${VARBASE}/{db,games,log,spool,www}
|
|
|
|
# packing list utilities. This generates a packing list from the WRKINST
|
|
# directory. Not perfect, but pretty close. The generated file
|
|
# will have to have some tweaks done by hand.
|
|
# In particular, since we no longer run fake as root
|
|
|
|
_update_plist = ${_cache_fragment}; \
|
|
PORTSDIR=${PORTSDIR} \
|
|
${_UPDATE_PLIST_SETUP} ${_PERLSCRIPT}/update-plist \
|
|
-w ${PATCHORIG} -w ${DISTORIG} -w .beforesubst \
|
|
-i ARCH -i BASE_PKGPATH -i FULLPKGNAME -i PKGSTEM -i FULLPKGPATH \
|
|
-i LOCALSTATEDIR -i MACHINE_ARCH \
|
|
-s BASE_PKGPATH -s LOCALBASE -s LOCALSTATEDIR -s PREFIX \
|
|
-s RCDIR -s SYSCONFDIR -s X11BASE \
|
|
-X ${_FAKE_COOKIE} -X ${_INSTALL_PRE_COOKIE} -X ${WRKINST}/.saved_libs
|
|
|
|
.for _d in ${_FAKE_TREE_LIST}
|
|
_update_plist += -X ${_d:Q}
|
|
.endfor
|
|
|
|
_update_plist += -L ${WRKINST}/.fake_log \
|
|
-P ${PKGDIR} ${UPDATE_PLIST_ARGS} ${UPDATE_PLIST_OPTS} --
|
|
.for i in ${BUILD_PACKAGES}
|
|
_update_plist += `SUBPACKAGE=$i make run-depends-args lib-depends-args` ${PKG_ARGS$i} ${FULLPKGNAME$i}
|
|
.endfor
|
|
|
|
|
|
###
|
|
### end of variable setup. Only targets now
|
|
###
|
|
dump-vars:
|
|
.if ${MULTI_PACKAGES} == "-"
|
|
. for _v in ${_ALL_VARIABLES} ${_ALL_VARIABLES_INDEXED}
|
|
. if defined(${_v}-)
|
|
. if !empty(${_v}-)
|
|
@echo ${FULLPKGPATH}.${_v}=${${_v}-:Q}
|
|
. endif
|
|
. elif defined(${_v}) && !empty(${_v})
|
|
@echo ${FULLPKGPATH}.${_v}=${${_v}:Q}
|
|
. endif
|
|
. endfor
|
|
. for _v in ${_ALL_VARIABLES_PER_ARCH}
|
|
. for _a in ${ALL_ARCHS}
|
|
. if defined(${_v}-${_a}) && !empty(${_v}-${_a})
|
|
@echo ${FULLPKGPATH}.${_v}-${_a}=${${_v}-${_a}:Q}
|
|
. endif
|
|
. endfor
|
|
. endfor
|
|
.else
|
|
. for _S in ${MULTI_PACKAGES}
|
|
. if !${DPB:L:Mshorter} || "${_S}" == "${SUBPACKAGE}"
|
|
. for _v in ${_ALL_VARIABLES}
|
|
. if defined(${_v}) && !empty(${_v})
|
|
@echo ${FULLPKGPATH${_S}}.${_v}=${${_v}:Q}
|
|
. endif
|
|
. endfor
|
|
. for _v in ${_ALL_VARIABLES_PER_ARCH}
|
|
. for _a in ${ALL_ARCHS}
|
|
. if defined(${_v}-${_a}) && !empty(${_v}-${_a})
|
|
@echo ${FULLPKGPATH${_S}}.${_v}-${_a}=${${_v}-${_a}:Q}
|
|
. endif
|
|
. endfor
|
|
. endfor
|
|
. endif
|
|
. for _v in ${_ALL_VARIABLES_INDEXED}
|
|
. if defined(${_v}${_S}) && !empty(${_v}${_S})
|
|
@echo ${FULLPKGPATH${_S}}.${_v}=${${_v}${_S}:Q}
|
|
. endif
|
|
. endfor
|
|
. endfor
|
|
.endif
|
|
|
|
check-register:
|
|
.if empty(PLIST_DB)
|
|
@exit 1
|
|
.else
|
|
@if cd ${.CURDIR} && PKGPATH=${PKGPATH} ${MAKE} print-plist-with-depends | ${_PERLSCRIPT}/register-plist -p ${PLIST_DB}; then \
|
|
echo "${FULLPKGNAME${SUBPACKAGE}} okay"; \
|
|
else \
|
|
echo "${FULLPKGNAME${SUBPACKAGE}} BAD"; \
|
|
fi
|
|
.endif
|
|
|
|
check-register-all:
|
|
.for _S in ${MULTI_PACKAGES}
|
|
@cd ${.CURDIR} && SUBPACKAGE=${_S} PKGPATH=${PKGPATH} ${MAKE} check-register
|
|
.endfor
|
|
|
|
fix-permissions:
|
|
.if ${PORTS_PRIVSEP:L} == "yes"
|
|
@if test `id -u` != 0; then \
|
|
echo 1>&2 "This must be run as root"; \
|
|
exit 1; \
|
|
fi
|
|
@f=`id -gn ${FETCH_USER}`; \
|
|
echo "give ${DISTDIR} to ${FETCH_USER}:$$f (but not build-stats)"; \
|
|
if test -d ${DISTDIR}; then \
|
|
cd ${DISTDIR} && \
|
|
find . -path ./build-stats -prune -o -exec chown ${FETCH_USER}:$$f {} +; \
|
|
else \
|
|
install -o ${FETCH_USER} -g $$f -d ${DISTDIR}; \
|
|
fi
|
|
. for d in ${LOCKDIR} ${PACKAGE_REPOSITORY} ${PLIST_REPOSITORY} ${WRKOBJDIR}
|
|
@b=`id -gn ${BUILD_USER}`; \
|
|
echo "give $d to ${BUILD_USER}:$$b"; \
|
|
if test -d $d; then \
|
|
cd $d && chown -R ${BUILD_USER}:$$b .; \
|
|
else \
|
|
install -o ${BUILD_USER} -g $$b -d $d; \
|
|
fi
|
|
. endfor
|
|
.endif
|
|
|
|
.for _S in ${MULTI_PACKAGES}
|
|
|
|
# run under _pfetch
|
|
${_CACHE_REPO}${_PKGFILE${_S}}:
|
|
@install -d ${PACKAGE_REPOSITORY_MODE} ${@D}
|
|
@${ECHO_MSG} -n "===> Looking for ${_PKGFILE${_S}} in \$$PKG_PATH - "
|
|
@if ${SETENV} ${_TERM_ENV} PKG_CACHE=${_CACHE_REPO} TRUSTED_PKG_PATH=${_CACHE_REPO}:${_PKG_REPO}:${PACKAGE_REPOSITORY}/${NO_ARCH}/:${TRUSTED_PKG_PATH} PKG_PATH=${_PKG_PATH} ${PKG_ADD} -I -x -n -q ${_PKG_ADD_FORCE} -r -D installed -D downgrade ${FETCH_PACKAGES} ${_PKGFILE${_S}}; then \
|
|
${ECHO_MSG} "found"; \
|
|
exit 0; \
|
|
else \
|
|
${ECHO_MSG} "not found"; \
|
|
exit 1; \
|
|
fi
|
|
|
|
|
|
# The real package
|
|
|
|
${_PACKAGE_COOKIE${_S}}:
|
|
@${_PBUILD} install -d ${PACKAGE_REPOSITORY_MODE} ${@D} ${_TMP_REPO}
|
|
. if ${FETCH_PACKAGES:L} != "no" && !defined(_TRIED_FETCHING_${_PACKAGE_COOKIE${_S}})
|
|
@${_INSTALL_CACHE_REPO} ${_CACHE_REPO}
|
|
@f=${_CACHE_REPO}${_PKGFILE${_S}}; \
|
|
cd ${.CURDIR} && ${_PFETCH} ${MAKE} $$f && \
|
|
{ ${_PBUILD} ln $$f $@ 2>/dev/null || ${_PBUILD} cp -p $$f $@ ; } || \
|
|
cd ${.CURDIR} && ${MAKE} _TRIED_FETCHING_${_PACKAGE_COOKIE${_S}}=Yes _internal-package-only _FETCH_RECURSE_HELPER=No
|
|
. else
|
|
@${_MAKE} ${_PACKAGE_COOKIE_DEPS}
|
|
# What PACKAGE normally does:
|
|
@${_MAKE} _internal-generate-readmes
|
|
@${ECHO_MSG} "===> Building package for ${FULLPKGNAME${_S}}"
|
|
@${ECHO_MSG} "Create ${_PACKAGE_COOKIE${_S}}"
|
|
@cd ${.CURDIR} && \
|
|
tmp=${_TMP_REPO}${_PKGFILE${_S}} pkgname=${_PKGFILE${_S}} permit_ftp=${PERMIT_PACKAGE_FTP${_S}:L:Q} permit_cdrom=${PERMIT_PACKAGE_CDROM${_S}:L:Q} && \
|
|
if deps=$$(SUBPACKAGE=${_S} wantlib_args=${_pkg_wantlib_args} \
|
|
${MAKE} print-package-args) && \
|
|
${_PBUILD} ${_PKG_CREATE} -DPORTSDIR="${PORTSDIR}" \
|
|
$$deps ${PKG_ARGS${_S}} $$tmp && \
|
|
${_check_lib_depends} $$tmp && \
|
|
${_register_plist${_S}} $$tmp && \
|
|
${_checksum_package} && \
|
|
${_PBUILD} mv $$tmp ${_PACKAGE_COOKIE${_S}}; then \
|
|
exit 0; \
|
|
else \
|
|
${_PBUILD} rm -f $$tmp; \
|
|
exit 1; \
|
|
fi
|
|
# End of PACKAGE.
|
|
@-rm -f ${_BULK_COOKIE} ${_UPDATE_COOKIE${_S}} ${_FUPDATE_COOKIE${_S}}
|
|
. endif
|
|
|
|
|
|
# The real install
|
|
|
|
${_INSTALL_COOKIE${_S}}:
|
|
. if ${FETCH_PACKAGES:L} != "no"
|
|
@cd ${.CURDIR} && SUBPACKAGE=${_S} PKGPATH=${PKGPATH} exec ${MAKE} subpackage
|
|
. else
|
|
|
|
@${_MAKE} package
|
|
. endif
|
|
@cd ${.CURDIR} && SUBPACKAGE=${_S} _DEPENDS_TARGET=install PKGPATH=${PKGPATH} \
|
|
exec ${MAKE} _internal-install-depends
|
|
@${ECHO_MSG} "===> Installing ${FULLPKGNAME${_S}} from ${_PKG_REPO}"
|
|
@${SETENV} ${_TERM_ENV} ${_SUDO_PKG_ADD_LOCAL} ${_PKG_ADD_AUTO} ${PKGFILE${_S}};
|
|
@-${SUDO} ${_MAKE_COOKIE} $@
|
|
|
|
|
|
${_UPDATE_COOKIE${_S}}:
|
|
@${_MAKE} _internal-package
|
|
. if empty(UPDATE_COOKIES_DIR)
|
|
@${_MAKE} ${WRKDIR}
|
|
. else
|
|
@mkdir -p ${UPDATE_COOKIES_DIR}
|
|
. endif
|
|
@${ECHO_MSG} "===> Updating for ${FULLPKGNAME${_S}}"
|
|
@b=$$(cd ${.CURDIR} && SUBPACKAGE=${_S} ${MAKE} print-plist|sed -ne '/^@pkgpath /s,,-e ,p'); \
|
|
a=$$(${PKG_INFO} -e ${FULLPKGPATH${_S}} $$b 2>/dev/null |sort -u); \
|
|
case $$a in \
|
|
'') ${ECHO_MSG} "Not installed, no update";; \
|
|
*) cd ${.CURDIR} && SUBPACKAGE=${_S} _DEPENDS_TARGET=package PKGPATH=${PKGPATH} \
|
|
${MAKE} _internal-install-depends; \
|
|
${ECHO_MSG} "Upgrading from $$a"; \
|
|
${SETENV} ${_TERM_ENV} ${_SUDO_PKG_ADD_LOCAL} ${_PKG_ADD_AUTO} -r ${_PKG_ADD_FORCE} ${PKGFILE${_S}};; \
|
|
esac
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
${_FUPDATE_COOKIE${_S}}:
|
|
@${_MAKE} _internal-package
|
|
@cd ${.CURDIR} && SUBPACKAGE=${_S} _DEPENDS_TARGET=package PKGPATH=${PKGPATH} \
|
|
exec ${MAKE} _internal-install-depends
|
|
. if empty(UPDATE_COOKIES_DIR)
|
|
@${_MAKE} ${WRKDIR}
|
|
. else
|
|
@mkdir -p ${UPDATE_COOKIES_DIR}
|
|
. endif
|
|
@${ECHO_MSG} "===> Updating/installing for ${FULLPKGNAME${_S}}"
|
|
@${SETENV} ${_TERM_ENV} ${_SUDO_PKG_ADD_LOCAL} ${_PKG_ADD_AUTO} -r ${_PKG_ADD_FORCE} ${PKGFILE${_S}}
|
|
@${_MAKE_COOKIE} $@
|
|
.endfor
|
|
|
|
.PRECIOUS: ${_PACKAGE_COOKIES} ${_INSTALL_COOKIES}
|
|
|
|
makesum:
|
|
@${_warn_checksum}
|
|
@mv -f ${CHECKSUM_FILE}{,.orig} 2>/dev/null || true
|
|
@${MAKE} fetch-all _MAKESUM=true
|
|
.if !empty(MAKESUMFILES)
|
|
@cd ${DISTDIR} && cksum -b -a "${_CIPHER}" -- ${MAKESUMFILES} >> ${CHECKSUM_FILE}
|
|
@cd ${DISTDIR} && \
|
|
for file in ${MAKESUMFILES}; do \
|
|
${_size_fragment} $$file $$file >> ${CHECKSUM_FILE}; \
|
|
done
|
|
@sort -u -o ${CHECKSUM_FILE} ${CHECKSUM_FILE}
|
|
@diff -Lold -Lnew -u ${CHECKSUM_FILE}{.orig,} 2>/dev/null|| true
|
|
@rm -f ${CHECKSUM_FILE}.orig
|
|
.endif
|
|
|
|
################################################################
|
|
# Dependency checking
|
|
################################################################
|
|
|
|
|
|
|
|
_internal-prepare: ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE}
|
|
|
|
_internal-install-depends: ${_DEPRUN_COOKIES} ${_DEPRUNLIB_COOKIES} \
|
|
${_DEPRUNWANTLIB_COOKIE}
|
|
|
|
_internal-test-depends: ${_DEPTEST_COOKIES}
|
|
|
|
# and the rules for the actual dependencies
|
|
|
|
_print-metadata:
|
|
@echo '${FULLPKGNAME${SUBPACKAGE}}' '${PKGSPEC${SUBPACKAGE}}' '${FULLPKGPATH${SUBPACKAGE}}'
|
|
|
|
_print-packagename:
|
|
.if ${_FULL_PACKAGE_NAME:L} == "yes"
|
|
@echo '${PKGPATH}/${FULLPKGNAME${SUBPACKAGE}}'
|
|
.else
|
|
@echo ${FULLPKGNAME${SUBPACKAGE}}
|
|
.endif
|
|
|
|
.for _i in ${_DEPLIST}
|
|
. if !target(${WRKDIR}/.dep-${_i:C,>=,ge-,g:C,<=,le-,g:C,<,lt-,g:C,>,gt-,g:C,\*,ANY,g:C,[|:/=],-,g})
|
|
${WRKDIR}/.dep-${_i:C,>=,ge-,g:C,<=,le-,g:C,<,lt-,g:C,>,gt-,g:C,\*,ANY,g:C,[|:/=],-,g}: ${_WRKDIR_COOKIE}
|
|
@unset _DEPENDS_TARGET _MASTER WRKDIR|| true; \
|
|
echo '${_i}'| while ${_read_spec}; do \
|
|
${_parse_spec}; \
|
|
_ignore_cookie=${@:S/.dep/.ignored/}; \
|
|
toset="$$toset _IGNORE_COOKIE=$${_ignore_cookie}"; \
|
|
case "X$$target" in X) target=${_DEPENDS_TARGET};; esac; \
|
|
case "X$$target" in \
|
|
Xinstall|Xreinstall) wantsub=false; check_installed=true; try_install=true;; \
|
|
Xpackage|Xfake) wantsub=false; check_installed=true; try_install=false;; \
|
|
Xpatch|Xconfigure|Xbuild) \
|
|
wantsub=true; check_installed=false; try_install=false; \
|
|
${_PBUILD} install -d ${WRKOBJDIR_MODE} `dirname ${WRKDIR}`; \
|
|
${_PBUILD} mkdir -p ${WRKDIR}/$$dir; \
|
|
toset="$$toset _MASTER='[${FULLPKGNAME${SUBPACKAGE}}]${_MASTER}' WRKDIR=${WRKDIR}/$$dir";; \
|
|
*) \
|
|
${ECHO_MSG} "===> Error: can't depend on $$target"; \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1;; \
|
|
esac; \
|
|
${_complete_pkgspec}; \
|
|
toset="$$toset _DEPENDENCY_STACK='${_DEPENDENCY_STACK} ${PKGPATH}'"; \
|
|
h="===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} depends on: $$pkg -"; \
|
|
for second_pass in false true; do \
|
|
if $$check_installed; then \
|
|
case ${PREPARE_CHECK_ONLY:L} in \
|
|
yes) \
|
|
second_pass=true;; \
|
|
esac; \
|
|
$$try_install && ${_force_update_fragment}; \
|
|
x=`mktemp /tmp/dep2.XXXXXXXXXX`; \
|
|
if $$(${PKG_INFO} -e "$$pkg" -r "$$pkg" $$default >$$x); then \
|
|
sed -ne '/^inst:/s///p' <$$x| \
|
|
{ read v || v=found; \
|
|
echo "$$v" ${_PREDIR} $@; \
|
|
${ECHO_MSG} "$$h> $$v"; } ;\
|
|
rm $$x; \
|
|
break; \
|
|
else \
|
|
r=$$?; \
|
|
rm $$x; \
|
|
case $$r in \
|
|
1|3) \
|
|
${ECHO_MSG} "$$h not found";; \
|
|
esac; \
|
|
case $$r in \
|
|
2|3) \
|
|
${ECHO_MSG} "$$h default $$default does not match"; \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1;; \
|
|
esac; \
|
|
fi; \
|
|
else \
|
|
if ! ${PKG_INFO} -q -r "$$pkg" $$default; \
|
|
then \
|
|
${ECHO_MSG} "$$h default $$default does not match"; \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1; \
|
|
fi; \
|
|
fi; \
|
|
if $$second_pass; then \
|
|
${ECHO_MSG} "Dependency check failed"; \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1; \
|
|
fi; \
|
|
${ECHO_MSG} "===> Verifying $$target for $$pkg in $$dir"; \
|
|
if (eval $$toset exec ${MAKE} _FETCH_RECURSE_HELPER=Yes $$target) && \
|
|
! test -e $${_ignore_cookie}; then \
|
|
if $$wantsub; then \
|
|
eval $$toset ${MAKE} show-prepare-results ${_PREDIR} $@; \
|
|
fi; \
|
|
${ECHO_MSG} "===> Returning to build of ${FULLPKGNAME${SUBPACKAGE}}${_MASTER}"; \
|
|
else \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1; \
|
|
fi; \
|
|
$$try_install || break; \
|
|
done; \
|
|
done
|
|
@${_PBUILD} install -d ${WRKOBJDIR_MODE} `dirname ${WRKDIR}`
|
|
@${_PBUILD} mkdir -p ${WRKDIR} ${WRKDIR}/bin
|
|
@${_PMAKE_COOKIE} $@
|
|
. endif
|
|
.endfor
|
|
|
|
show-prepare-results: prepare
|
|
@sort -u ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} /dev/null
|
|
|
|
show-prepare-test-results: prepare test-depends
|
|
@sort -u ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} ${_DEPTEST_COOKIES} /dev/null
|
|
|
|
# very quick rule, create this to force reevaluation of next rule when
|
|
# the dependencies in the Makefile are changed
|
|
. if !empty(_DEPLIBSPECS_COOKIES)
|
|
${_DEPLIBSPECS_COOKIES}: ${_WRKDIR_COOKIE}
|
|
@${_PMAKE_COOKIE} $@
|
|
.endif
|
|
|
|
# similar rules for _DEPBUILDWANTLIB_COOKIE and _DEPRUNWANTLIB_COOKIE
|
|
.for _m in BUILD RUN
|
|
. if !empty(_DEP${_m}WANTLIB_COOKIE)
|
|
${_DEP${_m}WANTLIB_COOKIE}: ${_DEP${_m}LIBSPECS_COOKIES} \
|
|
${_DEP${_m}LIB_COOKIES} ${_WRKDIR_COOKIE}
|
|
. if !empty(_DEP${_m}LIBS)
|
|
@${ECHO_MSG} "===> Verifying specs: ${_DEP${_m}LIBS}"
|
|
@${_cache_fragment}; if found=`{ \
|
|
for i in ${_LIB4:QL}; do echo "$$i"; done | \
|
|
while ${_read_spec}; do \
|
|
${_parse_spec}; \
|
|
${_libs2cache}; \
|
|
cat $$cached_libs; \
|
|
done; \
|
|
for i in ${LOCALBASE}/lib${_lib}; do echo $$i; done; \
|
|
${_list_system_libs}; \
|
|
for d in ${_DEP${_m}LIBS:QL}; do \
|
|
case "$$d" in \
|
|
/*) echo $${d%/*}${_lib};; \
|
|
*/*) echo ${LOCALBASE}/$${d%/*}${_lib};; \
|
|
esac; \
|
|
done; } | ${_resolve_lib} ${_DEP${_m}LIBS:QL}`; \
|
|
then \
|
|
line="===> found"; \
|
|
for k in $$found; do line="$$line $$k"; done; \
|
|
${ECHO_MSG} "$$line"; \
|
|
else \
|
|
echo 1>&2 "Fatal error"; \
|
|
exit 1; \
|
|
fi
|
|
. endif
|
|
@${_PMAKE_COOKIE} $@
|
|
. if ${FETCH_PACKAGES:L} == "no" || ${_FETCH_RECURSE_HELPER:L} == "no"
|
|
${_DEP${_m}WANTLIB_COOKIE}: ${_DEPBUILD_COOKIES}
|
|
. endif
|
|
. endif
|
|
|
|
.endfor
|
|
|
|
_internal-fetch-all:
|
|
# See ports/infrastructure/templates/Makefile.template
|
|
@${ECHO_MSG} "===> Checking files for ${FULLPKGNAME}${_MASTER}"
|
|
# What FETCH-ALL normally does:
|
|
. if !empty(MAKESUMFILES)
|
|
@${_MAKE} ${MAKESUMFILES:S@^@${DISTDIR}/@}
|
|
. endif
|
|
# End of FETCH
|
|
|
|
.if (!empty(IGNORE${SUBPACKAGE}) || defined(_EXTRA_IGNORE)) && !defined(NO_IGNORE)
|
|
_internal-all _internal-build _internal-checksum _internal-configure \
|
|
_internal-deinstall _internal-extract _internal-fake _internal-fetch \
|
|
_internal-install _internal-install-all _internal-gen \
|
|
_internal-package _internal-patch _internal-plist _internal-test \
|
|
_internal-subpackage _internal-subupdate _internal-uninstall \
|
|
_internal-update _internal-update-or-install _internal-generate-readmes \
|
|
_internal-update-or-install-all _internal-update-plist \
|
|
lib-depends-check port-lib-depends-check update-patches:
|
|
. if !defined(IGNORE_SILENT)
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} ${IGNORE${SUBPACKAGE}} ${_EXTRA_IGNORE}."
|
|
. endif
|
|
. if defined(_IGNORE_COOKIE)
|
|
@echo "${IGNORE${SUBPACKAGE}} ${_EXTRA_IGNORE}" ${_PREDIR} ${_IGNORE_COOKIE}
|
|
. endif
|
|
.else
|
|
|
|
lib-depends-check:
|
|
@${_cache_fragment}; cd ${.CURDIR} && ${MAKE} package; \
|
|
${_CHECK_LIB_DEPENDS} ${_PACKAGE_COOKIE}
|
|
|
|
${WRKINST}/.saved_libs: ${_FAKE_COOKIE}
|
|
@${_PBUILD} ${SETENV} ${_CHECK_LIB_DEPENDS} -O $@t && ${_PBUILD} mv $@t $@
|
|
|
|
port-lib-depends-check: ${WRKINST}/.saved_libs
|
|
@-${_cache_fragment}; for s in ${BUILD_PACKAGES}; do \
|
|
SUBPACKAGE=$$s ${MAKE} print-plist-with-depends \
|
|
lib_depends_args=all-lib-depends-args \
|
|
wantlib_args=fake-wantlib-args| \
|
|
${_CHECK_LIB_DEPENDS} -i -s ${WRKINST}/.saved_libs; \
|
|
done
|
|
|
|
# Most standard port targets create a cookie to avoid being re-run.
|
|
#
|
|
# fetch is an exception, as it uses the files it fetches as `cookies',
|
|
# and it's run by checksum, so in essence it's a sub-goal of extract,
|
|
# in normal use.
|
|
#
|
|
# Besides, fetch can't create cookies, as it does not have WRKDIR available
|
|
# in the first place.
|
|
#
|
|
|
|
_internal-fetch:
|
|
# See ports/infrastructure/templates/Makefile.template
|
|
@${ECHO_MSG} "===> Checking files for ${FULLPKGNAME}${_MASTER}"
|
|
# What FETCH normally does:
|
|
. if !empty(CHECKSUMFILES)
|
|
@${_MAKE} ${CHECKSUMFILES:S@^@${DISTDIR}/@}
|
|
. endif
|
|
# End of FETCH
|
|
|
|
|
|
_internal-checksum: _internal-fetch
|
|
@${_warn_checksum}
|
|
@fgrep 2>/dev/null SIZE ${CHECKSUM_FILE} | \
|
|
sed -e '/SIZE (\(.*\)).*/s//\1/'|\
|
|
while read i; do \
|
|
for j in ${MAKESUMFILES}; do \
|
|
missing=true; \
|
|
if test $$i = $$j; then \
|
|
missing=false; \
|
|
break; \
|
|
fi; \
|
|
done; \
|
|
if $$missing; then \
|
|
bad=true; \
|
|
echo 1>&2 "!!! Extra file '$$i' in ${CHECKSUM_FILE}"; \
|
|
echo 1>&2 "!!! Read up on SUPDISTFILES in bsd.port.mk(5)"; \
|
|
exit 1; \
|
|
fi; \
|
|
done
|
|
. if empty(CHECKSUMFILES)
|
|
@${ECHO_MSG} ">> No DISTFILES nor PATCHFILES."
|
|
. else
|
|
. if !defined(NO_CHECKSUM)
|
|
@if [ ! -f ${CHECKSUM_FILE} ]; then \
|
|
${ECHO_MSG} 1>&2 ">> No ${CHECKSUM_FILE}."; \
|
|
exit 1; \
|
|
fi
|
|
@cd ${DISTDIR}; OK=true; list=''; files=''; \
|
|
for file in ${CHECKSUMFILES}; do \
|
|
if set -- $$(grep "^${_CIPHER:U} ($$file)" ${CHECKSUM_FILE}); \
|
|
then \
|
|
echo -n '>> '; \
|
|
if ! echo "$$@" | cksum -c; then \
|
|
list="$$list $$file ${_CIPHER} $$4"; \
|
|
files="$$files ${DISTDIR}/$$file"; \
|
|
OK=false; \
|
|
fi; \
|
|
else \
|
|
${ECHO_MSG} ">> No ${_CIPHER} recorded for $$file."; \
|
|
OK=false; \
|
|
fi; \
|
|
done; \
|
|
set --; \
|
|
if ! $$OK; then \
|
|
if ${REFETCH}; then \
|
|
${_PFETCH} rm -f $$files && \
|
|
cd ${.CURDIR} && \
|
|
PKGPATH=${PKGPATH} ${MAKE} $$files _REFETCH_INFO="$$list" && \
|
|
PKGPATH=${PKGPATH} ${MAKE} _internal-checksum REFETCH=false; \
|
|
else \
|
|
echo "Make sure the Makefile and ${CHECKSUM_FILE}"; \
|
|
echo "are up to date. If you want to fetch a good copy of this file"; \
|
|
echo "from the OpenBSD main archive, type"; \
|
|
echo "\tmake REFETCH=true [other args]"; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
. endif
|
|
. endif
|
|
|
|
|
|
# The cookie's recipe hold the real rule for each of those targets.
|
|
|
|
_internal-extract: ${_EXTRACT_COOKIE}
|
|
_internal-patch: ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE} ${_PATCH_COOKIE}
|
|
_internal-distpatch: ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE} ${_DISTPATCH_COOKIE}
|
|
_internal-gen: ${_GEN_COOKIE}
|
|
_internal-configure: ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE} ${_CONFIGURE_COOKIE}
|
|
_internal-build _internal-all: ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE} ${_BUILD_COOKIE}
|
|
_internal-install: ${_INSTALL_COOKIE${SUBPACKAGE}}
|
|
_internal-install-all: ${_INSTALL_COOKIES}
|
|
_internal-fake: ${_FAKE_COOKIE}
|
|
_internal-subupdate: ${_UPDATE_COOKIE${SUBPACKAGE}}
|
|
_internal-update: ${_UPDATE_COOKIES}
|
|
_internal-update-or-install: ${_FUPDATE_COOKIE${SUBPACKAGE}}
|
|
_internal-update-or-install-all: ${_FUPDATE_COOKIES}
|
|
|
|
regress: test
|
|
|
|
. if !empty(_IGNORE_TEST)
|
|
_internal-test:
|
|
. if !defined(IGNORE_SILENT)
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} ${_IGNORE_TEST}."
|
|
. endif
|
|
. else
|
|
_internal-test: ${_BUILD_COOKIE} ${_DEPTEST_COOKIES} ${_TEST_COOKIE}
|
|
. endif
|
|
|
|
_internal-plist _internal-update-plist: _internal-fake
|
|
@${ECHO_MSG} "===> Updating plist for ${FULLPKGNAME}${_MASTER}"
|
|
@mkdir -p ${PKGDIR}
|
|
@${_MAKE} _internal-generate-readmes
|
|
@${_update_plist}
|
|
|
|
update-patches:
|
|
@toedit=`WRKDIST=${WRKDIST} PATCHDIR=${PATCHDIR} \
|
|
PATCH_LIST='${PATCH_LIST}' DIFF_ARGS='${DIFF_ARGS}' \
|
|
DISTORIG=${DISTORIG} PATCHORIG=${PATCHORIG} \
|
|
${_PERLSCRIPT}/update-patches`; \
|
|
if [ -n "$$toedit" ] && [ "${EDIT_PATCHES:L}" != no ]; then \
|
|
cd ${PATCHDIR} && $${VISUAL:-$${EDITOR:-/usr/bin/vi}} $$toedit; \
|
|
fi
|
|
|
|
.endif # IGNORECMD
|
|
|
|
|
|
# Top-level targets redirect to the real _internal-target, along with locking
|
|
# if locking exists.
|
|
|
|
.for _t in extract patch distpatch gen configure build all install fake \
|
|
subupdate fetch fetch-all checksum test prepare install-depends \
|
|
test-depends clean plist update-plist generate-readmes \
|
|
update update-or-install update-or-install-all package install-all
|
|
. if defined(_LOCK)
|
|
${_t}:
|
|
@${_DO_LOCK}; cd ${.CURDIR} && PKGPATH=${PKGPATH} ${MAKE} _internal-${_t}
|
|
. else
|
|
${_t}: _internal-${_t}
|
|
. endif
|
|
.endfor
|
|
|
|
lock:
|
|
@lock=${_LOCKNAME}; ${_LOCK}
|
|
export _LOCKS_HELD="${_LOCKS_HELD} ${_LOCKNAME}"
|
|
|
|
unlock:
|
|
@lock=${_LOCKNAME}; ${_UNLOCK}
|
|
.for _i in ${_LOCKNAME}
|
|
export _LOCKS_HELD="${_LOCKS_HELD:N${_i}}"
|
|
.endfor
|
|
|
|
subpackage:
|
|
# XXX both _DO_LOCK and _cache_fragment use trap, so subshell
|
|
@${_DO_LOCK}; (${_cache_fragment}; cd ${.CURDIR} && ${MAKE} _internal-subpackage)
|
|
|
|
_internal-package:
|
|
@${_cache_fragment}; cd ${.CURDIR} && ${MAKE} _internal-package-only
|
|
# XXX loop needed for M to work
|
|
.for p in ${PKGPATH}
|
|
. if ${BULK_$p:L} == "yes"
|
|
@${_MAKE} ${_BULK_COOKIE}
|
|
. elif ${BULK_$p:L} == "auto"
|
|
. if !empty(_DEPENDENCY_STACK)
|
|
. if !${_DEPENDENCY_STACK:M$p}
|
|
@${_MAKE} ${_BULK_COOKIE}
|
|
. endif
|
|
. endif
|
|
. endif
|
|
.endfor
|
|
|
|
|
|
${_BULK_COOKIE}:
|
|
@${_cache_fragment}; cd ${.CURDIR} && ${MAKE} _internal-package-only
|
|
@mkdir -p ${BULK_COOKIES_DIR}
|
|
.for _i in ${BULK_TARGETS_${PKGPATH}}
|
|
@${ECHO_MSG} "===> Running ${_i}"
|
|
@${_MAKE} ${_i} ${BULK_FLAGS}
|
|
.endfor
|
|
.if !empty(BULK_DO_${PKGPATH})
|
|
@${BULK_DO_${PKGPATH}}
|
|
.endif
|
|
@${_MAKE} _internal-clean
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
# The real targets. Note that some parts always get run, some parts can be
|
|
# disabled, and there are hooks to override behavior.
|
|
|
|
${_WRKDIR_COOKIE}:
|
|
@${_PBUILD} rm -rf ${WRKDIR}
|
|
@appdefaults=${LOCALBASE}/lib/X11/app-defaults; \
|
|
if ! test -d $$appdefaults -a -h $$appdefaults; then \
|
|
echo 1>&2 "Fatal: $$appdefaults should exist and be a symlink"; \
|
|
exit 1; \
|
|
fi
|
|
@${_PBUILD} install -d ${WRKOBJDIR_MODE} `dirname ${WRKDIR}`
|
|
@${_PBUILD} mkdir -p ${WRKDIR} ${WRKDIR}/bin
|
|
@${_wrap_install_commands}
|
|
.if !empty(WRKDIR_LINKNAME)
|
|
@${_PBUILD} ln -sf ${WRKDIR} ${.CURDIR}/${WRKDIR_LINKNAME}
|
|
.endif
|
|
# poison some common gettext-tools binaries
|
|
.if !defined(BUILD_DEPENDS) || !${BUILD_DEPENDS:Mdevel/gettext-tools} && \
|
|
!${BUILD_DEPENDS:M*textproc/intltool}
|
|
@printf '#!/bin/sh\n\
|
|
echo "*** $$0 was called without gettext-tools dependency ***" >&2\n\
|
|
exit 1\n' ${_PREDIR} ${WRKDIR}/bin/msgfmt
|
|
@${_PBUILD} chmod 555 ${WRKDIR}/bin/msgfmt
|
|
. for name in msgcat msginit autopoint xgettext gettextize
|
|
@${_PBUILD} ln -sf msgfmt ${WRKDIR}/bin/${name}
|
|
. endfor
|
|
.endif
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
${_EXTRACT_COOKIE}: ${_WRKDIR_COOKIE}
|
|
@${_MAKE} _internal-checksum _internal-prepare
|
|
@${ECHO_MSG} "===> Extracting for ${FULLPKGNAME}${_MASTER}"
|
|
.if target(pre-extract)
|
|
@${_PMAKE} pre-extract
|
|
.endif
|
|
@${_PMAKE} do-extract
|
|
.if target(post-extract)
|
|
@${_PMAKE} post-extract
|
|
.endif
|
|
@${_PMAKE} _post-extract-finalize
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
# run as _pbuild
|
|
_post-extract-finalize:
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_post-extract)
|
|
@${MOD${_m}_post-extract}
|
|
. endif
|
|
.endfor
|
|
.if ${FIX_EXTRACT_PERMISSIONS:L} == "yes"
|
|
@chmod -R a+rX ${WRKDIR}
|
|
.endif
|
|
|
|
# run as _pbuild
|
|
.if !target(do-extract)
|
|
do-extract:
|
|
# What EXTRACT normally does:
|
|
@PATH=${PORTPATH}; set -e; cd ${WRKDIR}; \
|
|
for archive in ${EXTRACT_ONLY}; do \
|
|
case $$archive in \
|
|
${EXTRACT_CASES} \
|
|
esac; \
|
|
done
|
|
# End of EXTRACT
|
|
.endif
|
|
|
|
|
|
# Both distpatch and patch invoke pre-patch, if it's defined.
|
|
# Hence it needs special treatment (a specific cookie).
|
|
|
|
# run as _pbuild
|
|
.if target(pre-patch)
|
|
${_PREPATCH_COOKIE}:
|
|
@${_MAKE} pre-patch
|
|
. if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_MAKE_COOKIE} $@
|
|
. endif
|
|
.endif
|
|
|
|
|
|
|
|
# The real distpatch
|
|
|
|
${_DISTPATCH_COOKIE}: ${_EXTRACT_COOKIE}
|
|
.if target(pre-patch)
|
|
@${_PMAKE} ${_PREPATCH_COOKIE}
|
|
.endif
|
|
@${_PMAKE} do-distpatch
|
|
.if target(post-distpatch)
|
|
@${_PMAKE} post-distpatch
|
|
.endif
|
|
.if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_PMAKE_COOKIE} $@
|
|
.endif
|
|
|
|
# run as _pbuild
|
|
.if !target(do-distpatch)
|
|
do-distpatch:
|
|
# What DISTPATCH normally does
|
|
. if !empty(_LIST_PATCHFILES)
|
|
@${ECHO_MSG} "===> Applying distribution patches for ${FULLPKGNAME}${_MASTER}"
|
|
@cd ${FULLDISTDIR}; \
|
|
for patchfile in ${_LIST_PATCHFILES}; do \
|
|
case "${PATCH_DEBUG:L}" in \
|
|
no) ;; \
|
|
*) ${ECHO_MSG} "===> Applying distribution patch $$patchfile" ;; \
|
|
esac; \
|
|
case $$patchfile in \
|
|
${PATCH_CASES} \
|
|
esac; \
|
|
done
|
|
. endif
|
|
# End of DISTPATCH.
|
|
.endif
|
|
|
|
# The real patch
|
|
|
|
${_PATCH_COOKIE}: ${_EXTRACT_COOKIE}
|
|
@${ECHO_MSG} "===> Patching for ${FULLPKGNAME}${_MASTER}"
|
|
.if target(pre-patch)
|
|
@${_PMAKE} ${_PREPATCH_COOKIE}
|
|
.endif
|
|
.if target(do-patch)
|
|
@${_PMAKE} do-patch
|
|
.else
|
|
# What PATCH normally does:
|
|
# XXX test for efficiency, don't bother with distpatch if it's not needed
|
|
. if target(do-distpatch) || target(post-distpatch) || !empty(PATCHFILES)
|
|
@${_MAKE} _internal-distpatch
|
|
. endif
|
|
@if cd ${PATCHDIR} 2>/dev/null || [ x"${PATCH_LIST:M/*}" != x"" ]; then \
|
|
error=false; \
|
|
for i in ${PATCH_LIST}; do \
|
|
case $$i in \
|
|
*.orig|*.rej|*~) \
|
|
${ECHO_MSG} "===> Ignoring patchfile $$i" ; \
|
|
;; \
|
|
*) \
|
|
if [ -e $$i ]; then \
|
|
case "${PATCH_DEBUG:L}" in \
|
|
no) ;; \
|
|
*) ${ECHO_MSG} "===> Applying OpenBSD patch $$i" ;; \
|
|
esac; \
|
|
if [ -s $$i ]; then \
|
|
${_PBUILD} ${PATCH} ${PATCH_ARGS} < $$i || \
|
|
{ echo "***> $$i did not apply cleanly"; \
|
|
error=true; }; \
|
|
else \
|
|
${ECHO_MSG} "===> Ignoring empty patchfile $$i"; \
|
|
fi; \
|
|
else \
|
|
if [ $$i != "patch-*" ]; then \
|
|
echo "===> Can't find patch matching $$i"; \
|
|
error=true; \
|
|
fi; \
|
|
fi; \
|
|
;; \
|
|
esac; \
|
|
done;\
|
|
if $$error; then exit 1; fi; \
|
|
fi
|
|
# End of PATCH.
|
|
.endif
|
|
.if target(post-patch)
|
|
@${_PMAKE} post-patch
|
|
.endif
|
|
.if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_PMAKE} _post-patch-finalize
|
|
@${_PMAKE_COOKIE} $@
|
|
.endif
|
|
|
|
# Run as _pbuild
|
|
_post-patch-finalize:
|
|
.if ${USE_WXNEEDED:L} == "yes"
|
|
@wrktmp=`df -P ${WRKOBJDIR_${PKGPATH}} | awk 'END { print $$6 }'`; \
|
|
if ! mount | grep -q " $${wrktmp} .*wxallowed"; then \
|
|
echo "Fatal: ${WRKOBJDIR_${PKGPATH}} must be on a wxallowed filesystem" \
|
|
"(in ${PKGPATH})" >&2; \
|
|
false; \
|
|
fi
|
|
.endif
|
|
.if ${USE_WXNEEDED:L} == "yes" || ${_NONDEFAULT_LD:L} == "yes"
|
|
@printf '#!/bin/sh\nexec ${_LD_PROGRAM} ${_WXNEEDED_FLAGS} "$$@"\n' >${WRKDIR}/bin/ld
|
|
@chmod 555 ${WRKDIR}/bin/ld
|
|
.endif
|
|
.for _wrap _comp in ${COMPILER_LINKS}
|
|
@echo '===> Compiler link: ${_wrap} -> ${COMPILER_WRAPPER:= }${_comp}'
|
|
@printf '#!/bin/sh\nexec ${COMPILER_WRAPPER} ${_comp} -B ${WRKDIR}/bin "$$@"\n' > ${WRKDIR}/bin/${_wrap}
|
|
@chmod 555 ${WRKDIR}/bin/${_wrap}
|
|
.endfor
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_post-patch)
|
|
@${MOD${_m}_post-patch}
|
|
. endif
|
|
.endfor
|
|
|
|
# run as _pbuild
|
|
_gen-finalize:
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_gen)
|
|
@${MOD${_m}_gen}
|
|
. endif
|
|
.endfor
|
|
.if !empty(REORDER_DEPENDENCIES)
|
|
@sed -e '/^#/d' ${REORDER_DEPENDENCIES} | \
|
|
tsort -r|while read f; do \
|
|
cd ${WRKSRC}; \
|
|
case $$f in \
|
|
/*) \
|
|
find . -name $${f#/} -print| while read i; \
|
|
do ${ECHO_REORDER} "Touching $$i"; touch $$i; done \
|
|
;; \
|
|
*) \
|
|
if test -e $$f ; then \
|
|
${ECHO_REORDER} "Touching $$f"; touch $$f; \
|
|
fi \
|
|
;; \
|
|
esac; done
|
|
.endif
|
|
|
|
# The real gen stage
|
|
|
|
${_GEN_COOKIE}: ${_PATCH_COOKIE}
|
|
@${ECHO_MSG} "===> Generating configure for ${FULLPKGNAME}${_MASTER}"
|
|
.if target(do-gen)
|
|
@${_PMAKE} do-gen
|
|
.endif
|
|
@${_PMAKE} _gen-finalize
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
# The real configure
|
|
|
|
# run as _pbuild
|
|
_pre-configure-modules:
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_pre-configure)
|
|
@${MOD${_m}_pre-configure}
|
|
. endif
|
|
.endfor
|
|
|
|
# run as _pbuild
|
|
.if !target(do-configure)
|
|
do-configure:
|
|
# What CONFIGURE normally does
|
|
. for _c in ${CONFIGURE_STYLE:U}
|
|
. if defined(MOD${_c}_configure)
|
|
@${MOD${_c}_configure}
|
|
. endif
|
|
. endfor
|
|
# End of CONFIGURE.
|
|
.endif
|
|
|
|
|
|
# The real configure
|
|
|
|
${_CONFIGURE_COOKIE}: ${_GEN_COOKIE}
|
|
@${ECHO_MSG} "===> Configuring for ${FULLPKGNAME}${_MASTER}"
|
|
.if defined(_CONFIG_SITE)
|
|
@cd ${PORTSDIR}/infrastructure/db && cat ${CONFIG_SITE_LIST} ${_PREDIR} ${_CONFIG_SITE}
|
|
@echo "Using ${_CONFIG_SITE} (generated)"
|
|
.endif
|
|
@${_PBUILD} mkdir -p ${WRKBUILD}
|
|
.if target(pre-configure)
|
|
@${_PMAKE} pre-configure
|
|
.endif
|
|
@${_PMAKE} _pre-configure-modules
|
|
@${_PMAKE} do-configure
|
|
.if target(post-configure)
|
|
@${_PMAKE} post-configure
|
|
.endif
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
# The real build
|
|
|
|
${_BUILD_COOKIE}: ${_CONFIGURE_COOKIE}
|
|
.if ${NO_BUILD:L} == "no"
|
|
@${ECHO_MSG} "===> Building for ${FULLPKGNAME}${_MASTER}"
|
|
. if target(pre-build)
|
|
@${_PMAKE} pre-build
|
|
. endif
|
|
. if target(do-build)
|
|
@${_PMAKE} do-build
|
|
. else
|
|
# What BUILD normally does:
|
|
@cd ${WRKBUILD} && exec ${_PBUILD} ${SETENV} ${MAKE_ENV} \
|
|
${MAKE_PROGRAM} ${MAKE_FLAGS} -f ${MAKE_FILE} ${ALL_TARGET}
|
|
# End of BUILD
|
|
. endif
|
|
. if target(post-build)
|
|
@${_PMAKE} post-build
|
|
. endif
|
|
.endif
|
|
@${_check_wrkdir} ${WRKDIR} ${_TS_COOKIE} ${WRKDIR_CHANGES_OKAY}
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
${_TEST_COOKIE}: ${_BUILD_COOKIE}
|
|
.if ${NO_TEST:L} == "no"
|
|
@${ECHO_MSG} "===> Regression tests for ${FULLPKGNAME}${_MASTER}"
|
|
# When interactive tests need X11
|
|
. if ${TEST_IS_INTERACTIVE:L} == "x11"
|
|
. if !defined(DISPLAY) || !exists(${XAUTHORITY})
|
|
@echo 1>&2 "The regression tests require a running instance of X."
|
|
@echo 1>&2 "You will also need to set the environment variable DISPLAY"
|
|
@echo 1>&2 "to point to an active X11 display and XAUTHORITY to point"
|
|
@echo 1>&2 "to the appropriate .Xauthority file."
|
|
@exit 1
|
|
. endif
|
|
. endif
|
|
. if target(pre-test)
|
|
@${_PMAKE} pre-test
|
|
. endif
|
|
. if target(do-test)
|
|
@cd ${.CURDIR} && exec 3>&1 && exit `exec 4>&1 1>&3; \
|
|
(exec; set +e; PKGPATH=${PKGPATH} ${_PBUILD} ${MAKE} do-test; \
|
|
echo $$? >&4) 2>&1 ${TEST_LOG}`
|
|
. else
|
|
# What TEST normally does:
|
|
@cd ${WRKBUILD} && exec 3>&1 && exit `exec 4>&1 1>&3; \
|
|
(exec; set +e; ${_PBUILD} ${SETENV} ${ALL_TEST_ENV} ${MAKE_PROGRAM} \
|
|
${ALL_TEST_FLAGS} -f ${MAKE_FILE} ${TEST_TARGET}; \
|
|
echo $$? >&4) 2>&1 ${TEST_LOG}`
|
|
# End of TEST
|
|
. endif
|
|
. if target(post-test)
|
|
@${_PMAKE} post-test
|
|
. endif
|
|
.else
|
|
@echo 1>&2 "No regression tests for ${FULLPKGNAME}"
|
|
.endif
|
|
@${_PMAKE_COOKIE} $@
|
|
|
|
# run as _pbuild
|
|
_post-install-modules:
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_post-install)
|
|
@${MOD${_m}_post-install}
|
|
. endif
|
|
.endfor
|
|
|
|
# run as _pbuild
|
|
_pre-fake-modules:
|
|
.for _m in ${MODULES:T:U}
|
|
. if defined(MOD${_m}_pre-fake)
|
|
@${MOD${_m}_pre-fake}
|
|
. endif
|
|
.endfor
|
|
|
|
${_FAKE_COOKIE}: ${_BUILD_COOKIE}
|
|
@${ECHO_MSG} "===> Faking installation for ${FULLPKGNAME}${_MASTER}"
|
|
@if [ x`umask 022;${_PBUILD} /bin/sh -c umask` != x022 ]; then \
|
|
echo >&2 "Error: your umask is \"`${_PBUILD} /bin/sh -c umask`"\".; \
|
|
exit 1; \
|
|
fi
|
|
@${_PBUILD} mkdir -p ${_FAKE_TREE_LIST}
|
|
@${_wrap_install_commands}
|
|
@${_SUDOMAKESYS} _pre-fake-modules ${FAKE_SETUP}
|
|
.if target(pre-fake)
|
|
@${_SUDOMAKESYS} pre-fake ${FAKE_SETUP}
|
|
.endif
|
|
@${_PBUILD} ${_MAKE_COOKIE} ${_INSTALL_PRE_COOKIE}
|
|
.if target(pre-install)
|
|
@${_SUDOMAKESYS} pre-install ${FAKE_SETUP}
|
|
.endif
|
|
.if target(do-install)
|
|
@${_SUDOMAKESYS} do-install ${FAKE_SETUP}
|
|
.else
|
|
# What FAKE normally does:
|
|
@cd ${WRKBUILD} && umask 022 && exec ${_PBUILD} \
|
|
${SETENV} ${MAKE_ENV} ${FAKE_SETUP} \
|
|
${MAKE_PROGRAM} ${ALL_FAKE_FLAGS} -f ${MAKE_FILE} ${FAKE_TARGET}
|
|
# End of FAKE.
|
|
.endif
|
|
.if target(post-install)
|
|
@${_SUDOMAKESYS} post-install ${FAKE_SETUP}
|
|
.endif
|
|
@${_SUDOMAKESYS} _post-install-modules ${FAKE_SETUP}
|
|
@${_check_wrkdir} ${WRKDIR} ${_TS_COOKIE} ${WRKDIR_CHANGES_OKAY}
|
|
@${_PBUILD} ${_MAKE_COOKIE} $@
|
|
|
|
# XXX this is a separate step that is "always on" and doesn't generate
|
|
# cookies
|
|
_internal-generate-readmes: ${_FAKE_COOKIE}
|
|
.if ${MULTI_PACKAGES} == "-"
|
|
@r=${WRKINST}${_README_DIR}/${PKGSTEM}; \
|
|
if test -e ${PKGDIR}/README; then \
|
|
echo "Installing ${PKGDIR}/README as $$r"; \
|
|
${_PBUILD} ${SUBST_CMD} -m ${SHAREMODE} -c ${PKGDIR}/README $$r; \
|
|
fi
|
|
.else
|
|
. for _s in ${MULTI_PACKAGES}
|
|
@r=${WRKINST}${_README_DIR}/${PKGSTEM${_s}}; \
|
|
if test -e ${PKGDIR}/README${_s}; then \
|
|
echo "Installing ${PKGDIR}/README${_s} as $$r"; \
|
|
${_PBUILD} ${SUBST_CMD${_s}} -m ${SHAREMODE} -c ${PKGDIR}/README${_s} $$r; \
|
|
fi
|
|
. endfor
|
|
.endif
|
|
@cd ${PKGDIR} && for i in *.rc; do \
|
|
if test X"$$i" != "X*.rc"; then \
|
|
r=${WRKINST}${RCDIR}/$${i%.rc}; \
|
|
echo "Installing ${PKGDIR}/$$i as $$r"; \
|
|
${_PBUILD} ${SUBST_CMD} -m ${BINMODE} -c $$i $$r; \
|
|
fi; \
|
|
done
|
|
|
|
print-plist:
|
|
@${_PKG_CREATE} -n -q ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}
|
|
|
|
print-plist-with-depends:
|
|
@if a=`SUBPACKAGE=${SUBPACKAGE} PKGPATH=${PKGPATH} ${MAKE} print-package-args`; \
|
|
then \
|
|
${_PKG_CREATE} -n -q $$a ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
|
|
print-plist-libs-with-depends:
|
|
@if a=`SUBPACKAGE=${SUBPACKAGE} PKGPATH=${PKGPATH} ${MAKE} print-package-args`; \
|
|
then \
|
|
${_PKG_CREATE} -DLIBS_ONLY -n -q $$a ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
|
|
print-plist-all:
|
|
.for _S in ${BUILD_PACKAGES}
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${_S}}"
|
|
. if ${STATIC_PLIST${_s}:L} == "yes"
|
|
@${_PKG_CREATE} -n -q ${PKG_ARGS${_S}} ${_PACKAGE_COOKIE${_S}}
|
|
. else
|
|
@${_PKG_CREATE} -n -q ${PKG_ARGS${_S}:S@^-f$@-D@g} -f/dev/null ${_PACKAGE_COOKIE${_S}}
|
|
. endif
|
|
.endfor
|
|
|
|
print-plist-all-with-depends:
|
|
.for _S in ${BUILD_PACKAGES}
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${_S}}"
|
|
@if a=`SUBPACKAGE=${_S} PKGPATH=${PKGPATH} ${MAKE} print-package-args`; \
|
|
then \
|
|
${_PKG_CREATE} -n -q $$a ${PKG_ARGS${_S}} ${_PACKAGE_COOKIE${_S}}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
.endfor
|
|
|
|
print-plist-contents:
|
|
@${_PKG_CREATE} -n -Q ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}
|
|
|
|
print-plist-libs:
|
|
@${_PKG_CREATE} -DLIBS_ONLY -n -Q ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}|${_grab_libs_from_plist}
|
|
|
|
_internal-package-only: ${_PACKAGE_COOKIES}
|
|
|
|
_internal-subpackage: ${_PACKAGE_COOKIES${SUBPACKAGE}}
|
|
|
|
# Separate target for each file fetch-all will retrieve
|
|
|
|
# first we special case _REFETCH stuff, specifically get them from our mirrors
|
|
# _REFETCH_INFO is set by _internal-checksum if REFETCH
|
|
_REFETCH_INFO ?=
|
|
|
|
# list is pretty much self explanatory
|
|
.for f cipher value in ${_REFETCH_INFO}
|
|
${DISTDIR}/$f:
|
|
@lock=${@:T}.dist; ${_SIMPLE_LOCK}; \
|
|
${_PFETCH} install -d ${DISTDIR_MODE} ${@:H}; \
|
|
cd ${@:H}; \
|
|
file=$@.part; \
|
|
for site in ${MASTER_SITE_OPENBSD:=by_cipher/${cipher}/${value:C/(..).*/\1/}/${value}/} ${MASTER_SITE_OPENBSD:=${cipher}/${value}/}; do \
|
|
${ECHO_MSG} ">> Fetch $${site}$u"; \
|
|
if ${_PFETCH} ${FETCH_CMD} -o $$file $${site}$u; then \
|
|
ck=`${_size_fragment} $$file $p`; \
|
|
if grep -q "^$$ck\$$" ${CHECKSUM_FILE}; then \
|
|
${_PFETCH} mv $$file $@; \
|
|
exit 0; \
|
|
else \
|
|
${ECHO_MSG} ">> Size does not match for $p"; \
|
|
${_PFETCH} rm -f $$file; \
|
|
fi; \
|
|
fi; \
|
|
done;
|
|
exit 1
|
|
.endfor
|
|
|
|
# then we do normal files, just avoid the ones in _REFETCH_INFO
|
|
.for p f m u in ${_FULL_FETCH_LIST}
|
|
. if empty(_REFETCH_INFO:M$f)
|
|
${DISTDIR}/$p:
|
|
. if ${FETCH_MANUALLY:L} != "no"
|
|
. if !empty(MISSING_FILES)
|
|
@echo "*** You're missing files: ${MISSING_FILES}"
|
|
. endif
|
|
. for _M in ${FETCH_MANUALLY}
|
|
@echo "*** ${_M}"
|
|
. endfor
|
|
@exit 1
|
|
. else
|
|
@lock=${@:T}.dist; ${_SIMPLE_LOCK}; \
|
|
${_PFETCH} install -d ${DISTDIR_MODE} ${@:H}; \
|
|
cd ${@:H}; \
|
|
test -f ${@:T} && exit 0; \
|
|
f=$f; \
|
|
if ! ${_MAKESUM} && ! grep -q "SIZE ($p)" ${CHECKSUM_FILE} 2>/dev/null; then \
|
|
${ECHO_MSG} ">> No size recorded for $p"; \
|
|
exit 1; \
|
|
fi; \
|
|
file=$@.part; \
|
|
for site in ${$m}; do \
|
|
${ECHO_MSG} ">> Fetch $${site}$u"; \
|
|
if ${_PFETCH} ${FETCH_CMD} -o $$file $${site}$u; then \
|
|
if ${_MAKESUM}; then \
|
|
${_PFETCH} mv $$file $@; \
|
|
exit 0; \
|
|
else \
|
|
ck=`${_size_fragment} $$file $p`; \
|
|
if grep -q "^$$ck\$$" ${CHECKSUM_FILE}; then \
|
|
${_PFETCH} mv $$file $@; \
|
|
exit 0; \
|
|
else \
|
|
${ECHO_MSG} ">> Size does not match for $p"; \
|
|
${_PFETCH} rm -f $$file; \
|
|
fi; \
|
|
fi; \
|
|
fi; \
|
|
done; \
|
|
if ${_MAKESUM}; then \
|
|
if test -z ${$m}; then \
|
|
${ECHO_MSG} ">> No master site in $m"; \
|
|
fi; \
|
|
exit 1; \
|
|
fi; \
|
|
for site in ${MASTER_SITE_BACKUP}; do \
|
|
${ECHO_MSG} ">> Fetch $${site}$p"; \
|
|
if ${_PFETCH} ${FETCH_CMD} -o $$file $${site}$p; then \
|
|
ck=`${_size_fragment} $$file $p`; \
|
|
if grep -q "^$$ck\$$" ${CHECKSUM_FILE}; then \
|
|
${_PFETCH} mv $$file $@; \
|
|
exit 0; \
|
|
else \
|
|
${ECHO_MSG} ">> Size does not match for $p"; \
|
|
${_PFETCH} rm -f $$file; \
|
|
fi; \
|
|
fi; \
|
|
done; \
|
|
exit 1
|
|
. endif
|
|
. endif
|
|
.endfor
|
|
|
|
.for _l _o in ${_PACKAGE_LINKS}
|
|
${PACKAGE_REPOSITORY}/${_l}: ${PACKAGE_REPOSITORY}/${_o}
|
|
@echo "Link to $@"
|
|
@${_PBUILD} install -d ${PACKAGE_REPOSITORY_MODE} ${@D}
|
|
@${_PBUILD} rm -f $@
|
|
@${_PBUILD} ln $? $@ 2>/dev/null || \
|
|
${_PBUILD} cp -p $? $@
|
|
.endfor
|
|
|
|
# Cleaning up
|
|
|
|
_internal-clean:
|
|
.if ${_clean:Mdepends} && ${_CLEANDEPENDS:L} == "yes"
|
|
@PKGPATH=${PKGPATH} ${MAKE} all-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} _CLEANDEPENDS=No clean; \
|
|
done
|
|
.endif
|
|
@${ECHO_MSG} "===> Cleaning for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
.if ${_clean:Mfake}
|
|
@if cd ${WRKINST} 2>/dev/null; then ${_PBUILD} rm -rf ${WRKINST}; fi
|
|
.endif
|
|
.if ${_clean:Mwork} || (${_clean:Mbuild} && ${SEPARATE_BUILD:L} == "no")
|
|
. if ${_clean:Mflavors}
|
|
@for i in ${.CURDIR}/w-*; do \
|
|
if [ -L $$i ]; then ${SUDO} rm -rf `readlink $$i`; fi; \
|
|
${SUDO} rm -rf $$i; \
|
|
done
|
|
. endif
|
|
. for l in ${_WRKDIRS}
|
|
. if "$l" != ""
|
|
@if [ -L $l ]; then ${_PBUILD} rm -rf `readlink $l`; fi
|
|
@if [ -e $l ]; then ${_PBUILD} rm -rf $l; fi
|
|
. endif
|
|
. endfor
|
|
. if !empty(WRKDIR_LINKNAME)
|
|
@if [ -L ${WRKDIR_LINKNAME} ]; then rm -f ${.CURDIR}/${WRKDIR_LINKNAME}; fi
|
|
. endif
|
|
.elif ${_clean:Mbuild} && ${SEPARATE_BUILD:L} != "no"
|
|
@${_PBUILD} rm -rf ${WRKBUILD} ${_CONFIGURE_COOKIE} ${_BUILD_COOKIE}
|
|
.endif
|
|
.if ${_clean:Mdist}
|
|
@${ECHO_MSG} "===> Dist cleaning for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@if cd ${DISTDIR} 2>/dev/null; then \
|
|
${_PFETCH} rm -f ${MAKESUMFILES}; \
|
|
fi
|
|
. if !empty(DIST_SUBDIR)
|
|
-@${_PFETCH} rmdir ${FULLDISTDIR}
|
|
. endif
|
|
.endif
|
|
.if ${_clean:Minstall}
|
|
. if ${_clean:Msub}
|
|
-${SUDO} ${_PKG_DELETE} ${PKGNAMES}
|
|
. else
|
|
-${SUDO} ${_PKG_DELETE} ${FULLPKGNAME${SUBPACKAGE}}
|
|
. endif
|
|
.endif
|
|
.if ${_clean:Mpackages} || ${_clean:Mpackage} && ${_clean:Msub}
|
|
${_PBUILD} rm -f ${_PACKAGE_COOKIES}
|
|
${_PFETCH} rm -f ${_CACHE_PACKAGE_COOKIES}
|
|
rm -f ${_UPDATE_COOKIES}
|
|
.elif ${_clean:Mpackage}
|
|
${_PBUILD} rm -f ${_PACKAGE_COOKIES${SUBPACKAGE}}
|
|
rm -f ${_UPDATE_COOKIE${SUBPACKAGE}}
|
|
.endif
|
|
.if ${_clean:Mbulk}
|
|
rm -f ${_BULK_COOKIE}
|
|
.endif
|
|
.if ${_clean:Mplist}
|
|
. for _d in ${PLIST_DB:S/:/ /}
|
|
. for _p in ${PKGNAMES}
|
|
${_PBUILD} rm -f ${_d}/${_p}
|
|
. endfor
|
|
. endfor
|
|
.endif
|
|
|
|
print-build-depends:
|
|
.if !empty(_BUILD_DEP)
|
|
@echo -n 'This port requires package(s) "'
|
|
@PKGPATH=${PKGPATH} ${MAKE} full-build-depends| ${_lines2list}
|
|
@echo '" to build.'
|
|
.endif
|
|
|
|
print-run-depends:
|
|
.if !empty(_RUN_DEP)
|
|
@echo -n 'This port requires package(s) "'
|
|
@PKGPATH=${PKGPATH} ${MAKE} full-run-depends| ${_lines2list}
|
|
@echo '" to run.'
|
|
.endif
|
|
|
|
# full-build-depends, full-all-depends, full-run-depends full-test-depends
|
|
.for _i in build all run test
|
|
full-${_i}-depends:
|
|
@PKGPATH=${PKGPATH} ${MAKE} ${_i}-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} _print-packagename ; \
|
|
done
|
|
.endfor
|
|
|
|
license-check:
|
|
.for _S in ${BUILD_PACKAGES}
|
|
. if ${PERMIT_PACKAGE_CDROM${_S}:L} == "yes" || \
|
|
${PERMIT_PACKAGE_FTP${_S}:L} == "yes"
|
|
@SUBPACKAGE=${_S} PKGPATH=${PKGPATH} ${MAKE} all-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
_MASTER_PERMIT_CDROM=${PERMIT_PACKAGE_CDROM${_S}:Q}; \
|
|
_MASTER_PERMIT_FTP=${PERMIT_PACKAGE_FTP${_S}:Q}; \
|
|
export _MASTER_PERMIT_CDROM _MASTER_PERMIT_FTP; \
|
|
eval $$toset ${MAKE} _license-check; \
|
|
done
|
|
. endif
|
|
.endfor
|
|
|
|
_license-check:
|
|
.for _i in FTP CDROM
|
|
. if defined(_MASTER_PERMIT_${_i}) && ${_MASTER_PERMIT_${_i}:L} == "yes" && \
|
|
${PERMIT_PACKAGE_${_i}:L} != "yes"
|
|
@echo >&2 "Warning: dependency ${PKGPATH} is not allowed for ${_i}"
|
|
. endif
|
|
.endfor
|
|
|
|
# run-depends-list, build-depends-list, lib-depends-list, test-depends-list
|
|
.for _i in RUN BUILD LIB TEST
|
|
${_i:L}-depends-list:
|
|
. if !empty(_${_i}_DEP3)
|
|
@echo -n "This port requires \""
|
|
@echo -n '${_${_i}_DEP3:C/ +/ /g}'| tr '\040' '\012'|sort -u|tr '\012' '\040' | sed -e 's, $$,,'
|
|
@echo "\" for ${_i:L}."
|
|
. endif
|
|
.endfor
|
|
|
|
# recursive depend targets
|
|
|
|
print-package-signature print-update-signature:
|
|
@if a=`SUBPACKAGE=${SUBPACKAGE} PKGPATH=${PKGPATH} ${MAKE} print-package-args`; \
|
|
then \
|
|
${_PKG_CREATE} -n -S $$a ${PKG_ARGS${SUBPACKAGE}} ${_PACKAGE_COOKIE${SUBPACKAGE}}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
|
|
print-package-args: run-depends-args
|
|
|
|
print-package-args: ${lib_depends_args} ${wantlib_args}
|
|
|
|
run-depends-args:
|
|
@${_emit_run_depends} | while ${_read_spec}; do \
|
|
${_parse_spec}; \
|
|
${_complete_pkgspec}; \
|
|
echo "-P $$pkgpath:$$pkg:$$default"; \
|
|
done
|
|
|
|
# waive checks for WANTLIB when we're running lib-depends-check
|
|
# since we're trying to figure out what's actually needed
|
|
all-lib-depends-args:
|
|
@${_emit_lib_depends} |while ${_read_spec}; do \
|
|
${_parse_spec}; \
|
|
${_complete_pkgspec}; \
|
|
echo "-P $$pkgpath:$$pkg:$$default"; \
|
|
done
|
|
|
|
# - remove lib-depends-args if we're only scanning for common dirs in
|
|
# update-plist and we're not shared only
|
|
# - zap wantlib-args when we're only solving for @depends in pkg_create(1).
|
|
no-lib-depends-args no-wantlib-args:
|
|
@:
|
|
|
|
# those are expensive computations, so don't do them if we don't have to
|
|
.if empty(_DEPRUNLIBS)
|
|
lib-depends-args wantlib-args port-wantlib-args fake-wantlib-args:
|
|
.else
|
|
|
|
lib-depends-args:
|
|
@${_cache_fragment}; ${_emit_lib_depends}| while ${_read_spec}; do \
|
|
${_if_check_needed}; then \
|
|
${_complete_pkgspec}; \
|
|
echo "-P $$pkgpath:$$pkg:$$default"; \
|
|
else \
|
|
echo "LIB_DEPENDS $$d not needed for ${FULLPKGPATH${SUBPACKAGE}} ?" 1>&2; \
|
|
fi; \
|
|
done
|
|
|
|
wantlib-args:
|
|
@${_cache_fragment}; \
|
|
a=$${_DEPENDS_CACHE}/portstree-${FULLPKGNAME${SUBPACKAGE}}; \
|
|
b=$${_DEPENDS_CACHE}/inst-${FULLPKGNAME${SUBPACKAGE}}; \
|
|
if cd ${.CURDIR} && \
|
|
${MAKE} port-wantlib-args ${_PREDIR} $$a && \
|
|
${MAKE} fake-wantlib-args ${_PREDIR} $$b; then \
|
|
if ! cmp -s $$a $$b; \
|
|
then \
|
|
echo 1>&2 "${_check_msg}: Libraries in packing-lists in the ports tree"; \
|
|
echo 1>&2 " and libraries from installed packages don't match"; \
|
|
diff 1>&2 -u $$a $$b ${_check_error}; \
|
|
fi; \
|
|
cat $$b; \
|
|
${_PBUILD} rm $$a $$b; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
|
|
port-wantlib-args:
|
|
@${_cache_fragment}; \
|
|
if found=`${_list_port_libs} | ${_resolve_lib} ${_DEPRUNLIBS:QL}`; \
|
|
then \
|
|
${_show_found}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
|
|
fake-wantlib-args:
|
|
@if found=`{ \
|
|
echo {${WRKINST},}${LOCALBASE}/lib${_lib} /usr/lib${_lib} ${X11BASE}/lib${_lib}; \
|
|
for d in ${_DEPRUNLIBS:QL}; do \
|
|
case "$$d" in \
|
|
/*) echo {${WRKINST},}$${d%/*}${_lib};; \
|
|
*/*) echo {${WRKINST},}${LOCALBASE}/$${d%/*}${_lib};; \
|
|
esac; \
|
|
done } | perl -pe 's,\Q${WRKINST}\E,,g' | \
|
|
${_resolve_lib} ${_DEPRUNLIBS:QL}`; then \
|
|
${_show_found}; \
|
|
else \
|
|
exit 1; \
|
|
fi
|
|
.endif
|
|
|
|
_print-package-signature-run:
|
|
@${_emit_run_depends} |while ${_read_spec}; do \
|
|
${_parse_spec}; \
|
|
${_compute_default}; \
|
|
echo "@$$default"; \
|
|
done
|
|
|
|
_print-package-signature-lib:
|
|
@${_list_port_libs}| ${_resolve_lib} ${_DEPRUNLIBS:QL}; \
|
|
${_emit_lib_depends}| while ${_read_spec}; do \
|
|
${_if_check_needed}; then \
|
|
${_complete_pkgspec}; \
|
|
echo "@$$default"; \
|
|
fi; \
|
|
done
|
|
|
|
# recursively build a list of dirs for package running, ready for tsort
|
|
_recurse-run-dir-depends:
|
|
.for _dir in ${_RUN_DEP}
|
|
@echo "$$self ${_dir}"; \
|
|
if ! fgrep -q -e "r|${_dir}|" -e "a|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "r|${_dir}|" >> $${_DEPENDS_FILE}; \
|
|
subdir=${_dir}; ${_flavor_fragment}; \
|
|
toset="$$toset self=\"${_dir}\""; \
|
|
if ! eval $$toset ${MAKE} _recurse-run-dir-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
.endfor
|
|
|
|
run-dir-depends:
|
|
.if !empty(_RUN_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "r|${_FULLPKGPATH}|" -e "a|${_FULLPKGPATH}" $${_DEPENDS_FILE}; then \
|
|
echo "r|${_FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${_FULLPKGPATH} PKGPATH=${PKGPATH} ${MAKE} _recurse-run-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${_FULLPKGPATH} ${_FULLPKGPATH}"
|
|
.endif
|
|
|
|
# recursively build a list of dirs for package regression tests, ready for tsort
|
|
_recurse-test-dir-depends:
|
|
.for _dir in ${_TEST_DEP}
|
|
@echo "$$self ${_dir}"; \
|
|
if ! fgrep -q -e "R|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "R|${_dir}|" >> $${_DEPENDS_FILE}; \
|
|
subdir=${_dir}; ${_flavor_fragment}; \
|
|
toset="$$toset self=\"${_dir}\""; \
|
|
if ! eval $$toset ${MAKE} _recurse-run-dir-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
.endfor
|
|
|
|
test-dir-depends:
|
|
.if !empty(_TEST_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "R|${_FULLPKGPATH}|" $${_DEPENDS_FILE}; then \
|
|
echo "R|${_FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${_FULLPKGPATH} PKGPATH=${PKGPATH} ${MAKE} _recurse-test-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${_FULLPKGPATH} ${_FULLPKGPATH}"
|
|
.endif
|
|
|
|
# recursively build a list of dirs for package building, ready for tsort
|
|
# second and further stages need _RUN_DEP.
|
|
_recurse-all-dir-depends:
|
|
.for _dir in ${_BUILD_DEP} ${_RUN_DEP}
|
|
@echo "$$self ${_dir}"; \
|
|
if ! fgrep -q "a|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "a|${_dir}|" >> $${_DEPENDS_FILE}; \
|
|
subdir=${_dir}; ${_flavor_fragment}; \
|
|
toset="$$toset self=\"${_dir}\""; \
|
|
if ! eval $$toset ${MAKE} _recurse-all-dir-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
.endfor
|
|
|
|
# first stage does not need _RUN_DEP
|
|
_build-dir-depends:
|
|
.for _dir in ${_BUILD_DEP}
|
|
@echo "$$self ${_dir}"; \
|
|
if ! fgrep -q -e "b|${_dir}|" -e "a|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "b|${_dir}|" >> $${_DEPENDS_FILE}; \
|
|
subdir=${_dir}; ${_flavor_fragment}; \
|
|
toset="$$toset self=\"${_dir}\""; \
|
|
if ! eval $$toset ${MAKE} _recurse-all-dir-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
fi
|
|
.endfor
|
|
|
|
build-dir-depends:
|
|
.if !empty(_BUILD_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "b|${_FULLPKGPATH}|" -e "a|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "b|${_FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${_FULLPKGPATH} PKGPATH=${PKGPATH} ${MAKE} _build-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${_FULLPKGPATH} ${_FULLPKGPATH}"
|
|
.endif
|
|
|
|
all-dir-depends:
|
|
.if !empty(_BUILD_DEP) || !empty(_RUN_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q "|${_FULLPKGPATH}|" $${_DEPENDS_FILE}; then \
|
|
echo "|${_FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${_FULLPKGPATH} PKGPATH=${PKGPATH} ${MAKE} _recurse-all-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${_FULLPKGPATH} ${_FULLPKGPATH}"
|
|
.endif
|
|
|
|
# simpler list of package depends, no need to tsort, no duplicates
|
|
_recurse-show-run-depends:
|
|
@for d in ${_RUN_DEP}; do \
|
|
fgrep -q -e "|$$d|" $${_DEPENDS_FILE} && continue; \
|
|
echo "$$d"; \
|
|
echo "|$$d|" >> $${_DEPENDS_FILE}; \
|
|
subdir=$$d; ${_flavor_fragment}; \
|
|
if ! eval $$toset ${MAKE} _recurse-show-run-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
done
|
|
|
|
show-run-depends:
|
|
.if !empty(_RUN_DEP)
|
|
@${_depfile_fragment}; \
|
|
echo "|${_FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
for d in ${_RUN_DEP}; do \
|
|
fgrep -q -e "|$$d|" $${_DEPENDS_FILE} && continue; \
|
|
echo "$$d"; \
|
|
echo "|$$d|" >> $${_DEPENDS_FILE}; \
|
|
subdir=$$d; ${_flavor_fragment}; \
|
|
if ! eval $$toset ${MAKE} _recurse-show-run-depends; then \
|
|
echo 1>&2 "*** Problem checking deps in \"$$dir\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
done
|
|
.endif
|
|
|
|
#####################################################
|
|
# convenience targets, not really needed
|
|
#####################################################
|
|
|
|
checkpatch:
|
|
@${_MAKE} PATCH_CHECK_ONLY=Yes patch
|
|
|
|
clean-depends:
|
|
@${_MAKE} clean=depends
|
|
|
|
distclean:
|
|
@${_MAKE} clean=dist
|
|
|
|
reinstall:
|
|
@${_MAKE} clean='install force'
|
|
@cd ${.CURDIR} && _DEPENDS_TARGET=reinstall PKGPATH=${PKGPATH} exec ${MAKE} install
|
|
|
|
repackage:
|
|
@${_MAKE} clean=packages
|
|
@${_MAKE} package
|
|
|
|
rebuild:
|
|
@${_PBUILD} rm -f ${_BUILD_COOKIE}
|
|
@${_MAKE} build
|
|
|
|
regen:
|
|
@${_PBUILD} rm -f ${_GEN_COOKIE}
|
|
@${_MAKE} gen
|
|
|
|
reprepare:
|
|
@${_PBUILD} rm -f ${_DEPBUILD_COOKIES} ${_DEPBUILDLIB_COOKIES} \
|
|
${_DEPBUILDWANTLIB_COOKIE}
|
|
@${_MAKE} prepare
|
|
|
|
uninstall deinstall:
|
|
@${ECHO_MSG} "===> Deinstalling for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@${SUDO} ${_PKG_DELETE} ${FULLPKGNAME${SUBPACKAGE}}
|
|
|
|
peek-ftp:
|
|
@echo "DISTFILES=${DISTFILES}"
|
|
@${_PFETCH} install -d ${DISTDIR_MODE} ${FULLDISTDIR}; \
|
|
cd ${FULLDISTDIR}; echo "cd ${FULLDISTDIR}"; \
|
|
for i in ${MASTER_SITES:Mftp*}; do \
|
|
echo "Connecting to $$i"; ${_PFETCH} ${FETCH_CMD} $$i ; break; \
|
|
done
|
|
|
|
show-required-by:
|
|
@cd ${PORTSDIR} && make all-dir-depends | ${_PERLSCRIPT}/port-extract-dependencies-helper -r ${_ALLPKGPATHS}
|
|
|
|
|
|
show:
|
|
.for _s in ${show}
|
|
@echo ${${_s}:Q}
|
|
.endfor
|
|
|
|
show-indexed:
|
|
.for _s in ${show-indexed}
|
|
. if defined(${_s}${SUBPACKAGE})
|
|
@echo ${${_s}${SUBPACKAGE}:Q}
|
|
. else
|
|
@echo ${${_s}:Q}
|
|
. endif
|
|
.endfor
|
|
|
|
# du fails if it can't access everything
|
|
show-size:
|
|
@${_PBUILD} du -ks ${WRKDIR}
|
|
|
|
show-fake-size:
|
|
@${_PBUILD} du -ks ${WRKINST}
|
|
|
|
verbose-show:
|
|
.for _s in ${verbose-show}
|
|
. if defined(${_s})
|
|
@echo ${_s}=${${_s}:Q}
|
|
. endif
|
|
.endfor
|
|
|
|
_all_phony = ${_recursive_depends_targets} \
|
|
${_recursive_targets} ${_dangerous_recursive_targets} \
|
|
_build-dir-depends _hook-post-install \
|
|
_internal-all _internal-build _internal-build-depends \
|
|
_internal-checksum _internal-clean _internal-gen _internal-configure \
|
|
_internal-distpatch _internal-extract _internal-fake _internal-fetch \
|
|
_internal-fetch-all _internal-install-depends _internal-install-all \
|
|
_internal-package _internal-package-only _internal-plist _internal-prepare \
|
|
_internal-test _internal-test-depends \
|
|
_internal-subpackage _internal-subupdate \
|
|
_internal-update _internal-update _internal-update-plist \
|
|
_internal_install _license-check \
|
|
print-package-args _print-package-signature-lib \
|
|
_print-package-signature-run _print-packagename _recurse-all-dir-depends \
|
|
_recurse-test-dir-depends _recurse-run-dir-depends \
|
|
build-depends-list checkpatch clean clean-depends \
|
|
delete-package distpatch do-build do-configure do-distpatch \
|
|
do-gen do-extract do-install do-test fetch-all \
|
|
install-all lib-depends lib-depends-list \
|
|
peek-ftp port-lib-depends-check post-build post-configure \
|
|
post-distpatch post-extract post-install \
|
|
post-patch post-test pre-build pre-configure pre-extract pre-fake \
|
|
pre-install pre-patch pre-test prepare \
|
|
print-build-depends print-run-depends rebuild regen reprepare \
|
|
test-depends test-depends-list run-depends-list \
|
|
show-required-by subpackage uninstall _print-metadata \
|
|
run-depends-args lib-depends-args all-lib-depends-args wantlib-args \
|
|
port-wantlib-args fake-wantlib-args no-wantlib-args no-lib-depends-args \
|
|
_recurse-show-run-depends show-run-depends \
|
|
_post-extract-finalize _post-patch-finalize _pre-fake-modules \
|
|
_gen-finalize _post-install-modules fix-permissions
|
|
|
|
.if defined(_DEBUG_TARGETS)
|
|
. for _t in ${_all_phony}
|
|
. if !target(${_t})
|
|
ERRORS += "Fatal: phony target ${_t} does not exist"
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
|
|
.if defined(ERRORS)
|
|
.BEGIN:
|
|
. for _m in ${ERRORS}
|
|
@echo 1>&2 ${_m} "(in ${PKGPATH})"
|
|
. endfor
|
|
. if !empty(ERRORS:M"Fatal\:*") || !empty(ERRORS:M'Fatal\:*')
|
|
@exit 1
|
|
. endif
|
|
.endif
|
|
|
|
.PHONY: ${_all_phony}
|