2007-01-22 21:47:06 +01:00
|
|
|
# $NetBSD: bsd.pkg.use.mk,v 1.40 2007/01/22 20:47:06 rillig Exp $
|
2005-02-11 16:55:13 +01:00
|
|
|
#
|
|
|
|
# Turn USE_* macros into proper depedency logic. Included near the top of
|
|
|
|
# bsd.pkg.mk, after bsd.prefs.mk.
|
2007-01-07 14:38:52 +01:00
|
|
|
#
|
|
|
|
# Package-settable variables:
|
|
|
|
#
|
|
|
|
# USE_BSD_MAKEFILE
|
|
|
|
# Should be set to "yes" whenever a package uses a BSD-style
|
|
|
|
# Makefile. These Makefiles typically end with a line including
|
|
|
|
# <bsd.prog.mk>.
|
|
|
|
#
|
2005-02-11 16:55:13 +01:00
|
|
|
|
2007-01-07 14:38:52 +01:00
|
|
|
.if defined(USE_BSD_MAKEFILE)
|
|
|
|
MAKE_ENV+= ${BSD_MAKE_ENV}
|
|
|
|
USE_TOOLS+= nroff
|
|
|
|
.endif
|
2005-02-11 16:55:13 +01:00
|
|
|
|
2005-05-18 00:22:52 +02:00
|
|
|
.if defined(USE_IMAKE) || !empty(USE_TOOLS:Mimake)
|
2005-12-05 23:07:07 +01:00
|
|
|
PLIST_SUBST+= IMAKE_MAN_SOURCE_PATH=${IMAKE_MAN_SOURCE_PATH:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_MAN_DIR=${IMAKE_MAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_LIBMAN_DIR=${IMAKE_LIBMAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_KERNMAN_DIR=${IMAKE_KERNMAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_FILEMAN_DIR=${IMAKE_FILEMAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_GAMEMAN_DIR=${IMAKE_GAMEMAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_MISCMAN_DIR=${IMAKE_MISCMAN_DIR:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_MAN_SUFFIX=${IMAKE_MAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_LIBMAN_SUFFIX=${IMAKE_LIBMAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_KERNMAN_SUFFIX=${IMAKE_KERNMAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_FILEMAN_SUFFIX=${IMAKE_FILEMAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_GAMEMAN_SUFFIX=${IMAKE_GAMEMAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_MISCMAN_SUFFIX=${IMAKE_MISCMAN_SUFFIX:Q}
|
|
|
|
PLIST_SUBST+= IMAKE_MANNEWSUFFIX=${IMAKE_MANNEWSUFFIX:Q}
|
2005-06-14 04:09:38 +02:00
|
|
|
.endif
|
|
|
|
|
Teach the tools framework about the following new tools:
itools, intltool, diff3, sdiff, msgmerge
* Adding USE_TOOLS+=itools to a package Makefile will cause the
tool-directory versions of imake, makedepend, mkdirhier and xmkmf
to point to the ones from the devel/nbitools package.
This change will remove the need for nbitools/buildlink3.mk, which
currently does a bit of hackery to force the "right" imake tools to
be used by packages that need it.
* Adding USE_TOOLS+=intltool to a package Makefile will cause the
local versions of intltool-* inside ${WRKSRC} to be replaced by
copies from the textproc/intltool package. If "intltool" is not
specified as a tool, then we create "broken" intltool-* tools in
the tools directory to help highlight hidden dependencies on the
intltool package.
In addition, modify the tools framework so that if "perl" is not
specified as a tool, then we create a "broken" perl tool in the
tools directory for the same reason as for "intltool".
These two changes together will remove the need for
intltools/buildlink3.mk and should also catch all cases where the
sources' intltools may have been silently used because perl was
found on the system.
* Adding USE_TOOLS+=diff3, USE_TOOLS+=sdiff, or USE_TOOLS+=msgmerge
to a package Makefile will cause the corresponding tool to be pulled
into the tools directory.
These are convenience tools to help simplify dependencies for some
packages.
2006-07-05 06:32:10 +02:00
|
|
|
.if defined(USE_IMAKE) && empty(USE_TOOLS:Mitools)
|
2005-06-14 04:09:38 +02:00
|
|
|
USE_X11BASE?= implied
|
Teach the tools framework about the following new tools:
itools, intltool, diff3, sdiff, msgmerge
* Adding USE_TOOLS+=itools to a package Makefile will cause the
tool-directory versions of imake, makedepend, mkdirhier and xmkmf
to point to the ones from the devel/nbitools package.
This change will remove the need for nbitools/buildlink3.mk, which
currently does a bit of hackery to force the "right" imake tools to
be used by packages that need it.
* Adding USE_TOOLS+=intltool to a package Makefile will cause the
local versions of intltool-* inside ${WRKSRC} to be replaced by
copies from the textproc/intltool package. If "intltool" is not
specified as a tool, then we create "broken" intltool-* tools in
the tools directory to help highlight hidden dependencies on the
intltool package.
In addition, modify the tools framework so that if "perl" is not
specified as a tool, then we create a "broken" perl tool in the
tools directory for the same reason as for "intltool".
These two changes together will remove the need for
intltools/buildlink3.mk and should also catch all cases where the
sources' intltools may have been silently used because perl was
found on the system.
* Adding USE_TOOLS+=diff3, USE_TOOLS+=sdiff, or USE_TOOLS+=msgmerge
to a package Makefile will cause the corresponding tool to be pulled
into the tools directory.
These are convenience tools to help simplify dependencies for some
packages.
2006-07-05 06:32:10 +02:00
|
|
|
.endif
|
|
|
|
|
|
|
|
.if defined(USE_IMAKE)
|
2005-03-24 18:46:00 +01:00
|
|
|
MAKE_FLAGS+= CC=${CC:Q} CXX=${CXX:Q}
|
2005-02-11 16:55:13 +01:00
|
|
|
.endif
|
|
|
|
|
|
|
|
.if defined(USE_X11BASE)
|
2005-06-23 20:41:57 +02:00
|
|
|
MTREE_FILE?= ${PKGSRCDIR}/mk/platform/${OPSYS}.x11.dist
|
2006-12-20 02:04:46 +01:00
|
|
|
. if ${X11_TYPE} != "modular"
|
|
|
|
. include "../../mk/x11.buildlink3.mk"
|
|
|
|
. endif
|
2005-02-11 16:55:13 +01:00
|
|
|
.endif
|
|
|
|
|
|
|
|
.if ${PKG_INSTALLATION_TYPE} == "pkgviews"
|
|
|
|
PREFIX= ${DEPOTBASE}/${PKGNAME}
|
|
|
|
.elif ${PKG_INSTALLATION_TYPE} == "overwrite"
|
|
|
|
. if defined(INSTALLATION_PREFIX)
|
|
|
|
PREFIX= ${INSTALLATION_PREFIX}
|
|
|
|
. elif defined(USE_X11BASE)
|
|
|
|
PREFIX= ${X11PREFIX}
|
|
|
|
. elif defined(USE_CROSSBASE)
|
|
|
|
PREFIX= ${CROSSBASE}
|
|
|
|
. else
|
|
|
|
PREFIX= ${LOCALBASE}
|
|
|
|
. endif
|
|
|
|
.endif
|
|
|
|
|
|
|
|
.if (${PKG_INSTALLATION_TYPE} == "pkgviews") && defined(INSTALLATION_PREFIX)
|
|
|
|
PKG_SKIP_REASON= "INSTALLATION_PREFIX can't be used in a pkgviews package"
|
|
|
|
.endif
|
2005-02-11 17:11:36 +01:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
# General settings
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
### PKG_USE_KERBEROS
|
|
|
|
|
|
|
|
.if defined(PKG_USE_KERBEROS)
|
|
|
|
CRYPTO?= uses Kerberos encryption code
|
|
|
|
BUILD_DEFS+= KERBEROS
|
|
|
|
.endif
|
|
|
|
|
|
|
|
### USE_DIRS
|
|
|
|
|
|
|
|
USE_DIRS?= # empty
|
|
|
|
.if !empty(USE_DIRS) && ${PKG_INSTALLATION_TYPE} == "overwrite"
|
|
|
|
. include "../../mk/dirs.mk"
|
|
|
|
.endif
|
|
|
|
|
|
|
|
### USE_LIBTOOL, PKG_[SH]LIBTOOL
|
|
|
|
|
|
|
|
#
|
|
|
|
# PKG_LIBTOOL is the path to the libtool script installed by libtool-base.
|
|
|
|
# _LIBTOOL is the path the libtool used by the build, which could be the
|
|
|
|
# path to a libtool wrapper script.
|
|
|
|
# LIBTOOL is the publicly-readable variable that should be used by
|
|
|
|
# Makefiles to invoke the proper libtool.
|
|
|
|
#
|
|
|
|
PKG_LIBTOOL?= ${LOCALBASE}/bin/libtool
|
|
|
|
PKG_SHLIBTOOL?= ${LOCALBASE}/bin/shlibtool
|
|
|
|
_LIBTOOL?= ${PKG_LIBTOOL}
|
|
|
|
_SHLIBTOOL?= ${PKG_SHLIBTOOL}
|
|
|
|
LIBTOOL?= ${PKG_LIBTOOL}
|
|
|
|
SHLIBTOOL?= ${PKG_SHLIBTOOL}
|
|
|
|
.if defined(USE_LIBTOOL)
|
2005-09-21 22:37:01 +02:00
|
|
|
LIBTOOL_REQD?= 1.5.18nb5
|
2005-02-11 17:11:36 +01:00
|
|
|
BUILD_DEPENDS+= libtool-base>=${_OPSYS_LIBTOOL_REQD:U${LIBTOOL_REQD}}:../../devel/libtool-base
|
|
|
|
CONFIGURE_ENV+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}"
|
|
|
|
MAKE_ENV+= LIBTOOL="${LIBTOOL} ${LIBTOOL_FLAGS}"
|
|
|
|
.endif
|
|
|
|
|
|
|
|
### USE_XPKGWEDGE
|
|
|
|
|
2005-06-14 22:04:36 +02:00
|
|
|
.if (defined(USE_X11BASE) || \
|
2005-07-20 01:01:55 +02:00
|
|
|
defined(USE_IMAKE) || !empty(USE_TOOLS:Mimake) || \
|
|
|
|
!empty(USE_TOOLS:Mimake\:*:Nimake\:pkgsrc)) && \
|
Teach the tools framework about the following new tools:
itools, intltool, diff3, sdiff, msgmerge
* Adding USE_TOOLS+=itools to a package Makefile will cause the
tool-directory versions of imake, makedepend, mkdirhier and xmkmf
to point to the ones from the devel/nbitools package.
This change will remove the need for nbitools/buildlink3.mk, which
currently does a bit of hackery to force the "right" imake tools to
be used by packages that need it.
* Adding USE_TOOLS+=intltool to a package Makefile will cause the
local versions of intltool-* inside ${WRKSRC} to be replaced by
copies from the textproc/intltool package. If "intltool" is not
specified as a tool, then we create "broken" intltool-* tools in
the tools directory to help highlight hidden dependencies on the
intltool package.
In addition, modify the tools framework so that if "perl" is not
specified as a tool, then we create a "broken" perl tool in the
tools directory for the same reason as for "intltool".
These two changes together will remove the need for
intltools/buildlink3.mk and should also catch all cases where the
sources' intltools may have been silently used because perl was
found on the system.
* Adding USE_TOOLS+=diff3, USE_TOOLS+=sdiff, or USE_TOOLS+=msgmerge
to a package Makefile will cause the corresponding tool to be pulled
into the tools directory.
These are convenience tools to help simplify dependencies for some
packages.
2006-07-05 06:32:10 +02:00
|
|
|
empty(USE_TOOLS:Mitools) && \
|
2006-01-12 19:39:13 +01:00
|
|
|
empty(PKGPATH:Mpkgtools/xpkgwedge) && \
|
2005-06-14 22:04:36 +02:00
|
|
|
!empty(USE_XPKGWEDGE:M[yY][eE][sS])
|
2006-01-12 20:05:06 +01:00
|
|
|
BUILD_DEPENDS+= xpkgwedge>=${_XPKGWEDGE_REQD:U1.15}:../../pkgtools/xpkgwedge
|
2005-02-11 17:11:36 +01:00
|
|
|
.endif
|