cde96256b8
simplify some .if defined(A) . for i in $A ... . endfor .endfor into .for i in $A ... . endfor .endfor since empty loops work just fine.
2849 lines
81 KiB
Makefile
2849 lines
81 KiB
Makefile
#-*- mode: Makefile; tab-width: 4; -*-
|
|
# ex:ts=4 sw=4 filetype=make:
|
|
# $OpenBSD: bsd.port.mk,v 1.805 2006/11/19 12:05:10 espie Exp $
|
|
# $FreeBSD: bsd.port.mk,v 1.264 1996/12/25 02:27:44 imp Exp $
|
|
# $NetBSD: bsd.port.mk,v 1.62 1998/04/09 12:47:02 hubertf Exp $
|
|
#
|
|
# 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).
|
|
|
|
# Enquiries as to the bsd.port.mk framework should usually be directed
|
|
# to ports@openbsd.org.
|
|
|
|
|
|
.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 v in PKGREPOSITORY PKGREPOSITORYBASE CDROM_PACKAGES FTP_PACKAGES
|
|
. if defined($v)
|
|
ERRORS+= "Fatal: Variable $v is obsolete, use PACKAGE_REPOSITORY instead."
|
|
. endif
|
|
.endfor
|
|
|
|
# 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.
|
|
#
|
|
#
|
|
# Variables to change if you want a special behavior:
|
|
#
|
|
# DEPENDS_TARGET - The target to execute when a port is calling a
|
|
# dependency (default: "install").
|
|
#
|
|
|
|
# Default sequence for "all" is: fetch checksum 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
|
|
#
|
|
|
|
# User settings
|
|
TRUST_PACKAGES?=No
|
|
FETCH_PACKAGES?=No
|
|
CLEANDEPENDS?=No
|
|
USE_SYSTRACE?= No
|
|
BULK?=No
|
|
RECURSIVE_FETCH_LIST?= Yes
|
|
WRKOBJDIR?=
|
|
FAKEOBJDIR?=
|
|
BULK_TARGETS?=
|
|
BULK_DO?=
|
|
FORCE_UPDATE?=No
|
|
# All variables relevant to the port's description
|
|
_ALL_VARIABLES?=HOMEPAGE DISTNAME LIB_DEPENDS \
|
|
BUILD_DEPENDS RUN_DEPENDS REGRESS_DEPENDS USE_GMAKE MODULES FLAVORS \
|
|
NO_BUILD NO_REGRESS SHARED_ONLY ONLY_FOR_ARCHS IS_INTERACTIVE \
|
|
BROKEN MULTI_PACKAGES PSEUDO_FLAVORS CATEGORIES \
|
|
REGRESS_IS_INTERACTIVE DISTFILES DIST_SUBDIR \
|
|
PERMIT_DISTFILES_CDROM PERMIT_DISTFILES_FTP \
|
|
CONFIGURE_STYLE USE_LIBTOOL SEPARATE_BUILD WANTLIB \
|
|
SHARED_LIBS USE_MOTIF PACKAGES MASTER_SITES \
|
|
MASTER_SITES0 MASTER_SITES1 MASTER_SITES2 MASTER_SITES3 MASTER_SITES4 \
|
|
MASTER_SITES5 MASTER_SITES6 MASTER_SITES7 MASTER_SITES8 MASTER_SITES9 \
|
|
MAINTAINER SUBPACKAGE PACKAGING DESCR SUPDISTFILES \
|
|
AUTOCONF_VERSION AUTOMAKE_VERSION CONFIGURE_ARGS
|
|
# and stuff needing to be MULTI_PACKAGE'd
|
|
_ALL_VARIABLES2?=COMMENT FULLPKGNAME PKGNAME PKG_ARCH \
|
|
PERMIT_PACKAGE_FTP PERMIT_PACKAGE_CDROM
|
|
|
|
# special purpose user settings
|
|
PATCH_CHECK_ONLY?=No
|
|
REFETCH?=false
|
|
|
|
# Constants used by the ports tree
|
|
ARCH!= uname -m
|
|
OPSYS= OpenBSD
|
|
OPSYS_VER= ${OSREV}
|
|
|
|
LP64_ARCHS=alpha amd64 hppa64 sparc64 mips64
|
|
NO_SHARED_ARCHS=m88k vax
|
|
|
|
# Set NO_SHARED_LIBS for those machines that don't support shared libraries.
|
|
.for _m in ${MACHINE_ARCH}
|
|
. if !empty(NO_SHARED_ARCHS:M${_m})
|
|
NO_SHARED_LIBS?= Yes
|
|
. endif
|
|
.endfor
|
|
NO_SHARED_LIBS?= No
|
|
|
|
# Global path locations.
|
|
PORTSDIR?= /usr/ports
|
|
LOCALBASE?= /usr/local
|
|
X11BASE?= /usr/X11R6
|
|
DISTDIR?= ${PORTSDIR}/distfiles
|
|
BULK_COOKIES_DIR?= ${PORTSDIR}/bulk/${MACHINE_ARCH}
|
|
UPDATE_COOKIES_DIR?= ${PORTSDIR}/update/${MACHINE_ARCH}
|
|
TEMPLATES?= ${PORTSDIR}/infrastructure/templates
|
|
TMPDIR?= /tmp
|
|
PLIST_DB?=
|
|
|
|
PACKAGE_REPOSITORY?=${PORTSDIR}/packages
|
|
|
|
# local path locations
|
|
.include "${PORTSDIR}/infrastructure/mk/pkgpath.mk"
|
|
|
|
WRKOBJDIR_${PKGPATH}?= ${WRKOBJDIR}
|
|
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
|
|
|
|
FETCH_CMD?= /usr/bin/ftp -V -m
|
|
|
|
PKG_TMPDIR?= /var/tmp
|
|
PKG_CMD?= /usr/sbin/pkg_create
|
|
PKG_DELETE?= /usr/sbin/pkg_delete
|
|
# remount those mount points ro before fake.
|
|
# XXX tends to panic the OS
|
|
PROTECT_MOUNT_POINTS?=
|
|
|
|
.if exists(${.CURDIR}/../Makefile.inc)
|
|
.include "${.CURDIR}/../Makefile.inc"
|
|
.endif
|
|
|
|
.if !defined(PERMIT_PACKAGE_CDROM) || !defined(PERMIT_PACKAGE_FTP) || \
|
|
!defined(PERMIT_DISTFILES_CDROM) || !defined(PERMIT_DISTFILES_FTP)
|
|
ERRORS+="The licensing info for ${FULLPKGNAME} is incomplete."
|
|
ERRORS+="Please notify the OpenBSD port maintainer:"
|
|
ERRORS+=" ${MAINTAINER}"
|
|
_BAD_LICENSING=Yes
|
|
PERMIT_PACKAGE_CDROM = No
|
|
PERMIT_DISTFILES_CDROM = No
|
|
PERMIT_PACKAGE_FTP = No
|
|
PERMIT_DISTFILES_FTP = No
|
|
.endif
|
|
|
|
.if defined(verbose-show)
|
|
.MAIN: verbose-show
|
|
.elif defined(show)
|
|
.MAIN: show
|
|
.elif defined(clean)
|
|
.MAIN: clean
|
|
.elif defined(_internal-clean)
|
|
clean=${_internal-clean}
|
|
.MAIN: _internal-clean
|
|
.else
|
|
.MAIN: all
|
|
.endif
|
|
|
|
FAKE?=Yes
|
|
USE_FAKE_LIB?=No
|
|
|
|
# need to go through an extra var because clean is set in stone,
|
|
# on the cmdline.
|
|
_clean=${clean}
|
|
.if empty(_clean) || ${_clean:L} == "depends"
|
|
_clean+=work
|
|
.endif
|
|
.if ${CLEANDEPENDS_${PKGPATH}:L} == "yes"
|
|
_clean+=depends
|
|
.endif
|
|
.if ${_clean:L:Mwork}
|
|
_clean+=fake
|
|
.endif
|
|
.if ${_clean:L:Mforce}
|
|
_clean+=-f
|
|
.endif
|
|
# check that clean is clean
|
|
_okay_words=depends work fake -f flavors dist install sub packages package \
|
|
readmes bulk force
|
|
.for _w in ${_clean:L}
|
|
. if !${_okay_words:M${_w}}
|
|
ERRORS+="Fatal: unknown clean command: ${_w}"
|
|
. endif
|
|
.endfor
|
|
|
|
NOMANCOMPRESS?= Yes
|
|
DEF_UMASK?= 022
|
|
|
|
.if exists(${.CURDIR}/Makefile.${ARCH})
|
|
.include "${.CURDIR}/Makefile.${ARCH}"
|
|
.elif exists(${.CURDIR}/Makefile.${MACHINE_ARCH})
|
|
.include "${.CURDIR}/Makefile.${MACHINE_ARCH}"
|
|
.endif
|
|
|
|
# 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_REGRESS?= No
|
|
INSTALL_TARGET?= install
|
|
|
|
.if ${CONFIGURE_STYLE:L:Mautomake} || ${CONFIGURE_STYLE:L:Mautoconf} || ${CONFIGURE_STYLE:L:Mautoupdate}
|
|
. if !${CONFIGURE_STYLE:L:Mgnu}
|
|
CONFIGURE_STYLE+=gnu
|
|
. endif
|
|
.endif
|
|
|
|
.for _i in perl gnu imake
|
|
. if ${CONFIGURE_STYLE:L:M${_i}}
|
|
MODULES+=${_i}
|
|
. endif
|
|
.endfor
|
|
|
|
.if defined(MODULES)
|
|
_MODULES_DONE=
|
|
. include "${PORTSDIR}/infrastructure/mk/modules.port.mk"
|
|
.endif
|
|
|
|
###
|
|
### Variable setup that can happen after modules
|
|
###
|
|
|
|
.if ${MACHINE_ARCH} != ${ARCH}
|
|
PKG_ARCH?=${MACHINE_ARCH},${ARCH}
|
|
.else
|
|
PKG_ARCH?=${MACHINE_ARCH}
|
|
.endif
|
|
|
|
SHARED_ONLY?= No
|
|
SEPARATE_BUILD?= No
|
|
|
|
DIST_SUBDIR?=
|
|
|
|
.if !empty(DIST_SUBDIR)
|
|
FULLDISTDIR?= ${DISTDIR}/${DIST_SUBDIR}
|
|
.else
|
|
FULLDISTDIR?= ${DISTDIR}
|
|
.endif
|
|
|
|
.if exists(${.CURDIR}/patches.${ARCH})
|
|
PATCHDIR?= ${.CURDIR}/patches.${ARCH}
|
|
.elif exists(${.CURDIR}/patches.${MACHINE_ARCH})
|
|
PATCHDIR?= ${.CURDIR}/patches.${MACHINE_ARCH}
|
|
.else
|
|
PATCHDIR?= ${.CURDIR}/patches
|
|
.endif
|
|
|
|
PATCH_LIST?= patch-*
|
|
|
|
.if exists(${.CURDIR}/files.${ARCH})
|
|
FILESDIR?= ${.CURDIR}/files.${ARCH}
|
|
.elif exists(${.CURDIR}/files.${MACHINE_ARCH})
|
|
FILESDIR?= ${.CURDIR}/files.${MACHINE_ARCH}
|
|
.else
|
|
FILESDIR?= ${.CURDIR}/files
|
|
.endif
|
|
|
|
.if exists(${.CURDIR}/pkg.${ARCH})
|
|
PKGDIR?= ${.CURDIR}/pkg.${ARCH}
|
|
.elif exists(${.CURDIR}/pkg.${MACHINE_ARCH})
|
|
PKGDIR?= ${.CURDIR}/pkg.${MACHINE_ARCH}
|
|
.else
|
|
PKGDIR?= ${.CURDIR}/pkg
|
|
.endif
|
|
|
|
PREFIX?= ${LOCALBASE}
|
|
TRUEPREFIX?= ${PREFIX}
|
|
DESTDIRNAME?= DESTDIR
|
|
DESTDIR?= ${WRKINST}
|
|
|
|
MAKE_FLAGS?=
|
|
LIBTOOL_FLAGS?=
|
|
.if !defined(FAKE_FLAGS)
|
|
FAKE_FLAGS=${DESTDIRNAME}=${WRKINST}
|
|
.endif
|
|
|
|
# where configuration files should go
|
|
SYSCONFDIR?= /etc
|
|
USE_GMAKE?= No
|
|
.if ${USE_GMAKE:L} == "yes"
|
|
BUILD_DEPENDS+= ::devel/gmake
|
|
MAKE_PROGRAM= ${GMAKE}
|
|
.else
|
|
MAKE_PROGRAM= ${MAKE}
|
|
.endif
|
|
|
|
USE_LIBTOOL?=No
|
|
_lt_libs=
|
|
.if ${USE_LIBTOOL:L} == "yes"
|
|
LIBTOOL?= ${DEPBASE}/bin/libtool
|
|
BUILD_DEPENDS+= ::devel/libtool
|
|
CONFIGURE_ENV+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}" ${_lt_libs}
|
|
MAKE_ENV+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}" ${_lt_libs}
|
|
MAKE_FLAGS+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}" ${_lt_libs}
|
|
FAKE_FLAGS+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}" ${_lt_libs}
|
|
.endif
|
|
MAKE_FLAGS+= SHARED_LIBS_LOG=${WRKBUILD}/shared_libs.log
|
|
|
|
.if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M-main)
|
|
SUBPACKAGE?=
|
|
PKGNAMES=${FULLPKGNAME}
|
|
_FMN=${PKGPATH}/${FULLPKGNAME}
|
|
.else
|
|
SUBPACKAGE?=-main
|
|
_FMN=
|
|
.endif
|
|
FLAVOR?=
|
|
FLAVORS?=
|
|
PSEUDO_FLAVORS?=
|
|
FLAVORS+=${PSEUDO_FLAVORS}
|
|
|
|
.if !empty(FLAVORS:L:Mregress) && empty(FLAVOR:L:Mregress)
|
|
NO_REGRESS= Yes
|
|
.endif
|
|
|
|
USE_MOTIF?=No
|
|
|
|
.if ${USE_MOTIF:L} != "no"
|
|
. if ${USE_MOTIF:L} == "lesstif"
|
|
LIB_DEPENDS+= Xm.>=1::x11/lesstif
|
|
. elif ${USE_MOTIF:L} == "openmotif"
|
|
LIB_DEPENDS+= Xm.>=2::x11/openmotif
|
|
. elif ${USE_MOTIF:L} == "any" || ${USE_MOTIF:L} == "yes"
|
|
FLAVORS+=lesstif
|
|
. if ${FLAVOR:L:Mlesstif} && ${FLAVOR:L:Mmotif}
|
|
ERRORS+="Fatal: choose motif or lesstif, not both."
|
|
. endif
|
|
. if ${FLAVOR:L:Mlesstif}
|
|
LIB_DEPENDS+= Xm.>=1::x11/lesstif
|
|
. else
|
|
LIB_DEPENDS+= Xm.>=2::x11/openmotif
|
|
. endif
|
|
. else
|
|
ERRORS+= "Fatal: Unknown USE_MOTIF=${USE_MOTIF} settings."
|
|
. endif
|
|
MOTIFLIB=-L${DEPBASE}/lib -lXm
|
|
.endif
|
|
|
|
.if !empty(SUBPACKAGE)
|
|
. for _i in ${SUBPACKAGE}
|
|
. if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M${_i})
|
|
ERRORS+= "Fatal: Subpackage ${SUBPACKAGE} does not exist."
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
.if defined(MULTI_PACKAGES) && !empty(MULTI_PACKAGES:N-*)
|
|
ERRORS+= "Fatal: SUBPACKAGES should always beging with -: ${MULTI_PACKAGES:N-*}."
|
|
.endif
|
|
|
|
.if defined(SED_PLIST)
|
|
ERRORS+="Fatal: SED_PLIST deprecated"
|
|
.endif
|
|
|
|
# Build FLAVOR_EXT, checking that no flavors are misspelled
|
|
FLAVOR_EXT:=
|
|
# _FLAVOR_EXT2 is used internally for working directories.
|
|
# It encodes flavors and pseudo-flavors.
|
|
_FLAVOR_EXT2:=
|
|
|
|
# (applies only to PLIST for now)
|
|
.if !empty(FLAVORS)
|
|
. for _i in ${FLAVORS:L}
|
|
. if empty(FLAVOR:L:M${_i})
|
|
PKG_ARGS+=-D${_i}=0
|
|
. else
|
|
_FLAVOR_EXT2:=${_FLAVOR_EXT2}-${_i}
|
|
. if empty(PSEUDO_FLAVORS:L:M${_i})
|
|
FLAVOR_EXT:=${FLAVOR_EXT}-${_i}
|
|
. endif
|
|
PKG_ARGS+=-D${_i}=1
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
.if ${NO_SHARED_LIBS:L} == "yes"
|
|
PKG_ARGS+=-DSHARED_LIBS=0
|
|
.else
|
|
PKG_ARGS+=-DSHARED_LIBS=1
|
|
.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:L}
|
|
. if empty(FLAVORS:L:M${_i})
|
|
ERRORS+= "Fatal: Unknown flavor: ${_i}"
|
|
ERRORS+= " (Possible flavors are: ${FLAVORS})."
|
|
. endif
|
|
. endfor
|
|
. else
|
|
ERRORS+= "Fatal: no flavors for this port."
|
|
. endif
|
|
.endif
|
|
|
|
PKG_SUFX?= .tgz
|
|
|
|
PKGNAME?=${DISTNAME}
|
|
FULLPKGNAME?=${PKGNAME}${FLAVOR_EXT}
|
|
_MASTER?=
|
|
_SOLVING_DEP?=No
|
|
|
|
.if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
. if !defined(FULLPKGNAME${_s})
|
|
. if defined(PKGNAME${_s})
|
|
FULLPKGNAME${_s} = ${PKGNAME${_s}}${FLAVOR_EXT}
|
|
. else
|
|
FULLPKGNAME${_s} = ${PKGNAME}${_s}${FLAVOR_EXT}
|
|
. endif
|
|
. endif
|
|
. endfor
|
|
.endif
|
|
|
|
_SYSTRACE_COOKIE= ${WRKDIR}/systrace.policy
|
|
_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
|
|
_INSTALL_COOKIE= ${PKG_DBDIR}/${FULLPKGNAME${SUBPACKAGE}}/+CONTENTS
|
|
_BULK_COOKIE= ${BULK_COOKIES_DIR}/${FULLPKGNAME}
|
|
_FAKE_COOKIE= ${WRKINST}/.fake_done
|
|
_INSTALL_PRE_COOKIE=${WRKINST}/.install_started
|
|
.if !empty(UPDATE_COOKIES_DIR)
|
|
_UPDATE_COOKIE= ${UPDATE_COOKIES_DIR}/${FULLPKGNAME${SUBPACKAGE}}
|
|
.else
|
|
_UPDATE_COOKIE= ${WRKDIR}/.update_${FULLPKGNAME${SUBPACKAGE}}
|
|
.endif
|
|
.if ${SEPARATE_BUILD:L} != "no"
|
|
_CONFIGURE_COOKIE= ${WRKBUILD}/.configure_done
|
|
_BUILD_COOKIE= ${WRKBUILD}/.build_done
|
|
_REGRESS_COOKIE= ${WRKBUILD}/.regress_done
|
|
.else
|
|
_CONFIGURE_COOKIE= ${WRKDIR}/.configure_done
|
|
_BUILD_COOKIE= ${WRKDIR}/.build_done
|
|
_REGRESS_COOKIE= ${WRKDIR}/.regress_done
|
|
.endif
|
|
|
|
_ALL_COOKIES=${_EXTRACT_COOKIE} ${_PATCH_COOKIE} ${_CONFIGURE_COOKIE} \
|
|
${_INSTALL_PRE_COOKIE} ${_BUILD_COOKIE} ${_REGRESS_COOKIE} \
|
|
${_SYSTRACE_COOKIE} ${_PACKAGE_COOKIES} \
|
|
${_DISTPATCH_COOKIE} ${_PREPATCH_COOKIE} ${_FAKE_COOKIE} \
|
|
${_WRKDIR_COOKIE} ${_DEPLIB_COOKIES} ${_DEPBUILD_COOKIES} \
|
|
${_DEPRUN_COOKIES} ${_DEPREGRESS_COOKIES} ${_UPDATE_COOKIE} \
|
|
${_DEPlibs_COOKIE} ${_DEPlibs_COOKIES}
|
|
|
|
_MAKE_COOKIE=touch
|
|
|
|
# Miscellaneous overridable commands:
|
|
GMAKE?= gmake
|
|
|
|
CHECKSUM_FILE?= ${.CURDIR}/distinfo
|
|
|
|
# Don't touch !!! Used for generating checksums.
|
|
_CIPHERS= sha1 rmd160 md5
|
|
|
|
# This is the one you can override
|
|
PREFERRED_CIPHERS?= ${_CIPHERS}
|
|
|
|
PORTPATH?= ${WRKDIR}/bin:/usr/bin:/bin:/usr/sbin:/sbin:${DEPBASE}/bin:${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.
|
|
.if defined(COPTS)
|
|
CFLAGS+= ${COPTS}
|
|
.endif
|
|
.if defined(CXXOPTS)
|
|
CXXFLAGS+= ${CXXOPTS}
|
|
.endif
|
|
.if defined(WARNINGS) && ${WARNINGS:L} == "yes"
|
|
. if defined(CDIAGFLAGS)
|
|
CFLAGS+= ${CDIAGFLAGS}
|
|
. endif
|
|
. if defined(CXXDIAGFLAGS)
|
|
CXXFLAGS+= ${CXXDIAGFLAGS}
|
|
. endif
|
|
.endif
|
|
|
|
MAKE_FILE?= Makefile
|
|
PORTHOME?= /${PKGNAME}_writes_to_HOME
|
|
|
|
MAKE_ENV+= PATH='${PORTPATH}' PREFIX='${PREFIX}' \
|
|
LOCALBASE='${LOCALBASE}' DEPBASE='${DEPBASE}' X11BASE='${X11BASE}' \
|
|
MOTIFLIB='${MOTIFLIB}' 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?=No
|
|
.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
|
|
|
|
|
|
MAKE_ENV+= EXTRA_SYS_MK_INCLUDES="<bsd.own.mk>"
|
|
|
|
|
|
.if !empty(FAKEOBJDIR_${PKGPATH})
|
|
WRKINST?= ${FAKEOBJDIR_${PKGPATH}}/${PKGNAME}${_FLAVOR_EXT2}
|
|
.else
|
|
WRKINST?= ${WRKDIR}/fake-${ARCH}${_FLAVOR_EXT2}
|
|
.endif
|
|
|
|
.if !empty(WRKOBJDIR_${PKGPATH})
|
|
. if ${SEPARATE_BUILD:L:Mflavored}
|
|
WRKDIR?= ${WRKOBJDIR_${PKGPATH}}/${PKGNAME}
|
|
. else
|
|
WRKDIR?= ${WRKOBJDIR_${PKGPATH}}/${PKGNAME}${_FLAVOR_EXT2}
|
|
. endif
|
|
.else
|
|
. if ${SEPARATE_BUILD:L:Mflavored}
|
|
WRKDIR?= ${.CURDIR}/w-${PKGNAME}
|
|
. else
|
|
WRKDIR?= ${.CURDIR}/w-${PKGNAME}${_FLAVOR_EXT2}
|
|
. endif
|
|
.endif
|
|
|
|
WRKDIST?= ${WRKDIR}/${DISTNAME}
|
|
|
|
WRKSRC?= ${WRKDIST}
|
|
|
|
.if ${SEPARATE_BUILD:L} != "no"
|
|
WRKBUILD?= ${WRKDIR}/build-${MACHINE_ARCH}${_FLAVOR_EXT2}
|
|
WRKPKG?= ${WRKBUILD}/pkg
|
|
.else
|
|
WRKBUILD?= ${WRKSRC}
|
|
WRKPKG?= ${WRKDIR}/pkg
|
|
.endif
|
|
WRKCONF?= ${WRKBUILD}
|
|
|
|
ALL_TARGET?= all
|
|
|
|
FAKE_TARGET ?= ${INSTALL_TARGET}
|
|
|
|
REGRESS_TARGET ?= regress
|
|
REGRESS_FLAGS ?= ${MAKE_FLAGS}
|
|
|
|
_PACKAGE_COOKIE_DEPS=${_FAKE_COOKIE}
|
|
|
|
.for _s in ${MULTI_PACKAGES}
|
|
PKGNAMES += ${FULLPKGNAME${_s}}
|
|
.endfor
|
|
|
|
.if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
. for _v in PKG_ARCH PERMIT_PACKAGE_FTP PERMIT_PACKAGE_CDROM
|
|
${_v}${_s} ?= ${${_v}}
|
|
. endfor
|
|
. endfor
|
|
.endif
|
|
|
|
_PACKAGE_LINKS=
|
|
_PKGFILE= ${FULLPKGNAME${SUBPACKAGE}}${PKG_SUFX}
|
|
NO_ARCH?= no-arch
|
|
.if ${PKG_ARCH${SUBPACKAGE}} == "*" && ${NO_ARCH} != ${MACHINE_ARCH}/all
|
|
_PACKAGE_COOKIE= ${PACKAGE_REPOSITORY}/${NO_ARCH}/${_PKGFILE}
|
|
_PACKAGE_LINKS+= ${MACHINE_ARCH}/all ${NO_ARCH}
|
|
_PACKAGE_COOKIES+= ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/${_PKGFILE}
|
|
.else
|
|
_PACKAGE_COOKIE= ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/${_PKGFILE}
|
|
.endif
|
|
_PKG_REPO= ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/all/
|
|
_CACHE_REPO= ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/cache/
|
|
PKGFILE=${_PKG_REPO}${_PKGFILE}
|
|
|
|
_PACKAGE_COOKIES += ${_PACKAGE_COOKIE}
|
|
.if ${PERMIT_PACKAGE_FTP${SUBPACKAGE}:L} == "yes"
|
|
_PACKAGE_COOKIES += ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/ftp/${_PKGFILE}
|
|
_PACKAGE_LINKS += ${MACHINE_ARCH}/ftp ${MACHINE_ARCH}/all
|
|
.endif
|
|
.if ${PERMIT_PACKAGE_CDROM${SUBPACKAGE}:L} == "yes"
|
|
_PACKAGE_COOKIES += ${PACKAGE_REPOSITORY}/${MACHINE_ARCH}/cdrom/${_PKGFILE}
|
|
_PACKAGE_LINKS += ${MACHINE_ARCH}/cdrom ${MACHINE_ARCH}/all
|
|
.endif
|
|
|
|
.if empty(SUBPACKAGE)
|
|
FULLPKGPATH=${PKGPATH}${FLAVOR_EXT:S/-/,/g}
|
|
.else
|
|
FULLPKGPATH=${PKGPATH},${SUBPACKAGE}${FLAVOR_EXT:S/-/,/g}
|
|
.endif
|
|
|
|
# A few aliases for *-install targets
|
|
INSTALL_PROGRAM= \
|
|
${INSTALL} ${INSTALL_COPY} ${INSTALL_STRIP} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE}
|
|
INSTALL_SCRIPT= \
|
|
${INSTALL} ${INSTALL_COPY} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE}
|
|
INSTALL_DATA= \
|
|
${INSTALL} ${INSTALL_COPY} -o ${SHAREOWN} -g ${SHAREGRP} -m ${SHAREMODE}
|
|
INSTALL_MAN= \
|
|
${INSTALL} ${INSTALL_COPY} -o ${MANOWN} -g ${MANGRP} -m ${MANMODE}
|
|
|
|
INSTALL_PROGRAM_DIR= \
|
|
${INSTALL} -d -o ${BINOWN} -g ${BINGRP} -m ${DIRMODE}
|
|
INSTALL_SCRIPT_DIR= \
|
|
${INSTALL_PROGRAM_DIR}
|
|
INSTALL_DATA_DIR= \
|
|
${INSTALL} -d -o ${SHAREOWN} -g ${SHAREGRP} -m ${DIRMODE}
|
|
INSTALL_MAN_DIR= \
|
|
${INSTALL} -d -o ${MANOWN} -g ${MANGRP} -m ${DIRMODE}
|
|
|
|
_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 systrace variables
|
|
NO_SYSTRACE?= No
|
|
.if ${USE_SYSTRACE:L} == "yes" && ${NO_SYSTRACE:L} == "no"
|
|
_SYSTRACE_CMD?= /bin/systrace -e -i -a -f ${_SYSTRACE_COOKIE}
|
|
.else
|
|
_SYSTRACE_CMD=
|
|
.endif
|
|
SYSTRACE_FILTER?= ${PORTSDIR}/infrastructure/db/systrace.filter
|
|
_SYSTRACE_POLICIES+= /bin/sh /usr/bin/env /usr/bin/make \
|
|
/usr/bin/patch ${DEPBASE}/bin/gmake
|
|
SYSTRACE_SUBST_VARS+= DISTDIR PKG_TMPDIR PORTSDIR TMPDIR WRKDIR
|
|
.for _v in ${SYSTRACE_SUBST_VARS}
|
|
_SYSTRACE_SED_SUBST+=-e 's,$${${_v}},${${_v}},g'
|
|
.endfor
|
|
|
|
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, from subst vars
|
|
SUBST_VARS+=MACHINE_ARCH ARCH HOMEPAGE PREFIX SYSCONFDIR FLAVOR_EXT MAINTAINER
|
|
_tmpvars=
|
|
_SED_SUBST=sed
|
|
|
|
_PKG_ADD_AUTO?=
|
|
.if ${_SOLVING_DEP:L} == "yes"
|
|
_PKG_ADD_AUTO+=-a
|
|
.endif
|
|
|
|
.for _v in ${SUBST_VARS}
|
|
_SED_SUBST+=-e 's|$${${_v}}|${${_v}}|g'
|
|
PKG_ARGS+=-D${_v}='${${_v}}'
|
|
_tmpvars += ${_v}='${${_v}}'
|
|
.endfor
|
|
PKG_ARGS+=-DFLAVORS='${FLAVOR_EXT}'
|
|
PKG_ARGS+=-DFULLPKGPATH=${FULLPKGPATH}
|
|
PKG_ARGS+=-DPERMIT_PACKAGE_CDROM=${PERMIT_PACKAGE_CDROM${SUBPACKAGE}:Q}
|
|
PKG_ARGS+=-DPERMIT_PACKAGE_FTP=${PERMIT_PACKAGE_FTP${SUBPACKAGE}:Q}
|
|
_tmpvars += FLAVORS='${FLAVOR_EXT}'
|
|
_SED_SUBST+=-e 's,$${FLAVORS},${FLAVOR_EXT},g' -e 's,$$\\,$$,g'
|
|
|
|
# find out the most appropriate PLIST source
|
|
.if !defined(PLIST) && exists(${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.${ARCH})
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.${ARCH}
|
|
.else
|
|
. if !defined(PLIST) && exists(${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.${MACHINE_ARCH})
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.${MACHINE_ARCH}
|
|
. endif
|
|
.endif
|
|
.if !defined(PLIST) && ${NO_SHARED_LIBS:L} == "yes" && exists(${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.noshared)
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}.noshared
|
|
.endif
|
|
.if !defined(PLIST) && exists(${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT})
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}${FLAVOR_EXT}
|
|
.endif
|
|
.if !defined(PLIST) && exists(${PKGDIR}/PLIST${SUBPACKAGE}.${ARCH})
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}.${ARCH}
|
|
.else
|
|
. if !defined(PLIST) && exists(${PKGDIR}/PLIST${SUBPACKAGE}.${MACHINE_ARCH})
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}.${MACHINE_ARCH}
|
|
. endif
|
|
.endif
|
|
.if !defined(PLIST) && ${NO_SHARED_LIBS:L} == "yes" && exists(${PKGDIR}/PLIST${SUBPACKAGE}.noshared)
|
|
PLIST= ${PKGDIR}/PLIST${SUBPACKAGE}.noshared
|
|
.endif
|
|
PLIST?= ${PKGDIR}/PLIST${SUBPACKAGE}
|
|
|
|
# Likewise for DESCR/MESSAGE/COMMENT
|
|
.if defined(COMMENT${SUBPACKAGE}${FLAVOR_EXT})
|
|
_COMMENT=${COMMENT${SUBPACKAGE}${FLAVOR_EXT}}
|
|
.elif defined(COMMENT${SUBPACKAGE})
|
|
_COMMENT=${COMMENT${SUBPACKAGE}}
|
|
.endif
|
|
|
|
.if exists(${PKGDIR}/MESSAGE${SUBPACKAGE})
|
|
MESSAGE?= ${PKGDIR}/MESSAGE${SUBPACKAGE}
|
|
.endif
|
|
.if exists(${PKGDIR}/UNMESSAGE${SUBPACKAGE})
|
|
UNMESSAGE?= ${PKGDIR}/UNMESSAGE${SUBPACKAGE}
|
|
.endif
|
|
|
|
DESCR?= ${PKGDIR}/DESCR${SUBPACKAGE}
|
|
|
|
MTREE_FILE?=
|
|
MTREE_FILE+=${PORTSDIR}/infrastructure/db/fake.mtree
|
|
|
|
# Fill out package command, and package dependencies
|
|
_PKG_PREREQ= ${WRKPKG}/DESCR${SUBPACKAGE} ${WRKPKG}/COMMENT${SUBPACKAGE}
|
|
PKG_ARGS+= -c '${WRKPKG}/COMMENT${SUBPACKAGE}' -d ${WRKPKG}/DESCR${SUBPACKAGE}
|
|
PKG_ARGS+=-f ${PLIST} -p ${PREFIX}
|
|
.if exists(${PKGDIR}/INSTALL${SUBPACKAGE})
|
|
PKG_ARGS+= -i ${PKGDIR}/INSTALL${SUBPACKAGE}
|
|
.endif
|
|
.if exists(${PKGDIR}/DEINSTALL${SUBPACKAGE})
|
|
PKG_ARGS+= -k ${PKGDIR}/DEINSTALL${SUBPACKAGE}
|
|
.endif
|
|
.if exists(${PKGDIR}/REQ${SUBPACKAGE})
|
|
PKG_ARGS+= -r ${PKGDIR}/REQ${SUBPACKAGE}
|
|
.endif
|
|
.if exists(${PKGDIR}/MODULE${SUBPACKAGE}.pm)
|
|
PKG_ARGS+= -m ${PKGDIR}/MODULE${SUBPACKAGE}.pm
|
|
.endif
|
|
.if defined(MESSAGE)
|
|
PKG_ARGS+= -M ${MESSAGE}
|
|
.endif
|
|
.if defined(UNMESSAGE)
|
|
PKG_ARGS+= -U ${UNMESSAGE}
|
|
.endif
|
|
PKG_ARGS+= -B ${WRKINST}
|
|
PKG_ARGS+=-A'${PKG_ARCH${SUBPACKAGE}}'
|
|
.if ${LOCALBASE} != "/usr/local"
|
|
PKG_ARGS+=-L${LOCALBASE}
|
|
.endif
|
|
.if !defined(_COMMENT)
|
|
ERRORS+="Fatal: Missing comment."
|
|
.endif
|
|
|
|
CHMOD?= /bin/chmod
|
|
CHOWN?= /usr/sbin/chown
|
|
GUNZIP_CMD?= /usr/bin/gunzip -f
|
|
GZCAT?= /usr/bin/gzcat
|
|
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
|
|
SH?= /bin/sh
|
|
|
|
# Used to print all the '===>' style prompts - override this to turn them off.
|
|
ECHO_MSG?= echo
|
|
|
|
# basic master sites configuration
|
|
|
|
.if exists(${PORTSDIR}/infrastructure/db/network.conf)
|
|
.include "${PORTSDIR}/infrastructure/db/network.conf"
|
|
.else
|
|
.include "${PORTSDIR}/infrastructure/templates/network.conf.template"
|
|
.endif
|
|
|
|
# Empty declarations to avoid "variable XXX is recursive" errors
|
|
MASTER_SITES?=
|
|
# I guess we're in the master distribution business! :) As we gain mirror
|
|
# sites for distfiles, add them to this list.
|
|
.if !defined(MASTER_SITE_OVERRIDE)
|
|
MASTER_SITES:= ${MASTER_SITES} ${MASTER_SITE_BACKUP}
|
|
.else
|
|
MASTER_SITES:= ${MASTER_SITE_OVERRIDE} ${MASTER_SITES}
|
|
.endif
|
|
|
|
# _SITE_SELECTOR chooses the value of sites based on select.
|
|
_SITE_SELECTOR=case $$select in
|
|
|
|
|
|
.for _I in 0 1 2 3 4 5 6 7 8 9
|
|
. if defined(MASTER_SITES${_I})
|
|
. if !defined(MASTER_SITE_OVERRIDE)
|
|
MASTER_SITES${_I}:= ${MASTER_SITES${_I}} ${MASTER_SITE_BACKUP}
|
|
. else
|
|
MASTER_SITES${_I}:= ${MASTER_SITE_OVERRIDE} ${MASTER_SITES${_I}}
|
|
. endif
|
|
_SITE_SELECTOR+=*:${_I}) sites="${MASTER_SITES${_I}}";;
|
|
. else
|
|
_SITE_SELECTOR+=*:${_I}) echo >&2 "Error: MASTER_SITES${_I} not defined";;
|
|
. endif
|
|
.endfor
|
|
_SITE_SELECTOR+=*) sites="${MASTER_SITES}";; esac
|
|
|
|
|
|
# OpenBSD code to handle ports distfiles on a CDROM.
|
|
#
|
|
#CDROM_SITE?= /cdrom/distfiles/${DIST_SUBDIR}
|
|
CDROM_SITE?=
|
|
|
|
.if !empty(CDROM_SITE)
|
|
. if defined(FETCH_SYMLINK_DISTFILES)
|
|
_CDROM_OVERRIDE=if ln -s ${CDROM_SITE}/$$f .; then exit 0; fi
|
|
. else
|
|
_CDROM_OVERRIDE=if cp -f ${CDROM_SITE}/$$f .; then exit 0; fi
|
|
. endif
|
|
.else
|
|
_CDROM_OVERRIDE=:
|
|
.endif
|
|
|
|
EXTRACT_SUFX?= .tar.gz
|
|
|
|
DISTFILES?= ${DISTNAME}${EXTRACT_SUFX}
|
|
|
|
_EVERYTHING=${DISTFILES}
|
|
_DISTFILES= ${DISTFILES:C/:[0-9]$//}
|
|
ALLFILES= ${_DISTFILES}
|
|
|
|
.if defined(PATCHFILES)
|
|
_PATCHFILES=${PATCHFILES:C/:[0-9]$//}
|
|
_EVERYTHING+=${PATCHFILES}
|
|
ALLFILES+= ${_PATCHFILES}
|
|
.endif
|
|
|
|
.if make(makesum) || make(addsum) || defined(__FETCH_ALL)
|
|
. if defined(SUPDISTFILES)
|
|
_EVERYTHING+= ${SUPDISTFILES}
|
|
ALLFILES+= ${SUPDISTFILES:C/:[0-9]$//}
|
|
. endif
|
|
.endif
|
|
|
|
__CKSUMFILES=
|
|
# First, remove duplicates
|
|
.for _file in ${ALLFILES}
|
|
. if empty(__CKSUMFILES:M${_file})
|
|
__CKSUMFILES+=${_file}
|
|
. endif
|
|
.endfor
|
|
ALLFILES:=${__CKSUMFILES}
|
|
|
|
.if defined(IGNOREFILES)
|
|
ERRORS+= "Fatal: don't use IGNOREFILES"
|
|
.endif
|
|
|
|
# List of all files, with ${DIST_SUBDIR} in front. Used for checksum.
|
|
.if !empty(DIST_SUBDIR)
|
|
_CKSUMFILES= ${__CKSUMFILES:S/^/${DIST_SUBDIR}\//}
|
|
.else
|
|
_CKSUMFILES= ${__CKSUMFILES}
|
|
.endif
|
|
|
|
# This is what is actually going to be extracted, and is overridable
|
|
# by user.
|
|
EXTRACT_ONLY?= ${_DISTFILES}
|
|
|
|
# okay, time for some guess work
|
|
.if !empty(EXTRACT_ONLY:M*.zip)
|
|
_USE_ZIP?= Yes
|
|
.endif
|
|
.if !empty(EXTRACT_ONLY:M*.tar.bz2) || (defined(PATCHFILES) && !empty(_PATCHFILES:M*.bz2))
|
|
_USE_BZIP2?= Yes
|
|
.endif
|
|
_USE_ZIP?= No
|
|
_USE_BZIP2?= No
|
|
|
|
EXTRACT_CASES?=
|
|
|
|
_PERL_FIX_SHAR?=perl -ne 'print if $$s || ($$s = m:^\#(\!\s*/bin/sh\s*| This is a shell archive):)'
|
|
|
|
# XXX note that we DON'T set EXTRACT_SUFX.
|
|
.if ${_USE_ZIP:L} != "no"
|
|
BUILD_DEPENDS+= :unzip-*:archivers/unzip
|
|
EXTRACT_CASES+= *.zip) ${UNZIP} -oq ${FULLDISTDIR}/$$archive -d ${WRKDIR};;
|
|
.endif
|
|
.if ${_USE_BZIP2:L} != "no"
|
|
BUILD_DEPENDS+= :bzip2-*:archivers/bzip2
|
|
EXTRACT_CASES+= *.tar.bz2) ${BZIP2} -dc ${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
.endif
|
|
EXTRACT_CASES+= *.tar) ${TAR} xf ${FULLDISTDIR}/$$archive;;
|
|
EXTRACT_CASES+= *.shar.gz|*.shar.Z|*.sh.gz|*.sh.Z) ${GZIP_CMD} -dc ${FULLDISTDIR}/$$archive | ${_PERL_FIX_SHAR} | /bin/sh;;
|
|
EXTRACT_CASES+= *.shar | *.sh) ${_PERL_FIX_SHAR} ${FULLDISTDIR}/$$archive | /bin/sh;;
|
|
EXTRACT_CASES+= *.tar.gz) ${GZIP_CMD} -dc ${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
EXTRACT_CASES+= *.gz) ${GZIP_CMD} -dc ${FULLDISTDIR}/$$archive >`basename $$archive .gz`;;
|
|
EXTRACT_CASES+= *) ${GZIP_CMD} -dc ${FULLDISTDIR}/$$archive | ${TAR} xf -;;
|
|
|
|
PATCH_CASES?=
|
|
.if ${_USE_BZIP2:L} != "no"
|
|
PATCH_CASES+= *.bz2) ${BZIP2} -dc $$patchfile | ${PATCH} ${PATCH_DIST_ARGS};;
|
|
.endif
|
|
PATCH_CASES+= *.Z|*.gz) ${GZCAT} $$patchfile | ${PATCH} ${PATCH_DIST_ARGS};;
|
|
PATCH_CASES+= *) ${PATCH} ${PATCH_DIST_ARGS} < $$patchfile;;
|
|
|
|
# Documentation
|
|
MAINTAINER?= The OpenBSD ports mailing-list <ports@openbsd.org>
|
|
|
|
.if !defined(CATEGORIES)
|
|
ERRORS+= "Fatal: CATEGORIES is mandatory."
|
|
.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}
|
|
|
|
.if ${NO_SHARED_LIBS:L} == "yes"
|
|
CONFIGURE_SHARED?= --disable-shared
|
|
.else
|
|
CONFIGURE_SHARED?= --enable-shared
|
|
.endif
|
|
|
|
USE_X11?=No
|
|
|
|
FETCH_MANUALLY?=No
|
|
.if ${FETCH_MANUALLY:L} != "no"
|
|
_ALLFILES_PRESENT=Yes
|
|
. for _F in ${ALLFILES:S@^@${FULLDISTDIR}/@}
|
|
. if !exists(${_F})
|
|
_ALLFILES_PRESENT=No
|
|
. endif
|
|
. endfor
|
|
. if ${_ALLFILES_PRESENT:L} == "no"
|
|
IS_INTERACTIVE=Yes
|
|
. endif
|
|
.endif
|
|
|
|
################################################################
|
|
# Many ways to disable a port.
|
|
#
|
|
# 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.
|
|
################################################################
|
|
|
|
.if !defined(NO_IGNORE) && !defined(DESCRIBE_TARGET)
|
|
. if (defined(REGRESS_IS_INTERACTIVE) && defined(BATCH))
|
|
_IGNORE_REGRESS= "has interactive tests"
|
|
. elif (!defined(REGRESS_IS_INTERACTIVE) && defined(INTERACTIVE))
|
|
_IGNORE_REGRESS= "does not have interactive tests"
|
|
. endif
|
|
. if (defined(IS_INTERACTIVE) && defined(BATCH))
|
|
IGNORE= "is an interactive port"
|
|
. elif (!defined(IS_INTERACTIVE) && defined(INTERACTIVE))
|
|
IGNORE= "is not an interactive port"
|
|
. elif ${USE_X11:L} == "yes" && !exists(${X11BASE})
|
|
IGNORE= "uses X11, but ${X11BASE} not found"
|
|
. elif defined(ONLY_FOR_ARCHS)
|
|
. for __ARCH in ${MACHINE_ARCH} ${ARCH}
|
|
. if !empty(ONLY_FOR_ARCHS:M${__ARCH})
|
|
_ARCH_OK=1
|
|
. endif
|
|
. endfor
|
|
. if !defined(_ARCH_OK)
|
|
. if ${MACHINE_ARCH} == "${ARCH}"
|
|
IGNORE= "is only for ${ONLY_FOR_ARCHS}, not ${MACHINE_ARCH}"
|
|
. else
|
|
IGNORE= "is only for ${ONLY_FOR_ARCHS}, not ${MACHINE_ARCH} \(${ARCH}\)"
|
|
. endif
|
|
. endif
|
|
. elif defined(NOT_FOR_ARCHS)
|
|
. for __ARCH in ${MACHINE_ARCH} ${ARCH}
|
|
. if !empty(NOT_FOR_ARCHS:M${__ARCH})
|
|
IGNORE= "is not for ${NOT_FOR_ARCHS}"
|
|
. endif
|
|
. endfor
|
|
. elif ${SHARED_ONLY:L} == "yes" && ${NO_SHARED_LIBS:L} == "yes"
|
|
IGNORE="requires shared libraries"
|
|
. endif
|
|
.endif # NO_IGNORE
|
|
|
|
.if !defined(NO_IGNORE)
|
|
. if defined(BROKEN)
|
|
IGNORE= "is marked as broken: ${BROKEN}"
|
|
. elif defined(COMES_WITH)
|
|
IGNORE= "-- ${FULLPKGNAME${SUBPACKAGE}:C/-[0-9].*//g} comes with ${OPSYS} as of release ${COMES_WITH}"
|
|
. endif
|
|
.endif
|
|
|
|
.if !defined(DEPENDS_TARGET)
|
|
. if make(reinstall)
|
|
DEPENDS_TARGET= reinstall
|
|
. else
|
|
DEPENDS_TARGET= install
|
|
. endif
|
|
.endif
|
|
|
|
################################################################
|
|
# Dependency checking
|
|
################################################################
|
|
|
|
# Various dependency styles
|
|
|
|
_build_depends_fragment= \
|
|
if pkg_info -q -e "$$pkg"; then \
|
|
found=true; \
|
|
fi
|
|
_run_depends_fragment=${_build_depends_fragment}
|
|
|
|
_regress_depends_fragment=${_build_depends_fragment}
|
|
|
|
.if ${NO_SHARED_LIBS:L} == "yes"
|
|
_noshared=-noshared
|
|
.else
|
|
_noshared=
|
|
.endif
|
|
|
|
_libresolve_fragment = \
|
|
case "$$d" in \
|
|
*/*) shdir="${LOCALBASE}/$${d%/*}";; \
|
|
*) shdir="${LOCALBASE}/lib";; \
|
|
esac; \
|
|
check=`eval $$listlibs 2>/dev/null| LOCALBASE=${LOCALBASE} X11BASE=${X11BASE} perl \
|
|
${PORTSDIR}/infrastructure/build/resolve-lib ${_noshared} $$d` \
|
|
|| check=Failed
|
|
|
|
_syslibresolve_fragment = \
|
|
case "$$d" in \
|
|
/*) shdir="$${d%/*}/";; \
|
|
*/*) shdir="${DEPBASE}/$${d%/*}";; \
|
|
*) shdir="${DEPBASE}/lib"; listlibs="$$listlibs /usr/lib/lib* ${X11BASE}/lib/lib*";; \
|
|
esac; \
|
|
check=`eval $$listlibs 2>/dev/null| LOCALBASE=${LOCALBASE} X11BASE=${X11BASE} perl \
|
|
${PORTSDIR}/infrastructure/build/resolve-lib ${_noshared} $$d` \
|
|
|| check=Failed
|
|
|
|
_lib_depends_fragment = \
|
|
if $$defaulted; then \
|
|
pkg=`echo $$pkg|${_version2default}`; \
|
|
fi; \
|
|
what="$$pkg"; \
|
|
if pkg_info -q -e "$$pkg"; then \
|
|
found=true; \
|
|
fi
|
|
|
|
.if (${FAKE:L} == "lib" || ${FAKE:L} == "all") && ${USE_FAKE_LIB:L} == "yes"
|
|
PORT_LD_LIBRARY_PATH=${DEPBASE}/lib:${LOCALBASE}/lib:${X11BASE}/lib:/usr
|
|
_set_ld_library_path=export LD_LIBRARY_PATH=${PORT_LD_LIBRARY_PATH}
|
|
MAKE_ENV+=LD_LIBRARY_PATH=${PORT_LD_LIBRARY_PATH}
|
|
CONFIGURE_ENV+=LD_LIBRARY_PATH=${PORT_LD_LIBRARY_PATH}
|
|
DEPBASE=${DEPDIR}${LOCALBASE}
|
|
DEPDIR?=${WRKDIR}/dependencies
|
|
_lib_depends_target=pseudofake
|
|
.else
|
|
PORT_LD_LIBRARY_PATH=${LOCALBASE}/lib:${X11BASE}/lib:/usr
|
|
_set_ld_library_path=:
|
|
DEPBASE=${LOCALBASE}
|
|
DEPDIR=
|
|
.endif
|
|
.if ${FAKE:L} == "all" && ${USE_FAKE_LIB:L} == "yes"
|
|
_build_depends_target=pseudofake
|
|
.endif
|
|
|
|
_lib_depends_target?=${DEPENDS_TARGET}
|
|
_build_depends_target?=${DEPENDS_TARGET}
|
|
_run_depends_target=${DEPENDS_TARGET}
|
|
_regress_depends_target=${DEPENDS_TARGET}
|
|
|
|
.if ${FORCE_UPDATE:L} == "yes" || ${FORCE_UPDATE:L} == "hard"
|
|
_force_update_fragment=eval $$toset ${MAKE} subupdate
|
|
_PKG_ADD_FORCE=-F update -F updatedepends -r
|
|
. if ${FORCE_UPDATE:L} == "hard"
|
|
_PKG_ADD_FORCE+= -F installed
|
|
. endif
|
|
.else
|
|
_force_update_fragment=:
|
|
_PKG_ADD_FORCE=
|
|
.endif
|
|
|
|
_FULL_PACKAGE_NAME?=No
|
|
|
|
.for _DEP in BUILD RUN LIB REGRESS
|
|
_DEP${_DEP}_COOKIES=
|
|
. if ${NO_DEPENDS:L} == "no"
|
|
. for _i in ${${_DEP}_DEPENDS}
|
|
_DEP${_DEP}_COOKIES+=${WRKDIR}/.dep${_i:C,[|:./<=>*],-,g}
|
|
. endfor
|
|
. endif
|
|
.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} && ${_SYSTRACE_CMD} ${SETENV} \
|
|
CC="${CC}" ac_cv_path_CC="${CC}" CFLAGS="${CFLAGS:C/ *$//}" \
|
|
CXX="${CXX}" ac_cv_path_CXX="${CXX}" CXXFLAGS="${CXXFLAGS:C/ *$//}" \
|
|
INSTALL="/usr/bin/install -c -o ${BINOWN} -g ${BINGRP}" \
|
|
ac_given_INSTALL="/usr/bin/install -c -o ${BINOWN} -g ${BINGRP}" \
|
|
INSTALL_PROGRAM="${INSTALL_PROGRAM}" INSTALL_MAN="${INSTALL_MAN}" \
|
|
INSTALL_SCRIPT="${INSTALL_SCRIPT}" INSTALL_DATA="${INSTALL_DATA}" \
|
|
YACC="${YACC}" \
|
|
${CONFIGURE_ENV} ${_CONFIGURE_SCRIPT} ${CONFIGURE_ARGS}
|
|
|
|
VMEM_WARNING?= No
|
|
|
|
_FAKE_SETUP=TRUEPREFIX=${PREFIX} PREFIX=${WRKINST}${PREFIX} ${DESTDIRNAME}=${WRKINST}
|
|
|
|
_CLEANDEPENDS?=Yes
|
|
|
|
# mirroring utilities
|
|
.if !empty(DIST_SUBDIR)
|
|
_ALLFILES=${ALLFILES:S/^/${DIST_SUBDIR}\//}
|
|
.else
|
|
_ALLFILES=${ALLFILES}
|
|
.endif
|
|
|
|
.if defined(MULTI_PACKAGES)
|
|
. for _S in ${MULTI_PACKAGES}
|
|
_FMN+= ${PKGPATH}/${FULLPKGNAME${_S}}
|
|
. endfor
|
|
.endif
|
|
|
|
# Internal variables, used by dependencies targets
|
|
# Only keep pkg:dir spec
|
|
.if defined(LIB_DEPENDS) && ${NO_SHARED_LIBS:L} != "yes"
|
|
_ALWAYS_DEP2 = ${LIB_DEPENDS:C/^[^:]*:([^:]*:[^:]*).*$/\1/}
|
|
_ALWAYS_DEP= ${_ALWAYS_DEP2:C/[^:]*://}
|
|
_DEPLIBS=${LIB_DEPENDS:C/:.*//:S/,/ /g}
|
|
.else
|
|
_ALWAYS_DEP2=
|
|
_ALWAYS_DEP=
|
|
_DEPLIBS=
|
|
.endif
|
|
|
|
.if defined(WANTLIB)
|
|
_DEPLIBS+=${WANTLIB}
|
|
.endif
|
|
|
|
.if defined(RUN_DEPENDS)
|
|
_RUN_DEP2 = ${RUN_DEPENDS:C/^[^:]*:([^:]*:[^:]*).*$/\1/}
|
|
_RUN_DEP = ${_RUN_DEP2:C/[^:]*://}
|
|
.else
|
|
_RUN_DEP2=
|
|
_RUN_DEP=
|
|
.endif
|
|
|
|
.if defined(REGRESS_DEPENDS)
|
|
_REGRESS_DEP2 = ${REGRESS_DEPENDS:C/^[^:]*:([^:]*:[^:]*).*$/\1/}
|
|
_REGRESS_DEP = ${_REGRESS_DEP2:C/[^:]*://}
|
|
.else
|
|
_REGRESS_DEP2=
|
|
_REGRESS_DEP=
|
|
.endif
|
|
|
|
_DEPlibs_COOKIES=
|
|
.if !empty(_DEPLIBS) && ${NO_DEPENDS:L} == "no"
|
|
. for i in ${WANTLIB:C,[|:./<=>*],-,g}
|
|
_DEPlibs_COOKIES+=${WRKDIR}/.wantlib-$i
|
|
. endfor
|
|
_DEPlibs_COOKIE=${WRKDIR}/.wantlibs
|
|
.else
|
|
_DEPlibs_COOKIE=
|
|
.endif
|
|
|
|
|
|
.if defined(BUILD_DEPENDS)
|
|
_BUILD_DEP2 = ${BUILD_DEPENDS:C/^[^:]*:([^:]*:[^:]*).*$/\1/}
|
|
_BUILD_DEP = ${_BUILD_DEP2:C/[^:]*://}
|
|
.else
|
|
_BUILD_DEP2=
|
|
_BUILD_DEP=
|
|
.endif
|
|
|
|
_LIB_DEP2= ${LIB_DEPENDS}
|
|
|
|
README_NAME?= ${TEMPLATES}/README.port
|
|
|
|
REORDER_DEPENDENCIES?=
|
|
|
|
# Lock infrastructure:
|
|
# nothing happens unless LOCKDIR is defined to a non-empty value
|
|
|
|
LOCKDIR?=
|
|
LOCK_CMD?= perl ${PORTSDIR}/infrastructure/build/dolock
|
|
UNLOCK_CMD?=rm -f
|
|
_LOCKS_HELD?=
|
|
LOCK_VERBOSE?=No
|
|
.if !empty(LOCKDIR)
|
|
. if ${LOCK_VERBOSE:L} == "yes"
|
|
_LOCK=echo "Locking $$lock from $@"; ${LOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
_UNLOCK=echo "Unlocking $$lock from $@"; ${UNLOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
. else
|
|
_LOCK=${LOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
_UNLOCK=${UNLOCK_CMD} ${LOCKDIR}/$$lock.lock
|
|
. endif
|
|
. if ${SEPARATE_BUILD:L:Mflavored}
|
|
_LOCKNAME=${PKGNAME}
|
|
. else
|
|
_LOCKNAME=${FULLPKGNAME}
|
|
. 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}; trap '${_UNLOCK}' 0 1 2 3 13 15
|
|
|
|
.endif
|
|
_SIMPLE_LOCK?=:
|
|
_DO_LOCK?=:
|
|
|
|
_size_fragment=wc -c $$file 2>/dev/null| awk '{print "SIZE (" $$2 ") = " $$1}'
|
|
|
|
# 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}
|
|
|
|
_version2default= sed -e 's,-[0-9].*,-*,'
|
|
|
|
_grab_libs_from_plist= sed -n -e '/^@lib /{ s///; p; }' \
|
|
-e '/^@file .*\/lib\/lib.*\.a$$/{ s/^@file //; p; }'
|
|
|
|
|
|
###
|
|
### end of variable setup. Only targets now
|
|
###
|
|
|
|
|
|
${_CACHE_REPO}/${_PKGFILE}:
|
|
@mkdir -p ${@D}
|
|
@${ECHO_MSG} -n "===> Looking for ${_PKGFILE} in \$$PKG_PATH - "
|
|
@if ${SETENV} PKG_CACHE=${_CACHE_REPO} PKG_PATH=${_CACHE_REPO}:${_PKG_REPO}:${PACKAGE_REPOSITORY}/${NO_ARCH}/:${PKG_PATH} PKG_TMPDIR=${PKG_TMPDIR} pkg_add -n -q ${_PKG_ADD_FORCE} ${_PKGFILE} >/dev/null 2>&1; then \
|
|
${ECHO_MSG} "found"; \
|
|
exit 0; \
|
|
else \
|
|
${ECHO_MSG} "not found"; \
|
|
exit 1; \
|
|
fi
|
|
|
|
${_PACKAGE_COOKIE}:
|
|
.if !defined(PACKAGING)
|
|
@echo "Error: can't make $@ without PACKAGING set"; exit 1
|
|
.endif
|
|
@mkdir -p ${@D}
|
|
.if ${FETCH_PACKAGES:L} == "yes" && !defined(_TRIED_FETCHING)
|
|
@f=${_CACHE_REPO}/${_PKGFILE}; \
|
|
cd ${.CURDIR} && ${MAKE} $$f && \
|
|
{ ln $$f $@ 2>/dev/null || cp -p $$f $@ ; } || \
|
|
cd ${.CURDIR} && ${MAKE} _TRIED_FETCHING=Yes $@
|
|
.else
|
|
@cd ${.CURDIR} && unset PACKAGING || true && exec ${MAKE} ${_PACKAGE_COOKIE_DEPS} ${_PKG_PREREQ}
|
|
. if target(pre-package)
|
|
@cd ${.CURDIR} && exec ${MAKE} pre-package
|
|
. endif
|
|
. if target(do-package)
|
|
@cd ${.CURDIR} && exec ${MAKE} do-package
|
|
. else
|
|
# What PACKAGE normally does:
|
|
@${ECHO_MSG} "===> Building package for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@${ECHO_MSG} "Create ${_PACKAGE_COOKIE}"
|
|
@cd ${.CURDIR} && \
|
|
deps=`${MAKE} _print-package-args` && \
|
|
if ${SUDO} ${PKG_CMD} `echo "$$deps"|sort -u` ${PKG_ARGS} ${_PACKAGE_COOKIE}; then \
|
|
mode=`id -u`:`id -g`; ${SUDO} ${CHOWN} $${mode} ${_PACKAGE_COOKIE}; \
|
|
if ${_register_plist}; then \
|
|
exit 0; \
|
|
fi; \
|
|
fi && \
|
|
${SUDO} ${MAKE} _internal-clean=package && \
|
|
exit 1
|
|
# End of PACKAGE.
|
|
. endif
|
|
. if target(post-package)
|
|
@cd ${.CURDIR} && exec ${MAKE} post-package
|
|
. endif
|
|
@rm -f ${_BULK_COOKIE} ${_UPDATE_COOKIE}
|
|
.endif
|
|
|
|
.PRECIOUS: ${_PACKAGE_COOKIES} ${_INSTALL_COOKIE}
|
|
|
|
${_SYSTRACE_COOKIE}: ${_WRKDIR_COOKIE}
|
|
@rm -f $@
|
|
.for _i in ${_SYSTRACE_POLICIES}
|
|
@echo "Policy: ${_i}, Emulation: native" >> $@
|
|
@if [ -f ${.CURDIR}/systrace.filter ]; then \
|
|
sed ${_SYSTRACE_SED_SUBST} ${.CURDIR}/systrace.filter >> $@; \
|
|
fi
|
|
@sed ${_SYSTRACE_SED_SUBST} ${SYSTRACE_FILTER} >> $@
|
|
.endfor
|
|
@if [ -f ${.CURDIR}/systrace.policy ]; then \
|
|
sed ${_SYSTRACE_SED_SUBST} ${.CURDIR}/systrace.policy >> $@; \
|
|
fi
|
|
|
|
# create the packing stuff from source
|
|
${WRKPKG}/COMMENT${SUBPACKAGE}:
|
|
@echo ${_COMMENT} >$@
|
|
|
|
${WRKPKG}/DESCR${SUBPACKAGE}: ${DESCR}
|
|
@${_SED_SUBST} <$? >$@.tmp && mv -f $@.tmp $@
|
|
@echo "\nMaintainer: ${MAINTAINER}" >>$@
|
|
.if defined(HOMEPAGE)
|
|
@fgrep -q '$${HOMEPAGE}' $? || echo "\nWWW: ${HOMEPAGE}" >>$@
|
|
.endif
|
|
|
|
${WRKPKG}/mtree.spec: ${MTREE_FILE}
|
|
@${_SED_SUBST} ${MTREE_FILE}>$@.tmp && mv -f $@.tmp $@
|
|
|
|
|
|
makesum: fetch-all
|
|
.if !defined(NO_CHECKSUM)
|
|
@rm -f ${CHECKSUM_FILE}
|
|
@cd ${DISTDIR} && \
|
|
for cipher in ${_CIPHERS}; do \
|
|
$$cipher ${_CKSUMFILES} >> ${CHECKSUM_FILE}; \
|
|
done
|
|
@cd ${DISTDIR} && \
|
|
for file in ${_CKSUMFILES}; do \
|
|
${_size_fragment} >> ${CHECKSUM_FILE}; \
|
|
done
|
|
@sort -u -o ${CHECKSUM_FILE} ${CHECKSUM_FILE}
|
|
.endif
|
|
|
|
|
|
addsum: fetch-all
|
|
.if !defined(NO_CHECKSUM)
|
|
@touch ${CHECKSUM_FILE}
|
|
@cd ${DISTDIR} && \
|
|
for cipher in ${_CIPHERS}; do \
|
|
$$cipher ${_CKSUMFILES} >> ${CHECKSUM_FILE}; \
|
|
done
|
|
@cd ${DISTDIR} && \
|
|
for file in ${_CKSUMFILES}; do \
|
|
${_size_fragment} >> ${CHECKSUM_FILE}; \
|
|
done
|
|
@sort -u -o ${CHECKSUM_FILE} ${CHECKSUM_FILE}
|
|
@if [ `sed -e 's/\=.*$$//' ${CHECKSUM_FILE} | uniq -d | wc -l` -ne 0 ]; then \
|
|
echo "Inconsistent checksum in ${CHECKSUM_FILE}"; \
|
|
exit 1; \
|
|
else \
|
|
${ECHO_MSG} "${CHECKSUM_FILE} updated okay, don't forget to remove cruft"; \
|
|
fi
|
|
.endif
|
|
|
|
################################################################
|
|
# Dependency checking
|
|
################################################################
|
|
|
|
|
|
|
|
_internal-depends: _internal-lib-depends _internal-build-depends \
|
|
_internal-run-depends _internal-libs-depends _internal-regress-depends
|
|
|
|
# and the rules for the actual dependencies
|
|
|
|
_print-packagename:
|
|
.if ${_FULL_PACKAGE_NAME:L} == "yes"
|
|
@echo '${PKGPATH}/${FULLPKGNAME${SUBPACKAGE}}'
|
|
.else
|
|
@echo ${FULLPKGNAME${SUBPACKAGE}}
|
|
.endif
|
|
|
|
.for _DEP in BUILD RUN LIB REGRESS
|
|
. if ${NO_DEPENDS:L} == "no"
|
|
. for _i in ${${_DEP}_DEPENDS}
|
|
${WRKDIR}/.dep${_i:C,[|:./<=>*],-,g}: ${_WRKDIR_COOKIE}
|
|
@unset PACKAGING DEPENDS_TARGET _MASTER WRKDIR|| true; \
|
|
echo '${_i}'|{ \
|
|
IFS=:; read dep pkg subdir target; \
|
|
extra_msg="(${_DEP}_DEPENDS ${_i})"; \
|
|
${_flavor_fragment}; defaulted=false; \
|
|
case "X$$target" in X) target=${_${_DEP:L}_depends_target};; esac; \
|
|
case "X$$target" in \
|
|
Xinstall|Xreinstall) early_exit=false;; \
|
|
Xpackage|Xfake) early_exit=true;; \
|
|
Xpseudofake) early_exit=true; dep="/fake";; \
|
|
*) \
|
|
early_exit=true; mkdir -p ${WRKDIR}/$$dir; \
|
|
toset="$$toset _MASTER='[${FULLPKGNAME${SUBPACKAGE}}]${_MASTER}' WRKDIR=${WRKDIR}/$$dir"; \
|
|
dep="/nonexistent";; \
|
|
esac; \
|
|
toset="$$toset _SOLVING_DEP=Yes"; \
|
|
case "X$$pkg" in X) \
|
|
if pkg=`eval $$toset ${MAKE} _print-packagename`; \
|
|
then \
|
|
defaulted=true; \
|
|
else \
|
|
${ECHO_MSG} "===> Error in evaluating dependency ${_i}"; \
|
|
exit 1; \
|
|
fi;; esac; \
|
|
for abort in false false true; do \
|
|
if $$abort; then \
|
|
${ECHO_MSG} "Dependency check failed"; \
|
|
exit 1; \
|
|
fi; \
|
|
found=false; \
|
|
what=$$pkg; \
|
|
case "$$dep" in \
|
|
"/nonexistent") ;; \
|
|
"/fake") \
|
|
${ECHO_MSG} "===> Verifying package for $$what in $$dir"; \
|
|
if eval $$toset ${MAKE} package; then \
|
|
${ECHO_MSG} "===> Returning to build of ${FULLPKGNAME${SUBPACKAGE}}${_MASTER}"; \
|
|
else \
|
|
${ECHO_MSG} "===> Error in evaluating dependency ${_i}"; \
|
|
${REPORT_PROBLEM}; \
|
|
exit 1; \
|
|
fi; \
|
|
$$defaulted || pkg=`eval $$toset ${MAKE} _print-packagename`; \
|
|
mkdir -p ${DEPDIR}/pkgdb ${DEPDIR}/usr ${DEPDIR}/usr/X11R6; \
|
|
ln -sfh /usr/lib ${DEPDIR}/usr/lib; \
|
|
ln -sfh /usr/X11R6/lib ${DEPDIR}/usr/X11R6/lib; \
|
|
test -e ${DEPDIR}/pkgdb/$$pkg && exit 0; \
|
|
cd ${_PKG_REPO} && PKG_DBDIR=${DEPDIR}/pkgdb PKG_PATH=${_PKG_REPO} pkg_add -F nonroot -Q ${DEPDIR} $$pkg && exit 0;; \
|
|
*) \
|
|
$$early_exit || ${_force_update_fragment}; \
|
|
${_${_DEP:L}_depends_fragment}; \
|
|
if $$found; then \
|
|
${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} depends on: $$what - found"; \
|
|
break; \
|
|
else \
|
|
: $${msg:= not found}; \
|
|
${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} depends on: $$what -$$msg"; \
|
|
fi;; \
|
|
esac; \
|
|
${ECHO_MSG} "===> Verifying $$target for $$what in $$dir"; \
|
|
if eval $$toset ${MAKE} $$target; then \
|
|
${ECHO_MSG} "===> Returning to build of ${FULLPKGNAME${SUBPACKAGE}}${_MASTER}"; \
|
|
else \
|
|
exit 1; \
|
|
fi; \
|
|
if $$early_exit; then \
|
|
break; \
|
|
fi; \
|
|
done; \
|
|
}
|
|
@mkdir -p ${WRKDIR} ${WRKDIR}/bin
|
|
@${_MAKE_COOKIE} $@
|
|
. endfor
|
|
. endif
|
|
_internal-${_DEP:L}-depends: ${_DEP${_DEP}_COOKIES}
|
|
.endfor
|
|
|
|
.if !empty(_DEPlibs_COOKIE)
|
|
${_DEPlibs_COOKIES}: ${_WRKDIR_COOKIE}
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
${_DEPlibs_COOKIE}: ${_DEPlibs_COOKIES} ${_DEPLIB_COOKIES} ${_DEPBUILD_COOKIES} ${_WRKDIR_COOKIE}
|
|
@${ECHO_MSG} "===> Verifying specs: ${_DEPLIBS}"
|
|
@listlibs="echo ${LOCALBASE}/lib/lib* /usr/lib/lib* ${X11BASE}/lib/lib*"; \
|
|
for d in ${_DEPLIBS:S/>/\>/g}; do \
|
|
case "$$d" in \
|
|
/*) listlibs="$$listlibs $${d%/*}/lib*";; \
|
|
*/*) listlibs="$$listlibs ${DEPBASE}/$${d%/*}/lib*";; \
|
|
esac; \
|
|
done; \
|
|
if found=`eval $$listlibs 2>/dev/null| \
|
|
LOCALBASE=${LOCALBASE} X11BASE=${X11BASE} perl \
|
|
${PORTSDIR}/infrastructure/build/resolve-lib ${_noshared} ${_DEPLIBS:S/>/\>/g}`; then \
|
|
line="===> found"; \
|
|
for k in $$found; do line="$$line $$k"; done; \
|
|
${ECHO_MSG} "$$line"; \
|
|
else \
|
|
echo 1>&2 "Fatal error"; \
|
|
exit 1; \
|
|
fi
|
|
@${_MAKE_COOKIE} $@
|
|
.endif
|
|
|
|
_internal-libs-depends: ${_DEPlibs_COOKIE}
|
|
|
|
.if defined(IGNORE) && !defined(NO_IGNORE)
|
|
_internal-fetch _internal-checksum _internal-extract _internal-patch \
|
|
_internal-configure _internal-all _internal-build _internal-install \
|
|
_internal-regress _internal-uninstall _internal-deinstall _internal-fake \
|
|
_internal-update _internal-plist _internal-package _internal-install-all \
|
|
_internal-update-plist update-patches _internal-subupdate \
|
|
dump-vars describe _internal-subpackage sublib-depends-check \
|
|
_internal-manpages-check:
|
|
. if !defined(IGNORE_SILENT)
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} ${IGNORE}."
|
|
. endif
|
|
|
|
.else
|
|
|
|
. if ${ELF_TOOLCHAIN:L} == "no"
|
|
_NEWLIB_DEPENDS_FLAGS=-o
|
|
. else
|
|
_NEWLIB_DEPENDS_FLAGS=
|
|
. endif
|
|
|
|
sublib-depends-check:
|
|
@cd ${.CURDIR} && exec ${MAKE} subpackage
|
|
@perl ${PORTSDIR}/infrastructure/package/check-newlib-depends \
|
|
${_NEWLIB_DEPENDS_FLAGS} -d ${_PKG_REPO} ${_PACKAGE_COOKIE}
|
|
|
|
_internal-manpages-check: ${_FAKE_COOKIE}
|
|
@cd ${WRKINST}${TRUEPREFIX}/man && \
|
|
${SUDO} /usr/libexec/makewhatis -p . && \
|
|
cat whatis.db
|
|
|
|
# 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.
|
|
#
|
|
# IMPORTANT: pre-fetch/do-fetch/post-fetch MUST be designed so that they
|
|
# can be run several times in a row.
|
|
|
|
_internal-fetch:
|
|
# See ports/infrastructure/templates/Makefile.template
|
|
@${ECHO_MSG} "===> Checking files for ${FULLPKGNAME}${_MASTER}"
|
|
. if target(pre-fetch)
|
|
@cd ${.CURDIR} && exec ${MAKE} pre-fetch
|
|
. endif
|
|
. if target(do-fetch)
|
|
@cd ${.CURDIR} && exec ${MAKE} do-fetch
|
|
. else
|
|
# What FETCH normally does:
|
|
. if !empty(ALLFILES)
|
|
@cd ${.CURDIR} && exec ${MAKE} ${ALLFILES:S@^@${FULLDISTDIR}/@}
|
|
. endif
|
|
# End of FETCH
|
|
. endif
|
|
. if target(post-fetch)
|
|
@cd ${.CURDIR} && exec ${MAKE} post-fetch
|
|
. endif
|
|
|
|
|
|
_internal-checksum: _internal-fetch
|
|
. if ! defined(NO_CHECKSUM)
|
|
@checksum_file=${CHECKSUM_FILE}; \
|
|
if [ -z "${DISTFILES}" ]; then \
|
|
${ECHO_MSG} ">> No distfiles."; \
|
|
elif [ ! -f $$checksum_file ]; then \
|
|
${ECHO_MSG} ">> No checksum file."; \
|
|
exit 1; \
|
|
else \
|
|
cd ${DISTDIR}; OK=true; list=''; \
|
|
for file in ${_CKSUMFILES}; do \
|
|
for cipher in ${PREFERRED_CIPHERS}; do \
|
|
set -- `grep -i "^$$cipher ($$file)" $$checksum_file` && break || \
|
|
${ECHO_MSG} ">> No $$cipher checksum recorded for $$file."; \
|
|
done; \
|
|
case "$$4" in \
|
|
"") \
|
|
${ECHO_MSG} ">> No checksum recorded for $$file."; \
|
|
OK=false;; \
|
|
"IGNORE") \
|
|
echo ">> Error: checksum for $$file is set to IGNORE in distinfo"; \
|
|
OK=false;; \
|
|
*) \
|
|
CKSUM=`$$cipher < $$file`; \
|
|
case "$$CKSUM" in \
|
|
"$$4") \
|
|
${ECHO_MSG} ">> Checksum OK for $$file. ($$cipher)";; \
|
|
*) \
|
|
echo ">> Checksum mismatch for $$file. ($$cipher)"; \
|
|
list="$$list $$file $$cipher $$4"; \
|
|
OK=false;; \
|
|
esac;; \
|
|
esac; \
|
|
done; \
|
|
set --; \
|
|
if ! $$OK; then \
|
|
if ${REFETCH}; then \
|
|
cd ${.CURDIR} && ${MAKE} _refetch _PROBLEMS="$$list"; \
|
|
else \
|
|
echo "Make sure the Makefile and checksum file ($$checksum_file)"; \
|
|
echo "are up to date. If you want to fetch a good copy of this"; \
|
|
echo "file from the OpenBSD main archive, type"; \
|
|
echo "\"make REFETCH=true [other args]\"."; \
|
|
exit 1; \
|
|
fi; \
|
|
fi ; \
|
|
fi
|
|
. endif
|
|
|
|
_refetch:
|
|
. for file cipher value in ${_PROBLEMS}
|
|
@rm ${DISTDIR}/${file}
|
|
@cd ${.CURDIR} && exec ${MAKE} ${DISTDIR}/${file} \
|
|
MASTER_SITE_OVERRIDE="ftp://ftp.openbsd.org/pub/OpenBSD/distfiles/${cipher}/${value}/"
|
|
. endfor
|
|
cd ${.CURDIR} && exec ${MAKE} _internal-checksum REFETCH=false
|
|
|
|
|
|
# The cookie's recipe hold the real rule for each of those targets.
|
|
|
|
_internal-extract: ${_EXTRACT_COOKIE}
|
|
_internal-patch: ${_DEPBUILD_COOKIES} ${_DEPLIB_COOKIES} ${_DEPlibs_COOKIE} \
|
|
${_PATCH_COOKIE}
|
|
_internal-distpatch: ${_DEPBUILD_COOKIES} ${_DEPLIB_COOKIES} ${_DEPlibs_COOKIE} \
|
|
${_DISTPATCH_COOKIE}
|
|
_internal-configure: ${_DEPBUILD_COOKIES} ${_DEPLIB_COOKIES} ${_DEPlibs_COOKIE} \
|
|
${_CONFIGURE_COOKIE}
|
|
_internal-build _internal-all: ${_DEPBUILD_COOKIES} ${_DEPLIB_COOKIES} \
|
|
${_DEPlibs_COOKIE} ${_BUILD_COOKIE}
|
|
_internal-install: ${_INSTALL_COOKIE}
|
|
_internal-fake: ${_FAKE_COOKIE}
|
|
_internal-subupdate: ${_UPDATE_COOKIE}
|
|
|
|
. if defined(_IGNORE_REGRESS)
|
|
_internal-regress:
|
|
. if !defined(IGNORE_SILENT)
|
|
@${ECHO_MSG} "===> ${FULLPKGNAME${SUBPACKAGE}}${_MASTER} ${_IGNORE_REGRESS}."
|
|
. endif
|
|
. else
|
|
_internal-regress: ${_BUILD_COOKIE} ${_DEPREGRESS_COOKIES} ${_REGRESS_COOKIE}
|
|
. endif
|
|
|
|
# packing list utilities. This generates a packing list from a recently
|
|
# installed port. Not perfect, but pretty close. The generated file
|
|
# will have to have some tweaks done by hand.
|
|
# Note: add @comment PACKAGE(arch=${MACHINE_ARCH}, opsys=${OPSYS}, vers=${OPSYS_VER})
|
|
# when port is installed or package created.
|
|
#
|
|
.if ${SHARED_ONLY:L} == "yes"
|
|
_do_libs_too=
|
|
.else
|
|
_do_libs_too=NO_SHARED_LIBS=Yes
|
|
.endif
|
|
|
|
_extra_prefixes=
|
|
.if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
_extra_prefixes+=PREFIX${_s}=`cd ${.CURDIR} && SUBPACKAGE=${_s} PACKAGING=${_s} ${MAKE} show=PREFIX`
|
|
. endfor
|
|
.endif
|
|
|
|
_internal-plist _internal-update-plist: _internal-fake
|
|
@${ECHO_MSG} "===> Updating plist for ${FULLPKGNAME}${_MASTER}"
|
|
@mkdir -p ${PKGDIR}
|
|
@DESTDIR=${WRKINST} PREFIX=${WRKINST}${PREFIX} \
|
|
TRUEPREFIX=${TRUEPREFIX} \
|
|
MTREE_FILE=${WRKPKG}/mtree.spec \
|
|
INSTALL_PRE_COOKIE=${_INSTALL_PRE_COOKIE} \
|
|
DEPPATHS="`${MAKE} run-dir-depends ${_do_libs_too}|${_sort_dependencies}`" \
|
|
MAKE="${MAKE}" \
|
|
PORTSDIR=${PORTSDIR} \
|
|
PLIST=${PLIST} \
|
|
PFRAG=${PKGDIR}/PFRAG \
|
|
FLAVORS='${FLAVORS}' MULTI_PACKAGES='${MULTI_PACKAGES}' \
|
|
OKAY_FILES='${_FAKE_COOKIE} ${_INSTALL_PRE_COOKIE}' \
|
|
SHARED_ONLY="${SHARED_ONLY}" \
|
|
OWNER=`id -u` \
|
|
GROUP=`id -g` \
|
|
${SUDO} perl ${PORTSDIR}/infrastructure/install/make-plist \
|
|
${_extra_prefixes} ${_tmpvars}
|
|
|
|
update-patches:
|
|
@toedit=`WRKDIST=${WRKDIST} PATCHDIR=${PATCHDIR} \
|
|
PATCH_LIST='${PATCH_LIST}' DIFF_ARGS='${DIFF_ARGS}' \
|
|
DISTORIG=${DISTORIG} PATCHORIG=${PATCHORIG} \
|
|
/bin/sh ${PORTSDIR}/infrastructure/build/update-patches`; \
|
|
case $$toedit in "");; \
|
|
*) read i?'edit patches: '; \
|
|
cd ${PATCHDIR} && $${VISUAL:-$${EDITOR:-/usr/bin/vi}} $$toedit;; esac
|
|
|
|
|
|
|
|
.endif # IGNORECMD
|
|
|
|
|
|
# Top-level targets redirect to the real _internal-target, along with locking
|
|
# if locking exists.
|
|
|
|
.for _t in extract patch distpatch configure build all install fake \
|
|
subupdate fetch checksum regress depends lib-depends build-depends \
|
|
run-depends regress-depends clean manpages-check \
|
|
plist update-plist update package install-all
|
|
. if defined(_LOCK)
|
|
${_t}:
|
|
@${_DO_LOCK}; cd ${.CURDIR} && ${MAKE} _internal-${_t}
|
|
. else
|
|
${_t}: _internal-${_t}
|
|
. endif
|
|
.endfor
|
|
|
|
subpackage:
|
|
@${_DO_LOCK}; cd ${.CURDIR} && PACKAGING='${SUBPACKAGE}' ${MAKE} _internal-subpackage
|
|
|
|
# Redirectors for top-level targets involving subpackages
|
|
.for _t _r in _internal-package-only _internal-subpackage \
|
|
describe subdescribe lib-depends-check sublib-depends-check \
|
|
dump-vars subdump-vars _internal-install-all _internal-install \
|
|
print-plist-all print-plist \
|
|
readmes _readme _internal-update _internal-subupdate
|
|
${_t}:
|
|
. if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M-main)
|
|
@cd ${.CURDIR} && SUBPACKAGE='' PACKAGING='' exec ${MAKE} ${_r}
|
|
. endif
|
|
. if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
@${ECHO_MSG} "===> ${PKGPATH}${FLAVOR_EXT:S/-/,/g},${_s}"
|
|
@cd ${.CURDIR} && SUBPACKAGE='${_s}' PACKAGING='${_s}' exec ${MAKE} ${_r}
|
|
. endfor
|
|
. endif
|
|
.endfor
|
|
|
|
|
|
_internal-package:
|
|
.if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M-main)
|
|
@cd ${.CURDIR} && SUBPACKAGE='' PACKAGING='' exec ${MAKE} _internal-subpackage
|
|
.endif
|
|
.if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
@cd ${.CURDIR} && SUBPACKAGE='${_s}' PACKAGING='${_s}' exec ${MAKE} _internal-subpackage
|
|
. endfor
|
|
.endif
|
|
.if ${BULK_${PKGPATH}:L} == "yes"
|
|
@cd ${.CURDIR} && exec ${MAKE} ${_BULK_COOKIE}
|
|
.endif
|
|
|
|
|
|
${_BULK_COOKIE}:
|
|
@cd ${.CURDIR} && exec ${MAKE} _internal-package-only
|
|
@mkdir -p ${BULK_COOKIES_DIR}
|
|
.for _i in ${BULK_TARGETS_${PKGPATH}}
|
|
@${ECHO_MSG} "===> Running ${_i}"
|
|
@cd ${.CURDIR} && exec ${MAKE} ${_i} ${BULK_FLAGS}
|
|
.endfor
|
|
.if !empty(BULK_DO_${PKGPATH})
|
|
@${BULK_DO_${PKGPATH}}
|
|
.endif
|
|
@cd ${.CURDIR} && exec ${SUDO} ${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}:
|
|
@rm -rf ${WRKDIR}
|
|
@mkdir -p ${WRKDIR} ${WRKDIR}/bin ${DEPDIR}
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
${_EXTRACT_COOKIE}: ${_WRKDIR_COOKIE} ${_SYSTRACE_COOKIE}
|
|
@cd ${.CURDIR} && exec ${MAKE} _internal-checksum _internal-build-depends _internal-lib-depends _internal-libs-depends
|
|
@${ECHO_MSG} "===> Extracting for ${FULLPKGNAME}${_MASTER}"
|
|
.if target(pre-extract)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} pre-extract
|
|
.endif
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} do-extract
|
|
.if target(post-extract)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} post-extract
|
|
.endif
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
.if !target(do-extract)
|
|
do-extract:
|
|
# What EXTRACT normally does:
|
|
@PATH=${PORTPATH}; set -e; cd ${WRKDIR}; \
|
|
${_set_ld_library_path}; \
|
|
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).
|
|
.if target(pre-patch)
|
|
${_PREPATCH_COOKIE}:
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} pre-patch
|
|
. if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_MAKE_COOKIE} $@
|
|
. endif
|
|
.endif
|
|
|
|
|
|
|
|
# The real distpatch
|
|
|
|
${_DISTPATCH_COOKIE}: ${_EXTRACT_COOKIE}
|
|
.if target(pre-patch)
|
|
@cd ${.CURDIR} && exec ${MAKE} ${_PREPATCH_COOKIE}
|
|
.endif
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} do-distpatch
|
|
.if target(post-distpatch)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} post-distpatch
|
|
.endif
|
|
.if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_MAKE_COOKIE} $@
|
|
.endif
|
|
|
|
.if !target(do-distpatch)
|
|
do-distpatch:
|
|
# What DISTPATCH normally does
|
|
. if defined(_PATCHFILES)
|
|
@${ECHO_MSG} "===> Applying distribution patches for ${FULLPKGNAME}${_MASTER}"
|
|
@cd ${FULLDISTDIR}; \
|
|
for patchfile in ${_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)
|
|
@cd ${.CURDIR} && exec ${MAKE} ${_PREPATCH_COOKIE}
|
|
.endif
|
|
.if target(do-patch)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} 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) || defined(PATCHFILES)
|
|
@cd ${.CURDIR} && exec ${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 ${OPSYS} patch $$i" ;; \
|
|
esac; \
|
|
${_SYSTRACE_CMD} ${PATCH} ${PATCH_ARGS} < $$i || \
|
|
{ echo "***> $$i did not apply cleanly"; \
|
|
error=true; }\
|
|
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)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} post-patch
|
|
.endif
|
|
.for _m in ${MODULES}
|
|
. if defined(MOD${_m:U}_post-patch)
|
|
@${MOD${_m:U}_post-patch}
|
|
. 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 "Touching $$i"; touch $$i; done \
|
|
;; \
|
|
*) \
|
|
if test -e $$f ; then \
|
|
echo "Touching $$f"; touch $$f; \
|
|
fi \
|
|
;; \
|
|
esac; done
|
|
.endif
|
|
.if ${PATCH_CHECK_ONLY:L} != "yes"
|
|
@${_MAKE_COOKIE} $@
|
|
.endif
|
|
|
|
|
|
# The real configure
|
|
|
|
${_CONFIGURE_COOKIE}: ${_PATCH_COOKIE}
|
|
@${ECHO_MSG} "===> Configuring for ${FULLPKGNAME}${_MASTER}"
|
|
@mkdir -p ${WRKBUILD} ${WRKPKG}
|
|
.if target(pre-configure)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} pre-configure
|
|
.endif
|
|
.if target(do-configure)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} do-configure
|
|
.else
|
|
# What CONFIGURE normally does
|
|
. for _c in ${CONFIGURE_STYLE:L}
|
|
. if defined(MOD${_c:U}_configure)
|
|
@${MOD${_c:U}_configure}
|
|
. endif
|
|
. endfor
|
|
# End of CONFIGURE.
|
|
.endif
|
|
.if target(post-configure)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} post-configure
|
|
.endif
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
# The real build
|
|
|
|
${_BUILD_COOKIE}: ${_CONFIGURE_COOKIE}
|
|
.if ${NO_BUILD:L} == "no"
|
|
@${ECHO_MSG} "===> Building for ${FULLPKGNAME}${_MASTER}"
|
|
.if ${VMEM_WARNING:L} == "yes"
|
|
@echo ""; \
|
|
echo "*** WARNING: you may see an error such as"; \
|
|
echo "*** virtual memory exhausted"; \
|
|
echo "*** when building this package. If you do you must increase"; \
|
|
echo "*** your limits. See the man page for your shell and look"; \
|
|
echo "*** for the 'limit' or 'ulimit' command. You may also want to"; \
|
|
echo "*** see the login.conf(5) manual page."; \
|
|
echo "*** Some examples are: "; \
|
|
echo "*** csh(1) and tcsh(1): limit datasize <kbytes of memory>"; \
|
|
echo "*** ksh(1), zsh(1) and bash(1): ulimit -d <kbytes of memory>"; \
|
|
echo ""
|
|
.endif
|
|
. if target(pre-build)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} pre-build
|
|
. endif
|
|
. if target(do-build)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} do-build
|
|
. else
|
|
# What BUILD normally does:
|
|
@cd ${WRKBUILD} && exec ${_SYSTRACE_CMD} ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${MAKE_FLAGS} -f ${MAKE_FILE} ${ALL_TARGET}
|
|
# End of BUILD
|
|
. endif
|
|
. if target(post-build)
|
|
@cd ${.CURDIR} && exec ${_SYSTRACE_CMD} ${MAKE} post-build
|
|
. endif
|
|
.endif
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
${_REGRESS_COOKIE}: ${_BUILD_COOKIE}
|
|
.if ${NO_REGRESS:L} == "no"
|
|
@${ECHO_MSG} "===> Regression check for ${FULLPKGNAME}${_MASTER}"
|
|
. if target(pre-regress)
|
|
@cd ${.CURDIR} && exec ${MAKE} pre-regress
|
|
. endif
|
|
. if target(do-regress)
|
|
@cd ${.CURDIR} && exec ${MAKE} do-regress
|
|
. else
|
|
# What REGRESS normally does:
|
|
@cd ${WRKBUILD} && exec ${SETENV} ${MAKE_ENV} ${MAKE_PROGRAM} ${REGRESS_FLAGS} -f ${MAKE_FILE} ${REGRESS_TARGET}
|
|
# End of REGRESS
|
|
. endif
|
|
. if target(post-regress)
|
|
@cd ${.CURDIR} && exec ${MAKE} post-regress
|
|
. endif
|
|
.else
|
|
@echo 1>&2 "No regression check for ${FULLPKGNAME}"
|
|
.endif
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
${_FAKE_COOKIE}: ${_BUILD_COOKIE} ${WRKPKG}/mtree.spec
|
|
@${ECHO_MSG} "===> Faking installation for ${FULLPKGNAME}${_MASTER}"
|
|
@if [ x`${SUDO} /bin/sh -c umask` != x${DEF_UMASK} ]; then \
|
|
echo >&2 "Error: your umask is \"`/bin/sh -c umask`"\".; \
|
|
exit 1; \
|
|
fi
|
|
@${SUDO} install -d -m 755 -o root -g wheel ${WRKINST}
|
|
@${SUDO} /usr/sbin/mtree -U -e -d -n -p ${WRKINST} \
|
|
-f ${WRKPKG}/mtree.spec >/dev/null
|
|
.for _p in ${PROTECT_MOUNT_POINTS}
|
|
@${SUDO} mount -u -r ${_p}
|
|
.endfor
|
|
.for _m in ${MODULES}
|
|
. if defined(MOD${_m:U}_pre-fake)
|
|
@${MOD${_m:U}_pre-fake}
|
|
. endif
|
|
.endfor
|
|
|
|
.if target(pre-fake)
|
|
@cd ${.CURDIR} && exec ${SUDO} ${_SYSTRACE_CMD} ${MAKE} pre-fake ${_FAKE_SETUP}
|
|
.endif
|
|
@${SUDO} ${_MAKE_COOKIE} ${_INSTALL_PRE_COOKIE}
|
|
.if target(pre-install)
|
|
@cd ${.CURDIR} && exec ${SUDO} ${_SYSTRACE_CMD} ${MAKE} pre-install ${_FAKE_SETUP}
|
|
.endif
|
|
.if target(do-install)
|
|
@cd ${.CURDIR} && exec ${SUDO} ${_SYSTRACE_CMD} ${MAKE} do-install ${_FAKE_SETUP}
|
|
.else
|
|
# What FAKE normally does:
|
|
@cd ${WRKBUILD} && exec ${SUDO} ${_SYSTRACE_CMD} ${SETENV} ${MAKE_ENV} ${_FAKE_SETUP} ${MAKE_PROGRAM} ${FAKE_FLAGS} -f ${MAKE_FILE} ${FAKE_TARGET}
|
|
# End of FAKE.
|
|
.endif
|
|
.if target(post-install)
|
|
@cd ${.CURDIR} && exec ${SUDO} ${_SYSTRACE_CMD} ${MAKE} post-install ${_FAKE_SETUP}
|
|
.endif
|
|
.for _p in ${PROTECT_MOUNT_POINTS}
|
|
@${SUDO} mount -u -w ${_p}
|
|
.endfor
|
|
@${SUDO} ${_MAKE_COOKIE} $@
|
|
|
|
# The real install
|
|
|
|
${_INSTALL_COOKIE}:
|
|
@cd ${.CURDIR} && exec ${MAKE} package
|
|
@cd ${.CURDIR} && DEPENDS_TARGET=install PACKAGING='${SUBPACKAGE}' exec ${MAKE} _internal-run-depends _internal-lib-depends
|
|
@${ECHO_MSG} "===> Installing ${FULLPKGNAME${SUBPACKAGE}} from ${_PKG_REPO}"
|
|
.for _m in ${MODULES}
|
|
. if defined(MOD${_m:U}_pre_install)
|
|
@${MOD${_m:U}_pre_install}
|
|
. endif
|
|
.endfor
|
|
.if ${TRUST_PACKAGES:L} == "yes"
|
|
@if pkg_info -q -e ${FULLPKGNAME${SUBPACKAGE}}; then \
|
|
echo "Package ${FULLPKGNAME${SUBPACKAGE}} is already installed"; \
|
|
else \
|
|
${SUDO} ${SETENV} PKG_PATH=${_PKG_REPO} PKG_TMPDIR=${PKG_TMPDIR} pkg_add ${_PKG_ADD_AUTO} ${PKGFILE}; \
|
|
fi
|
|
.else
|
|
@${SUDO} ${SETENV} PKG_PATH=${_PKG_REPO} PKG_TMPDIR=${PKG_TMPDIR} pkg_add ${_PKG_ADD_AUTO} ${PKGFILE}
|
|
.endif
|
|
@-${SUDO} ${_MAKE_COOKIE} $@
|
|
|
|
${_UPDATE_COOKIE}:
|
|
@cd ${.CURDIR} && exec ${MAKE} _internal-package
|
|
.if empty(UPDATE_COOKIES_DIR)
|
|
@exec ${MAKE} ${WRKDIR}
|
|
.else
|
|
@mkdir -p ${UPDATE_COOKIES_DIR}
|
|
.endif
|
|
@${ECHO_MSG} "===> Updating for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@a=`pkg_info -e ${FULLPKGPATH} 2>/dev/null || true`; \
|
|
case $$a in \
|
|
'') ${ECHO_MSG} "Not installed, no update";; \
|
|
*) ${ECHO_MSG} "Upgrading from $$a"; \
|
|
${SUDO} ${SETENV} PKG_PATH=${_PKG_REPO} PKG_TMPDIR=${PKG_TMPDIR} pkg_add ${_PKG_ADD_AUTO} -r ${_PKG_ADD_FORCE} ${PKGFILE};; \
|
|
esac
|
|
@${_MAKE_COOKIE} $@
|
|
|
|
# The real package
|
|
|
|
.if empty(PLIST_DB)
|
|
_register_plist=:
|
|
.else
|
|
_register_plist=perl ${PORTSDIR}/infrastructure/package/register-plist ${PLIST_DB} ${_PACKAGE_COOKIE}
|
|
.endif
|
|
|
|
print-plist:
|
|
@${PKG_CMD} -n -q ${PKG_ARGS} ${_PACKAGE_COOKIE}
|
|
|
|
print-plist-contents:
|
|
@${PKG_CMD} -n -Q ${PKG_ARGS} ${_PACKAGE_COOKIE}
|
|
|
|
_internal-subpackage: ${_PACKAGE_COOKIES}
|
|
|
|
|
|
fetch-all:
|
|
@cd ${.CURDIR} && exec ${MAKE} __FETCH_ALL=Yes __ARCH_OK=Yes NO_IGNORE=Yes fetch
|
|
|
|
# Separate target for each file fetch will retrieve
|
|
|
|
.for _F in ${ALLFILES:S@^@${FULLDISTDIR}/@}
|
|
${_F}:
|
|
. if ${FETCH_MANUALLY:L} != "no"
|
|
. for _M in ${FETCH_MANUALLY}
|
|
@echo "*** ${_M}"
|
|
. endfor
|
|
@exit 1
|
|
. else
|
|
@lock=${_F:T}.dist; ${_SIMPLE_LOCK}; mkdir -p ${_F:H}; \
|
|
cd ${_F:H}; \
|
|
select=${_EVERYTHING:M*${_F:S@^${FULLDISTDIR}/@@}\:[0-9]}; \
|
|
f=${_F:S@^${FULLDISTDIR}/@@}; \
|
|
${ECHO_MSG} ">> $$f doesn't seem to exist on this system."; \
|
|
${_CDROM_OVERRIDE}; \
|
|
${_SITE_SELECTOR}; \
|
|
for site in $$sites; do \
|
|
${ECHO_MSG} ">> Fetch $${site}$$f."; \
|
|
if ${FETCH_CMD} $${site}$$f; then \
|
|
file=${_F:S@^${DISTDIR}/@@}; \
|
|
ck=`cd ${DISTDIR} && ${_size_fragment}`; \
|
|
if [ ! -f ${CHECKSUM_FILE} ]; then \
|
|
${ECHO_MSG} ">> Checksum file does not exist"; \
|
|
exit 0; \
|
|
elif grep -q "^$$ck\$$" ${CHECKSUM_FILE}; then \
|
|
${ECHO_MSG} ">> Size matches for ${_F}"; \
|
|
exit 0; \
|
|
else \
|
|
if grep -q "SIZE ($$file)" ${CHECKSUM_FILE}; then \
|
|
${ECHO_MSG} ">> Size does not match for ${_F}"; \
|
|
test `{ wc -c "$$file" 2>/dev/null || echo 0 ; }| awk '{print $$1}'` -lt 30000 && rm -f $$file; \
|
|
else \
|
|
${ECHO_MSG} ">> No size recorded for ${_F}"; \
|
|
exit 0; \
|
|
fi; \
|
|
fi; \
|
|
fi; \
|
|
done; exit 1
|
|
. endif
|
|
.endfor
|
|
|
|
.for _l _o in ${_PACKAGE_LINKS}
|
|
${PACKAGE_REPOSITORY}/${_l}/${_PKGFILE}: ${PACKAGE_REPOSITORY}/${_o}/${_PKGFILE}
|
|
@echo "Link to $@"
|
|
@mkdir -p ${@D}
|
|
@rm -f $@
|
|
@ln $? $@ 2>/dev/null || \
|
|
cp -p $? $@
|
|
.endfor
|
|
|
|
# Cleaning up
|
|
|
|
_internal-clean:
|
|
.if ${_clean:L:Mdepends} && ${_CLEANDEPENDS:L} == "yes"
|
|
@PACKAGING='${SUBPACKAGE}' ${MAKE} all-dir-depends|tsort -r|${_zap_last_line}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} _CLEANDEPENDS=No clean; \
|
|
done
|
|
.endif
|
|
@${ECHO_MSG} "===> Cleaning for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
.if ${_clean:L:Mfake}
|
|
@if cd ${WRKINST} 2>/dev/null; then ${SUDO} rm -rf ${WRKINST}; fi
|
|
.endif
|
|
.if ${_clean:L:Mwork}
|
|
. if ${_clean:L:Mflavors}
|
|
@for i in ${.CURDIR}/w-*; do \
|
|
if [ -L $$i ]; then ${SUDO} rm -rf `readlink $$i`; fi; \
|
|
${SUDO} rm -rf $$i; \
|
|
done
|
|
. else
|
|
@if [ -L ${WRKDIR} ]; then rm -rf `readlink ${WRKDIR}`; fi
|
|
@rm -rf ${WRKDIR}
|
|
. endif
|
|
.endif
|
|
.if ${_clean:L:Mdist}
|
|
@${ECHO_MSG} "===> Dist cleaning for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@if cd ${FULLDISTDIR} 2>/dev/null; then \
|
|
rm -f ${_DISTFILES} ${_PATCHFILES}; \
|
|
fi
|
|
. if !empty(DIST_SUBDIR)
|
|
-@rmdir ${FULLDISTDIR}
|
|
. endif
|
|
.endif
|
|
.if ${_clean:L:Minstall}
|
|
. if ${_clean:L:Msub}
|
|
. for _s in ${MULTI_PACKAGES}
|
|
-${SUDO} ${PKG_DELETE} ${FULLPKGNAME${_s}}
|
|
. endfor
|
|
. else
|
|
-${SUDO} ${PKG_DELETE} ${FULLPKGNAME${SUBPACKAGE}}
|
|
. endif
|
|
.endif
|
|
.if ${_clean:L:Mpackages} || ${_clean:L:Mpackage} && ${_clean:L:Msub}
|
|
. if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M-main)
|
|
@cd ${.CURDIR} && PACKAGING='' SUBPACKAGE='' exec ${MAKE} clean=package
|
|
. endif
|
|
. if defined(MULTI_PACKAGES)
|
|
. for _s in ${MULTI_PACKAGES}
|
|
@cd ${.CURDIR} && PACKAGING='${_s}' SUBPACKAGE='${_s}' exec ${MAKE} clean=package
|
|
. endfor
|
|
. endif
|
|
.elif ${_clean:L:Mpackage}
|
|
rm -f ${_PACKAGE_COOKIES}
|
|
.endif
|
|
.if ${_clean:L:Mreadmes}
|
|
. if !defined(MULTI_PACKAGES) || empty(MULTI_PACKAGES:M-main)
|
|
rm -f ${.CURDIR}/${FULLPKGNAME}.html
|
|
. endif
|
|
. for _s in ${MULTI_PACKAGES}
|
|
rm -f ${.CURDIR}/${FULLPKGNAME${_s}}.html
|
|
. endfor
|
|
.endif
|
|
.if ${_clean:L:Mbulk}
|
|
rm -f ${_BULK_COOKIE}
|
|
.endif
|
|
|
|
# mirroring utilities
|
|
fetch-makefile:
|
|
@exec ${MAKE} __FETCH_ALL=Yes __ARCH_OK=Yes NO_IGNORE=Yes _fetch-makefile
|
|
|
|
_fetch-makefile:
|
|
.if !defined(COMES_WITH)
|
|
@echo -n "all"
|
|
. if ${PERMIT_DISTFILES_FTP:L} == "yes"
|
|
@echo -n " ftp"
|
|
. endif
|
|
. if ${PERMIT_DISTFILES_CDROM:L} == "yes"
|
|
@echo -n " cdrom"
|
|
. endif
|
|
@echo ":: ${_FMN}"
|
|
# write generic package dependencies
|
|
@echo ".PHONY: ${_FMN}"
|
|
. if ${RECURSIVE_FETCH_LIST:L} == "yes"
|
|
@echo "${_FMN}: ${_ALLFILES} "`_FULL_PACKAGE_NAME=Yes ${MAKE} full-all-depends`
|
|
. else
|
|
@echo "${_FMN}: ${_ALLFILES}"
|
|
. endif
|
|
.endif
|
|
.if !empty(ALLFILES)
|
|
. for _F in ${_ALLFILES}
|
|
@: $${_DONE_FILES:=/dev/null}; if ! fgrep -q "|${_F}|" $${_DONE_FILES}; then \
|
|
echo "|${_F}|" >>$${_DONE_FILES}; \
|
|
${MAKE} _fetch-onefile _file=${_F}; \
|
|
fi
|
|
. endfor
|
|
.endif
|
|
@echo
|
|
|
|
|
|
_fetch-onefile:
|
|
# XXX loop so that M${_F} will work
|
|
.for _F in ${_file}
|
|
@echo '${_F}: $$F'
|
|
@echo -n '\t@MAINTAINER="${MAINTAINER}" '
|
|
. if !empty(DIST_SUBDIR)
|
|
@echo -n 'DIST_SUBDIR="${DIST_SUBDIR}" '
|
|
. endif
|
|
@echo '\\'
|
|
@select='${_EVERYTHING:M*${_F:S@^${DIST_SUBDIR}/@@}\:[0-9]}'; \
|
|
${_SITE_SELECTOR}; \
|
|
echo "\t SITES=\"$$sites\" \\"
|
|
. if ${FETCH_MANUALLY:L} != "no"
|
|
@echo '\t FETCH_MANUALLY="Yes" \\'
|
|
. endif
|
|
. if !defined(NO_CHECKSUM) && !empty(_CKSUMFILES:M${_F})
|
|
@checksum_file=${CHECKSUM_FILE}; \
|
|
if [ ! -f $$checksum_file ]; then \
|
|
echo >&2 "Missing checksum file: $$checksum_file"; \
|
|
echo '\t ERROR="no checksum file" \\'; \
|
|
else \
|
|
for c in ${PREFERRED_CIPHERS}; do \
|
|
if set -- `grep -i "^$$c (${_F})" $$checksum_file`; then break; fi; \
|
|
done; \
|
|
case "$$4" in \
|
|
"") \
|
|
echo >&2 "No checksum recorded for ${_F}."; \
|
|
echo '\t ERROR="no checksum" \\';; \
|
|
"IGNORE") \
|
|
echo >&2 "Checksum for ${_F} is IGNORE in $$checksum_file"; \
|
|
echo >&2 'but file is not in $${IGNORE_FILES}'; \
|
|
echo '\t ERROR="IGNORE inconsistent" \\';; \
|
|
*) \
|
|
echo "\t CIPHER=\"$$c\" CKSUM=\"$$4\" \\";; \
|
|
esac; \
|
|
fi
|
|
. endif
|
|
@echo '\t $${EXEC} $${FETCH} "$$@"'
|
|
.endfor
|
|
|
|
|
|
# This target generates an index entry suitable for aggregation into
|
|
# a large index. Format is:
|
|
#
|
|
# distribution-name|port-path|installation-prefix|comment| \
|
|
# description-file|maintainer|categories|lib-deps|build-deps|run-deps| \
|
|
# for-arch|package-cdrom|package-ftp|distfiles-cdrom|distfiles-ftp
|
|
#
|
|
subdescribe:
|
|
@echo -n "${FULLPKGNAME${SUBPACKAGE}}|${FULLPKGPATH}|"
|
|
.if ${PREFIX} == ${LOCALBASE}
|
|
@echo -n "|"
|
|
.else
|
|
@echo -n "${PREFIX}|"
|
|
.endif
|
|
@echo -n ${_COMMENT}"|"; \
|
|
if [ -f ${DESCR} ]; then \
|
|
echo -n "${DESCR:S,^${PORTSDIR}/,,}|"; \
|
|
else \
|
|
echo -n "/dev/null|"; \
|
|
fi; \
|
|
echo -n "${MAINTAINER}|${CATEGORIES}|"
|
|
.for _d in LIB BUILD RUN
|
|
. if !empty(_${_d}_DEP2)
|
|
@cd ${.CURDIR} && _FINAL_ECHO=: _INITIAL_ECHO=: exec ${MAKE} ${_d:L}-depends-list
|
|
. endif
|
|
@echo -n "|"
|
|
.endfor
|
|
@case "${ONLY_FOR_ARCHS}" in \
|
|
"") case "${NOT_FOR_ARCHS}" in \
|
|
"") echo -n "any|";; \
|
|
*) echo -n "!${NOT_FOR_ARCHS}|";; \
|
|
esac;; \
|
|
*) echo -n "${ONLY_FOR_ARCHS}|";; \
|
|
esac
|
|
|
|
.if defined(_BAD_LICENSING)
|
|
@echo "?|?|?|?"
|
|
.else
|
|
. if ${PERMIT_PACKAGE_CDROM${SUBPACKAGE}:L} == "yes"
|
|
@echo -n "y|"
|
|
. else
|
|
@echo -n "n|"
|
|
. endif
|
|
. if ${PERMIT_PACKAGE_FTP${SUBPACKAGE}:L} == "yes"
|
|
@echo -n "y|"
|
|
. else
|
|
@echo -n "n|"
|
|
. endif
|
|
. if ${PERMIT_DISTFILES_CDROM:L} == "yes"
|
|
@echo -n "y|"
|
|
. else
|
|
@echo -n "n|"
|
|
. endif
|
|
. if ${PERMIT_DISTFILES_FTP:L} == "yes"
|
|
@echo "y"
|
|
. else
|
|
@echo "n"
|
|
. endif
|
|
.endif
|
|
|
|
_readme:
|
|
@cd ${.CURDIR} && exec ${MAKE} README_NAME=${README_NAME} ${FULLPKGNAME${SUBPACKAGE}}.html
|
|
|
|
${FULLPKGNAME${SUBPACKAGE}}.html:
|
|
@echo ${_COMMENT} | ${HTMLIFY} >$@.tmp-comment
|
|
@echo ${FULLPKGNAME${SUBPACKAGE}} | ${HTMLIFY} > $@.tmp3
|
|
.if defined(HOMEPAGE)
|
|
@echo 'See <a href="${HOMEPAGE}">${HOMEPAGE}</a> for details.' >$@.tmp4
|
|
.else
|
|
@echo "" >$@.tmp4
|
|
.endif
|
|
.if defined(MULTI_PACKAGES)
|
|
. if empty(SUBPACKAGE)
|
|
@echo "<h2>Subpackages</h2>" >$@.tmp-subpackages
|
|
@echo "<ul>" >>$@.tmp-subpackages
|
|
|
|
. for _S in ${MULTI_PACKAGES}
|
|
@name=`SUBPACKAGE=${_S} ${MAKE} _print-packagename _FULL_PACKAGE_NAME=No`; \
|
|
echo "<li><a href=\"$$name.html\">$$name</a>" >>$@.tmp-subpackages
|
|
. endfor
|
|
@echo "</ul>" >>$@.tmp-subpackages
|
|
. else
|
|
@name=`unset SUBPACKAGE; ${MAKE} _print-packagename _FULL_PACKAGE_NAME=No`; \
|
|
echo "<h2>Subpackage of <a href=\"$$name.html\">$$name</a></h2>" >$@.tmp-subpackages
|
|
. endif
|
|
.else
|
|
@>$@.tmp-subpackages
|
|
.endif
|
|
.for _I in build run
|
|
. if !empty(_ALWAYS_DEP) || !empty(_${_I:U}_DEP)
|
|
@cd ${.CURDIR} && ${MAKE} full-${_I}-depends _FULL_PACKAGE_NAME=Yes| \
|
|
while read n; do \
|
|
j=`dirname $$n|${HTMLIFY}`; k=`basename $$n|${HTMLIFY}`; \
|
|
echo "<li><a href=\"${PKGDEPTH}$$j/$$k.html\">$$k</a>"; \
|
|
done >$@.tmp-${_I}
|
|
. else
|
|
@echo "<li>none" >$@.tmp-${_I}
|
|
. endif
|
|
.endfor
|
|
@cat ${README_NAME} | \
|
|
sed -e 's|%%PORT%%|'"`echo ${FULLPKGPATH} | ${HTMLIFY}`"'|g' \
|
|
-e '/%%PKG%%/r$@.tmp3' -e '//d' \
|
|
-e '/%%COMMENT%%/r$@.tmp-comment' -e '//d' \
|
|
-e '/%%DESCR%%/r${PKGDIR}/DESCR${SUBPACKAGE}' -e '//d' \
|
|
-e '/%%HOMEPAGE%%/r$@.tmp4' -e '//d' \
|
|
-e '/%%BUILD_DEPENDS%%/r$@.tmp-build' -e '//d' \
|
|
-e '/%%RUN_DEPENDS%%/r$@.tmp-run' -e '//d' \
|
|
-e '/%%SUBPACKAGES%%/r$@.tmp-subpackages' -e '//d' \
|
|
>> $@
|
|
@rm -f $@.tmp*
|
|
|
|
|
|
print-build-depends:
|
|
.if !empty(_ALWAYS_DEP) || !empty(_BUILD_DEP)
|
|
@echo -n 'This port requires package(s) "'
|
|
@${MAKE} full-build-depends| ${_lines2list}
|
|
@echo '" to build.'
|
|
.endif
|
|
|
|
print-run-depends:
|
|
.if !empty(_ALWAYS_DEP) || !empty(_RUN_DEP)
|
|
@echo -n 'This port requires package(s) "'
|
|
@${MAKE} full-run-depends| ${_lines2list}
|
|
@echo '" to run.'
|
|
.endif
|
|
|
|
# full-build-depends, full-all-depends, full-run-depends full-regress-depends
|
|
.for _i in build all run regress
|
|
full-${_i}-depends:
|
|
@${MAKE} ${_i}-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} _print-packagename ; \
|
|
done
|
|
.endfor
|
|
|
|
license-check:
|
|
.if ${PERMIT_PACKAGE_CDROM${SUBPACKAGE}:L} == "yes" || ${PERMIT_PACKAGE_FTP${SUBPACKAGE}:L} == "yes"
|
|
@${MAKE} all-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
_MASTER_PERMIT_CDROM=${PERMIT_PACKAGE_CDROM${SUBPACKAGE}:Q}; \
|
|
_MASTER_PERMIT_FTP=${PERMIT_PACKAGE_FTP${SUBPACKAGE}:Q}; \
|
|
export _MASTER_PERMIT_CDROM _MASTER_PERMIT_FTP; \
|
|
eval $$toset ${MAKE} _license-check; \
|
|
done
|
|
.endif
|
|
|
|
_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
|
|
.for _i in RUN BUILD LIB
|
|
${_i:L}-depends-list:
|
|
. if !empty(_${_i}_DEP2)
|
|
@unset FLAVOR SUBPACKAGE || true; \
|
|
: $${_INITIAL_ECHO:='echo -n "This port requires \""'}; \
|
|
: $${_ECHO='echo -n'}; \
|
|
: $${_FINAL_ECHO:='echo "\" for ${_i:L}."'}; space=''; \
|
|
eval $${_INITIAL_ECHO}; \
|
|
for spec in `echo '${_${_i}_DEP2}' \
|
|
| tr '\040' '\012' | sort -u`; do \
|
|
$${_ECHO} "$$space$${spec}"; \
|
|
space=' '; \
|
|
done; eval $${_FINAL_ECHO}
|
|
. endif
|
|
.endfor
|
|
|
|
# recursive depend targets
|
|
|
|
print-package-signature:
|
|
@echo -n ${FULLPKGNAME${SUBPACKAGE}}
|
|
.if !empty(_DEPLIBS)
|
|
@cd ${.CURDIR} && PACKAGING='${SUBPACKAGE}' LIST_LIBS=`${MAKE} _list-port-libs` ${MAKE} _print-package-signature-lib _print-package-signature-run| \
|
|
sort -u| \
|
|
while read i; do echo -n ",$$i"; done
|
|
.else
|
|
@cd ${.CURDIR} && PACKAGING='${SUBPACKAGE}' ${MAKE} _print-package-signature-run | \
|
|
sort -u| \
|
|
while read i; do echo -n ",$$i"; done
|
|
.endif
|
|
@echo
|
|
|
|
_print-package-args:
|
|
.for _i in ${RUN_DEPENDS}
|
|
@echo '${_i}' |{ \
|
|
IFS=:; read dep pkg subdir target; \
|
|
${_flavor_fragment}; \
|
|
default=`eval $$toset ${MAKE} _print-packagename`; \
|
|
case "X$$pkg" in X) pkg=`echo $$default|${_version2default}`;; esac; \
|
|
echo "-P $$subdir:$$pkg:$$default"; \
|
|
}
|
|
.endfor
|
|
.if ${NO_SHARED_LIBS:L} != "yes"
|
|
. for _i in ${LIB_DEPENDS}
|
|
@echo '${_i}'|{ \
|
|
IFS=:; read dep pkg subdir target; \
|
|
${_flavor_fragment}; \
|
|
libspecs='';comma=''; \
|
|
default=`eval $$toset ${MAKE} _print-packagename`; \
|
|
case "X$$pkg" in X) pkg=`echo $$default|${_version2default}`;; esac; \
|
|
if pkg_info -q -e $$pkg; then \
|
|
listlibs='echo ${DEPDIR}$$shdir/lib*'; \
|
|
case $$dir in ${PKGPATH}) \
|
|
listlibs="$$toset ${MAKE} print-plist-contents|${_grab_libs_from_plist}; $$listlibs";; \
|
|
esac; \
|
|
else \
|
|
listlibs="$$toset ${MAKE} print-plist-contents|${_grab_libs_from_plist}"; \
|
|
fi; \
|
|
IFS=,; for d in $$dep; do \
|
|
${_libresolve_fragment}; \
|
|
case "$$check" in \
|
|
*.a) continue;; \
|
|
Failed) \
|
|
echo 1>&2 "Can't resolve libspec $$d"; \
|
|
exit 1;; \
|
|
*) \
|
|
echo "-W $$check";; \
|
|
esac; \
|
|
done; \
|
|
echo "-P $$subdir:$$pkg:$$default"; \
|
|
}
|
|
. endfor
|
|
. for _i in ${WANTLIB}
|
|
@d='${_i}'; listlibs='echo $$shdir/lib*'; \
|
|
${_syslibresolve_fragment}; \
|
|
case "$$check" in \
|
|
*.a) ;; \
|
|
Failed) \
|
|
echo 1>&2 "Can't resolve libspec $$d"; \
|
|
exit 1;; \
|
|
*) \
|
|
echo "-W $$check";; \
|
|
esac
|
|
. endfor
|
|
.endif
|
|
|
|
_list-port-libs:
|
|
.if defined(_PORT_LIBS_CACHE) && defined(_DEPENDS_CACHE) && defined(_DEPENDS_FILE)
|
|
@if ! fgrep -q -e "r|${FULLPKGPATH}|" -e "a|${FULLPKGPATH}" $${_DEPENDS_FILE}; then \
|
|
${MAKE} run-dir-depends >>${_DEPENDS_CACHE}; \
|
|
fi
|
|
@perl ${PORTSDIR}/infrastructure/build/extract-dependencies ${FULLPKGPATH} <${_DEPENDS_CACHE}|while read subdir; do \
|
|
fulldir=${_PORT_LIBS_CACHE}/$$subdir; \
|
|
if test -f $$fulldir; then \
|
|
cat $$fulldir; \
|
|
else \
|
|
mkdir -p $${fulldir%/*}; \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} print-plist-contents | \
|
|
${_grab_libs_from_plist}|tee $$fulldir; \
|
|
fi; \
|
|
done
|
|
.else
|
|
@${MAKE} run-dir-depends|${_sort_dependencies}|while read subdir; do \
|
|
${_flavor_fragment}; \
|
|
eval $$toset ${MAKE} print-plist-contents ; \
|
|
done | ${_grab_libs_from_plist}
|
|
.endif
|
|
@echo /usr/lib/lib* ${X11BASE}/lib/lib*
|
|
|
|
_print-package-signature-run:
|
|
.for _i in ${RUN_DEPENDS}
|
|
@echo '${_i}' |{ \
|
|
IFS=:; read dep pkg subdir target; \
|
|
${_flavor_fragment}; \
|
|
default=`eval $$toset ${MAKE} _print-packagename`; \
|
|
echo "$$default"; \
|
|
}
|
|
.endfor
|
|
|
|
_print-package-signature-lib:
|
|
@echo $$LIST_LIBS| LOCALBASE=${LOCALBASE} X11BASE=${X11BASE} perl ${PORTSDIR}/infrastructure/build/resolve-lib ${_DEPLIBS:S/>/\>/g}
|
|
.for _i in ${LIB_DEPENDS}
|
|
@echo '${_i}' |{ \
|
|
IFS=:; read dep pkg subdir target; \
|
|
${_flavor_fragment}; \
|
|
default=`eval $$toset ${MAKE} _print-packagename`; \
|
|
echo "$$default"; \
|
|
}
|
|
.endfor
|
|
|
|
# recursively build a list of dirs for package running, ready for tsort
|
|
_recurse-run-dir-depends:
|
|
.for _dir in ${_ALWAYS_DEP} ${_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(_ALWAYS_DEP) || !empty(_RUN_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "r|${FULLPKGPATH}|" -e "a|${FULLPKGPATH}" $${_DEPENDS_FILE}; then \
|
|
echo "r|${FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${FULLPKGPATH} PACKAGING='${SUBPACKAGE}' ${MAKE} _recurse-run-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${FULLPKGPATH} ${FULLPKGPATH}"
|
|
.endif
|
|
|
|
# recursively build a list of dirs for package regression, ready for tsort
|
|
_recurse-regress-dir-depends:
|
|
.for _dir in ${_REGRESS_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
|
|
|
|
regress-dir-depends:
|
|
.if !empty(_REGRESS_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "R|${FULLPKGPATH}|" $${_DEPENDS_FILE}; then \
|
|
echo "R|${FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${FULLPKGPATH} PACKAGING='${SUBPACKAGE}' ${MAKE} _recurse-regress-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 ${_ALWAYS_DEP} ${_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 ${_ALWAYS_DEP} ${_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(_ALWAYS_DEP) || !empty(_BUILD_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q -e "b|${FULLPKGPATH}|" -e "a|${_dir}|" $${_DEPENDS_FILE}; then \
|
|
echo "b|${FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${FULLPKGPATH} ${MAKE} _build-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${FULLPKGPATH} ${FULLPKGPATH}"
|
|
.endif
|
|
|
|
all-dir-depends:
|
|
.if !empty(_ALWAYS_DEP) || !empty(_BUILD_DEP) || !empty(_RUN_DEP)
|
|
@${_depfile_fragment}; \
|
|
if ! fgrep -q "|${FULLPKGPATH}|" $${_DEPENDS_FILE}; then \
|
|
echo "|${FULLPKGPATH}|" >>$${_DEPENDS_FILE}; \
|
|
self=${FULLPKGPATH} ${MAKE} _recurse-all-dir-depends; \
|
|
fi
|
|
.else
|
|
@echo "${FULLPKGPATH} ${FULLPKGPATH}"
|
|
.endif
|
|
|
|
link-categories:
|
|
.for _CAT in ${CATEGORIES}
|
|
@linkname=${PORTSDIR}/${_CAT}/`basename ${.CURDIR}`; \
|
|
if [ ! -e $$linkname ]; then \
|
|
echo "$$linkname -> ${.CURDIR}"; \
|
|
mkdir -p ${PORTSDIR}/${_CAT}; \
|
|
ln -s ${.CURDIR} $$linkname; \
|
|
fi
|
|
.endfor
|
|
|
|
unlink-categories:
|
|
.for _CAT in ${CATEGORIES}
|
|
@linkname=${PORTSDIR}/${_CAT}/`basename ${.CURDIR}`; \
|
|
if [ -L $$linkname ]; then \
|
|
echo "rm $$linkname"; \
|
|
rm $$linkname; \
|
|
if rmdir ${PORTSDIR}/${_CAT} 2>/dev/null; then \
|
|
echo "rmdir ${PORTSDIR}/${_CAT}"; \
|
|
fi; \
|
|
fi
|
|
.endfor
|
|
|
|
homepage-links:
|
|
.if defined(HOMEPAGE)
|
|
@echo '<li><A HREF="${HOMEPAGE}">${PKGNAME}</A>'
|
|
.else
|
|
@echo '<li>${PKGNAME}'
|
|
.endif
|
|
|
|
#####################################################
|
|
# convenience targets, not really needed
|
|
#####################################################
|
|
|
|
checkpatch:
|
|
@cd ${.CURDIR} && exec ${MAKE} PATCH_CHECK_ONLY=Yes patch
|
|
|
|
clean-depends:
|
|
@cd ${.CURDIR} && exec ${MAKE} clean=depends
|
|
|
|
distclean:
|
|
@cd ${.CURDIR} && exec ${MAKE} clean=dist
|
|
|
|
delete-package:
|
|
@cd ${.CURDIR} && exec ${MAKE} clean=package
|
|
|
|
reinstall:
|
|
@cd ${.CURDIR} && exec ${MAKE} clean='install force'
|
|
@cd ${.CURDIR} && DEPENDS_TARGET=${DEPENDS_TARGET} exec ${MAKE} install
|
|
|
|
repackage:
|
|
@cd ${.CURDIR} && exec ${MAKE} clean=packages
|
|
@cd ${.CURDIR} && exec ${MAKE} package
|
|
|
|
rebuild:
|
|
@rm -f ${_BUILD_COOKIE}
|
|
@cd ${.CURDIR} && exec ${MAKE} build
|
|
|
|
uninstall deinstall:
|
|
@${ECHO_MSG} "===> Deinstalling for ${FULLPKGNAME${SUBPACKAGE}}"
|
|
@${SUDO} ${PKG_DELETE} ${FULLPKGNAME${SUBPACKAGE}}
|
|
|
|
.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
|
|
|
|
peek-ftp:
|
|
@mkdir -p ${FULLDISTDIR}; cd ${FULLDISTDIR}; echo "cd ${FULLDISTDIR}"; \
|
|
for i in ${MASTER_SITES:Mftp*}; do echo "Connecting to $$i"; ${FETCH_CMD} $$i ; break; done
|
|
|
|
show-required-by:
|
|
@cd ${PORTSDIR} && make all-dir-depends | perl ${PORTSDIR}/infrastructure/build/extract-dependencies -r ${FULLPKGPATH}
|
|
|
|
show:
|
|
.for _s in ${show}
|
|
@echo ${${_s}:Q}
|
|
.endfor
|
|
|
|
verbose-show:
|
|
.for _s in ${verbose-show}
|
|
. if defined(${_s})
|
|
@echo ${_s}=${${_s}:Q}
|
|
. endif
|
|
.endfor
|
|
|
|
subdump-vars:
|
|
.for _s in ${_ALL_VARIABLES}
|
|
. if defined(${_s})
|
|
@echo ${FULLPKGPATH}.${_s}=${${_s}:Q}
|
|
. endif
|
|
.endfor
|
|
.for _s in ${_ALL_VARIABLES2}
|
|
. if defined(${_s}${SUBPACKAGE})
|
|
@echo ${FULLPKGPATH}.${_s}=${${_s}${SUBPACKAGE}:Q}
|
|
. endif
|
|
.endfor
|
|
|
|
.PHONY: \
|
|
_build-dir-depends _fetch-makefile _fetch-onefile \
|
|
_print-packagename \
|
|
_recurse-all-dir-depends \
|
|
_recurse-run-dir-depends _refetch \
|
|
addsum _print-package-args \
|
|
all all-dir-depends build \
|
|
build-depends build-depends-list build-dir-depends \
|
|
checkpatch checksum clean \
|
|
clean-depends configure deinstall \
|
|
delete-package \
|
|
depends \
|
|
describe distclean distpatch \
|
|
do-build do-configure do-distpatch \
|
|
do-extract do-fetch do-install \
|
|
do-package do-regress extract \
|
|
fake fetch fetch-all \
|
|
fetch-makefile full-all-depends full-build-depends \
|
|
full-run-depends homepage-links install \
|
|
lib-depends lib-depends-check lib-depends-list \
|
|
link-categories makesum manpages-check \
|
|
package patch \
|
|
plist post-build post-configure \
|
|
post-distpatch post-extract post-fetch \
|
|
post-install post-package post-patch \
|
|
post-regress pre-build pre-configure \
|
|
pre-extract pre-fake pre-fetch \
|
|
pre-install pre-package pre-patch \
|
|
pre-regress print-build-depends print-package-signature \
|
|
print-run-depends \
|
|
readmes _readme rebuild \
|
|
regress regress-depends \
|
|
reinstall repackage run-depends \
|
|
run-depends-list run-dir-depends show verbose-show dump-vars \
|
|
uninstall unlink-categories update-patches \
|
|
update-plist \
|
|
license-check _license-check \
|
|
_internal-extract _internal-distpatch _internal-configure \
|
|
_internal-build _internal-all _internal_install _internal-fake \
|
|
_internal-package _internal-package-only \
|
|
_internal-fetch _internal-checksum \
|
|
_internal-depends _internal-lib-depends _internal-libs-depends \
|
|
_internal-build-depends \
|
|
_internal-run-depends _internal-regress-depends \
|
|
_internal-regress _internal-clean _internal-lib-depends-check \
|
|
_internal-newlib-depends-check \
|
|
_internal-manpages-check _internal-plist _internal-update-plist \
|
|
_internal-update update print-plist print-plist-contents \
|
|
_list-port-libs _print-package-signature-lib _print-package-signature-run \
|
|
show-required-by peek-ftp _internal-subpackage subdescribe \
|
|
sublib-depends-check subdump-vars _internal-install-all install-all \
|
|
subpackage _internal-subupdate _internal-update \
|
|
regress-dir-depends _recurse-regress-dir-depends \
|
|
full-regress-depends print-plist-all
|