1994-08-21 13:12:57 +00:00
|
|
|
# bsd.port.mk - 940820 Jordan K. Hubbard.
|
|
|
|
# This file is in the public domain.
|
|
|
|
#
|
1994-08-21 17:42:24 +00:00
|
|
|
# $Id: bsd.port.mk,v 1.6 1994/08/21 16:55:54 jkh Exp $
|
1994-08-21 13:12:57 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# Supported Variables and their behaviors:
|
|
|
|
#
|
|
|
|
# GMAKE - Set to path of GNU make if not in $PATH.
|
|
|
|
# DISTDIR - Where to get gzip'd, tarballed copies of original sources.
|
|
|
|
# DISTNAME - Name of package or distribution.
|
|
|
|
# WRKDIR - A temporary working directory that gets *clobbered* on clean.
|
|
|
|
# WRKSRC - A subdirectory of ${WRKDIR} where the distribution actually
|
|
|
|
# unpacks to. Defaults to ${WRKDIR}/${DISTNAME}.
|
|
|
|
# PATCHDIR - A directory containing required patches.
|
|
|
|
# SCRIPTDIR - A directory containing auxilliary scripts.
|
|
|
|
# FILESDIR - A directory containing any miscellaneous additional files.
|
|
|
|
# PKGDIR - Package creation files.
|
|
|
|
#
|
|
|
|
# USE_GMAKE - Says that the package uses gmake (*).
|
1994-08-21 15:04:03 +00:00
|
|
|
# HAS_CONFIGURE - Says that the package has its own configure script (*).
|
|
|
|
# CONFIGURE_ARGS - Pass these args to configure, if $HAS_CONFIGURE.
|
1994-08-21 13:12:57 +00:00
|
|
|
# HOME_LOCATION - site/path name (or user's email address) describing
|
|
|
|
# where this package came from or can be obtained if the
|
|
|
|
# tarball is missing.
|
1994-08-21 16:37:09 +00:00
|
|
|
# DEPENDS - A list of other packages this package depends on being
|
|
|
|
# made first.
|
1994-08-21 13:12:57 +00:00
|
|
|
#
|
|
|
|
#
|
|
|
|
# Default targets and their behaviors:
|
|
|
|
#
|
|
|
|
# extract - Unpacks ${DISTDIR}/${DISTNAME}.tar.gz into ${WRKDIR}.
|
|
|
|
# configure - Applys patches, if any, and runs either GNU configure, a
|
|
|
|
# local configure or nothing, depending on settings.
|
|
|
|
# build - Actually compile the sources.
|
|
|
|
# install - Install the results of a build.
|
|
|
|
# package - Create a package from a build.
|
|
|
|
|
|
|
|
|
|
|
|
.if exists(${.CURDIR}/../Makefile.inc)
|
|
|
|
.include "${.CURDIR}/../Makefile.inc"
|
|
|
|
.endif
|
|
|
|
|
|
|
|
GMAKE?= gmake
|
|
|
|
|
1994-08-21 16:37:09 +00:00
|
|
|
# These need to be absolute since we don't know how deep in the ports
|
1994-08-21 13:12:57 +00:00
|
|
|
# tree we are and thus can't go relative. It can, of course, be overridden
|
|
|
|
# by individual Makefiles.
|
1994-08-21 16:37:09 +00:00
|
|
|
PORTSDIR?= /usr/ports
|
|
|
|
DISTDIR?= ${PORTSDIR}/distfiles
|
1994-08-21 13:12:57 +00:00
|
|
|
|
|
|
|
WRKDIR?= ${.CURDIR}/work
|
|
|
|
WRKSRC?= ${WRKDIR}/${DISTNAME}
|
|
|
|
PATCHDIR?= ${.CURDIR}/patches
|
|
|
|
SCRIPTDIR?= ${.CURDIR}/scripts
|
|
|
|
FILESDIR?= ${.CURDIR}/files
|
|
|
|
PKGDIR?= ${.CURDIR}/pkg
|
|
|
|
|
|
|
|
# Miscellaneous overridable commands:
|
|
|
|
EXTRACT_CMD?= tar
|
|
|
|
EXTRACT_SUFX?= .tar.gz
|
|
|
|
EXTRACT_ARGS?= -C ${WRKDIR} -xzf
|
|
|
|
|
|
|
|
HOME_LOCATION?= <original site unknown>
|
|
|
|
|
|
|
|
.MAIN: all
|
|
|
|
all: extract configure build
|
|
|
|
|
|
|
|
.if !target(install)
|
|
|
|
install:
|
|
|
|
@echo "===> Installing for ${DISTNAME}"
|
|
|
|
.if defined(USE_GMAKE)
|
|
|
|
@(cd ${WRKSRC}; ${GMAKE} install)
|
|
|
|
.else defined(USE_GMAKE)
|
|
|
|
@(cd ${WRKSRC}; ${MAKE} install)
|
|
|
|
.endif
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(package)
|
|
|
|
package:
|
|
|
|
# Makes some gross assumptions about a fairly simple package with no
|
|
|
|
# install, require or deinstall scripts. Override this rule if your
|
|
|
|
# package is anything but run-of-the-mill (or show me a way to do this
|
|
|
|
# more generally).
|
|
|
|
@[ -d ${PKGDIR} ] && \
|
|
|
|
echo "===> Building package for ${DISTNAME}" ; \
|
|
|
|
pkg_create -c pkg/COMMENT -d pkg/DESCR -f pkg/PLIST ${DISTNAME}
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(build)
|
|
|
|
build: configure
|
|
|
|
@echo "===> Building for ${DISTNAME}"
|
1994-08-21 16:37:09 +00:00
|
|
|
.if defined(DEPENDS)
|
1994-08-21 17:42:24 +00:00
|
|
|
@echo "===> ${DISTNAME} depends on: ${DEPENDS}"
|
1994-08-21 16:37:09 +00:00
|
|
|
@for i in $(DEPENDS); do \
|
1994-08-21 17:42:24 +00:00
|
|
|
echo "===> Verifying build for $$i"; \
|
1994-08-21 16:37:09 +00:00
|
|
|
if [ ! -d ${PORTSDIR}/$$i ]; then \
|
1994-08-21 17:42:24 +00:00
|
|
|
echo ">> No directory for ${PORTSDIR}/$$i. Skipping.."; \
|
1994-08-21 16:37:09 +00:00
|
|
|
else \
|
|
|
|
(cd ${PORTSDIR}/$$i; ${MAKE}) ; \
|
|
|
|
fi \
|
|
|
|
done
|
1994-08-21 17:42:24 +00:00
|
|
|
@echo "===> Returning to build of ${DISTNAME}"
|
1994-08-21 16:37:09 +00:00
|
|
|
.endif
|
1994-08-21 13:12:57 +00:00
|
|
|
.if defined(USE_GMAKE)
|
|
|
|
@(cd ${WRKSRC}; ${GMAKE} all)
|
|
|
|
.else defined(USE_GMAKE)
|
|
|
|
@(cd ${WRKSRC}; ${MAKE} all)
|
|
|
|
.endif
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(configure)
|
1994-08-21 16:37:09 +00:00
|
|
|
# This is done with a .configure because configures are often expensive,
|
|
|
|
# and you don't want it done again gratuitously when you're trying to get
|
|
|
|
# a make of the whole tree to work.
|
1994-08-21 16:55:54 +00:00
|
|
|
configure: extract ${.CURDIR}/.configure_done
|
1994-08-21 16:37:09 +00:00
|
|
|
|
1994-08-21 16:55:54 +00:00
|
|
|
${.CURDIR}/.configure_done:
|
1994-08-21 13:12:57 +00:00
|
|
|
@echo "===> Configuring for ${DISTNAME}"
|
|
|
|
@if [ -d ${PATCHDIR} ]; then \
|
|
|
|
echo "===> Applying patches for ${DISTNAME}" ; \
|
|
|
|
for i in ${PATCHDIR}/patch-*; do \
|
|
|
|
patch -d ${WRKSRC} --quiet -E -p0 < $$i; \
|
|
|
|
done; \
|
|
|
|
fi
|
1994-08-21 14:32:40 +00:00
|
|
|
# We have a small convention for our local configure scripts, which
|
|
|
|
# is that ${.CURDIR} and the package working directory get passed as
|
|
|
|
# command-line arguments since all other methods are a little
|
|
|
|
# problematic.
|
1994-08-21 16:37:09 +00:00
|
|
|
@if [ -f ${SCRIPTDIR}/pre-configure ]; then \
|
|
|
|
sh ${SCRIPTDIR}/pre-configure ${.CURDIR} ${WRKSRC}; \
|
|
|
|
fi
|
1994-08-21 14:32:40 +00:00
|
|
|
@if [ -f ${SCRIPTDIR}/configure ]; then \
|
|
|
|
sh ${SCRIPTDIR}/configure ${.CURDIR} ${WRKSRC}; \
|
|
|
|
fi
|
1994-08-21 16:37:09 +00:00
|
|
|
.if defined(HAS_CONFIGURE)
|
|
|
|
@(cd ${WRKSRC}; ./configure ${CONFIGURE_ARGS})
|
|
|
|
.endif
|
|
|
|
@if [ -f ${SCRIPTDIR}/post-configure ]; then \
|
|
|
|
sh ${SCRIPTDIR}/post-configure ${.CURDIR} ${WRKSRC}; \
|
|
|
|
fi
|
|
|
|
@touch -f ${.CURDIR}/.configure_done
|
1994-08-21 13:12:57 +00:00
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(extract)
|
|
|
|
# We need to depend on .extract_done rather than the presence of ${WRKDIR}
|
|
|
|
# because if the user interrupts the extract in the middle (and it's often
|
|
|
|
# a long procedure), we get tricked into thinking that we've got a good dist
|
|
|
|
# in ${WRKDIR}.
|
|
|
|
extract: ${.CURDIR}/.extract_done
|
|
|
|
|
|
|
|
${.CURDIR}/.extract_done:
|
|
|
|
@echo "===> Extracting for ${DISTNAME}"
|
|
|
|
@rm -rf ${WRKDIR}
|
|
|
|
@mkdir -p ${WRKDIR}
|
|
|
|
@if [ ! -f ${DISTDIR}/${DISTNAME}${EXTRACT_SUFX} ]; then \
|
1994-08-21 14:32:40 +00:00
|
|
|
echo "Sorry, can't find: ${DISTDIR}/${DISTNAME}${EXTRACT_SUFX}"; \
|
1994-08-21 13:12:57 +00:00
|
|
|
echo "Please obtain this file from:"; \
|
1994-08-21 14:32:40 +00:00
|
|
|
echo " ${HOME_LOCATION}"; \
|
1994-08-21 13:12:57 +00:00
|
|
|
echo "before proceeding."; \
|
1994-08-21 14:32:40 +00:00
|
|
|
exit 1; \
|
1994-08-21 13:12:57 +00:00
|
|
|
fi
|
|
|
|
@${EXTRACT_CMD} ${EXTRACT_ARGS} ${DISTDIR}/${DISTNAME}${EXTRACT_SUFX}
|
|
|
|
@touch -f ${.CURDIR}/.extract_done
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(clean)
|
|
|
|
clean:
|
|
|
|
@echo "===> Cleaning for ${DISTNAME}"
|
1994-08-21 16:37:09 +00:00
|
|
|
@rm -f ${.CURDIR}/.extract_done ${.CURDIR}/.configure_done
|
1994-08-21 13:12:57 +00:00
|
|
|
@rm -rf ${WRKDIR}
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if !target(cleandir)
|
|
|
|
cleandir: clean
|
|
|
|
.endif
|