X-Git-Url: http://git.tuebingen.mpg.de/?a=blobdiff_plain;f=configure.ac;h=20b8b52cf767995e69eb3db88c8e1fb74902b31e;hb=aa95c5c31ea1d990cd02907e5537eef477a539d3;hp=79b41a3addcf36f0066838c68edfea2b8de0b7c9;hpb=2cbca80137dd7b4229ba984080ac5410da546c71;p=paraslash.git diff --git a/configure.ac b/configure.ac index 79b41a3a..20b8b52c 100644 --- a/configure.ac +++ b/configure.ac @@ -24,6 +24,46 @@ AC_DEFUN([objlist_to_errlist],[ \ make_errlist_defines($@) \ [const char **para_errlist[[]]] = {make_para_errlists($@)} \ ]) +AC_DEFUN([LIB_ARG_WITH], [ + AC_ARG_WITH($1-headers, [AS_HELP_STRING(--with-$1-headers=dir, + [look for $1 headers in dir])]) + AC_ARG_WITH($1-libs, [AS_HELP_STRING(--with-$1-libs=dir, + [look for $1 libraries in dir])]) + if test -n "$with_$1_headers"; then + $1_cppflags="-I$with_$1_headers" + CPPFLAGS="$CPPFLAGS $$1_cppflags" + fi + if test -n "$with_$1_libs"; then + $1_ldflags="-L$with_$1_libs $2" + else + $1_ldflags="$2" + fi + LDFLAGS="$LDFLAGS $$1_ldflags" +]) + +AC_DEFUN([STASH_FLAGS], [ + OLD_CPPFLAGS="$CPPFLAGS" + OLD_LDFLAGS="$LDFLAGS" + OLD_LIBS="$LIBS" +]) + +AC_DEFUN([UNSTASH_FLAGS], [ + CPPFLAGS="$OLD_CPPFLAGS" + LDFLAGS="$OLD_LDFLAGS" + LIBS="$OLD_LIBS" +]) +AC_DEFUN([LIB_SUBST_FLAGS], [ + if test "$HAVE_[]m4_toupper([$1])" == 'yes'; then + AC_DEFINE(HAVE_[]m4_toupper([$1]), 1, + define to 1 to turn on $1 support) + else + $1_cppflags= + $1_ldflags= + fi + AC_SUBST(HAVE_[]m4_toupper([$1])) + AC_SUBST($1_cppflags) + AC_SUBST($1_ldflags) +]) AC_PATH_PROG(UNAMEPATH, uname, no) if test "$UNAMEPATH" = "no"; then @@ -69,41 +109,15 @@ fi if test "$clock_gettime_lib" = "rt"; then AC_SUBST(clock_gettime_ldflags, -lrt) fi -########################################################################### osl -have_osl=yes -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" -AC_ARG_WITH(osl_headers, [AS_HELP_STRING(--with-osl-headers=dir, - [look for osl.h also in dir])]) -if test -n "$with_osl_headers"; then - osl_cppflags="-I$with_osl_headers" - CPPFLAGS="$CPPFLAGS $osl_cppflags" -fi -AC_ARG_WITH(osl_libs, [AS_HELP_STRING(--with-osl-libs=dir, - [look for libosl also in dir])]) -if test -n "$with_osl_libs"; then - osl_libs="-L$with_osl_libs" - LDFLAGS="$LDFLAGS $osl_libs" -fi -AC_CHECK_HEADER(osl.h, [], have_osl=no) -AC_CHECK_LIB([osl], [osl_open_table], [], have_osl=no) -if test "$have_osl" = "yes"; then - AC_SUBST(osl_cppflags) - osl_ldflags="$osl_libs -losl" - AC_SUBST(osl_ldflags) -else - AC_MSG_WARN([libosl not found, can not build para_server. -Download libosl at - http://people.tuebingen.mpg.de/maan/osl/ -or execute - git clone git://git.tuebingen.mpg.de/osl - ]) -fi -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" +########################################################################### osl +STASH_FLAGS +LIB_ARG_WITH([osl], [-losl]) +HAVE_OSL=yes +AC_CHECK_HEADER(osl.h, [], [HAVE_OSL=no]) +AC_CHECK_LIB([osl], [osl_open_table], [], [HAVE_OSL=no]) +LIB_SUBST_FLAGS(osl) +UNSTASH_FLAGS ########################################################################### crypto AC_ARG_ENABLE(cryptolib, [AS_HELP_STRING(--enable-cryptolib=lib, [ Force using crypto library "lib". This package requires either @@ -301,19 +315,30 @@ if test ${have_core_audio} = yes; then AC_SUBST(core_audio_ldflags) AC_DEFINE(HAVE_CORE_AUDIO, 1, define to 1 on Mac Os X) fi +########################################################################### ogg +STASH_FLAGS +LIB_ARG_WITH([ogg], [-logg]) +HAVE_OGG=yes +AC_CHECK_HEADERS([ogg/ogg.h], [], [HAVE_OGG=no]) +AC_CHECK_LIB([ogg], [ogg_stream_init], [], [HAVE_OGG=no]) +LIB_SUBST_FLAGS(ogg) +UNSTASH_FLAGS +######################################################################### vorbis +STASH_FLAGS +LIB_ARG_WITH([vorbis], [-lvorbis -lvorbisfile]) +HAVE_VORBIS=yes +AC_CHECK_HEADERS([vorbis/codec.h], [], [HAVE_VORBIS=no]) +AC_CHECK_LIB([vorbis], [vorbis_info_init], [], [HAVE_VORBIS=no]) +LIB_SUBST_FLAGS(vorbis) +UNSTASH_FLAGS + +AC_DEFUN([NEED_OGG_OBJECTS], [{ + test "$HAVE_OGG" = 'yes' -a "$HAVE_VORBIS" = 'yes' +}]) +AC_DEFUN([NEED_VORBIS_OBJECTS], [{ + test "$HAVE_OGG" = 'yes' -a "$HAVE_VORBIS" = 'yes' +}]) ####################################################### ogg/vorbis/speex/opus -have_ogg="yes" -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" -AC_ARG_WITH(ogg_headers, [AS_HELP_STRING(--with-ogg-headers=dir, - [look for ogg headers also in dir])]) -AC_ARG_WITH(ogg_libs, [AS_HELP_STRING(--with-ogg-libs=dir, - [look for ogg libs also in dir])]) -AC_ARG_WITH(vorbis_headers, [AS_HELP_STRING(--with-vorbis-headers=dir, - [look for vorbis headers also in dir])]) -AC_ARG_WITH(vorbis_libs, [AS_HELP_STRING(--with-vorbis-libs=dir, - [look for vorbis libs also in dir])]) AC_ARG_WITH(speex_headers, [AS_HELP_STRING(--with-speex-headers=dir, [look for speex headers also in dir])]) AC_ARG_WITH(speex_libs, [AS_HELP_STRING(--with-speex-libs=dir, @@ -323,41 +348,9 @@ AC_ARG_WITH(opus_headers, [AS_HELP_STRING(--with-opus-headers=dir, AC_ARG_WITH(opus_libs, [AS_HELP_STRING(--with-opus-libs=dir, [look for opus libs also in dir])]) -if test -n "$with_ogg_headers"; then - ogg_cppflags="-I$with_ogg_headers" - CPPFLAGS="$CPPFLAGS $ogg_cppflags" -fi -if test -n "$with_ogg_libs"; then - ogg_libs="-L$with_ogg_libs" - LDFLAGS="$LDFLAGS $ogg_libs" -fi -AC_CHECK_HEADERS([ogg/ogg.h], [], [ have_ogg="no"; ]) -AC_CHECK_LIB([ogg], [ogg_stream_init], [], [ have_ogg="no" ]) -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" - -have_vorbis="yes" have_speex="yes" have_opus="yes" -if test "$have_ogg" = "yes"; then - OLD_CPPFLAGS="$CPPFLAGS" - OLD_LDFLAGS="$LDFLAGS" - OLD_LIBS="$LIBS" - # vorbis - if test -n "$with_vorbis_headers"; then - vorbis_cppflags="-I$with_vorbis_headers" - CPPFLAGS="$CPPFLAGS $vorbis_cppflags" - fi - if test -n "$with_vorbis_libs"; then - vorbis_libs="-L$with_vorbis_libs" - LDFLAGS="$LDFLAGS $vorbis_libs" - fi - AC_CHECK_HEADERS([vorbis/codec.h], [], [ have_vorbis="no" ]) - AC_CHECK_LIB([vorbis], [vorbis_info_init], [], [ have_vorbis="no" ]) - CPPFLAGS="$OLD_CPPFLAGS" - LDFLAGS="$OLD_LDFLAGS" - LIBS="$OLD_LIBS" +if test "$HAVE_OGG" = 'yes'; then # speex OLD_CPPFLAGS="$CPPFLAGS" @@ -396,28 +389,10 @@ if test "$have_ogg" = "yes"; then LIBS="$OLD_LIBS" else AC_MSG_WARN([vorbis/speex/opus depend on libogg, which was not detected]) - have_vorbis="no" have_speex="no" have_opus="no" fi -msg="support in para_server/para_filter/para_afh" -if test "$have_vorbis" = "yes" || \ - test "$have_speex" = "yes" || \ - test "$have_opus" = "yes"; then - AC_SUBST(ogg_cppflags) - ogg_ldflags="$ogg_libs -logg" - if test "$OSTYPE" = "Darwin"; then - ogg_ldflags="-Wl,-bind_at_load $ogg_ldflags" - fi - AC_SUBST(ogg_ldflags) -fi -if test "$have_vorbis" = "yes"; then - AC_DEFINE(HAVE_OGGVORBIS, 1, define to 1 to turn on ogg/vorbis support) - AC_SUBST(vorbis_cppflags) - vorbis_ldflags="$vorbis_libs -lvorbis -lvorbisfile" - AC_SUBST(vorbis_ldflags) -fi if test "$have_speex" = "yes"; then AC_DEFINE(HAVE_SPEEX, 1, define to 1 to turn on ogg/speex support) AC_SUBST(speex_cppflags) @@ -781,7 +756,7 @@ LDFLAGS="$OLD_LDFLAGS" LIBS="$OLD_LIBS" ######################################################################### server if test \( "$have_openssl" = "yes" -o "$have_gcrypt" = "yes" \) \ - -a "$have_osl" = "yes" ; then + -a "$HAVE_OSL" = "yes" ; then build_server="yes" executables="$executables server" @@ -831,14 +806,8 @@ if test \( "$have_openssl" = "yes" -o "$have_gcrypt" = "yes" \) \ if test "$have_gcrypt" = "yes"; then server_errlist_objs="$server_errlist_objs gcrypt" fi - if test "$have_vorbis" = "yes" || \ - test "$have_speex" = "yes" || \ - test "$have_opus" = "yes"; then - server_errlist_objs="$server_errlist_objs ogg_afh_common" - fi - if test "$have_vorbis" = "yes"; then - server_errlist_objs="$server_errlist_objs ogg_afh" - fi + NEED_OGG_OBJECTS() && server_errlist_objs="$server_errlist_objs ogg_afh_common" + NEED_VORBIS_OBJECTS() && server_errlist_objs="$server_errlist_objs ogg_afh" if test "$have_speex" = "yes"; then server_errlist_objs="$server_errlist_objs spx_afh spx_common" fi @@ -960,10 +929,10 @@ if test "$have_openssl" = "yes" -o "$have_gcrypt" = "yes"; then audiod_errlist_objs="$audiod_errlist_objs osx_write ipc" audiod_cmdline_objs="$audiod_cmdline_objs osx_write" fi - if test "$have_vorbis" = "yes"; then + NEED_VORBIS_OBJECTS && { audiod_errlist_objs="$audiod_errlist_objs oggdec_filter" audiod_audio_formats="$audiod_audio_formats ogg" - fi + } if test "$have_speex" = "yes"; then audiod_errlist_objs="$audiod_errlist_objs spxdec_filter spx_common" audiod_audio_formats="$audiod_audio_formats spx" @@ -1128,11 +1097,10 @@ filter_cmdline_objs=" prebuffer_filter sync_filter " - -if test "$have_vorbis" = "yes"; then +NEED_VORBIS_OBJECTS && { filters="$filters oggdec" filter_errlist_objs="$filter_errlist_objs oggdec_filter" -fi +} if test "$have_speex" = "yes"; then filters="$filters spxdec" filter_errlist_objs="$filter_errlist_objs spxdec_filter spx_common" @@ -1204,14 +1172,10 @@ recv_errlist_objs=" mp3_afh version " -if test "$have_vorbis" = "yes" || \ - test "$have_speex" = "yes" || \ - test "$have_opus" = "yes"; then +if NEED_OGG_OBJECTS || test "$have_speex" = 'yes' || test "$have_opus" = 'yes'; then recv_errlist_objs="$recv_errlist_objs ogg_afh_common" fi -if test "$have_vorbis" = "yes"; then - recv_errlist_objs="$recv_errlist_objs ogg_afh" -fi +NEED_VORBIS_OBJECTS && recv_errlist_objs="$recv_errlist_objs ogg_afh" if test "$have_speex" = "yes"; then recv_errlist_objs="$recv_errlist_objs spx_afh spx_common" fi @@ -1244,15 +1208,13 @@ afh_errlist_objs=" version ggo " -if test "$have_vorbis" = "yes" || \ - test "$have_speex" = "yes" || \ - test "$have_opus" = "yes"; then +if NEED_OGG_OBJECTS || test "$have_speex" = 'yes' || test "$have_opus" = 'yes'; then afh_errlist_objs="$afh_errlist_objs ogg_afh_common" fi -if test "$have_vorbis" = "yes"; then +NEED_VORBIS_OBJECTS && { afh_errlist_objs="$afh_errlist_objs ogg_afh" audio_format_handlers="$audio_format_handlers ogg" -fi +} if test "$have_speex" = "yes"; then afh_errlist_objs="$afh_errlist_objs spx_afh spx_common" audio_format_handlers="$audio_format_handlers spx" @@ -1325,14 +1287,12 @@ if test "$have_core_audio" = "yes"; then play_errlist_objs="$play_errlist_objs osx_write ipc" play_cmdline_objs="$play_cmdline_objs osx_write" fi -if test "$have_vorbis" = "yes" || \ - test "$have_speex" = "yes" || \ - test "$have_opus" = "yes"; then +if NEED_OGG_OBJECTS || test "$have_speex" = 'yes' || test "$have_opus" = 'yes'; then play_errlist_objs="$play_errlist_objs ogg_afh_common" fi -if test "$have_vorbis" = "yes"; then +NEED_VORBIS_OBJECTS && { play_errlist_objs="$play_errlist_objs oggdec_filter ogg_afh" -fi +} if test "$have_speex" = "yes"; then play_errlist_objs="$play_errlist_objs spxdec_filter spx_afh spx_common" fi