Merge branch 'maint'
authorAndre Noll <maan@systemlinux.org>
Sun, 20 Feb 2011 11:44:05 +0000 (12:44 +0100)
committerAndre Noll <maan@systemlinux.org>
Sun, 20 Feb 2011 11:44:05 +0000 (12:44 +0100)
Conflicts:
configure.ac

1  2 
configure.ac

diff --combined configure.ac
@@@ -78,200 -78,82 +78,200 @@@ AC_CHECK_FUNCS([atexit dup2 memchr memm
        strncasecmp strrchr strspn alarm mkdir rmdir], [],
        [AC_MSG_ERROR([function not found, cannot live without it])])
  
 +cmdline_dir="cmdline"
 +AC_SUBST(cmdline_dir)
 +AC_DEFUN([add_cmdline],[$(for i in $@; do printf "${i}.cmdline "; done)])
 +
 +
  all_errlist_objs="server mp3_afh afh_common vss command net string signal time
  daemon stat crypt http_send close_on_fork ipc acl afh fade amp_filter
 -dccp_send fd user_list chunk_queue afs osl aft mood score attribute blob ringbuffer
 -playlist sha1 rbtree sched audiod grab_client filter_common wav_filter compress_filter
 +dccp_send fd user_list chunk_queue afs aft mood score attribute blob ringbuffer
 +playlist sha1 sched audiod grab_client filter_common wav_filter compress_filter
  http_recv dccp_recv recv_common write_common file_write audiod_command
 -client_common recv stdout filter stdin audioc write client fsck exec send_common ggo
 -udp_recv udp_send color fec fecdec_filter prebuffer_filter"
 +client_common recv stdout filter stdin audioc write client exec send_common ggo
 +udp_recv udp_send color fec fecdec_filter prebuffer_filter mm
 +server_command_list afs_command_list audiod_command_list bitstream imdct wma_afh
 +wma_common wmadec_filter buffer_tree
 +"
 +
 +executables="recv filter audioc write client afh audiod"
  
 -all_executables="server recv filter audioc write client fsck afh"
 +recv_cmdline_objs="add_cmdline(recv http_recv dccp_recv udp_recv)"
  
 -recv_cmdline_objs="recv.cmdline http_recv.cmdline dccp_recv.cmdline udp_recv.cmdline"
  recv_errlist_objs="http_recv recv_common recv time string net dccp_recv
 -      fd sched stdout ggo udp_recv fec"
 +      fd sched stdout ggo udp_recv fec buffer_tree"
  recv_ldflags=""
  
 -receivers=" http dccp udp"
 -senders=" http dccp udp"
 -
 -filter_cmdline_objs="filter.cmdline compress_filter.cmdline amp_filter.cmdline
 -      prebuffer_filter.cmdline"
 +filter_cmdline_objs="add_cmdline(filter compress_filter amp_filter prebuffer_filter)"
  filter_errlist_objs="filter_common wav_filter compress_filter filter string
        stdin stdout sched fd amp_filter ggo fecdec_filter fec
 -      prebuffer_filter time"
 -filter_ldflags=""
 -filters=" compress wav amp fecdec prebuffer"
 +      prebuffer_filter time bitstream imdct wma_common wmadec_filter buffer_tree"
 +filter_ldflags="-lm"
 +filters=" compress wav amp fecdec wmadec prebuffer"
  
 -audioc_cmdline_objs="audioc.cmdline"
 +audioc_cmdline_objs="add_cmdline(audioc)"
  audioc_errlist_objs="audioc string net fd"
  audioc_ldflags=""
  
 -audiod_cmdline_objs="audiod.cmdline grab_client.cmdline compress_filter.cmdline
 -      http_recv.cmdline dccp_recv.cmdline file_write.cmdline client.cmdline
 -      audiod_command_list amp_filter.cmdline udp_recv.cmdline
 -      prebuffer_filter.cmdline"
 +audiod_cmdline_objs="add_cmdline(audiod compress_filter http_recv dccp_recv file_write client amp_filter udp_recv prebuffer_filter)"
  audiod_errlist_objs="audiod signal string daemon stat net
        time grab_client filter_common wav_filter compress_filter amp_filter http_recv dccp_recv
        recv_common fd sched write_common file_write audiod_command crypt fecdec_filter
 -      client_common ggo udp_recv color fec prebuffer_filter"
 -audiod_ldflags=""
 -audiod_audio_formats=""
 +      client_common ggo udp_recv color fec prebuffer_filter sha1 audiod_command_list
 +      bitstream imdct wma_common wmadec_filter buffer_tree"
 +audiod_ldflags="-lm"
 +audiod_audio_formats="wma"
  
 -afh_cmdline_objs="afh.cmdline"
 -afh_errlist_objs="afh string fd mp3_afh afh_common time"
 +afh_cmdline_objs="add_cmdline(afh)"
 +afh_errlist_objs="afh string fd mp3_afh afh_common time wma_afh wma_common"
  afh_ldflags=""
  
 -server_cmdline_objs="server.cmdline server_command_list afs_command_list"
 +server_cmdline_objs="add_cmdline(server)"
  server_errlist_objs="server afh_common mp3_afh vss command net string signal
 -      time daemon stat crypt http_send close_on_fork
 -      ipc dccp_send fd user_list chunk_queue afs osl aft mood score attribute
 -      blob playlist sha1 rbtree sched acl send_common udp_send color fec"
 -server_ldflags=""
 -server_audio_formats=" mp3"
 -
 -write_cmdline_objs="write.cmdline file_write.cmdline"
 -write_errlist_objs="write write_common file_write time fd string sched stdin ggo"
 +      time daemon crypt http_send close_on_fork mm
 +      ipc dccp_send fd user_list chunk_queue afs aft mood score attribute
 +      blob playlist sha1 sched acl send_common udp_send color fec
 +      server_command_list afs_command_list wma_afh wma_common"
 +server_ldflags="-losl"
 +server_audio_formats="mp3 wma"
 +
 +write_cmdline_objs="add_cmdline(write file_write)"
 +write_errlist_objs="write write_common file_write time fd string sched stdin
 +      buffer_tree ggo"
  write_ldflags=""
  writers=" file"
  default_writer="FILE_WRITE"
  
 -client_cmdline_objs="client.cmdline"
 -client_errlist_objs="client net string crypt fd sched stdin stdout client_common"
 +client_cmdline_objs="add_cmdline(client)"
 +client_errlist_objs="client net string crypt fd sched stdin stdout time
 +      client_common sha1 buffer_tree"
  client_ldflags=""
  
 -fsck_cmdline_objs="fsck.cmdline"
 -fsck_errlist_objs="osl rbtree fsck string sha1 fd"
 -
 -gui_cmdline_objs="gui.cmdline"
 +gui_cmdline_objs="add_cmdline(gui)"
  gui_errlist_objs="exec signal string stat ringbuffer fd"
  gui_other_objs="gui gui_theme"
  gui_objs="$gui_cmdline_objs $gui_errlist_objs $gui_other_objs"
  
 -fade_cmdline_objs="fade.cmdline"
 +fade_cmdline_objs="add_cmdline(fade)"
  fade_errlist_objs="fade exec string fd"
  
  
 +########################################################################### snprintf
 +# ===========================================================================
 +#        http://www.nongnu.org/autoconf-archive/ax_func_snprintf.html
 +# ===========================================================================
 +#
 +# SYNOPSIS
 +#
 +#   AX_FUNC_SNPRINTF
 +#
 +# DESCRIPTION
 +#
 +#   Checks for a fully C99 compliant snprintf, in particular checks whether
 +#   it does bounds checking and returns the correct string length; does the
 +#   same check for vsnprintf. If no working snprintf or vsnprintf is found,
 +#   it prints an error message and aborts.
 +#
 +# LICENSE
 +#
 +#   Copyright (c) 2008 Ruediger Kuhlmann <info@ruediger-kuhlmann.de>
 +#
 +#   Copying and distribution of this file, with or without modification, are
 +#   permitted in any medium without royalty provided the copyright notice
 +#   and this notice are preserved.
 +
 +AU_ALIAS([AC_FUNC_SNPRINTF], [AX_FUNC_SNPRINTF])
 +AC_DEFUN([AX_FUNC_SNPRINTF],
 +[AC_CHECK_FUNCS(snprintf vsnprintf)
 +AC_MSG_CHECKING(for working snprintf)
 +AC_CACHE_VAL(ac_cv_have_working_snprintf,
 +[AC_TRY_RUN(
 +[#include <stdio.h>
 +
 +int main(void)
 +{
 +    char bufs[5] = { 'x', 'x', 'x', '\0', '\0' };
 +    char bufd[5] = { 'x', 'x', 'x', '\0', '\0' };
 +    int i;
 +    i = snprintf (bufs, 2, "%s", "111");
 +    if (strcmp (bufs, "1")) exit (1);
 +    if (i != 3) exit (1);
 +    i = snprintf (bufd, 2, "%d", 111);
 +    if (strcmp (bufd, "1")) exit (1);
 +    if (i != 3) exit (1);
 +    exit(0);
 +}], ac_cv_have_working_snprintf=yes, ac_cv_have_working_snprintf=no, ac_cv_have_working_snprintf=cross)])
 +AC_MSG_RESULT([$ac_cv_have_working_snprintf])
 +AC_MSG_CHECKING(for working vsnprintf)
 +AC_CACHE_VAL(ac_cv_have_working_vsnprintf,
 +[AC_TRY_RUN(
 +[#include <stdio.h>
 +#include <stdarg.h>
 +
 +int my_vsnprintf (char *buf, const char *tmpl, ...)
 +{
 +    int i;
 +    va_list args;
 +    va_start (args, tmpl);
 +    i = vsnprintf (buf, 2, tmpl, args);
 +    va_end (args);
 +    return i;
 +}
 +
 +int main(void)
 +{
 +    char bufs[5] = { 'x', 'x', 'x', '\0', '\0' };
 +    char bufd[5] = { 'x', 'x', 'x', '\0', '\0' };
 +    int i;
 +    i = my_vsnprintf (bufs, "%s", "111");
 +    if (strcmp (bufs, "1")) exit (1);
 +    if (i != 3) exit (1);
 +    i = my_vsnprintf (bufd, "%d", 111);
 +    if (strcmp (bufd, "1")) exit (1);
 +    if (i != 3) exit (1);
 +    exit(0);
 +}], ac_cv_have_working_vsnprintf=yes, ac_cv_have_working_vsnprintf=no, ac_cv_have_working_vsnprintf=cross)])
 +AC_MSG_RESULT([$ac_cv_have_working_vsnprintf])
 +if test x$ac_cv_have_working_snprintf$ac_cv_have_working_vsnprintf != "xyesyes"; then
 +AC_MSG_ERROR([fatal: buggy snprintf() detected])
 +fi])
 +AX_FUNC_SNPRINTF()
 +########################################################################### osl
 +have_osl=yes
 +OLD_CPPFLAGS="$CPPFLAGS"
 +OLD_LD_FLAGS="$LDFLAGS"
 +OLD_LIBS="$LIBS"
 +AC_ARG_WITH(osl_headers, [AC_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, [AC_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" = "no"; then
 +      AC_MSG_WARN([libosl not found, can not build para_server.
 +Download libosl at
 +      http://systemlinux.org/~maan/osl
 +or execute
 +      git clone git://git.tuebingen.mpg.de/osl
 +      ])
 +else
 +      extras="$extras server"
 +      executables="$executables server"
 +      AC_SUBST(osl_cppflags)
 +      server_ldflags="$server_ldflags -L$with_osl_libs"
 +fi
 +CPPFLAGS="$OLD_CPPFLAGS"
 +LDFLAGS="$OLD_LDFLAGS"
 +LIBS="$OLD_LIBS"
  ########################################################################### ssl
  dnl @synopsis CHECK_SSL
  dnl
@@@ -302,15 -184,19 +302,15 @@@ AC_DEFUN([CHECK_SSL]
                SSL_LDFLAGS="-L$ssldir/lib";
        fi
        AC_SUBST(SSL_CPPFLAGS)
 -      AC_SUBST(SSL_CFLAGS)
 -      AC_SUBST(SSL_LIBS)
 -      AC_SUBST(SSL_LDFLAGS)
  ])dnl
  
  AC_ARG_ENABLE(ssldir, [AS_HELP_STRING(--enable-ssldir=path,
        [Search for openssl also in path.])])
  if test "$enable_ssldir" = "yes"; then enable_ssldir=""; fi
  CHECK_SSL($enable_ssldir)
 -server_ldflags="$srver_ldflags $SSL_LDFLAGS $SSL_LIBS"
 +server_ldflags="$server_ldflags $SSL_LDFLAGS $SSL_LIBS"
  client_ldflags="$client_ldflags $SSL_LDFLAGS $SSL_LIBS"
  audiod_ldflags="$audiod_ldflags $SSL_LDFLAGS $SSL_LIBS"
 -fsck_ldflags="$fsck_ldflags $SSL_LDFLAGS $SSL_LIBS"
  
  ########################################################################### libsocket
  AC_CHECK_LIB([c], [socket],
@@@ -376,9 -262,10 +376,9 @@@ AC_CHECK_LIB([ncurses], [initscr], [], 
  ])
  if test "$have_ncurses" = "yes"; then
        AC_SUBST(ncurses_cppflags)
 -      AC_SUBST(ncurses_libs)
        AC_DEFINE(HAVE_NCURSES, 1, [define to 1 to turn on ncurses support])
 -      extras="$extras para_gui"
 -      all_executables="$all_executables gui"
 +      extras="$extras gui"
 +      executables="$executables gui"
  else
        AC_MSG_WARN([cannot build para_gui])
  fi
@@@ -427,88 -314,53 +427,88 @@@ if test ${have_core_audio} = yes; the
        default_writer="OSX_WRITE"
        AC_DEFINE(HAVE_CORE_AUDIO, 1, define to 1 on Mac Os X)
  fi
 -########################################################################### ogg
 +########################################################### ogg/vorbis/speex
  have_ogg="yes"
 +have_vorbis="yes"
 +have_speex="yes"
  OLD_CPPFLAGS="$CPPFLAGS"
  OLD_LD_FLAGS="$LDFLAGS"
  OLD_LIBS="$LIBS"
  AC_ARG_WITH(oggvorbis_headers, [AC_HELP_STRING(--with-oggvorbis-headers=dir,
 -      [look for vorbis/codec.h also in dir])])
 +      [look for ogg/vorbis/speex headers also in dir])])
  if test -n "$with_oggvorbis_headers"; then
 -      oggvorbis_cppflags="-I$with_oggvorbis_headers"
 -      CPPFLAGS="$CPPFLAGS $oggvorbis_cppflags"
 +      ogg_cppflags="-I$with_oggvorbis_headers"
 +      CPPFLAGS="$CPPFLAGS $ogg_cppflags"
  fi
  AC_ARG_WITH(oggvorbis_libs, [AC_HELP_STRING(--with-oggvorbis-libs=dir,
 -      [look for oggvorbis libs also in dir])])
 +      [look for ogg/vorbis/speex libs also in dir])])
  if test -n "$with_oggvorbis_libs"; then
 -      oggvorbis_libs="-L$with_oggvorbis_libs"
 -      LDFLAGS="$LDFLAGS $oggvorbis_libs"
 +      ogg_libs="-L$with_oggvorbis_libs"
 +      LDFLAGS="$LDFLAGS $ogg_libs"
  fi
  
  AC_CHECK_LIB([ogg], [ogg_stream_init], [], [ have_ogg="no" ])
 -AC_CHECK_LIB([vorbis], [vorbis_info_init], [], [ have_ogg="no" ])
 -AC_CHECK_HEADERS([ogg/ogg.h vorbis/codec.h], [], [ have_ogg="no" ])
 -if test "$have_ogg" = "yes"; then
 -      all_errlist_objs="$all_errlist_objs oggdec_filter ogg_afh"
 -      AC_DEFINE(HAVE_OGGVORBIS, 1, define to 1 to turn on ogg vorbis support)
 -      filters="$filters oggdec"
 +AC_CHECK_LIB([vorbis], [vorbis_info_init], [], [ have_vorbis="no" ])
 +AC_CHECK_LIB([speex], [speex_decoder_init], [], [ have_speex="no" ])
 +AC_CHECK_HEADERS([ogg/ogg.h], [], [ have_ogg="no"; ])
 +AC_CHECK_HEADERS([vorbis/codec.h], [], [ have_vorbis="no" ])
 +AC_CHECK_HEADERS([speex/speex.h], [], [ have_speex="no" ])
 +msg="support in para_server/para_filter/para_afh"
 +if test "$have_ogg" = "yes" && { test "$have_vorbis" = "yes" || test "$have_speex" = "yes"; }; then
 +      AC_SUBST(ogg_cppflags)
 +      ogg_libs="$ogg_libs -logg"
        if test "$OSTYPE" = "Darwin"; then
 -              oggvorbis_libs="-Wl,-bind_at_load  $oggvorbis_libs"
 +              ogg_libs="-Wl,-bind_at_load $ogg_libs $ogg_libs"
 +      fi
 +      server_ldflags="$server_ldflags $ogg_libs"
 +      filter_ldflags="$filter_ldflags $ogg_libs"
 +      audiod_ldflags="$audiod_ldflags $ogg_libs"
 +      all_errlist_objs="$all_errlist_objs ogg_afh_common"
 +      afh_ldflags="$afh_ldflags $ogg_libs"
 +      afh_errlist_objs="$afh_errlist_objs ogg_afh_common"
 +      server_errlist_objs="$server_errlist_objs ogg_afh_common"
 +      if test "$have_vorbis" = "yes"; then
 +              all_errlist_objs="$all_errlist_objs oggdec_filter ogg_afh"
 +              AC_DEFINE(HAVE_OGGVORBIS, 1, define to 1 to turn on ogg/vorbis support)
 +              filters="$filters oggdec"
 +              vorbis_libs="-lvorbis -lvorbisfile"
 +              server_ldflags="$server_ldflags $vorbis_libs"
 +              filter_ldflags="$filter_ldflags $vorbis_libs"
 +              audiod_ldflags="$audiod_ldflags $vorbis_libs"
 +              afh_ldflags="$afh_ldflags $vorbis_libs"
 +
 +              server_errlist_objs="$server_errlist_objs ogg_afh"
 +              filter_errlist_objs="$filter_errlist_objs oggdec_filter"
 +              audiod_errlist_objs="$audiod_errlist_objs oggdec_filter"
 +              afh_errlist_objs="$afh_errlist_objs ogg_afh"
 +
 +              audiod_audio_formats="$audiod_audio_formats ogg"
 +              server_audio_formats="$server_audio_formats ogg"
 +      else
 +              AC_MSG_WARN([no ogg/vorbis $msg])
 +      fi
 +      if test "$have_speex" = "yes"; then
 +              all_errlist_objs="$all_errlist_objs spxdec_filter spx_afh spx_common"
 +              AC_DEFINE(HAVE_SPEEX, 1, define to 1 to turn on ogg/speex support)
 +              filters="$filters spxdec"
 +              speex_libs="-lspeex"
 +              server_ldflags="$server_ldflags $speex_libs"
 +              filter_ldflags="$filter_ldflags $speex_libs"
 +              audiod_ldflags="$audiod_ldflags $speex_libs"
 +              afh_ldflags="$afh_ldflags $speex_libs"
 +
 +              server_errlist_objs="$server_errlist_objs spx_afh spx_common"
 +              filter_errlist_objs="$filter_errlist_objs spxdec_filter spx_common"
 +              audiod_errlist_objs="$audiod_errlist_objs spxdec_filter spx_common"
 +              afh_errlist_objs="$afh_errlist_objs spx_afh spx_common"
 +
 +              audiod_audio_formats="$audiod_audio_formats spx"
 +              server_audio_formats="$server_audio_formats spx"
 +      else
 +              AC_MSG_WARN([no ogg/speex $msg])
        fi
 -      server_ldflags="$server_ldflags $oggvorbis_libs -logg -lvorbis -lvorbisfile"
 -      filter_ldflags="$filter_ldflags $oggvorbis_libs -lvorbis -lvorbisfile"
 -      audiod_ldflags="$audiod_ldflags $oggvorbis_libs -lvorbis -lvorbisfile"
 -      afh_ldflags="$afh_ldflags $oggvorbis_libs -logg -lvorbis -lvorbisfile"
 -
 -      filter_cmdline_objs="$filter_cmdline_objs oggdec_filter.cmdline"
 -      audiod_cmdline_objs="$audiod_cmdline_objs oggdec_filter.cmdline"
 -
 -      server_errlist_objs="$server_errlist_objs ogg_afh"
 -      filter_errlist_objs="$filter_errlist_objs oggdec_filter"
 -      audiod_errlist_objs="$audiod_errlist_objs oggdec_filter"
 -      afh_errlist_objs="$afh_errlist_objs ogg_afh"
 -
 -      audiod_audio_formats="ogg"
 -      server_audio_formats="$server_audio_formats ogg"
 -      AC_SUBST(oggvorbis_cppflags)
 -      AC_SUBST(oggvorbis_libs)
  else
 -      AC_MSG_WARN([no ogg vorbis support in para_server/para_filter])
 +      AC_MSG_WARN([no ogg/vorbis ogg/speex $msg])
  fi
  CPPFLAGS="$OLD_CPPFLAGS"
  LDFLAGS="$OLD_LDFLAGS"
@@@ -547,6 -399,7 +547,6 @@@ if test "$have_faad" = "yes"; the
        server_audio_formats="$server_audio_formats aac"
        filters="$filters aacdec"
        AC_SUBST(faad_cppflags)
 -      AC_SUBST(faad_libs)
  else
        AC_MSG_WARN([no aac support in para_audiod/para_filter])
  fi
@@@ -579,8 -432,8 +579,8 @@@ AC_CHECK_LIB([mad], [mad_stream_init], 
  ])
  if test "$have_mad" = "yes"; then
        AC_DEFINE(HAVE_MAD, 1, define to 1 if you want to build the mp3dec filter)
 -      filter_cmdline_objs="$filter_cmdline_objs mp3dec_filter.cmdline"
 -      audiod_cmdline_objs="$audiod_cmdline_objs mp3dec_filter.cmdline"
 +      filter_cmdline_objs="$filter_cmdline_objs add_cmdline(mp3dec_filter)"
 +      audiod_cmdline_objs="$audiod_cmdline_objs add_cmdline(mp3dec_filter)"
        all_errlist_objs="$all_errlist_objs mp3dec_filter"
        filter_errlist_objs="$filter_errlist_objs mp3dec_filter"
        audiod_errlist_objs="$audiod_errlist_objs mp3dec_filter"
        audiod_audio_formats="$audiod_audio_formats mp3"
        filters="$filters mp3dec"
        AC_SUBST(mad_cppflags)
 -      AC_SUBST(mad_libs)
  else
        AC_MSG_WARN([no mp3dec support in para_audiod/para_filter])
  fi
 -if test -n "$audiod_audio_formats"; then
 -      extras="$extras para_audiod"
 -      all_executables="$all_executables audiod"
 -else
 -      AC_MSG_WARN([can not build para_audiod (no supported audio formats)])
 -fi
  CPPFLAGS="$OLD_CPPFLAGS"
  LDFLAGS="$OLD_LDFLAGS"
  LIBS="$OLD_LIBS"
@@@ -619,14 -479,14 +619,14 @@@ have_oss="yes
  msg="=> will not build para_fade/oss writer"
  
  AC_CHECK_HEADER(sys/soundcard.h, [
 -      extras="$extras para_fade"
 -      all_executables="$all_executables fade"
 +      extras="$extras fade"
 +      executables="$executables fade"
        all_errlist_objs="$all_errlist_objs oss_write"
        audiod_errlist_objs="$audiod_errlist_objs oss_write"
 -      audiod_cmdline_objs="$audiod_cmdline_objs oss_write.cmdline"
 +      audiod_cmdline_objs="$audiod_cmdline_objs add_cmdline(oss_write)"
  
        write_errlist_objs="$write_errlist_objs oss_write"
 -      write_cmdline_objs="$write_cmdline_objs oss_write.cmdline"
 +      write_cmdline_objs="$write_cmdline_objs add_cmdline(oss_write)"
        writers="$writers oss"
        default_writer="OSS_WRITE"
        AC_CHECK_LIB(ossaudio, _oss_ioctl, [
  if test "$have_alsa" = "yes"; then
        all_errlist_objs="$all_errlist_objs alsa_write"
        audiod_errlist_objs="$audiod_errlist_objs alsa_write"
 -      audiod_cmdline_objs="$audiod_cmdline_objs alsa_write.cmdline"
 +      audiod_cmdline_objs="$audiod_cmdline_objs add_cmdline(alsa_write)"
        audiod_ldflags="$audiod_ldflags -lasound"
  
        write_errlist_objs="$write_errlist_objs alsa_write"
 -      write_cmdline_objs="$write_cmdline_objs alsa_write.cmdline"
 +      write_cmdline_objs="$write_cmdline_objs add_cmdline(alsa_write)"
        write_ldflags="$write_ldflags -lasound"
        writers="$writers alsa"
        default_writer="ALSA_WRITE"
@@@ -687,22 -547,64 +687,22 @@@ CPPFLAGS="$OLD_CPPFLAGS
  LDFLAGS="$OLD_LDFLAGS"
  LIBS="$OLD_LIBS"
  
 -AC_SUBST(extra_binaries, [$extras])
 -AC_SUBST(extra_filter_objs, [$extra_filter_objs])
 -AC_SUBST(extra_filter_libs, [$extra_filter_libs])
  AC_SUBST(install_sh, [$INSTALL])
  AC_CONFIG_FILES([Makefile])
  
  
  AC_DEFUN([add_dot_o],[$(for i in $@; do printf "$i.o "; done)])
 +AC_DEFUN([add_para],[$(for i in $@; do printf "para_$i "; done)])
  AC_DEFUN([objlist_to_errlist],[$(for i in $@; do printf "DEFINE_ERRLIST($(echo $i| tr 'a-z' 'A-Z'));"; done) [const char **para_errlist[[]]] = {$(for i in $@; do printf "PARA_ERRLIST($(echo $i | tr 'a-z' 'A-Z')), "; done) }])
 -
  ############################################################# error2.h
 -AC_DEFUN([define_safe_error_enums],
 -[
 -      exe=""
 -      for i in $all_executables; do
 -#             eval echo checking if $1 is linked into $i
 -              for j in $(eval echo \$${i}_errlist_objs); do
 -                      if test $j = $1; then
 -                              exe="$exe $i"
 -                              break;
 -                      fi
 -              done
 -      done
 -      #echo "$1 gets linked into $exe"
 -      safe_errlists=""
 -      for i in $all_errlist_objs; do
 -              for j in $exe; do
 -                      found=0
 -                      for k in $(eval echo \$${j}_errlist_objs); do
 -                              if test $k = $i; then
 -                                      found=1
 -                                      break;
 -                              fi
 -                      done
 -                      if test $found -eq 0; then
 -                              break;
 -                      fi
 -              done
 -              if test $found -eq 1; then
 -                      safe_errlists="$safe_errlists $i"
 -              fi
 -      done
 -      #echo "safe errlists for $1: $safe_errlists"
 -      ss_defs=""
 -      for i in $safe_errlists; do
 -              echo "SS_ENUM($(echo $i | tr 'a-z' 'A-Z'));"
 -      done
 -]
 -)
 -
 -
  AC_MSG_NOTICE(creating error2.h)
 +for i in $executables; do
 +      echo "$i: "
 +      eval echo \$${i}_errlist_objs
 +done | ./error2.pl > error2.h
  for obj in $all_errlist_objs; do
        SS="$SS SS_$(echo $obj | tr 'a-z' 'A-Z'),"
 -      echo "#ifdef MAIN_INPUT_FILE_IS_$obj"
 -      define_safe_error_enums($obj)
 -      echo "#endif"
 -done > error2.h
 +done
  AC_DEFINE_UNQUOTED(DEFINE_ERRLIST_OBJECT_ENUM,
        [enum {$SS NUM_SS}],
        [list of all objects that use paraslash's error facility]
  ################################################################## status items
  
  status_items="basename status num_played mtime bitrate frequency file_size
 -status_flags format score audio_file_info taginfo1 taginfo2 afs_mode
 +status_flags format score techinfo afs_mode
  attributes_txt decoder_flags audiod_status play_time attributes_bitmap
  offset seconds_total stream_start current_time audiod_uptime image_id
  lyrics_id duration directory lyrics_name image_name path hash channels
 -last_played num_chunks chunk_time amplification"
 +last_played num_chunks chunk_time amplification artist title year album
 +comment"
  
  result=
  for i in $status_items; do
@@@ -732,11 -633,6 +732,10 @@@ don
  AC_DEFINE_UNQUOTED(STATUS_ITEM_ARRAY, [$result],
        [char * array of all status items])
  
 +AC_DEFINE_UNQUOTED(SERVER_AUDIO_FORMATS, "$server_audio_formats",
 +      [formats supported by para_server and para_afh])
 +
 +AC_SUBST(executables, add_para($executables))
  
  recv_objs="$recv_cmdline_objs $recv_errlist_objs"
  filter_objs="$filter_cmdline_objs $filter_errlist_objs"
@@@ -744,6 -640,7 +743,6 @@@ audiod_objs="$audiod_cmdline_objs $audi
  server_objs="$server_cmdline_objs $server_errlist_objs"
  write_objs="$write_cmdline_objs $write_errlist_objs"
  client_objs="$client_cmdline_objs $client_errlist_objs"
 -fsck_objs="$fsck_cmdline_objs $fsck_errlist_objs"
  audioc_objs="$audioc_cmdline_objs $audioc_errlist_objs"
  afh_objs="$afh_cmdline_objs $afh_errlist_objs"
  fade_objs="$fade_cmdline_objs $fade_errlist_objs"
@@@ -783,6 -680,11 +782,6 @@@ AC_SUBST(client_ldflags, $client_ldflag
  AC_DEFINE_UNQUOTED(INIT_CLIENT_ERRLISTS,
        objlist_to_errlist($client_errlist_objs), errors used by para_client)
  
 -AC_SUBST(fsck_objs, add_dot_o($fsck_objs))
 -AC_SUBST(fsck_ldflags, $fsck_ldflags)
 -AC_DEFINE_UNQUOTED(INIT_FSCK_ERRLISTS,
 -      objlist_to_errlist($fsck_errlist_objs), errors used by para_fsck)
 -
  AC_SUBST(audioc_objs, add_dot_o($audioc_objs))
  AC_SUBST(audioc_ldflags, $audioc_ldflags)
  AC_DEFINE_UNQUOTED(INIT_AUDIOC_ERRLISTS,
@@@ -824,12 -726,16 +823,12 @@@ names="$(for i in $audiod_audio_formats
  AC_DEFINE_UNQUOTED(AUDIOD_AUDIO_FORMAT_ARRAY, $names, array of audio formats supported by audiod)
  
  AC_OUTPUT
 -AC_MSG_NOTICE([creating Makefile.deps])
 -gcc -MM -MG $faad_cppflags $mad_cppflags $oggvorbis_cppflags *.c > Makefile.deps
  AC_MSG_NOTICE([
  paraslash configuration:
  ~~~~~~~~~~~~~~~~~~~~~~~~
  unix socket credentials: $have_ucred
  audio formats supported by para_server/para_afh: $server_audio_formats
  id3 version2 support: $have_libid3tag
 -senders supported by para_server: $senders
 -receivers supported by para_audiod/para_recv: $receivers
  filters supported by para_audiod/para_filter: $filters
  writers supported by para_audiod/para_write: $writers
  optional executables: $extras