pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/mk Add an apache.mk, similar to java-vm.mk and emacs.m...



details:   https://anonhg.NetBSD.org/pkgsrc/rev/9a38f547aad4
branches:  trunk
changeset: 460755:9a38f547aad4
user:      erh <erh%pkgsrc.org@localhost>
date:      Thu Sep 04 03:00:19 2003 +0000

description:
Add an apache.mk, similar to java-vm.mk and emacs.mk, that allows apache
modules that will work with more than one version of the apache web server
to not require a separate package for each version of apache.  This was
originally based on java-vm.mk
        Makefile variables added:
                PKG_APACHE_ACCEPTED : Contains the list of valid versions of apache.
                USE_APR : If set, the package required apr to run.
        User variabled added:
                PKG_APACHE_DEFAULT : The version of apache to install, if there is
                                     none yet.  Defaults to apache13
        Variables set:
                PKG_APACHE : Which version of apache is being used.

diffstat:

 mk/apache.mk |  161 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 161 insertions(+), 0 deletions(-)

diffs (165 lines):

diff -r f171822c7e1b -r 9a38f547aad4 mk/apache.mk
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/mk/apache.mk      Thu Sep 04 03:00:19 2003 +0000
@@ -0,0 +1,161 @@
+# $NetBSD: apache.mk,v 1.1 2003/09/04 03:00:19 erh Exp $
+#
+# This Makefile fragment handles Apache dependencies and make variables,
+# and is meant to be included by packages that require Apache either at
+# build-time or at run-time.  apache.mk will:
+#
+#      * set PKG_APACHE to the name of the apache web serverused
+#
+#      * add a full dependency on the apache server
+#
+#      * optionally add a full dependency on apr
+#
+# The available user variables are:
+#
+# PKG_APACHE_DEFAULT is a user-settable variable whose value is the default
+#      apache server to use.  Possible values are apache13, apache2 and apache6.
+#   If there is already a version of apache installed this will have no
+#   effect.
+#
+# The available makefile variables are:
+#
+# PKG_APACHE_ACCEPTED is a package-settable list of servers that may be used as
+#      possible dependencies for the package.  Possible values are the same as
+#   for PKG_APACHE_DEFAULT.
+#
+# USE_APR is used to note that the package requires the Apache Portable
+#   runtime to build and execute.  This is only takes effect if apache2
+#   is chosen (by this file) as the web server to use.  This adds a full
+#   dependency on apr.
+#
+
+.if !defined(APACHE_MK)
+APACHE_MK=     # defined
+
+.include "../../mk/bsd.prefs.mk"
+
+PKG_APACHE_DEFAULT?=   # empty
+
+_PKG_APACHES?= apache13 apache2 apache6
+
+.if defined(PKG_APACHE_ACCEPTED)
+.    for _ap_ in ${PKG_APACHE_ACCEPTED}
+.        if !empty(_PKG_APACHES:M${_ap_})
+           _PKG_APACHE_ACCEPTED+=${PKG_APACHE_ACCEPTED:M${_ap_}}
+.        endif
+.    endfor
+.endif
+
+_PKG_APACHE_ACCEPTED?= ${_PKG_APACHES}
+
+# Set the default apache for this platform.
+#
+.if !empty(PKG_APACHE_DEFAULT)
+_PKG_APACHE_DEFAULT=   ${PKG_APACHE_DEFAULT}
+.endif
+.if !defined(_PKG_APACHE_DEFAULT)
+_PKG_APACHE_DEFAULT?=  apache13
+.endif
+
+_APACHE_PKGBASE.apache13 = apache-1\*
+_APACHE_PKGBASE.apache2 = apache-2\*
+_APACHE_PKGBASE.apache6 = apache6
+
+# Mark the acceptable apaches and check which apache packages are installed.
+.for _ap_ in ${_PKG_APACHE_ACCEPTED}
+_PKG_APACHE_OK.${_ap_}=        yes
+_PKG_APACHE_INSTALLED.${_ap_}!= \
+       if ${PKG_INFO} -qe ${_APACHE_PKGBASE.${_ap_}}; then             \
+               ${ECHO} yes;                                            \
+       else                                                            \
+               ${ECHO} no;                                             \
+       fi
+.endfor
+
+# Use one of the installed apaches,...
+#
+.if !defined(_PKG_APACHE)
+.  for _ap_ in ${_PKG_APACHE_ACCEPTED}
+.    if !empty(_PKG_APACHE_INSTALLED.${_ap_}:M[yY][eE][sS])
+_PKG_APACHE?=  ${_ap_}
+.    else
+_PKG_APACHE_FIRSTACCEPTED?= ${_ap_}
+.    endif
+.  endfor
+.endif
+#
+# ...otherwise, prefer the default one if it's accepted,...
+#
+.if !defined(_PKG_APACHE)
+.  if defined(_PKG_APACHE_OK.${_PKG_APACHE_DEFAULT}) && \
+      !empty(_PKG_APACHE_OK.${_PKG_APACHE_DEFAULT}:M[yY][eE][sS])
+_PKG_APACHE=   ${_PKG_APACHE_DEFAULT}
+.  endif
+.endif
+#
+# ...otherwise, just use the first accepted apache.
+#
+.if !defined(_PKG_APACHE)
+.  if defined(_PKG_APACHE_FIRSTACCEPTED)
+_PKG_APACHE=   ${_PKG_APACHE_FIRSTACCEPTED}
+.  endif
+.endif
+#
+# If there are no acceptable apaches, then generate an error.
+#
+.if !defined(_PKG_APACHE)
+# force an error
+PKG_FAIL_REASON=       "no acceptable apache found"
+_PKG_APACHE=           "none"
+.endif
+
+BUILDLINK_DEPENDS.apache13?=   apache-1.3*
+BUILDLINK_DEPENDS.apache2?=            apache-2*
+BUILDLINK_DEPENDS.apache6?=            apache6*
+
+.if ${_PKG_APACHE} == "apache13"
+_APACHE_PKGSRCDIR=  ../../www/apache
+.elif ${_PKG_APACHE} == "apache2"
+_APACHE_PKGSRCDIR=  ../../www/apache2
+.elif ${_PKG_APACHE} == "apache6"
+_APACHE_PKGSRCDIR=  ../../www/apache6
+.endif
+
+_APACHE_DEPENDENCY?=   ${BUILDLINK_DEPENDS.${_PKG_APACHE}:${_APACHE_PKGSRCDIR}
+
+# Add a runtime dependency on the apache server.
+# This may or may not create an actual dependency depending on
+# what the apache buildlink2.mk file does.
+.if defined(_APACHE_PKGSRCDIR)
+.if defined(USE_BUILDLINK2) && empty(USE_BUILDLINK2:M[nN][oO])
+.  include "${_APACHE_PKGSRCDIR}/buildlink2.mk"
+.else
+DEPENDS+=              ${_APACHE_DEPENDENCY}
+.endif
+.endif
+
+# If we are building apache modules, then we might need a build-time
+# dependency on apr, and the apache sources?
+.if defined(USE_BUILDLINK2) && empty(USE_BUILDLINK2:M[nN][oO])
+.    if defined(_APACHE_PKGSRCDIR)
+.      include "${_APACHE_PKGSRCDIR}/buildlink2.mk"
+.    endif
+.else
+BUILD_DEPENDS+=                ${_APACHE_DEPENDENCY}
+.endif
+
+.if defined(USE_BUILDLINK2) && empty(USE_BUILDLINK2:M[nN][oO])
+.    if ${_PKG_APACHE} == "apache2"
+.        if defined(USE_APR) && !empty(USE_APR:M[yY][eE][sS])
+.          include "../../devel/apr/buildlink2.mk"
+.        endif
+.    endif
+.endif
+
+# PKG_APACHE is a publicly readable variable containing the name of the server
+#      we will be using.
+#
+PKG_APACHE:=           ${_PKG_APACHE}
+BUILD_DEFS+=           PKG_APACHE
+
+.endif # APACHE_MK



Home | Main Index | Thread Index | Old Index