aboutsummaryrefslogtreecommitdiffstats
path: root/Mk
diff options
context:
space:
mode:
authorjkh <jkh@FreeBSD.org>1994-09-09 14:21:43 +0800
committerjkh <jkh@FreeBSD.org>1994-09-09 14:21:43 +0800
commitf93f6586eb68e68c5fd860ced49acc7d82f183fb (patch)
treeffec223cb27f40f1283aac885a2e2b131fc16cb7 /Mk
parent5a1620d1426cf8d1aabe8700de2bdebaeb7059d0 (diff)
downloadfreebsd-ports-gnome-f93f6586eb68e68c5fd860ced49acc7d82f183fb.tar.gz
freebsd-ports-gnome-f93f6586eb68e68c5fd860ced49acc7d82f183fb.tar.zst
freebsd-ports-gnome-f93f6586eb68e68c5fd860ced49acc7d82f183fb.zip
Rearrange this a bit while I think about the whole problem of fetching
multiple targets when dealing with creating a set of distribution files from scratch. Another problem is *verifying* that a given file fetched from its HOME_LOCATION is the one we wanted (what if the stupid ftp site maintainer updated it in place?). Rich Morin pointed this out and suggested some solutions. I need to think about it some more (suggestions?). For now, we have a seperate `fetch' and `extract' target. Submitted by: jkh
Diffstat (limited to 'Mk')
-rw-r--r--Mk/bsd.port.mk105
1 files changed, 55 insertions, 50 deletions
diff --git a/Mk/bsd.port.mk b/Mk/bsd.port.mk
index 5f159350bc33..1e2c4bf48183 100644
--- a/Mk/bsd.port.mk
+++ b/Mk/bsd.port.mk
@@ -1,7 +1,7 @@
# bsd.port.mk - 940820 Jordan K. Hubbard.
# This file is in the public domain.
#
-# $Id: bsd.port.mk,v 1.27 1994/09/02 01:53:33 jkh Exp $
+# $Id: bsd.port.mk,v 1.28 1994/09/09 00:17:47 jkh Exp $
#
# Supported Variables and their behaviors:
@@ -10,9 +10,9 @@
#
# PORTSDIR - The root of the ports tree (default: /usr/ports).
# DISTDIR - Where to get gzip'd, tarballed copies of original sources
-# - (default: ${PORTSDIR}/distfiles.
+# - (default: ${PORTSDIR}/distfiles).
# PACKAGES - A top level directory where all packages go (rather than
-# - going someplace locally). (default: ${PORTSDIR}/packages).
+# - going locally to each port). (default: ${PORTSDIR}/packages).
# GMAKE - Set to path of GNU make if not in $PATH (default: gmake).
# XMKMF - Set to path of `xmkmf' if not in $PATH (default: xmkmf).
#
@@ -20,18 +20,22 @@
#
# 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}.
+# unpacks to. (Default: ${WRKDIR}/${DISTNAME} unless
+# NO_WRKSUBDIR is set, in which case simply ${WRKDIR}).
# DISTNAME - Name of port or distribution.
-# PATCHDIR - A directory containing required patches.
-# SCRIPTDIR - A directory containing auxilliary scripts.
+# DISTFILE - Name of archive file containing distribution
+# (default: ${DISTDIR}/${DISTNAME}${EXTRACT_SUFX}).
+# PATCHDIR - A directory containing any required patches.
+# SCRIPTDIR - A directory containing any auxilliary scripts.
# FILESDIR - A directory containing any miscellaneous additional files.
-# PKGDIR - Package creation files.
+# PKGDIR - A direction containing any package creation files.
#
# NO_EXTRACT - Use a dummy (do-nothing) extract target.
# NO_CONFIGURE - Use a dummy (do-nothing) configure target.
# NO_BUILD - Use a dummy (do-nothing) build target.
# NO_PACKAGE - Use a dummy (do-nothing) package target.
# NO_INSTALL - Use a dummy (do-nothing) install target.
+# NO_WRKSUBDIR - Assume port unpacks directly into ${WRKDIR}.
# USE_GMAKE - Says that the port uses gmake.
# USE_IMAKE - Says that the port uses imake.
# HAS_CONFIGURE - Says that the port has its own configure script.
@@ -42,28 +46,33 @@
# DEPENDS - A list of other ports this package depends on being
# made first, relative to ${PORTSDIR} (e.g. x11/tk, lang/tcl,
# etc).
-#
+# EXTRACT_CMD - Command for extracting archive (default: tar).
+# EXTRACT_SUFX - Suffix for archive names (default: .tar.gz).
+# EXTRACT_ARGS - Arguments to ${EXTRACT_CMD} (default: -C ${WRKDIR} -xzf).
+#
+# NCFTP - Full path to ncftp command if not in $PATH (default: ncftp).
+# NCFTP_ARGS - Arguments to ${NCFTP} (default: -N).
+#
#
# Default targets and their behaviors:
#
-# extract - Unpacks ${DISTDIR}/${DISTNAME}.tar.gz into ${WRKDIR}.
+# fetch - Retrieves ${DISTNAME}/${DISTNAME}${EXTRACT_SUFX} as and if
+# necessary.
+# extract - Unpacks ${DISTDIR}/${DISTNAME}${EXTRACT_SUFX} into ${WRKDIR}.
# configure - Applys patches, if any, and runs either GNU configure, one
# or more local configure scripts or nothing, depending on
# what's available.
# build - Actually compile the sources.
# install - Install the results of a build.
# package - Create a package from a build.
-# bundle - From an unextracted source tree, re-create tarballs.
+#
+# Default sequence for "all" is: fetch extract configure build
.if exists(${.CURDIR}/../Makefile.inc)
.include "${.CURDIR}/../Makefile.inc"
.endif
-GMAKE?= gmake
-NCFTP?= /usr/local/bin/ncftp
-NCFTPFLAGS?= -N
-
# These need to be absolute since we don't know how deep in the ports
# tree we are and thus can't go relative. They can, of course, be overridden
# by individual Makefiles.
@@ -72,7 +81,11 @@ DISTDIR?= ${PORTSDIR}/distfiles
PACKAGES?= ${PORTSDIR}/packages
WRKDIR?= ${.CURDIR}/work
+.if defined(NO_WRKSUBDIR)
+WRKSRC?= ${WRKDIR}
+.else
WRKSRC?= ${WRKDIR}/${DISTNAME}
+.endif
PATCHDIR?= ${.CURDIR}/patches
SCRIPTDIR?= ${.CURDIR}/scripts
FILESDIR?= ${.CURDIR}/files
@@ -87,13 +100,16 @@ CONFIGURE_COOKIE?= ${.CURDIR}/.configure_done
DO_NADA?= echo -n
# Miscellaneous overridable commands:
+GMAKE?= gmake
+XMKMF?= xmkmf
+
+NCFTP?= ncftp
+NCFTPFLAGS?= -N
+
EXTRACT_CMD?= tar
EXTRACT_SUFX?= .tar.gz
EXTRACT_ARGS?= -C ${WRKDIR} -xzf
-BUNDLE_CMD?= tar
-BUNDLE_ARGS?= -C ${WRKDIR} -czf
-
PKG_CMD?= pkg_create
PKG_ARGS?= -v -c ${PKGDIR}/COMMENT -d ${PKGDIR}/DESCR -f ${PKGDIR}/PLIST
PKG_SUFX?= .tgz
@@ -244,42 +260,13 @@ ${CONFIGURE_COOKIE}:
@touch -f ${CONFIGURE_COOKIE}
.endif
-.if !target(pre-bundle)
-pre-bundle:
- @${DO_NADA}
-.endif
-
-.if !target(bundle)
-bundle: pre-bundle
- @echo "===> Bundling for ${DISTNAME}"
- @if [ ! -f ${EXTRACT_COOKIE} ]; then \
- echo ">> There doesn't appear to be a properly extracted"; \
- echo ">> distribution for ${DISTNAME}. Skipping.."; \
- exit 0; \
- fi
- @if [ -f ${CONFIGURE_COOKIE} ]; then \
- echo ">> WARNING: This source has been configured and may"; \
- echo ">> produce a tainted distfile!"; \
- fi
- ${BUNDLE_CMD} ${BUNDLE_ARGS} ${DISTFILE} ${DISTNAME}
-.endif
-
-.if !target(pre-extract)
-pre-extract:
+.if !target(pre-fetch)
+pre-fetch:
@${DO_NADA}
.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: pre-extract ${EXTRACT_COOKIE}
-
-${EXTRACT_COOKIE}:
- @echo "===> Extracting for ${DISTNAME}"
- @rm -rf ${WRKDIR}
- @mkdir -p ${WRKDIR}
+.if !target(fetch)
+fetch: pre-fetch
.if defined(HOME_LOCATION)
@if [ ! -f ${DISTFILE} ]; then \
echo ">> Sorry, I can't seem to find: ${DISTFILE}"; \
@@ -313,6 +300,24 @@ ${EXTRACT_COOKIE}:
exit 1; \
fi
.endif
+.endif
+
+.if !target(pre-extract)
+pre-extract:
+ @${DO_NADA}
+.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: fetch pre-extract ${EXTRACT_COOKIE}
+
+${EXTRACT_COOKIE}:
+ @echo "===> Extracting for ${DISTNAME}"
+ @rm -rf ${WRKDIR}
+ @mkdir -p ${WRKDIR}
@${EXTRACT_CMD} ${EXTRACT_ARGS} ${DISTFILE}
@touch -f ${EXTRACT_COOKIE}
.endif