summaryrefslogtreecommitdiff
path: root/dns/ldns
diff options
context:
space:
mode:
authorJohn Marino <marino@FreeBSD.org>2016-09-10 01:37:39 +0000
committerJohn Marino <marino@FreeBSD.org>2016-09-10 01:37:39 +0000
commit2833e31685c826daa5f9114c8a5490698a9b111c (patch)
treee95dcd771d1ca66102a11973ac543b4d97072908 /dns/ldns
parentaf370df000ac1228247c1dcce16c2b22440fad5c (diff)
downloadfreebsd-ports-2833e31685c826daa5f9114c8a5490698a9b111c.zip
dns/ldns: Fix SSL library support, tidy options
The makefile for the ldns was very hard to follow due to preprocessor- like hunks changing the logic flow even across targets. As part of the SSL fix, I felt compelled to convert much of the options logic to the modern options framework to make it simpler to follow the makefile logic (as a side benefit the port is a bit more tidy). I also reworked the FreeBSD 9 + GOST option logic to set the new IGNORE_FreeBSD_9 variable if GOST was requested on FreeBSD 9 with the base SSL library. I believe the previous logic using the WITH_OPENSSL_PORT knob and CONFLICTS setting was incorrect. Approvd by: SSL blanket
Diffstat (limited to 'dns/ldns')
-rw-r--r--dns/ldns/Makefile56
1 files changed, 23 insertions, 33 deletions
diff --git a/dns/ldns/Makefile b/dns/ldns/Makefile
index d1b487865b83..684442302594 100644
--- a/dns/ldns/Makefile
+++ b/dns/ldns/Makefile
@@ -15,16 +15,21 @@ LICENSE= BSD3CLAUSE
LICENSE_FILE= ${WRKSRC}/LICENSE
GNU_CONFIGURE= yes
-USES= cpe gmake libtool
+USES= cpe gmake libtool ssl
CPE_VENDOR= nlnetlabs
-USE_OPENSSL= yes
USE_LDCONFIG= yes
+CONFIGURE_ARGS+= --with-ssl=${OPENSSLBASE}
+
.if ! (defined(BUILD_PYLDNS) || defined(BUILD_P5PERL))
OPTIONS_DEFINE= DOXYGEN EXAMPLES DRILL
OPTIONS_DEFAULT= DRILL
DRILL_DESC= With drill program
+
+DOXYGEN_BUILD_DEPENDS= doxygen:devel/doxygen
+DOXYGEN_ALL_TARGET= doc
+DOXYGEN_INSTALL_TARGET= install-manpages
.endif
OPTIONS_DEFINE+= GOST \
@@ -39,6 +44,13 @@ RRTYPETA_DESC= Enable draft RR type ta.
OPTIONS_SUB= yes
+GOST_CONFIGURE_ENABLE= gost
+RRTYPENINFO_CONFIGURE_ENABLE= rrtype-ninfo
+RRTYPERKEY_CONFIGURE_ENABLE= rrtype-rkey
+RRTYPECDS_CONFIGURE_ENABLE= rrtype-cds
+RRTYPEURI_CONFIGURE_ENABLE= rrtype-uri
+RRTYPETA_CONFIGURE_ENABLE= rrtype-ta
+
.include <bsd.port.options.mk>
.if defined(BUILD_PYLDNS)
@@ -52,7 +64,9 @@ LIB_DEPENDS+= libldns.so:dns/ldns
BUILD_DEPENDS+= ${LOCALBASE}/bin/swig:devel/swig13
post-patch:
- @${SED} -i '' -e 's=-I./include/ldns=-I${LOCALBASE}/include/ldns=' ${WRKSRC}/Makefile.in
+ @${REINPLACE_CMD} \
+ -e 's=-I./include/ldns=-I${LOCALBASE}/include/ldns=' \
+ ${WRKSRC}/Makefile.in
.elif defined(BUILD_P5PERL)
USES+= perl5
USE_PERL5= build run
@@ -70,46 +84,22 @@ post-patch:
ALL_TARGET= all
INSTALL_TARGET= install-lib install-h install-config
-.if ${PORT_OPTIONS:MDOXYGEN}
-BUILD_DEPENDS+= doxygen:devel/doxygen
-ALL_TARGET+= doc
-INSTALL_TARGET+=install-manpages
-.endif
-
.endif # BUILD_PYLDNS || BUILD_P5PERL
.if ${PORT_OPTIONS:MGOST}
-. if ${OSVERSION} < 1000015
-WITH_OPENSSL_PORT= yes
-CONFLICTS+= libressl-*
+. if !defined(SSL_DEFAULT) || ${SSL_DEFAULT} == "base"
+IGNORE_FreeBSD_9= Requires openssl version >= 1.0.0
. endif
.else
NO_GOST= --disable-gost
-CONFIGURE_ARGS+=${NO_GOST}
-.endif
-
-.if ${PORT_OPTIONS:MRRTYPENINFO}
-CONFIGURE_ARGS+= --enable-rrtype-ninfo
-.endif
-
-.if ${PORT_OPTIONS:MRRTYPERKEY}
-CONFIGURE_ARGS+= --enable-rrtype-rkey
-.endif
-
-.if ${PORT_OPTIONS:MRRTYPECDS}
-CONFIGURE_ARGS+= --enable-rrtype-cds
-.endif
-
-.if ${PORT_OPTIONS:MRRTYPEURI}
-CONFIGURE_ARGS+= --enable-rrtype-uri
-.endif
-
-.if ${PORT_OPTIONS:MRRTYPETA}
-CONFIGURE_ARGS+= --enable-rrtype-ta
.endif
.if ! (defined(BUILD_PYLDNS) || defined(BUILD_P5PERL))
+post-patch:
+# fix list CPPFLAGS in examples/configure for ssl in LOCALBASE case
+ @${REINPLACE_CMD} -e '/tmp_CPPFLAGS/d' ${WRKSRC}/examples/configure
+
post-configure:
# ac_cv_prog_libtool=../libtool => Always use bundled libtool
.if ${PORT_OPTIONS:MEXAMPLES}