diff options
| -rw-r--r-- | .travis.yml | 6 | ||||
| -rw-r--r-- | CMakeLists.txt | 1 | ||||
| -rw-r--r-- | RtAudio.cpp | 44 | ||||
| -rw-r--r-- | configure.ac | 246 | ||||
| -rw-r--r-- | rtaudio.pc.in | 2 |
5 files changed, 166 insertions, 133 deletions
diff --git a/.travis.yml b/.travis.yml index 2c687a7..838f834 100644 --- a/.travis.yml +++ b/.travis.yml @@ -27,12 +27,6 @@ matrix: env: HOST="" API="oss" compiler: clang - os: linux - env: HOST="--host=i686-w64-mingw32" API="winmm" CPPFLAGS="-Wno-unused-function" - compiler: gcc - - os: linux - env: HOST="--host=x86_64-w64-mingw32" API="winmm" CPPFLAGS="-Wno-unused-function" - compiler: gcc - - os: linux env: HOST="--host=i686-w64-mingw32" API="dsound" CPPFLAGS="-Wno-unused-function" compiler: gcc - os: linux diff --git a/CMakeLists.txt b/CMakeLists.txt index 9e4060a..2ce3b4b 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -257,6 +257,7 @@ message(STATUS "Compiling with support for: ${apilist}") # PkgConfig file string(REPLACE ";" " " req "${PKGCONFIG_REQUIRES}") string(REPLACE ";" " " api "${API_DEFS}") +set(prefix ${CMAKE_INSTALL_PREFIX}) configure_file("rtaudio.pc.in" "rtaudio.pc" @ONLY) # Add install rule. diff --git a/RtAudio.cpp b/RtAudio.cpp index a51608d..ea0c202 100644 --- a/RtAudio.cpp +++ b/RtAudio.cpp @@ -1973,7 +1973,7 @@ unsigned int RtApiJack :: getDeviceCount( void ) const char **ports; std::string port, previousPort; unsigned int nChannels = 0, nDevices = 0; - ports = jack_get_ports( client, NULL, NULL, 0 ); + ports = jack_get_ports( client, NULL, JACK_DEFAULT_AUDIO_TYPE, 0 ); if ( ports ) { // Parse the port names up to the first colon (:). size_t iColon = 0; @@ -2012,7 +2012,7 @@ RtAudio::DeviceInfo RtApiJack :: getDeviceInfo( unsigned int device ) const char **ports; std::string port, previousPort; unsigned int nPorts = 0, nDevices = 0; - ports = jack_get_ports( client, NULL, NULL, 0 ); + ports = jack_get_ports( client, NULL, JACK_DEFAULT_AUDIO_TYPE, 0 ); if ( ports ) { // Parse the port names up to the first colon (:). size_t iColon = 0; @@ -2047,7 +2047,7 @@ RtAudio::DeviceInfo RtApiJack :: getDeviceInfo( unsigned int device ) // Count the available ports containing the client name as device // channels. Jack "input ports" equal RtAudio output channels. unsigned int nChannels = 0; - ports = jack_get_ports( client, info.name.c_str(), NULL, JackPortIsInput ); + ports = jack_get_ports( client, info.name.c_str(), JACK_DEFAULT_AUDIO_TYPE, JackPortIsInput ); if ( ports ) { while ( ports[ nChannels ] ) nChannels++; free( ports ); @@ -2056,7 +2056,7 @@ RtAudio::DeviceInfo RtApiJack :: getDeviceInfo( unsigned int device ) // Jack "output ports" equal RtAudio input channels. nChannels = 0; - ports = jack_get_ports( client, info.name.c_str(), NULL, JackPortIsOutput ); + ports = jack_get_ports( client, info.name.c_str(), JACK_DEFAULT_AUDIO_TYPE, JackPortIsOutput ); if ( ports ) { while ( ports[ nChannels ] ) nChannels++; free( ports ); @@ -2168,7 +2168,7 @@ bool RtApiJack :: probeDeviceOpen( unsigned int device, StreamMode mode, unsigne const char **ports; std::string port, previousPort, deviceName; unsigned int nPorts = 0, nDevices = 0; - ports = jack_get_ports( client, NULL, NULL, 0 ); + ports = jack_get_ports( client, NULL, JACK_DEFAULT_AUDIO_TYPE, 0 ); if ( ports ) { // Parse the port names up to the first colon (:). size_t iColon = 0; @@ -2192,22 +2192,24 @@ bool RtApiJack :: probeDeviceOpen( unsigned int device, StreamMode mode, unsigne return FAILURE; } - // Count the available ports containing the client name as device - // channels. Jack "input ports" equal RtAudio output channels. - unsigned int nChannels = 0; unsigned long flag = JackPortIsInput; if ( mode == INPUT ) flag = JackPortIsOutput; - ports = jack_get_ports( client, deviceName.c_str(), NULL, flag ); - if ( ports ) { - while ( ports[ nChannels ] ) nChannels++; - free( ports ); - } - // Compare the jack ports for specified client to the requested number of channels. - if ( nChannels < (channels + firstChannel) ) { - errorStream_ << "RtApiJack::probeDeviceOpen: requested number of channels (" << channels << ") + offset (" << firstChannel << ") not found for specified device (" << device << ":" << deviceName << ")."; - errorText_ = errorStream_.str(); - return FAILURE; + if ( ! (options && (options->flags & RTAUDIO_JACK_DONT_CONNECT)) ) { + // Count the available ports containing the client name as device + // channels. Jack "input ports" equal RtAudio output channels. + unsigned int nChannels = 0; + ports = jack_get_ports( client, deviceName.c_str(), JACK_DEFAULT_AUDIO_TYPE, flag ); + if ( ports ) { + while ( ports[ nChannels ] ) nChannels++; + free( ports ); + } + // Compare the jack ports for specified client to the requested number of channels. + if ( nChannels < (channels + firstChannel) ) { + errorStream_ << "RtApiJack::probeDeviceOpen: requested number of channels (" << channels << ") + offset (" << firstChannel << ") not found for specified device (" << device << ":" << deviceName << ")."; + errorText_ = errorStream_.str(); + return FAILURE; + } } // Check the jack server sample rate. @@ -2221,7 +2223,7 @@ bool RtApiJack :: probeDeviceOpen( unsigned int device, StreamMode mode, unsigne stream_.sampleRate = jackRate; // Get the latency of the JACK port. - ports = jack_get_ports( client, deviceName.c_str(), NULL, flag ); + ports = jack_get_ports( client, deviceName.c_str(), JACK_DEFAULT_AUDIO_TYPE, flag ); if ( ports[ firstChannel ] ) { // Added by Ge Wang jack_latency_callback_mode_t cbmode = (mode == INPUT ? JackCaptureLatency : JackPlaybackLatency); @@ -2453,7 +2455,7 @@ void RtApiJack :: startStream( void ) // Get the list of available ports. if ( shouldAutoconnect_ && (stream_.mode == OUTPUT || stream_.mode == DUPLEX) ) { result = 1; - ports = jack_get_ports( handle->client, handle->deviceName[0].c_str(), NULL, JackPortIsInput); + ports = jack_get_ports( handle->client, handle->deviceName[0].c_str(), JACK_DEFAULT_AUDIO_TYPE, JackPortIsInput); if ( ports == NULL) { errorText_ = "RtApiJack::startStream(): error determining available JACK input ports!"; goto unlock; @@ -2477,7 +2479,7 @@ void RtApiJack :: startStream( void ) if ( shouldAutoconnect_ && (stream_.mode == INPUT || stream_.mode == DUPLEX) ) { result = 1; - ports = jack_get_ports( handle->client, handle->deviceName[1].c_str(), NULL, JackPortIsOutput ); + ports = jack_get_ports( handle->client, handle->deviceName[1].c_str(), JACK_DEFAULT_AUDIO_TYPE, JackPortIsOutput ); if ( ports == NULL) { errorText_ = "RtApiJack::startStream(): error determining available JACK output ports!"; goto unlock; diff --git a/configure.ac b/configure.ac index 286b7d9..322f1b4 100644 --- a/configure.ac +++ b/configure.ac @@ -38,9 +38,9 @@ use_asio="" # configure flags AC_ARG_ENABLE(debug, [AS_HELP_STRING([--enable-debug],[enable various debug output])]) -AC_ARG_WITH(jack, [AS_HELP_STRING([--with-jack], [choose JACK server support (mac and linux only)])]) +AC_ARG_WITH(jack, [AS_HELP_STRING([--with-jack], [choose JACK server support])]) AC_ARG_WITH(alsa, [AS_HELP_STRING([--with-alsa], [choose native ALSA API support (linux only)])]) -AC_ARG_WITH(pulse, [AS_HELP_STRING([--with-pulse], [choose PulseAudio API support (linux only)])]) +AC_ARG_WITH(pulse, [AS_HELP_STRING([--with-pulse], [choose PulseAudio API support (unixes)])]) AC_ARG_WITH(oss, [AS_HELP_STRING([--with-oss], [choose OSS API support (unixes)])]) AC_ARG_WITH(core, [AS_HELP_STRING([--with-core], [choose CoreAudio API support (mac only)])]) AC_ARG_WITH(asio, [AS_HELP_STRING([--with-asio], [choose ASIO API support (win32 only)])]) @@ -86,8 +86,8 @@ AC_CHECK_HEADERS(sys/ioctl.h unistd.h) AS_IF([test "x${GXX}" = "xyes" ], [ CXXFLAGS="-Wall -Wextra ${CXXFLAGS}" AS_IF([ test "x${enable_debug}" = "xyes" ], [ - # Add -Werror in debug mode - CXXFLAGS="-Werror ${CXXFLAGS}" + # Add -Werror in debug mode (except unused-function) + CXXFLAGS="-Werror -Wno-error=unused-function ${CXXFLAGS}" ], [ # hide private symbols in non-debug mode visibility="-fvisibility=hidden" @@ -147,114 +147,150 @@ AC_CONFIG_LINKS( [doc/images/ccrma.gif:doc/images/ccrma.gif] ) # Checks for package options and external software AC_CANONICAL_HOST -AC_MSG_CHECKING([for audio API]) +# Aggregate options into a single string. +AS_IF([test "x$with_jack" = "xyes"], [systems="$systems jack"]) +AS_IF([test "x$with_alsa" = "xyes"], [systems="$systems alsa"]) +AS_IF([test "x$with_pulse" = "xyes"], [systems="$systems pulse"]) +AS_IF([test "x$with_oss" = "xyes"], [systems="$systems oss"]) +AS_IF([test "x$with_core" = "xyes"], [systems="$systems core"]) +AS_IF([test "x$with_asio" = "xyes"], [systems="$systems asio"]) +AS_IF([test "x$with_dsound" = "xyes"], [systems="$systems ds"]) +AS_IF([test "x$with_wasapi" = "xyes"], [systems="$systems wasapi"]) +required=" $systems " + +# If none, assign defaults if any are known for this OS. +# User must specified with-* options for any unknown OS. +AS_IF([test "x$systems" = "x"], + AS_CASE([$host], + [*-*-netbsd*], [systems="oss"], + [*-*-freebsd*], [systems="oss"], + [*-*-linux*], [systems="alsa pulse jack oss"], + [*-apple*], [systems="core jack"], + [*-mingw32*], [systems="asio ds wasapi jack"] + )) + +# If any were specifically requested disabled, do it. +AS_IF([test "x$with_jack" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v jack`]) +AS_IF([test "x$with_alsa" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v alsa`]) +AS_IF([test "x$with_pulse" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v pulse`]) +AS_IF([test "x$with_oss" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v oss`]) +AS_IF([test "x$with_core" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v core`]) +AS_IF([test "x$with_asio" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v asio`]) +AS_IF([test "x$with_dsound" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v dsound`]) +AS_IF([test "x$with_wasapi" = "xno"], [systems=`echo $systems|tr ' ' \\\\n|grep -v wasapi`]) +systems=" `echo $systems|tr \\\\n ' '` " -AS_IF([test "x$with_jack" = "xyes"], [ - AC_MSG_RESULT([using JACK]) - AC_CHECK_LIB(jack, jack_client_open, , AC_MSG_ERROR([JACK support requires the jack library!])) - api="$api -D__UNIX_JACK__" - req="$req jack" +# For each audio system, check if it is selected and found. +# Note: Order specified above is not necessarily respected. However, +# *actual* priority is set at run-time, see RtAudio::openRtApi. +# One AS_CASE per system, since they are not mutually-exclusive. + +AS_CASE(["$systems"], [*" alsa "*], [ + AC_CHECK_LIB(asound, snd_pcm_open, + [api="$api -D__LINUX_ALSA__" + req="$req alsa" + need_pthread=yes + found="$found ALSA" + LIBS="-lasound $LIBS"], + AS_CASE(["$required"], [*" alsa "*], + AC_MSG_ERROR([ALSA support requires the asound library!]))) ]) +AS_CASE(["$systems"], [*" pulse "*], [ + AC_CHECK_LIB(pulse-simple, pa_simple_flush, + [api="$api -D__LINUX_PULSE__" + req="$req libpulse-simple" + need_pthread=yes + found="$found PulseAudio" + LIBS="-lpulse-simple $LIBS"], + AS_CASE(["$required"], [*" pulse "*], + AC_MSG_ERROR([PulseAudio support requires the pulse-simple library!]))) +]) -AS_CASE([$host], - [*-*-netbsd*], - AS_IF([test "x$api" = "x"], [ - AC_MSG_RESULT([using OSS]) - api="$api -D__LINUX_OSS__" - AC_CHECK_LIB(ossaudio, main, , AC_MSG_ERROR([RtAudio requires the ossaudio library])) - AC_CHECK_LIB(pthread, pthread_create, , AC_MSG_ERROR([RtAudio requires the pthread library!])) - ]), - [*-*-freebsd*], - AS_IF([test "x$api" = "x"], [ - AC_MSG_RESULT([using OSS]) - api="$api -D__LINUX_OSS__" - AC_CHECK_LIB(ossaudio, main, , AC_MSG_ERROR([RtAudio requires the ossaudio library])) - AC_CHECK_LIB(pthread, pthread_create, , AC_MSG_ERROR([RtAudio requires the pthread library!])) - ]), - [*-*-linux*], [ - # Look for ALSA flag - AS_IF([test "x$with_alsa" = "xyes"], [ - AC_MSG_RESULT([using ALSA]) - api="$api -D__LINUX_ALSA__" - req="$req alsa" - AC_CHECK_LIB(asound, snd_pcm_open, , AC_MSG_ERROR([ALSA support requires the asound library!])) - ]) - # Look for PULSE flag - AS_IF([test "x$with_pulse" = "xyes"], [ - AC_MSG_RESULT([using PulseAudio]) - api="$api -D__LINUX_PULSE__" - req="$req libpulse-simple" - AC_CHECK_LIB(pulse-simple, pa_simple_flush, , AC_MSG_ERROR([PulseAudio support requires the pulse-simple library!])) - ]) +AS_CASE(["$systems"], [*" oss "*], [ + # libossaudio not required on some platforms (e.g. linux) so we + # don't break things if it's not found, but issue a warning when we + # are not sure (i.e. not on linux) + AS_CASE([$host], [*-*-linux*], [], [*], [need_ossaudio=yes]) + AC_CHECK_LIB(ossaudio, main, [have_ossaudio=true], + AS_CASE(["$required"], [*" oss "*], + AS_IF([test "x$need_ossaudio" = xyes], + AC_MSG_WARN([RtAudio may require the ossaudio library])))) - # Look for OSS flag - AS_IF([test "x$with_oss" = "xyes"], [ - AC_MSG_RESULT([using OSS]) - api="$api -D__LINUX_OSS__" - ]) + # linux systems may have soundcard.h but *not* have OSS4 installed, + # we have to actually check if it exports OSS4 symbols + AC_CHECK_DECL(SNDCTL_SYSINFO, + [api="$api -D__LINUX_OSS__" + need_pthread=yes + found="$found OSS"], + AS_CASE(["$required"], [*" oss "*], + AC_MSG_ERROR([sys/soundcard.h not found])) + [], + [#include <sys/soundcard.h>]) +]) - # If no audio api flags specified, use ALSA - AS_IF([test "x$api" = "x" ], [ - AC_MSG_RESULT([using ALSA]) - api="${api} -D__LINUX_ALSA__" - req="${req} alsa" - AC_CHECK_LIB(asound, snd_pcm_open, , AC_MSG_ERROR([ALSA support requires the asound library!])) - ]) - AC_CHECK_LIB(pthread, pthread_create, , AC_MSG_ERROR([RtAudio requires the pthread library!])) - ], - [*-apple*],[ - # Look for Core flag - AS_IF([test "x$with_core" = "xyes"], [ - AC_MSG_RESULT([using CoreAudio]) - api="$api -D__MACOSX_CORE__" - AC_CHECK_HEADER(CoreAudio/CoreAudio.h, [], [AC_MSG_ERROR([CoreAudio header files not found!])] ) - LIBS="$LIBS -framework CoreAudio -framework CoreFoundation" - ]) - # If no audio api flags specified, use CoreAudio - AS_IF([test "x$api" = "x" ], [ - AC_MSG_RESULT([using CoreAudio]) - api="${api} -D__MACOSX_CORE__" - AC_CHECK_HEADER(CoreAudio/CoreAudio.h, - [], - [AC_MSG_ERROR([CoreAudio header files not found!])] ) - LIBS="LIBS -framework CoreAudio -framework CoreFoundation" - ]) - AC_CHECK_LIB(pthread, pthread_create, , AC_MSG_ERROR([RtAudio requires the pthread library!])) - ], - [*-mingw32*],[ - AS_IF([test "x$with_asio" = "xyes" ], [ - AC_MSG_RESULT([using ASIO]) - api="$api -D__WINDOWS_ASIO__" - use_asio=yes - CPPFLAGS="-I$srcdir/include $CPPFLAGS" - ]) - # Look for DirectSound flag - AS_IF([test "x$with_ds" = "xyes" ], [ - AC_MSG_RESULT([using DirectSound]) - api="$api -D__WINDOWS_DS__" - LIBS="-ldsound -lwinmm $LIBS" - ]) - # Look for WASAPI flag - AS_IF([test "x$with_wasapi" = "xyes"], [ - AC_MSG_RESULT([using WASAPI]) - api="$api -D__WINDOWS_WASAPI__" - LIBS="-lwinmm -luuid -lksuser $LIBS" - CPPFLAGS="-I$srcdir/include $CPPFLAGS" - ]) - # If no audio api flags specified, use DS - AS_IF([test "x$api" = "x" ], [ - AC_MSG_RESULT([using DirectSound]) - api="$api -D__WINDOWS_DS__" - LIBS="-ldsound -lwinmm $LIBS" - ]) - LIBS="-lole32 $LIBS" - ],[ +AS_CASE(["$systems"], [*" jack "*], [ + AC_CHECK_LIB(jack, jack_client_open, + [api="$api -D__UNIX_JACK__" + req="$req jack" + need_pthread=yes + found="$found JACK" + LIBS="-ljack $LIBS"], + AS_CASE(["$required"], [*" jack "*], + AC_MSG_ERROR([JACK support requires the jack library!]))) +]) + +AS_CASE(["$systems"], [*" core "*], [ + AC_CHECK_HEADER(CoreAudio/CoreAudio.h, + [api="$api -D__MACOSX_CORE__" + need_pthread=yes + found="$found CoreAudio", + LIBS="$LIBS -framework CoreAudio -framework CoreFoundation"], + AS_CASE(["$required"], [*" core "*], + AC_MSG_ERROR([CoreAudio header files not found!]))) +]) + +AS_CASE(["$systems"], [*" asio "*], [ + api="$api -D__WINDOWS_ASIO__" + use_asio=yes + CPPFLAGS="-I$srcdir/include $CPPFLAGS" + need_ole32=yes + found="$found ASIO" +]) + +AS_CASE(["$systems"], [*" ds "*], [ + AC_CHECK_HEADERS(mmsystem.h mmreg.h dsound.h, + [api="$api -D__WINDOWS_DS__" + need_ole32=yes + found="$found DirectSound" + LIBS="-ldsound -lwinmm $LIBS"]) +]) + +AS_CASE(["$systems"], [*" wasapi "*], [ + AC_CHECK_HEADERS(windows.h audioclient.h avrt.h mmdeviceapi.h, + [api="$api -D__WINDOWS_WASAPI__" + CPPFLAGS="-I$srcdir/include $CPPFLAGS" + need_ole32=yes + found="$found WASAPI" + LIBS="-lwinmm -luuid -lksuser $LIBS"]) +]) + +AS_IF([test -n "$need_ole32"], [LIBS="-lole32 $LIBS"]) + +AS_IF([test -n "$need_pthread"],[ + AC_MSG_CHECKING([for pthread]) + AC_CHECK_LIB(pthread, pthread_create, , + AC_MSG_ERROR([RtAudio requires the pthread library!]))]) + +AC_MSG_CHECKING([for audio API]) + +# Error case: no known realtime systems found. +AS_IF([test x"$api" = "x"], [ AC_MSG_RESULT([none]) - # Default case for unknown realtime systems. - AC_MSG_ERROR([Unknown system type for realtime support!]) - ] -) + AC_MSG_ERROR([No known system type found for realtime support!]) +], [ + AC_MSG_RESULT([$found]) +]) AM_CONDITIONAL( ASIO, [test "x${use_asio}" = "xyes" ]) diff --git a/rtaudio.pc.in b/rtaudio.pc.in index 7627780..0e81090 100644 --- a/rtaudio.pc.in +++ b/rtaudio.pc.in @@ -1,4 +1,4 @@ -prefix=@CMAKE_INSTALL_PREFIX@ +prefix=@prefix@ exec_prefix=${prefix} libdir=${exec_prefix}/lib includedir=${prefix}/include/rtaudio |
