X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=configure.ac;h=7bd5d87080d35d5fce7e12d6deb1e76bef26fef8;hp=dd64493bdbb1f5f8bfd3f99897e73c0bea019d55;hb=13f107bc240d351b1eb1915eff140efe1b4a95bb;hpb=e18b6b14b116a1672723ac4e5714a04174a114d0 diff --git a/configure.ac b/configure.ac index dd64493..7bd5d87 100644 --- a/configure.ac +++ b/configure.ac @@ -2,6 +2,7 @@ dnl This file is part of linux-call-router dnl Copyright (C) 2007 Joerg Habenicht (j.habenicht@gmx.de) +dnl Copyright (C) 2008 Peter Schlaile (peter -at- schlaile.de) dnl This program is free software; you can redistribute it and/or dnl modify it under the terms of the GNU General Public License as @@ -23,23 +24,22 @@ 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, 0.1.20071001, pbx4linux@koeln.ccc.de) -AC_PREREQ(2.61) +AC_INIT(lcr, 1.7, andreas@eversberg.eu) +AC_PREREQ(2.59) AC_CONFIG_SRCDIR([main.c]) -AC_CONFIG_HEADER([config.h]) +AM_CONFIG_HEADER(config.h) # fix warnings from autoconf + automake AC_GNU_SOURCE -AC_USE_SYSTEM_EXTENSIONS -AM_INIT_AUTOMAKE([dist-bzip2]) +# AC_USE_SYSTEM_EXTENSIONS +AM_INIT_AUTOMAKE(lcr,1.7) # Checks for programs. -dnl AC_CHECK_COMPILERS contains AC_PROG_CC AC_PROG_CPP and AC_PROG_CXX -AC_CHECK_COMPILERS -dnl AC_PROG_CXX -dnl AC_PROG_CC +AC_PROG_CPP +AC_PROG_CXX +AC_PROG_CC AC_PROG_INSTALL AC_PROG_MAKE_SET dnl required, if per binary CFLAGS are used @@ -53,11 +53,65 @@ dnl AC_PRESERVE_HELP_ORDER # check for asterisk AC_ARG_WITH([asterisk], [AS_HELP_STRING([--with-asterisk], - [compile with built-in Asterisk channel driver @<:@default=no@:>@]) + [compile with built-in Asterisk channel driver @<:@default=check@:>@]) ], - [with_asterisk_channel_driver="yes"], - [with_asterisk_channel_driver="no"]) -AM_CONDITIONAL(ENABLE_ASTERISK_CHANNEL_DRIVER, test "x$with_asterisk_channel_driver" == "xyes" ) + [], + [with_asterisk="check"]) + +AS_IF([test "x$with_asterisk" != xno], + [AC_CHECK_HEADERS([asterisk/compiler.h], + [with_asterisk="yes"], + [if test "x$with_asterisk" != xcheck ; then + AC_MSG_FAILURE( + [--with-asterisk was given, but test for header-file asterisk/compiler.h failed]) + fi + ]) + ]) + +if test "x$with_asterisk" = "xyes"; then + ast_tone_zone_sound= + + 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 + + if test "x$ast_tone_zone_sound" = "x"; then + AC_MSG_FAILURE([No ast_tone_zone_sound, confused...]) + fi + + AST_CFLAGS="-Dtone_zone_sound=$ast_tone_zone_sound" + AC_SUBST([AST_CFLAGS]) +fi + +AM_CONDITIONAL(ENABLE_ASTERISK_CHANNEL_DRIVER, test "x$with_asterisk" == "xyes" ) # check for crypto AC_ARG_WITH([ssl], @@ -83,41 +137,69 @@ AS_IF([test "x$with_ssl" != xno], ) ] ) -AM_CONDITIONAL(WITH_CRYPTO, test "x$LIBCRYPTO" == "x-lcrypto" ) -# self written test for mISDNuser lib -AC_PATH_MISDNUSER +# check for gsm-bs +AC_ARG_WITH([gsm-bs], + [AS_HELP_STRING([--with-gsm-bs], + [compile with OpenBSC support @<:@default=check@:>@]) + ], + [], + [with_gsm_bs="check"]) + +AS_IF([test "x$with_gsm_bs" != xno], + [AC_CHECK_FILE([openbsc/include/openbsc/gsm_data.h], + [with_gsm_bs="yes"], + [if 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! Pleas link OpenBSC and libosmocore source directory to LCR source directory: ln -s path_to_openbsc/openbsc/ openbsc ; ln -s patch_to_libosmocore libosmocore]) + fi + ]) + ]) + +AM_CONDITIONAL(ENABLE_GSM_BS, test "x$with_gsm_bs" == "xyes" ) -# self written test for mISDN kernel header -AC_PATH_MISDNKERNEL +# check for gsm-ms +AC_ARG_WITH([gsm-ms], + [AS_HELP_STRING([--with-gsm-ms], + [compile with Osmocom-bb support @<:@default=check@:>@]) + ], + [], + [with_gsm_ms="check"]) + +AS_IF([test "x$with_gsm_ms" != xno], + [AC_CHECK_FILE([layer23/include/osmocom/osmocom_data.h], + [with_gsm_ms="yes"], + [if test "x$with_gsm_ms" != xcheck ; then + AC_MSG_FAILURE( + [--with-gsm-ms was given, but osmocom-bb/include/osmocom/osmocom_data.h was not found! Pleas 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]) + 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 ss5 +AC_ARG_WITH([ss5], + [AS_HELP_STRING([--with-ss5], + [compile with CCITT No. 5 support @<:@default=no@:>@]) + ], + [], + [with_ss5="check"]) +AM_CONDITIONAL(ENABLE_SS5, test "x$with_ss5" == "xyes" ) # Checks for libraries. -dnl FIXME: Replace `main' with a function in `-ldl': -dnl AC_CHECK_LIB([dl], [main]) -dnl FIXME: Replace `main' with a function in `-lh323_linux_x86_r': -dnl AC_CHECK_LIB([h323_linux_x86_r], [main]) -dnl FIXME: Replace `main' with a function in `-lisdnnet': -dnl AC_CHECK_LIB([isdnnet], [main]) -# FIXME: Replace `main' with a function in `-lm': AC_CHECK_LIB([m], [main]) -dnl FIXME: Replace `main' with a function in `-lmISDN': -dnl AC_CHECK_LIB([mISDN], [main]) -# FIXME: Replace `main' with a function in `-lncurses': AC_CHECK_LIB([ncurses], [main]) -dnl FIXME: Replace `main' with a function in `-lpt_linux_x86_r': -dnl AC_CHECK_LIB([pt_linux_x86_r], [main]) -# FIXME: Replace `main' with a function in `-lpthread': AC_CHECK_LIB([pthread], [main]) # Checks for header files. 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]) -AC_HEADER_ASSERT +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]) # Checks for typedefs, structures, and compiler characteristics. AC_HEADER_STDBOOL @@ -140,11 +222,6 @@ AC_FUNC_STRTOD AC_FUNC_VPRINTF AC_CHECK_FUNCS([gettimeofday memmove memset mkdir socket strcasecmp strchr strerror strncasecmp strstr strtol strtoul]) -AC_SUBST(misdnuser_libraries) -AC_SUBST(misdnuser_includes) -AC_SUBST(misdnkernel_includes) -AC_SUBST(all_includes) -AC_SUBST(all_libraries) AC_CONFIG_FILES([Makefile]) AC_OUTPUT