diff mbox

[2/7] autotool conversion: use pkg-config to find 'libmnl', libnftnl' and 'ncurses'.

Message ID 1404728169-7899-3-git-send-email-giorgio.nicole@arcor.de
State Superseded
Delegated to: Pablo Neira
Headers show

Commit Message

Giorgio Dal Molin July 7, 2014, 10:16 a.m. UTC
From: Giorgio <giorgio.nicole@arcor.de>

Use pkg-config to find the compile and link flags for 'libnftnl' and
'libmnl'.

Use the special macro AX_LIB_READLINE to check for libreadline and its
dependencies.

The macro is part of the 'autoconf-archive' project:

https://www.gnu.org/software/autoconf-archive/ax_lib_readline.html
---
 configure.ac          |  19 +++++----
 m4/ax_lib_readlibe.m4 | 107 ++++++++++++++++++++++++++++++++++++++++++++++++++
 src/Makefile.am       |  45 +++++++++++++++++++++
 3 files changed, 163 insertions(+), 8 deletions(-)
 create mode 100644 m4/ax_lib_readlibe.m4
 create mode 100644 src/Makefile.am

Comments

Jan Engelhardt July 7, 2014, 1:08 p.m. UTC | #1
On Monday 2014-07-07 12:16, Giorgio Dal Molin wrote:
>-	     AC_MSG_ERROR([No suitable version of libnftnl found]))
>+dnl Check for package libnftnl
>+PKG_CHECK_MODULES(LIBMNL, [libmnl], , AC_MSG_ERROR([No suitable version of libmnl found]))
>+AC_SUBST(LIBMNL_CFLAGS)
>+AC_SUBST(LIBMNL_LIBS)

Substing CFLAGS and LIBS is not needed; this is already included
in PKG_CHECK_MODULES.

>--- /dev/null
>+++ b/src/Makefile.am
>@@ -0,0 +1,45 @@
>+sbin_PROGRAMS = nft
>+
>+nft_CFLAGS =	-fno-strict-aliasing							\
>+		-Wall									\
>+		-Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations		\
>+		-Wdeclaration-after-statement -Wsign-compare -Winit-self		\
>+		-Wformat-nonliteral -Wformat-security -Wmissing-format-attribute	\
>+		-Wcast-align -Wundef -Wbad-function-cast				\
>+		-Waggregate-return -Wunused -Wwrite-strings				\
>+		@LIBMNL_CFLAGS@ @LIBNFTNL_CFLAGS@
>+
>+nft_CPPFLAGS = -I${srcdir}/../include @DEBUG_CPPFLAGS@

As the pkg-config CFLAGS are really just CPPFLAGS, @LIBMNL_CFLAGS@
and @LIBNFTNL_CFLAGS@ should be put into nft_CPPFLAGS instead. In
fact, you can just use ${LIBMNL_CFLAGS} and ${LIBNFTNL_CFLAGS} (same
for _LIBS) instead, which ensures that you can override them at make
time. Also, if nft_CPPFLAGS is not strictly necessary, use
AM_CPPFLAGS (and AM_CFLAGS) instead.

See also the autotooling I had done earlier
and which you and me have talked about ;)

--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Giorgio Dal Molin July 7, 2014, 2:08 p.m. UTC | #2
----- Original Nachricht ----
Von:     Jan Engelhardt <jengelh@inai.de>
An:      Giorgio Dal Molin <giorgio.nicole@arcor.de>
Datum:   07.07.2014 15:08
Betreff: Re: [PATCH 2/7] autotool conversion: use pkg-config to find 'libmnl',
 libnftnl' and 'ncurses'.

> 
> On Monday 2014-07-07 12:16, Giorgio Dal Molin wrote:
> >-	     AC_MSG_ERROR([No suitable version of libnftnl found]))
> >+dnl Check for package libnftnl
> >+PKG_CHECK_MODULES(LIBMNL, [libmnl], , AC_MSG_ERROR([No suitable version of
> libmnl found]))
> >+AC_SUBST(LIBMNL_CFLAGS)
> >+AC_SUBST(LIBMNL_LIBS)
> 
> Substing CFLAGS and LIBS is not needed; this is already included
> in PKG_CHECK_MODULES.

OK.

> 
> >--- /dev/null
> >+++ b/src/Makefile.am
> >@@ -0,0 +1,45 @@
> >+sbin_PROGRAMS = nft
> >+
> >+nft_CFLAGS =	-fno-strict-aliasing							\
> >+		-Wall									\
> >+		-Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations		\
> >+		-Wdeclaration-after-statement -Wsign-compare -Winit-self		\
> >+		-Wformat-nonliteral -Wformat-security -Wmissing-format-attribute	\
> >+		-Wcast-align -Wundef -Wbad-function-cast				\
> >+		-Waggregate-return -Wunused -Wwrite-strings				\
> >+		@LIBMNL_CFLAGS@ @LIBNFTNL_CFLAGS@
> >+
> >+nft_CPPFLAGS = -I${srcdir}/../include @DEBUG_CPPFLAGS@
> 
> As the pkg-config CFLAGS are really just CPPFLAGS, @LIBMNL_CFLAGS@
> and @LIBNFTNL_CFLAGS@ should be put into nft_CPPFLAGS instead. In
> fact, you can just use ${LIBMNL_CFLAGS} and ${LIBNFTNL_CFLAGS} (same
> for _LIBS) instead, which ensures that you can override them at make
> time. Also, if nft_CPPFLAGS is not strictly necessary, use
> AM_CPPFLAGS (and AM_CFLAGS) instead.
> 
> See also the autotooling I had done earlier
> and which you and me have talked about ;)

OK.

giorgio
--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/configure.ac b/configure.ac
index 3a7647f..b31fe46 100644
--- a/configure.ac
+++ b/configure.ac
@@ -62,17 +62,20 @@  then
 fi
 
 # Checks for libraries.
-AC_CHECK_LIB([mnl], [mnl_socket_open], ,
-	     AC_MSG_ERROR([No suitable version of libmnl found]))
 
-AC_CHECK_LIB([nftnl], [nft_rule_alloc], ,
-	     AC_MSG_ERROR([No suitable version of libnftnl found]))
+dnl Check for package libnftnl
+PKG_CHECK_MODULES(LIBMNL, [libmnl], , AC_MSG_ERROR([No suitable version of libmnl found]))
+AC_SUBST(LIBMNL_CFLAGS)
+AC_SUBST(LIBMNL_LIBS)
 
-AC_CHECK_LIB([gmp], [__gmpz_init], ,
-	     AC_MSG_ERROR([No suitable version of libgmp found]))
+dnl Check for package libnftnl
+PKG_CHECK_MODULES(LIBNFTNL, [libnftnl], , AC_MSG_ERROR([No suitable version of libnftnl found]))
+AC_SUBST(LIBNFTNL_CFLAGS)
+AC_SUBST(LIBNFTNL_LIBS)
 
-AC_CHECK_LIB([readline], [readline], ,
-	     AC_MSG_ERROR([No suitable version of libreadline found]))
+AC_CHECK_LIB([gmp], [__gmpz_init], , AC_MSG_ERROR([No suitable version of libgmp found]))
+
+AX_LIB_READLINE
 
 # Checks for header files.
 AC_HEADER_STDC
diff --git a/m4/ax_lib_readlibe.m4 b/m4/ax_lib_readlibe.m4
new file mode 100644
index 0000000..056f25c
--- /dev/null
+++ b/m4/ax_lib_readlibe.m4
@@ -0,0 +1,107 @@ 
+# ===========================================================================
+#      http://www.gnu.org/software/autoconf-archive/ax_lib_readline.html
+# ===========================================================================
+#
+# SYNOPSIS
+#
+#   AX_LIB_READLINE
+#
+# DESCRIPTION
+#
+#   Searches for a readline compatible library. If found, defines
+#   `HAVE_LIBREADLINE'. If the found library has the `add_history' function,
+#   sets also `HAVE_READLINE_HISTORY'. Also checks for the locations of the
+#   necessary include files and sets `HAVE_READLINE_H' or
+#   `HAVE_READLINE_READLINE_H' and `HAVE_READLINE_HISTORY_H' or
+#   'HAVE_HISTORY_H' if the corresponding include files exists.
+#
+#   The libraries that may be readline compatible are `libedit',
+#   `libeditline' and `libreadline'. Sometimes we need to link a termcap
+#   library for readline to work, this macro tests these cases too by trying
+#   to link with `libtermcap', `libcurses' or `libncurses' before giving up.
+#
+#   Here is an example of how to use the information provided by this macro
+#   to perform the necessary includes or declarations in a C file:
+#
+#     #ifdef HAVE_LIBREADLINE
+#     #  if defined(HAVE_READLINE_READLINE_H)
+#     #    include <readline/readline.h>
+#     #  elif defined(HAVE_READLINE_H)
+#     #    include <readline.h>
+#     #  else /* !defined(HAVE_READLINE_H) */
+#     extern char *readline ();
+#     #  endif /* !defined(HAVE_READLINE_H) */
+#     char *cmdline = NULL;
+#     #else /* !defined(HAVE_READLINE_READLINE_H) */
+#       /* no readline */
+#     #endif /* HAVE_LIBREADLINE */
+#
+#     #ifdef HAVE_READLINE_HISTORY
+#     #  if defined(HAVE_READLINE_HISTORY_H)
+#     #    include <readline/history.h>
+#     #  elif defined(HAVE_HISTORY_H)
+#     #    include <history.h>
+#     #  else /* !defined(HAVE_HISTORY_H) */
+#     extern void add_history ();
+#     extern int write_history ();
+#     extern int read_history ();
+#     #  endif /* defined(HAVE_READLINE_HISTORY_H) */
+#       /* no history */
+#     #endif /* HAVE_READLINE_HISTORY */
+#
+# LICENSE
+#
+#   Copyright (c) 2008 Ville Laurikari <vl@iki.fi>
+#
+#   Copying and distribution of this file, with or without modification, are
+#   permitted in any medium without royalty provided the copyright notice
+#   and this notice are preserved. This file is offered as-is, without any
+#   warranty.
+
+#serial 6
+
+AU_ALIAS([VL_LIB_READLINE], [AX_LIB_READLINE])
+AC_DEFUN([AX_LIB_READLINE], [
+  AC_CACHE_CHECK([for a readline compatible library],
+                 ax_cv_lib_readline, [
+    ORIG_LIBS="$LIBS"
+    for readline_lib in readline edit editline; do
+      for termcap_lib in "" termcap curses ncurses; do
+        if test -z "$termcap_lib"; then
+          TRY_LIB="-l$readline_lib"
+        else
+          TRY_LIB="-l$readline_lib -l$termcap_lib"
+        fi
+        LIBS="$ORIG_LIBS $TRY_LIB"
+        AC_TRY_LINK_FUNC(readline, ax_cv_lib_readline="$TRY_LIB")
+        if test -n "$ax_cv_lib_readline"; then
+          break
+        fi
+      done
+      if test -n "$ax_cv_lib_readline"; then
+        break
+      fi
+    done
+    if test -z "$ax_cv_lib_readline"; then
+      ax_cv_lib_readline="no"
+    fi
+    LIBS="$ORIG_LIBS"
+  ])
+
+  if test "$ax_cv_lib_readline" != "no"; then
+    LIBS="$LIBS $ax_cv_lib_readline"
+    AC_DEFINE(HAVE_LIBREADLINE, 1,
+              [Define if you have a readline compatible library])
+    AC_CHECK_HEADERS(readline.h readline/readline.h)
+    AC_CACHE_CHECK([whether readline supports history],
+                   ax_cv_lib_readline_history, [
+      ax_cv_lib_readline_history="no"
+      AC_TRY_LINK_FUNC(add_history, ax_cv_lib_readline_history="yes")
+    ])
+    if test "$ax_cv_lib_readline_history" = "yes"; then
+      AC_DEFINE(HAVE_READLINE_HISTORY, 1,
+                [Define if your readline library has \`add_history'])
+      AC_CHECK_HEADERS(history.h readline/history.h)
+    fi
+  fi
+])dnl
diff --git a/src/Makefile.am b/src/Makefile.am
new file mode 100644
index 0000000..210147e
--- /dev/null
+++ b/src/Makefile.am
@@ -0,0 +1,45 @@ 
+sbin_PROGRAMS = nft
+
+nft_CFLAGS =	-fno-strict-aliasing							\
+		-Wall									\
+		-Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations		\
+		-Wdeclaration-after-statement -Wsign-compare -Winit-self		\
+		-Wformat-nonliteral -Wformat-security -Wmissing-format-attribute	\
+		-Wcast-align -Wundef -Wbad-function-cast				\
+		-Waggregate-return -Wunused -Wwrite-strings				\
+		@LIBMNL_CFLAGS@ @LIBNFTNL_CFLAGS@
+
+nft_CPPFLAGS = -I${srcdir}/../include @DEBUG_CPPFLAGS@
+
+nft_LDADD = @LIBMNL_LIBS@ @LIBNFTNL_LIBS@
+
+AM_YFLAGS = -d
+BUILT_SOURCES =	scanner.c scanner.h yacc_parser.c yacc_parser.h
+
+scanner.h: scanner.c
+
+nft_SOURCES = 	main.c				\
+		cli.c				\
+		rule.c				\
+		statement.c			\
+		datatype.c			\
+		expression.c			\
+		evaluate.c			\
+		proto.c				\
+		payload.c			\
+		exthdr.c			\
+		meta.c				\
+		ct.c				\
+		netlink.c			\
+		netlink_linearize.c		\
+		netlink_delinearize.c		\
+		segtree.c			\
+		rbtree.c			\
+		gmputil.c			\
+		utils.c				\
+		erec.c				\
+		mnl.c				\
+		scanner.l			\
+		yacc_parser.y
+
+CLEANFILES = *~ scanner.c scanner.h yacc_parser.c yacc_parser.h