diff options
| author | Stephen Sinclair <radarsat1@gmail.com> | 2018-10-16 15:01:30 +0200 |
|---|---|---|
| committer | Stephen Sinclair <radarsat1@gmail.com> | 2018-10-16 15:01:30 +0200 |
| commit | 4690b26068191afa44dc8a872e250990acb1d175 (patch) | |
| tree | 0b6b1e4d752315423590e134f72e844760601540 /rtaudio_c.cpp | |
| parent | 154627e9e314bc99d5f29a1675bdbd7a7c80c612 (diff) | |
| parent | 6919d3578769202957d1ba320ff458e959935e05 (diff) | |
Merge remote-tracking branch 'upstream/pr/136'
Diffstat (limited to 'rtaudio_c.cpp')
| -rw-r--r-- | rtaudio_c.cpp | 57 |
1 files changed, 25 insertions, 32 deletions
diff --git a/rtaudio_c.cpp b/rtaudio_c.cpp index 699d2ce..da3ab24 100644 --- a/rtaudio_c.cpp +++ b/rtaudio_c.cpp @@ -15,40 +15,33 @@ struct rtaudio { char errmsg[MAX_ERROR_MESSAGE_LENGTH]; }; -static const rtaudio_api_t compiled_api[] = { -#if defined(__UNIX_JACK__) - RTAUDIO_API_UNIX_JACK, -#endif -#if defined(__LINUX_ALSA__) - RTAUDIO_API_LINUX_ALSA, -#endif -#if defined(__LINUX_PULSE__) - RTAUDIO_API_LINUX_PULSE, -#endif -#if defined(__LINUX_OSS__) - RTAUDIO_API_LINUX_OSS, -#endif -#if defined(__WINDOWS_ASIO__) - RTAUDIO_API_WINDOWS_ASIO, -#endif -#if defined(__WINDOWS_WASAPI__) - RTAUDIO_API_WINDOWS_WASAPI, -#endif -#if defined(__WINDOWS_DS__) - RTAUDIO_API_WINDOWS_DS, -#endif -#if defined(__MACOSX_CORE__) - RTAUDIO_API_MACOSX_CORE, -#endif -#if defined(__RTAUDIO_DUMMY__) - RTAUDIO_API_DUMMY, -#endif - RTAUDIO_API_UNSPECIFIED, -}; - const char *rtaudio_version() { return RTAUDIO_VERSION; } -const rtaudio_api_t *rtaudio_compiled_api() { return compiled_api; } +extern "C" const rtaudio_api_t rtaudio_compiled_apis[]; // casting from RtAudio::Api[] +extern "C" const unsigned int rtaudio_num_compiled_apis; +const rtaudio_api_t *rtaudio_compiled_api() { return rtaudio_compiled_apis; } + +extern "C" const char* rtaudio_api_names[][2]; +const char *rtaudio_api_name(rtaudio_api_t api) { + if (api < 0 || api >= RTAUDIO_API_NUM) + return NULL; + return rtaudio_api_names[api][0]; +} + +const char *rtaudio_api_display_name(rtaudio_api_t api) +{ + if (api < 0 || api >= RTAUDIO_API_NUM) + return "Unknown"; + return rtaudio_api_names[api][1]; +} + +rtaudio_api_t rtaudio_compiled_api_by_name(const char *name) { + RtAudio::Api api = RtAudio::UNSPECIFIED; + if (name) { + api = RtAudio::getCompiledApiByName(name); + } + return (rtaudio_api_t)api; +} const char *rtaudio_error(rtaudio_t audio) { if (audio->has_error) { |
