Commit b90f1b90 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

audio: support setting device of current audio output (refs #10720)

parent ad19329c
...@@ -1508,26 +1508,42 @@ LIBVLC_API void libvlc_audio_output_device_list_release( ...@@ -1508,26 +1508,42 @@ LIBVLC_API void libvlc_audio_output_device_list_release(
libvlc_audio_output_device_t *p_list ); libvlc_audio_output_device_t *p_list );
/** /**
* Configures an explicit audio output device for a given audio output plugin. * Configures an explicit audio output device.
* A list of possible devices can be obtained with *
* If the module paramater is NULL, audio output will be moved to the device
* specified by the device identifier string immediately. This is the
* recommended usage.
*
* However passing NULL is supported in LibVLC version 2.2.0 and later only;
* in earlier versions, this function would have no effects when the module
* parameter was NULL.
*
* If the module parameter is not NULL, the device parameter of the
* corresponding audio output, if it exists, will be set to the specified
* string. Note that some audio output modules do not have such a parameter
* (notably MMDevice and PulseAudio).
*
* A list of adequate potential device strings can be obtained with
* libvlc_audio_output_device_list_get(). * libvlc_audio_output_device_list_get().
* *
* \note This function does not select the specified audio output plugin. * \note This function does not select the specified audio output plugin.
* libvlc_audio_output_set() is used for that purpose. * libvlc_audio_output_set() is used for that purpose.
* *
* \warning The syntax for the device parameter depends on the audio output. * \warning The syntax for the device parameter depends on the audio output.
* This is not portable. Only use this function if you know what you are doing.
* Some audio outputs do not support this function (e.g. PulseAudio, WASAPI).
* Some audio outputs require further parameters (e.g. ALSA: channels map).
* *
* \param p_mi media player * Some audio output modules require further parameters (e.g. a channels map
* \param psz_audio_output - name of audio output, \see libvlc_audio_output_t * in the case of ALSA).
* \param psz_device_id device *
* \return Nothing. Errors are ignored. * \param mp media player
* \param module If NULL, current audio output module.
* if non-NULL, name of audio output module
(\see libvlc_audio_output_t)
* \param device_id device identifier string
* \return Nothing. Errors are ignored (this is a design bug).
*/ */
LIBVLC_API void libvlc_audio_output_device_set( libvlc_media_player_t *p_mi, LIBVLC_API void libvlc_audio_output_device_set( libvlc_media_player_t *mp,
const char *psz_audio_output, const char *module,
const char *psz_device_id ); const char *device_id );
/** /**
* Stub for backward compatibility. * Stub for backward compatibility.
......
...@@ -211,19 +211,32 @@ char *libvlc_audio_output_device_id( libvlc_instance_t *p_instance, ...@@ -211,19 +211,32 @@ char *libvlc_audio_output_device_id( libvlc_instance_t *p_instance,
* Set device for using * Set device for using
*****************************/ *****************************/
void libvlc_audio_output_device_set( libvlc_media_player_t *mp, void libvlc_audio_output_device_set( libvlc_media_player_t *mp,
const char *psz_audio_output, const char *module, const char *devid )
const char *psz_device_id )
{ {
char *psz_config_name; if( devid == NULL )
if( !psz_audio_output || !psz_device_id )
return; return;
if( asprintf( &psz_config_name, "%s-audio-device", psz_audio_output ) == -1 )
if( module != NULL )
{
char *cfg_name;
if( asprintf( &cfg_name, "%s-audio-device", module ) == -1 )
return;
if( !var_Type( mp, cfg_name ) )
/* Don't recreate the same variable over and over and over... */
var_Create( mp, cfg_name, VLC_VAR_STRING );
var_SetString( mp, cfg_name, devid );
free( cfg_name );
return; return;
if( !var_Type( mp, psz_config_name ) ) }
/* Don't recreate the same variable over and over and over... */
var_Create( mp, psz_config_name, VLC_VAR_STRING ); audio_output_t *aout = GetAOut( mp );
var_SetString( mp, psz_config_name, psz_device_id ); if( aout != NULL )
free( psz_config_name ); return;
aout_DeviceSet( aout, devid );
vlc_object_release( aout );
} }
int libvlc_audio_output_get_device_type( libvlc_media_player_t *mp ) int libvlc_audio_output_get_device_type( libvlc_media_player_t *mp )
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment