Add -lncurses to LDD flags
[lcr.git] / configure.ac
index cf41b2c..dafd9e2 100644 (file)
@@ -25,24 +25,27 @@ dnl    Boston, MA 02110-1301, USA.
 dnl This keeps being the first instruction.
 dnl Change the 2nd argument if the version increases
 dnl 1st + 2nd argument is used for distribution package name
-AC_INIT(lcr, 1.9, andreas@eversberg.eu)
+AC_INIT(lcr, 1.14, andreas@eversberg.eu)
 AC_PREREQ(2.59)
+AC_CONFIG_AUX_DIR([build-aux])
 AC_CONFIG_SRCDIR([main.c])
-AM_CONFIG_HEADER(config.h)
+AC_CONFIG_HEADER([config.h])
 
 # fix warnings from autoconf + automake
 AC_GNU_SOURCE
-# AC_USE_SYSTEM_EXTENSIONS
-AM_INIT_AUTOMAKE(lcr,1.9)
+dnl AC_USE_SYSTEM_EXTENSIONS
+AM_INIT_AUTOMAKE([foreign subdir-objects])
 
 
 
 # Checks for programs.
+AC_PROG_GREP
 AC_PROG_CPP
 AC_PROG_CXX
 AC_PROG_CC
 AC_PROG_INSTALL
 AC_PROG_MAKE_SET
+AC_PROG_LIBTOOL
 dnl required, if per binary CFLAGS are used
 dnl AM_PROG_CC_C_O
 
@@ -51,6 +54,26 @@ dnl AM_PROG_CC_C_O
 dnl enable this to have all special options on one place
 dnl AC_PRESERVE_HELP_ORDER
 
+# check for mISDN
+AC_ARG_WITH([misdn],
+       [AS_HELP_STRING([--with-misdn],
+                       [compile with mISDN driver @<:@default=check@:>@])
+       ],
+       [],
+       [with_misdn="check"])
+
+AS_IF([test "x$with_misdn" != xno],
+      [AC_CHECK_HEADERS([mISDN/mbuffer.h],
+                       [with_misdn="yes"],
+                       [if test "x$with_misdn" != xcheck ; then
+                      AC_MSG_FAILURE(
+                        [--with-misdn was given, but test for header-file mISDN/mbuffer.h failed])
+                     fi
+                    ])
+      ])
+
+AM_CONDITIONAL(ENABLE_MISDN, test "x$with_misdn" == "xyes" )
+
 # check for asterisk
 AC_ARG_WITH([asterisk],
        [AS_HELP_STRING([--with-asterisk],
@@ -70,60 +93,45 @@ AS_IF([test "x$with_asterisk" != xno],
       ])
 
 if test "x$with_asterisk" = "xyes"; then
+       dnl detect whether asterisk/indications.h defines ast_tone_zone_sound (1.6.2
+       dnl and later), ind_tone_zone_sound (1.6.0) or tone_zone_sound (1.4)
        ast_tone_zone_sound=
+       apc_test_result=
        ast_1_8_or_higher=
 
-       AC_MSG_CHECKING([for struct tone_zone_sound in asterisk/indications.h])
-       tzs_test_result=no
-       AC_COMPILE_IFELSE([
-               AC_LANG_PROGRAM(
-                       [[#include <asterisk.h>],
-                       [#include <asterisk/linkedlists.h>],
-                       [#include <asterisk/indications.h>]],
-                       [[struct tone_zone_sound * ts = NULL; (void) ts->data;]])],
-               [tzs_test_result=yes])
-       AC_MSG_RESULT([$tzs_test_result])
-
-       if test "x$tzs_test_result" = "xyes"; then
-               ast_tone_zone_sound=tone_zone_sound
-       fi
-
-       if test "x$ast_tone_zone_sound" = "x"; then
-               AC_MSG_CHECKING([for struct ast_tone_zone_sound in asterisk/indications.h])
-               tzs_test_result=no
-               AC_COMPILE_IFELSE([
-                       AC_LANG_PROGRAM(
-                               [[#include <asterisk.h>],
-                               [#include <asterisk/linkedlists.h>],
-                               [#include <asterisk/indications.h>]],
-                               [[struct ast_tone_zone_sound * ts = NULL; (void) ts->name;]])],
-                       [tzs_test_result=yes])
-               AC_MSG_RESULT([$tzs_test_result])
-
-               if test "x$tzs_test_result" = "xyes"; then
-                       ast_tone_zone_sound=ast_tone_zone_sound
-               fi
-       fi
+       AC_CHECK_TYPE([struct ast_tone_zone_sound],
+               [ast_tone_zone_sound=ast_tone_zone_sound], [], [
+#include <asterisk.h>
+#include <asterisk/linkedlists.h>
+#include <asterisk/indications.h>])
+
+       AS_IF([test "x$ast_tone_zone_sound" = "x"],
+               [AC_CHECK_TYPE([struct ind_tone_zone_sound],
+                       [ast_tone_zone_sound=ind_tone_zone_sound], [], [
+#include <asterisk.h>
+#include <asterisk/linkedlists.h>
+#include <asterisk/indications.h>])])
+       AS_IF([test "x$ast_tone_zone_sound" = "x"],
+               [AC_CHECK_TYPE([struct tone_zone_sound],
+                       [ast_tone_zone_sound=tone_zone_sound], [], [
+#include <asterisk.h>
+#include <asterisk/indications.h>])])
 
        if test "x$ast_tone_zone_sound" = "x"; then
                AC_MSG_FAILURE([No ast_tone_zone_sound, confused...])
        fi
 
-       AC_MSG_CHECKING([for struct ast_party_caller in asterisk/channel.h])
-       apc_test_result=no
-       AC_COMPILE_IFELSE([
-               AC_LANG_PROGRAM(
-                       [[#include <asterisk.h>],
-                       [#include <asterisk/channel.h>]],
-                       [[struct ast_party_caller * caller = NULL; (void) caller->id;]])],
-               [apc_test_result=yes])
-       AC_MSG_RESULT([$apc_test_result])
+
+       AC_CHECK_TYPE([struct ast_party_caller],
+               [apc_test_result=yes], [], [
+#include <asterisk.h>
+#include <asterisk/channel.h>])
 
        if test "x$apc_test_result" = "xyes"; then
                ast_1_8_or_higher="-DAST_1_8_OR_HIGHER"
        fi
 
-       AST_CFLAGS="-Dtone_zone_sound=$ast_tone_zone_sound $ast_1_8_or_higher"
+       AST_CFLAGS="-Dast_tone_zone_sound=$ast_tone_zone_sound $ast_1_8_or_higher"
 
        AC_SUBST([AST_CFLAGS])
 fi
@@ -158,49 +166,46 @@ AS_IF([test "x$with_ssl" != xno],
 # check for gsm-bs
 AC_ARG_WITH([gsm-bs],
        [AS_HELP_STRING([--with-gsm-bs],
-                       [compile with OpenBSC support @<:@default=check@:>@])
+                       [compile with OpenBSC support @<:@default=no@:>@])
        ],
        [],
        [with_gsm_bs="check"])
 
-AS_IF([test "x$with_gsm_bs" != xno],
-      [AC_MSG_CHECKING(openbsc/include/openbsc/gsm_data.h)
-       if test -e openbsc/include/openbsc/gsm_data.h; then
-               with_gsm_bs="yes"
-               AC_MSG_RESULT(yes)
-       elif test "x$with_gsm_bs" != xcheck ; then
-               AC_MSG_FAILURE([--with-gsm-bs was given, but openbsc/include/openbsc/gsm_data.h was not found! Please link OpenBSC and libosmocore source directory to LCR source directory: ln -s path_to_openbsc/openbsc/ openbsc ; ln -s patch_to_libosmocore libosmocore])
-       else
-               AC_MSG_RESULT(no)
-       fi
-      ])
-
 AM_CONDITIONAL(ENABLE_GSM_BS, test "x$with_gsm_bs" == "xyes" )
 
 # check for gsm-ms
 AC_ARG_WITH([gsm-ms],
        [AS_HELP_STRING([--with-gsm-ms],
-                       [compile with Osmocom-bb support @<:@default=check@:>@])
+                       [compile with Osmocom-bb support @<:@default=no@:>@])
        ],
        [],
        [with_gsm_ms="check"])
 
-AS_IF([test "x$with_gsm_ms" != xno],
-      [AC_MSG_CHECKING(layer23/include/osmocom/bb/common/osmocom_data.h)
-       if test -e layer23/include/osmocom/bb/common/osmocom_data.h; then
-               with_gsm_ms="yes"
-               AC_MSG_RESULT(yes)
-       elif test "x$with_gsm_ms" != xcheck ; then
-               AC_MSG_FAILURE([--with-gsm-ms was given, but layer23/include/osmocom/bb/common/osmocom_data.h was not found! Please link Osmocom-BB and libosmocore source directory to LCR source directory: ln -s path_to_osmocom-bb/src/host/layer23/ layer23 ; ln -s path_to_libosmocore libosmocore])
-       else
-               AC_MSG_RESULT(no)
-       fi
-      ])
-
 AM_CONDITIONAL(ENABLE_GSM_MS, test "x$with_gsm_ms" == "xyes" )
 
 AM_CONDITIONAL(ENABLE_GSM, test "x$with_gsm_bs" == "xyes" -o "x$with_gsm_ms" == "xyes")
 
+# check for opencore-amrnb for AMR and EFR decoding
+found_opencore_amrnb=yes
+PKG_CHECK_MODULES(OPENCORE_AMRNB, opencore-amrnb >= 0.1.0, , found_opencore_amrnb=no)
+AM_CONDITIONAL(ENABLE_GSMAMR, test "$found_opencore_amrnb" = "yes")
+if test "$found_opencore_amrnb" = yes; then
+       AC_DEFINE(HAVE_OPENCORE_AMRNB, 1, [Define to 1 if OpenCore AMR-NB library is available])
+fi
+
+# check for HR codec
+AC_ARG_ENABLE(gsmhr,
+       [AS_HELP_STRING(
+               [--enable-gsmhr],
+               [Enable support for GSM HR codec using reference code]
+       )],
+       [enable_gsmhr=1], [enable_gsmhr=0])
+AM_CONDITIONAL(ENABLE_GSMHR, test "x$enable_gsmhr" = "x1")
+if test "x$enable_gsmhr" = "x1"; then
+       AM_PATH_PYTHON([2.4])
+       AC_DEFINE(HAVE_LIBGSMHR, 1, [Define to 1 if libgsmhr is available])
+fi
+
 # check for ss5
 AC_ARG_WITH([ss5],
        [AS_HELP_STRING([--with-ss5],
@@ -211,6 +216,34 @@ AC_ARG_WITH([ss5],
 
 AM_CONDITIONAL(ENABLE_SS5, test "x$with_ss5" == "xyes" )
 
+# check for SIP
+AC_ARG_WITH([sip],
+       [AS_HELP_STRING([--with-sip],
+                       [compile with SIP support (sofia-sip is required) @<:@default=no@:>@])
+       ],
+       [],
+       [with_sip="check"])
+
+AM_CONDITIONAL(ENABLE_SIP, test "x$with_sip" == "xyes" )
+
+AS_IF([test "x$with_sip" == xyes -o "x$with_sip" == xyes], [
+               PKG_CHECK_MODULES(SOFIA, sofia-sip-ua >= 1.12)
+       ])
+
+# check for VoOTP
+AC_ARG_WITH([vootp],
+       [AS_HELP_STRING([--with-vootp],
+                       [compile with VoOTP support (libvootp is required) @<:@default=no@:>@])
+       ],
+       [],
+       [with_vootp="check"])
+
+AM_CONDITIONAL(ENABLE_VOOTP, test "x$with_vootp" == "xyes" )
+
+AS_IF([test "x$with_vootp" == xyes -o "x$with_vootp" == xyes], [
+               PKG_CHECK_MODULES(VOOTP, libvootp >= 0.0)
+       ])
+
 # Checks for libraries.
 AC_CHECK_LIB([m], [main])
 AC_CHECK_LIB([ncurses], [main])
@@ -220,7 +253,7 @@ AC_CHECK_LIB([pthread], [main])
 AC_HEADER_DIRENT
 AC_HEADER_STDC
 AC_HEADER_SYS_WAIT
-AC_CHECK_HEADERS([fcntl.h netinet/in.h stdlib.h string.h sys/file.h sys/ioctl.h sys/socket.h sys/time.h unistd.h ctype.h assert.h mISDNuser/mbuffer.h assert.h])
+AC_CHECK_HEADERS([fcntl.h netinet/in.h stdlib.h string.h sys/file.h sys/ioctl.h sys/socket.h sys/time.h unistd.h ctype.h assert.h assert.h])
 
 # Checks for typedefs, structures, and compiler characteristics.
 AC_HEADER_STDBOOL
@@ -244,5 +277,17 @@ AC_FUNC_VPRINTF
 AC_CHECK_FUNCS([gettimeofday memmove memset mkdir socket strcasecmp strchr strerror strncasecmp strstr strtol strtoul])
 
 
-AC_CONFIG_FILES([Makefile])
+AC_CONFIG_FILES([Makefile include/Makefile include/gsmhr/Makefile libgsmhr/Makefile])
 AC_OUTPUT
+
+
+AS_IF([test "x$with_misdn" == xyes],[AC_MSG_NOTICE( Compiled with mISDN support )],[AC_MSG_NOTICE( Not compiled with mISDN support)])
+AS_IF([test "x$with_gsm_bs" == xyes],[AC_MSG_NOTICE( Compiled with GSM network side support )],[AC_MSG_NOTICE( Not compiled with GSM network side support)])
+AS_IF([test "x$with_gsm_ms" == xyes],[AC_MSG_NOTICE( Compiled with GSM mobile side support )],[AC_MSG_NOTICE( Not compiled with GSM mobile side support)])
+AS_IF([test "x$enable_gsmhr" == x1],[AC_MSG_NOTICE( Compiled with GSM half rate codec support )],[AC_MSG_NOTICE( Not compiled with GSM half rate codec support)])
+AS_IF([test "x$found_opencore_amrnb" == xyes],[AC_MSG_NOTICE( Compiled with GSM AMR codec support )],[AC_MSG_NOTICE( Not compiled with GSM AMR codec support)])
+AS_IF([test "x$with_asterisk" == xyes],[AC_MSG_NOTICE( Compiled with Asterisk channel driver support )],[AC_MSG_NOTICE( Not compiled with Asterisk channel driver support)])
+AS_IF([test "x$with_ss5" == xyes],[AC_MSG_NOTICE( Compiled with CCITT No.5 support )],[AC_MSG_NOTICE( Not compiled with CCITT No.5 support)])
+AS_IF([test "x$with_sip" == xyes],[AC_MSG_NOTICE( Compiled with SIP support )],[AC_MSG_NOTICE( Not compiled with SIP support)])
+AS_IF([test "x$with_vootp" == xyes],[AC_MSG_NOTICE( Compiled with VoOTP support )],[AC_MSG_NOTICE( Not compiled with VoOTP support)])
+