X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=configure.ac;h=d778c2c15e6c30514a5883dd3f7fefd735d26569;hp=5e01e41bb054eaef6a0b37e3c3e815850dd119a7;hb=729893ae61a8c4a9ffbcd4efbfda4fac5713c736;hpb=7798beeab23fa282d4a510c53d5f95ed3f8c2366 diff --git a/configure.ac b/configure.ac index 5e01e41..d778c2c 100644 --- a/configure.ac +++ b/configure.ac @@ -25,7 +25,7 @@ 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.8, andreas@eversberg.eu) +AC_INIT(lcr, 1.14, andreas@eversberg.eu) AC_PREREQ(2.59) AC_CONFIG_SRCDIR([main.c]) AM_CONFIG_HEADER(config.h) @@ -33,16 +33,18 @@ AM_CONFIG_HEADER(config.h) # fix warnings from autoconf + automake AC_GNU_SOURCE # AC_USE_SYSTEM_EXTENSIONS -AM_INIT_AUTOMAKE(lcr,1.8) +AM_INIT_AUTOMAKE(lcr,1.14) # 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 +53,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,62 +92,64 @@ 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 ], - [#include ], - [#include ]], - [[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 ], - [#include ], - [#include ]], - [[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 +#include +#include ]) + + 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 +#include +#include ])]) + AS_IF([test "x$ast_tone_zone_sound" = "x"], + [AC_CHECK_TYPE([struct tone_zone_sound], + [ast_tone_zone_sound=tone_zone_sound], [], [ +#include +#include ])]) 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 ], - [#include ]], - [[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 +#include ]) 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]) + + AC_CHECK_PROG(ASTERISK, asterisk, executable found,) + if test x"$ASTERISK" = x; then + AC_MSG_ERROR([asterisk executable not found]) + fi + + AC_MSG_CHECKING([for asterisk's version]) + version=`asterisk -V` + pri=`echo $version | sed 's#.* \([0-9]*\)\.\([0-9]*\)\.\([0-9]*\)#\1#' ` + sec=`echo $version | sed 's#.* \([0-9]*\)\.\([0-9]*\)\.\([0-9]*\)#\2#' ` + ter=`echo $version | sed 's#.* \([0-9]*\)\.\([0-9]*\)\.\([0-9]*\)#\3#' ` + numver="$(printf '%02d' "$pri")$(printf '%02d' "$sec")$(printf '%02d' "$ter")" +# if [ $numver -lt 100000 ]; then +# AC_MSG_ERROR([Asterisk version found is too old; x.y.z required]) +# fi + AC_MSG_RESULT([$numver]) + AC_DEFINE_UNQUOTED([ASTERISK_VERSION_NUM], $numver, [Asterisk version found]) fi AM_CONDITIONAL(ENABLE_ASTERISK_CHANNEL_DRIVER, test "x$with_asterisk" == "xyes" ) @@ -158,49 +182,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 +232,20 @@ 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) + ]) + # Checks for libraries. AC_CHECK_LIB([m], [main]) AC_CHECK_LIB([ncurses], [main]) @@ -220,7 +255,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 +279,16 @@ 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)]) +