X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=configure.ac;h=3bcd0d303f8c090614a1aefd3cf08fb2d2b86cb9;hp=5358c6e31f8e3f6d0f068c605fe59e9d69c561d7;hb=5e8cf70d0d16498fc1dd238c7268797ca2325e45;hpb=9aa1f3d69c0aa335b3026581defbc09eb2c4efb4 diff --git a/configure.ac b/configure.ac index 5358c6e3..3bcd0d30 100644 --- a/configure.ac +++ b/configure.ac @@ -354,216 +354,63 @@ AC_CHECK_LIB([id3tag], [id3_file_fdopen], [], HAVE_ID3TAG=no) LIB_SUBST_FLAGS(id3tag) UNSTASH_FLAGS ########################################################################### oss -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" - -have_oss="yes" -msg="=> will not build oss writer" - -AC_CHECK_HEADER(sys/soundcard.h, [ - AC_CHECK_LIB(ossaudio, _oss_ioctl, [ - oss_ldflags="-lossaudio" - AC_SUBST(oss_ldflags) - ] - ) - ], +STASH_FLAGS +LIB_ARG_WITH([oss], []) +AC_CHECK_HEADER(sys/soundcard.h, [HAVE_OSS=yes], [HAVE_OSS=no]) +AC_CHECK_LIB(ossaudio, _oss_ioctl, [oss_ldflags="$oss_ldflags -lossaudio"], []) +LIB_SUBST_FLAGS(oss) +UNSTASH_FLAGS +########################################################################### alsa +STASH_FLAGS +LIB_ARG_WITH([alsa], [-lasound]) +HAVE_ALSA=yes +AC_CHECK_HEADER(alsa/asoundlib.h, [], HAVE_ALSA=no) +AC_CHECK_LIB([asound], [snd_pcm_open], [], HAVE_ALSA=no) +LIB_SUBST_FLAGS(alsa) +UNSTASH_FLAGS +######################################################################### pthread +STASH_FLAGS +LIB_ARG_WITH([pthread], [-lpthread]) +HAVE_PTHREAD=yes +AC_CHECK_HEADER(pthread.h, [], HAVE_PTHREAD=no) +AC_CHECK_LIB([pthread], [pthread_create], [], HAVE_PTHREAD=no) +LIB_SUBST_FLAGS(pthread) +UNSTASH_FLAGS +########################################################################### libao +STASH_FLAGS +LIB_ARG_WITH([ao], [-lao]) +HAVE_AO=yes +AC_CHECK_HEADER(ao/ao.h, [], HAVE_AO=no) +AC_CHECK_LIB([ao], [ao_initialize], [], HAVE_AO=no) +LIB_SUBST_FLAGS(ao) +UNSTASH_FLAGS +AC_DEFUN([NEED_AO_OBJECTS], [{ test $HAVE_AO = yes -a $HAVE_PTHREAD = yes; }]) +######################################################################## readline +STASH_FLAGS +AC_SEARCH_LIBS([tgetent], [tinfo curses terminfo termcap]) +LIB_ARG_WITH([readline], [-lreadline $LIBS]) +HAVE_READLINE=yes +AC_CHECK_HEADER([readline/readline.h], [], [HAVE_READLINE=no]) +AC_CHECK_LIB([readline], [rl_free_keymap], [], HAVE_READLINE=no) +AC_CHECK_DECL( + [rl_free_keymap], + [AC_DEFINE(RL_FREE_KEYMAP_DECLARED, 1, readline >= 6.3)], + [], [ - have_oss="no" - AC_MSG_WARN([no sys/soundcard.h $msg]) + #include + #include ] ) -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" - -########################################################################### alsa -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" - -msg="=> no alsa support for para_audiod/para_write" -if test "$OSTYPE" != "Linux"; then - have_alsa="no" -else - have_alsa="yes" -fi -if test "$have_alsa" = "yes"; then - AC_CHECK_HEADERS([alsa/asoundlib.h], [], [ - have_alsa="no" - AC_MSG_WARN([no alsa/asoundlib $msg]) - ]) -fi - -if test "$have_alsa" = "yes"; then - AC_CHECK_LIB([asound], [snd_pcm_open], [], [ - have_alsa="no" - AC_MSG_WARN([no libasound $msg]) - ]) -fi - -if test "$have_alsa" = "yes"; then - alsa_ldflags="-lasound" - AC_SUBST(alsa_ldflags) -fi - -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" -########################################################################### libao -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" - -have_ao="yes" -AC_ARG_WITH(ao_headers, [AS_HELP_STRING(--with-ao-headers=dir, - [look for ao/ao.h also in dir])]) -if test -n "$with_ao_headers"; then - ao_cppflags="-I$with_ao_headers" - CPPFLAGS="$CPPFLAGS $ao_cppflags" -fi -AC_ARG_WITH(ao_libs, [AS_HELP_STRING(--with-ao-libs=dir, - [look for libao also in dir])]) -if test -n "$with_ao_libs"; then - ao_libs="-L$with_ao_libs" - LDFLAGS="$LDFLAGS $ao_libs" -fi -msg="no libao support for para_audiod/para_write" -AC_CHECK_HEADERS([ao/ao.h], [ - ], [ - have_ao="no" - AC_MSG_WARN([ao.h not found, $msg]) -]) -if test "$have_ao" = "yes"; then - AC_CHECK_LIB([ao], [ao_initialize], [], [ - have_ao="no" - AC_MSG_WARN([ao lib not found or not working, $msg]) - ]) -fi -if test "$have_ao" = "yes"; then - AC_CHECK_HEADERS([pthread.h], [ - ], [ - have_ao="no" - AC_MSG_WARN([pthread.h not found, $msg]) - ]) -fi -if test "$have_ao" = "yes"; then - AC_CHECK_LIB([pthread], [pthread_create], [], [ - have_ao="no" - AC_MSG_WARN([pthread lib not found or not working, $msg]) - ]) -fi -if test "$have_ao" = "yes"; then - AC_SUBST(ao_cppflags) - ao_ldflags="$ao_libs -lao -lpthread" - AC_SUBST(ao_ldflags) -fi - -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" -############################################################# readline -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" - -have_readline="yes" -AC_ARG_WITH(readline_headers, [AS_HELP_STRING(--with-readline-headers=dir, - [look for libreadline header files also in dir])]) -if test -n "$with_readline_headers"; then - readline_cppflags="-I$with_readline_headers" - CPPFLAGS="$CPPFLAGS $readline_cppflags" -fi - -AC_ARG_WITH(readline_libs, [AS_HELP_STRING(--with-readline-libs=dir, - [look for readline library also in dir])]) -if test -n "$with_readline_libs"; then - readline_libs="-L$with_readline_libs" - LDFLAGS="$LDFLAGS $readline_libs" -fi -msg="no interactive cli support" -AC_CHECK_HEADERS([readline/readline.h], [ - ], [ - have_readline="no" - AC_MSG_WARN([readline/readline.h not found, $msg]) -]) - -if test "$have_readline" = "yes"; then - readline_ldflags="$readline_libs" - AC_SEARCH_LIBS([rl_free_keymap], [readline], [ - readline_ldflags="$readline_ldflags -lreadline" - ], [have_readline="no"]) - if test "$have_readline" = "no"; then # try with -lcurses - # clear cache - AC_MSG_NOTICE([trying again with -lcurses]) - unset ac_cv_search_rl_free_keymap 2> /dev/null - AC_SEARCH_LIBS([rl_free_keymap], [readline], [ - have_readline=yes - readline_ldflags="$readline_ldflags -lreadline -lcurses" - ], [], [-lcurses]) - fi - if test "$have_readline" = "no"; then # try with -ltermcap - # clear cache - AC_MSG_NOTICE([trying again with -ltermcap]) - unset ac_cv_search_rl_free_keymap 2> /dev/null - AC_SEARCH_LIBS([rl_free_keymap], [readline], [ - have_readline=yes - readline_ldflags="$readline_ldflags -lreadline -ltermcap" - ], [], [-ltermcap]) - fi -fi - -if test "$have_readline" = "yes"; then - AC_CHECK_DECL( - [rl_free_keymap], - [AC_DEFINE(RL_FREE_KEYMAP_DECLARED, 1, readline >= 6.3)], - [], - [ - #include - #include - ] - ) - AC_SUBST(readline_cppflags) - AC_SUBST(readline_ldflags) - AC_DEFINE(HAVE_READLINE, 1, define to 1 to turn on readline support) -else - AC_MSG_WARN([libreadline not found or unusable]) -fi -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" +LIB_SUBST_FLAGS(readline) +UNSTASH_FLAGS ############################################################# libsamplerate -OLD_CPPFLAGS="$CPPFLAGS" -OLD_LDFLAGS="$LDFLAGS" -OLD_LIBS="$LIBS" - -have_samplerate="yes" -AC_ARG_WITH(samplerate_headers, [AS_HELP_STRING(--with-samplerate-headers=dir, - [look for samplerate headers also in dir])]) -if test -n "$with_samplerate_headers"; then - samplerate_cppflags="-I$with_samplerate_headers" - CPPFLAGS="$CPPFLAGS $samplerate_cppflags" -fi -AC_ARG_WITH(samplerate_libs, [AS_HELP_STRING(--with-samplerate-libs=dir, - [look for samplerate libs also in dir])]) -if test -n "$with_samplerate_libs"; then - samplerate_libs="-L$with_samplerate_libs" - LDFLAGS="$LDFLAGS $samplerate_libs" -fi - -AC_CHECK_HEADER(samplerate.h, [], have_samplerate=no) -AC_CHECK_LIB([samplerate], [src_process], [], have_samplerate=no, []) - -if test "$have_samplerate" = "yes"; then - AC_SUBST(samplerate_cppflags) - samplerate_ldflags="$samplerate_libs -lsamplerate" - AC_SUBST(samplerate_ldflags) -else - AC_MSG_WARN([no resample support in para_audiod/para_filter]) -fi -CPPFLAGS="$OLD_CPPFLAGS" -LDFLAGS="$OLD_LDFLAGS" -LIBS="$OLD_LIBS" +STASH_FLAGS +LIB_ARG_WITH([samplerate], [-lsamplerate]) +HAVE_SAMPLERATE=yes +AC_CHECK_HEADER(samplerate.h, [], HAVE_SAMPLERATE=no) +AC_CHECK_LIB([samplerate], [src_process], [], HAVE_SAMPLERATE=no) +LIB_SUBST_FLAGS(samplerate) +UNSTASH_FLAGS ######################################################################### server if test -n "$CRYPTOLIB" && test $HAVE_OSL = yes; then build_server="yes" @@ -652,7 +499,7 @@ if test -n "$CRYPTOLIB"; then else client_errlist_objs="$client_errlist_objs gcrypt" fi - if test "$have_readline" = "yes"; then + if test $HAVE_READLINE = yes; then client_errlist_objs="$client_errlist_objs interactive" fi client_objs="add_cmdline($client_cmdline_objs) $client_errlist_objs" @@ -751,19 +598,19 @@ if test -n "$CRYPTOLIB"; then audiod_cmdline_objs="$audiod_cmdline_objs mp3dec_filter" audiod_errlist_objs="$audiod_errlist_objs mp3dec_filter" fi - if test "$have_oss" = "yes"; then + if test $HAVE_OSS = yes; then audiod_errlist_objs="$audiod_errlist_objs oss_write" audiod_cmdline_objs="$audiod_cmdline_objs oss_write" fi - if test "$have_alsa" = "yes"; then + if test $HAVE_ALSA = yes; then audiod_errlist_objs="$audiod_errlist_objs alsa_write" audiod_cmdline_objs="$audiod_cmdline_objs alsa_write" fi - if test "$have_ao" = "yes"; then + NEED_AO_OBJECTS && { audiod_errlist_objs="$audiod_errlist_objs ao_write" audiod_cmdline_objs="$audiod_cmdline_objs ao_write" - fi - if test "$have_samplerate" = "yes"; then + } + if test $HAVE_SAMPLERATE = yes; then audiod_errlist_objs="$audiod_errlist_objs resample_filter check_wav" audiod_cmdline_objs="$audiod_cmdline_objs resample_filter" fi @@ -781,17 +628,17 @@ else build_audiod="no" fi ########################################################################### fade -if test "$have_oss" = "yes" -o "$have_alsa" = "yes"; then +if test $HAVE_OSS = yes -o $HAVE_ALSA = yes; then build_fade="yes" executables="$executables fade" fade_cmdline_objs="fade" fade_errlist_objs="fade exec string fd version ggo" - if test "$have_oss" = "yes"; then + if test $HAVE_OSS = yes; then fade_errlist_objs="$fade_errlist_objs oss_mix" mixers="${mixers}oss " default_mixer="OSS_MIX" fi - if test "$have_alsa" = "yes"; then + if test $HAVE_ALSA = yes; then fade_errlist_objs="$fade_errlist_objs alsa_mix" mixers="${mixers}alsa " default_mixer="ALSA_MIX" @@ -919,7 +766,7 @@ if test $HAVE_MAD = yes; then filter_errlist_objs="$filter_errlist_objs mp3dec_filter" filters="$filters mp3dec" fi -if test "$have_samplerate" = "yes"; then +if test $HAVE_SAMPLERATE = yes; then filter_errlist_objs="$filter_errlist_objs resample_filter check_wav" filter_cmdline_objs="$filter_cmdline_objs resample_filter" filters="$filters resample" @@ -1098,22 +945,22 @@ if test $HAVE_MAD = yes; then play_cmdline_objs="$play_cmdline_objs mp3dec_filter" play_errlist_objs="$play_errlist_objs mp3dec_filter" fi -if test "$have_oss" = "yes"; then +if test $HAVE_OSS = yes; then play_errlist_objs="$play_errlist_objs oss_write" play_cmdline_objs="$play_cmdline_objs oss_write" fi -if test "$have_alsa" = "yes"; then +if test $HAVE_ALSA = yes; then play_errlist_objs="$play_errlist_objs alsa_write" play_cmdline_objs="$play_cmdline_objs alsa_write" fi -if test "$have_ao" = "yes"; then +NEED_AO_OBJECTS && { play_errlist_objs="$play_errlist_objs ao_write" play_cmdline_objs="$play_cmdline_objs ao_write" -fi -if test "$have_readline" = "yes"; then +} +if test $HAVE_READLINE = yes; then play_errlist_objs="$play_errlist_objs interactive" fi -if test "$have_samplerate" = "yes"; then +if test $HAVE_SAMPLERATE = yes; then play_errlist_objs="$play_errlist_objs resample_filter check_wav" play_cmdline_objs="$play_cmdline_objs resample_filter" fi @@ -1150,19 +997,19 @@ if test "$have_core_audio" = "yes"; then writers="$writers osx" default_writer="OSX_WRITE" fi -if test "$have_ao" = "yes"; then +NEED_AO_OBJECTS && { write_errlist_objs="$write_errlist_objs ao_write" write_cmdline_objs="$write_cmdline_objs ao_write" writers="$writers ao" default_writer="AO_WRITE" -fi -if test "$have_oss" = "yes"; then +} +if test $HAVE_OSS = yes; then write_errlist_objs="$write_errlist_objs oss_write" write_cmdline_objs="$write_cmdline_objs oss_write" writers="$writers oss" default_writer="OSS_WRITE" fi -if test "$have_alsa" = "yes"; then +if test $HAVE_ALSA = yes; then write_errlist_objs="$write_errlist_objs alsa_write" write_cmdline_objs="$write_cmdline_objs alsa_write" writers="$writers alsa" @@ -1193,7 +1040,7 @@ audioc_errlist_objs=" version ggo " -if test "$have_readline" = "yes"; then +if test $HAVE_READLINE = yes; then audioc_errlist_objs="$audioc_errlist_objs buffer_tree interactive @@ -1284,7 +1131,7 @@ paraslash configuration: ~~~~~~~~~~~~~~~~~~~~~~~~ crypto lib: ${CRYPTOLIB:-[none]} unix socket credentials: $have_ucred -readline (interactive CLIs): $have_readline +readline (interactive CLIs): $HAVE_READLINE audio formats handlers: $audio_format_handlers id3 version 2 support: $HAVE_ID3TAG filters: $filters