Imported Upstream version 3.2.1
[debian/amanda] / config / amanda / readline.m4
index dbf8be5ed943d088eec73756ce507b50f9ff65be..12d8e4da33e1456cc11d400e868b2c41b84e382d 100644 (file)
 #
 # OVERVIEW
 #
-#   Check for readline support.  Defines HAVE_READLINE if readline
+#   Check for readline support.  Defines HAVE_LIBREADLINE if readline
 #   is available, and also checks for a number of readline headers and
 #   adds readline libraries to READLINE_LIBS.
 #
 #   See common-src/util.{c,h}.
 #
+#
+# Some idea taken from AX_LIB_READLINE:
+# ===========================================================================
+#      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
+
 AC_DEFUN([AMANDA_CHECK_READLINE], [
-    AC_ARG_WITH(readline,
-    dnl no initial space here, so the results line up properly
+  AC_ARG_WITH(readline,
+  dnl no initial space here, so the results line up properly
 AS_HELP_STRING([--with-readline], [require readline support (for amrecover)])
 AS_HELP_STRING([--without-readline], [don't search for readline]),
-        [ 
-            case "$withval" in
-                y | ye | yes | n | no) : ;;
-                *) AC_MSG_ERROR([*** --with-readline does not take a value])
-            esac
-            want_readline="$withval"
-        ], [
-            want_readline="maybe" # meaning "only if we can find it"
-        ])
+       [
+           case "$withval" in
+               y | ye | yes | n | no) : ;;
+               *) AC_MSG_ERROR([*** --with-readline does not take a value])
+           esac
+           want_readline="$withval"
+       ], [
+           want_readline="maybe" # meaning "only if we can find it"
+]      )
 
-    # unless the user said "no", look for readline.
-    if test x"$want_readline" != x"no"; then
-        # we need a tgetent() somewhere..
-        proceed="false"
-        AC_CHECK_LIB(termcap, tgetent, [
-            READLINE_LIBS="-ltermcap"
-            proceed="true"
-        ], [
-            AC_CHECK_LIB(curses, tgetent, [
-                READLINE_LIBS="-lcurses"
-                proceed="true"
-            ], [
-                AC_CHECK_LIB(ncurses, tgetent, [
-                    READLINE_LIBS="-lncurses"
-                    proceed="true"
-                ])
-            ])
-        ])
 
-        if $proceed; then
-            proceed="false"
-            AC_CHECK_HEADERS( history.h readline.h readline/history.h readline/readline.h, [
-                # found at least one of the headers, so we can proceed.
-                proceed="true"
-            ])
+  # unless the user said "no", look for readline.
+  if test x"$want_readline" != x"no"; then
+    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 $proceed; then
-            proceed="false"
-            AC_CHECK_LIB(readline,readline, [
-                READLINE_LIBS="-lreadline $READLINE_LIBS"
-                proceed="true"
-            ],,$READLINE_LIBS)
-        fi
+    if test "$ax_cv_lib_readline" != "no"; then
+      ORIG_LIBS="$LIBS"
+      LIBS="$LIBS $ax_cv_lib_readline"
+      READLINE_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
+      LIBS="$ORIG_LIBS"
 
-        if $proceed; then
-            # we have readline!
-            AC_DEFINE(HAVE_READLINE, 1, [System has readline support (headers and libraries)])
-        else
-            # no readline.  if the user *really* wanted it, bail out.
-            if test x"$want_readline" = x"yes"; then
-                AC_MSG_ERROR([*** No readline implementation found.  Try using --with-libraries and --with-includes])
-            fi
-            READLINE_LIBS=""
-        fi
+    else
+      # no readline.  if the user *really* wanted it, bail out.
+      if test x"$want_readline" = x"yes"; then
+       AC_MSG_ERROR([*** No readline implementation found.  Try using --with-libraries and --with-includes])
+      fi
+      READLINE_LIBS=""
     fi
-    AC_SUBST(READLINE_LIBS)
-])
+  fi
+  AC_SUBST(READLINE_LIBS)
+])dnl