+/********************************
+ * Get id name of device
+ *********************************/
+char * libvlc_audio_output_device_id( libvlc_instance_t *p_instance,
+ const char *psz_audio_output,
+ int i_device )
+{
+ char *psz_config_name = NULL;
+ if( !psz_audio_output )
+ return NULL;
+ if( asprintf( &psz_config_name, "%s-audio-device", psz_audio_output ) == -1)
+ return NULL;
+
+ module_config_t *p_module_config = config_FindConfig(
+ VLC_OBJECT( p_instance->p_libvlc_int ), psz_config_name );
+
+ if( p_module_config )
+ {
+ // refresh if there arent devices
+ if( p_module_config->i_list < 2 && p_module_config->pf_update_list )
+ {
+ vlc_value_t val;
+ val.psz_string = strdup( p_module_config->value.psz );
+
+ p_module_config->pf_update_list(
+ VLC_OBJECT( p_instance->p_libvlc_int ), psz_config_name, val, val, NULL );
+ free( val.psz_string );
+ }
+ free( psz_config_name );
+
+ if( i_device >= 0 && i_device < p_module_config->i_list )
+ return strdup( p_module_config->ppsz_list[i_device] );
+
+ }
+ else
+ free( psz_config_name );
+
+ return NULL;
+}
+
+/*****************************
+ * Set device for using
+ *****************************/
+VLC_PUBLIC_API void libvlc_audio_output_device_set( libvlc_instance_t *p_instance,
+ const char *psz_audio_output,
+ const char *psz_device_id )
+{
+ char *psz_config_name = NULL;
+ if( !psz_audio_output || !psz_device_id )
+ return;
+ if( asprintf( &psz_config_name, "%s-audio-device", psz_audio_output ) == -1 )
+ return;
+ config_PutPsz( p_instance->p_libvlc_int, psz_config_name, psz_device_id );
+ free( psz_config_name );
+}
+
+/*****************************************************************************
+ * libvlc_audio_output_get_device_type : Get the current audio device type
+ *****************************************************************************/
+int libvlc_audio_output_get_device_type( libvlc_instance_t *p_instance,
+ libvlc_exception_t *p_e )
+{
+ aout_instance_t *p_aout = GetAOut( p_instance, p_e );
+ if( p_aout )
+ {
+ vlc_value_t val;
+
+ var_Get( p_aout, "audio-device", &val );
+ vlc_object_release( p_aout );
+ return val.i_int;
+ }
+ libvlc_exception_raise( p_e, "Unable to get audio output" );
+ return libvlc_AudioOutputDevice_Error;
+}
+
+/*****************************************************************************
+ * libvlc_audio_output_set_device_type : Set the audio device type
+ *****************************************************************************/
+void libvlc_audio_output_set_device_type( libvlc_instance_t *p_instance,
+ int device_type,
+ libvlc_exception_t *p_e )
+{
+ aout_instance_t *p_aout = GetAOut( p_instance, p_e );
+ if( p_aout )
+ {
+ vlc_value_t val;
+ int i_ret = -1;
+
+ val.i_int = (int) device_type;
+ i_ret = var_Set( p_aout, "audio-device", val );
+ if( i_ret < 0 )
+ {
+ libvlc_exception_raise( p_e, "Failed setting audio device" );
+ vlc_object_release( p_aout );
+ return;
+ }
+
+ vlc_object_release( p_aout );
+ }
+}