← Back to team overview

openlp-core team mailing list archive

[Merge] lp:~googol/openlp/vlc into lp:openlp

 

Andreas Preikschat has proposed merging lp:~googol/openlp/vlc into lp:openlp.

Requested reviews:
  OpenLP Core (openlp-core)

For more details, see:
https://code.launchpad.net/~googol/openlp/vlc/+merge/149205

Hello,

- updated vlc.py


[andreas@andylaptop vlc]$ nosetests2 tests/functional/
...............................................................
----------------------------------------------------------------------
Ran 63 tests in 0.189s

OK
[andreas@andylaptop vlc]$ nosetests2 tests/interfaces/
........
----------------------------------------------------------------------
Ran 8 tests in 0.267s

OK
[andreas@andylaptop vlc]$
-- 
https://code.launchpad.net/~googol/openlp/vlc/+merge/149205
Your team OpenLP Core is requested to review the proposed merge of lp:~googol/openlp/vlc into lp:openlp.
=== modified file 'openlp/core/ui/media/vendor/vlc.py'
--- openlp/core/ui/media/vendor/vlc.py	2012-12-29 20:56:56 +0000
+++ openlp/core/ui/media/vendor/vlc.py	2013-02-19 07:20:28 +0000
@@ -2,7 +2,7 @@
 
 # Python ctypes bindings for VLC
 #
-# Copyright (C) 2009-2013 the VideoLAN team
+# Copyright (C) 2009-2012 the VideoLAN team
 # $Id: $
 #
 # Authors: Olivier Aubert <olivier.aubert at liris.cnrs.fr>
@@ -48,7 +48,7 @@
 from inspect import getargspec
 
 __version__ = "N/A"
-build_date  = "Fri Oct  5 21:35:59 2012"
+build_date  = "Wed Feb 13 18:40:24 2013"
 
 if sys.version_info[0] > 2:
     str = str
@@ -1000,6 +1000,50 @@
         ('rate_or_width',      ctypes.c_uint  ),
     ]
 
+class AudioTrack(_Cstruct):
+    _fields_ = [
+        ('channels', ctypes.c_uint),
+        ('rate', ctypes.c_uint),
+        ]
+
+class VideoTrack(_Cstruct):
+    _fields_ = [
+        ('height', ctypes.c_uint),
+        ('width', ctypes.c_uint),
+        ('sar_num', ctypes.c_uint),
+        ('sar_den', ctypes.c_uint),
+        ('frame_rate_num', ctypes.c_uint),
+        ('frame_rate_den', ctypes.c_uint),
+        ]
+
+class SubtitleTrack(_Cstruct):
+    _fields_ = [
+        ('encoding', ctypes.c_char_p),
+        ]
+
+class MediaTrackTracks(ctypes.Union):
+    _fields_ = [
+        ('audio', ctypes.POINTER(AudioTrack)),
+        ('video', ctypes.POINTER(VideoTrack)),
+        ('subtitle', ctypes.POINTER(SubtitleTrack)),
+        ]
+
+class MediaTrack(_Cstruct):
+    _anonymous_ = ("u",)
+    _fields_ = [
+        ('codec',              ctypes.c_uint32),
+        ('original_fourcc',    ctypes.c_uint32),
+        ('id',                 ctypes.c_int   ),
+        ('type',               TrackType      ),
+        ('profile',            ctypes.c_int   ),
+        ('level',              ctypes.c_int   ),
+
+        ('u',                  MediaTrackTracks),
+        ('bitrate',            ctypes.c_uint),
+        ('language',           ctypes.c_char_p),
+        ('description',        ctypes.c_char_p),
+        ]
+
 class PlaylistItem(_Cstruct):
     _fields_ = [
         ('id',   ctypes.c_int   ),
@@ -1122,6 +1166,17 @@
         libvlc_module_description_list_release(head)
     return r
 
+class AudioOutputDevice(_Cstruct):
+
+    def __str__(self):
+        return '%s(%d:%s)' % (self.__class__.__name__, self.id, self.name)
+
+AudioOutputDevice._fields_ = [  # recursive struct
+    ('next', ctypes.POINTER(AudioOutputDevice)),
+    ('device',   ctypes.c_char_p   ),
+    ('description', ctypes.c_char_p),
+    ]
+
  # End of header.py #
 
 class EventManager(_Ctype):
@@ -1282,7 +1337,7 @@
             m = libvlc_media_new_location(self, str_to_bytes(mrl))
         else:
             # Else it should be a local path.
-            m = libvlc_media_new_path(self, str_to_bytes(mrl))
+            m = libvlc_media_new_path(self, str_to_bytes(os.path.normpath(mrl)))
         for o in options:
             libvlc_media_add_option(m, str_to_bytes(o))
         m._instance = self
@@ -1361,27 +1416,6 @@
         '''
         return libvlc_set_user_agent(self, name, http)
 
-    def get_log_verbosity(self):
-        '''Always returns minus one.
-        This function is only provided for backward compatibility.
-        @return: always -1.
-        '''
-        return libvlc_get_log_verbosity(self)
-
-    def set_log_verbosity(self, level):
-        '''This function does nothing.
-        It is only provided for backward compatibility.
-        @param level: ignored.
-        '''
-        return libvlc_set_log_verbosity(self, level)
-
-    def log_open(self):
-        '''This function does nothing useful.
-        It is only provided for backward compatibility.
-        @return: an unique pointer or NULL on error.
-        '''
-        return libvlc_log_open(self)
-
     def media_new_location(self, psz_mrl):
         '''Create a media with a certain given media resource location,
         for instance a valid URL.
@@ -1445,34 +1479,26 @@
         return libvlc_media_library_new(self)
 
     def audio_output_list_get(self):
-        '''Get the list of available audio outputs.
+        '''Gets the list of available audio outputs.
         @return: list of available audio outputs. It must be freed it with In case of error, NULL is returned.
         '''
         return libvlc_audio_output_list_get(self)
 
-    def audio_output_device_count(self, psz_audio_output):
-        '''Get count of devices for audio output, these devices are hardware oriented
-        like analor or digital output of sound card.
-        @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-        @return: number of devices.
-        '''
-        return libvlc_audio_output_device_count(self, psz_audio_output)
-
-    def audio_output_device_longname(self, psz_audio_output, i_device):
-        '''Get long name of device, if not available short name given.
-        @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-        @param i_device: device index.
-        @return: long name of device.
-        '''
-        return libvlc_audio_output_device_longname(self, psz_audio_output, i_device)
-
-    def audio_output_device_id(self, psz_audio_output, i_device):
-        '''Get id name of device.
-        @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-        @param i_device: device index.
-        @return: id name of device, use for setting device, need to be free after use.
-        '''
-        return libvlc_audio_output_device_id(self, psz_audio_output, i_device)
+    def audio_output_device_list_get(self, aout):
+        '''Gets a list of audio output devices for a given audio output.
+        See L{audio_output_device_set}().
+        @note: Not all audio outputs support this. In particular, an empty (NULL)
+        list of devices does B{not} imply that the specified audio output does
+        not work.
+        @note: The list might not be exhaustive.
+        @warning: Some audio output devices in the list might not actually work in
+        some circumstances. By default, it is recommended to not specify any
+        explicit audio device.
+        @param psz_aout: audio output name (as returned by L{audio_output_list_get}()).
+        @return: A NULL-terminated linked list of potential audio output devices. It must be freed it with L{audio_output_device_list_release}().
+        @version: LibVLC 2.1.0 or later.
+        '''
+        return libvlc_audio_output_device_list_get(self, aout)
 
     def vlm_release(self):
         '''Release the vlm instance related to the given L{Instance}.
@@ -1683,87 +1709,6 @@
         '''
         return libvlc_vlm_get_event_manager(self)
 
-class Log(_Ctype):
-    '''Create a new VLC log instance.
-
-    '''
-
-    def __new__(cls, ptr=_internal_guard):
-        '''(INTERNAL) ctypes wrapper constructor.
-        '''
-        return _Constructor(cls, ptr)
-
-    def __iter__(self):
-        return self.get_iterator()
-
-    def dump(self):
-        return [ str(m) for m in self ]
-
-
-    def close(self):
-        '''Frees memory allocated by L{open}().
-        '''
-        return libvlc_log_close(self)
-
-    def count(self):
-        '''Always returns zero.
-        This function is only provided for backward compatibility.
-        @return: always zero.
-        '''
-        return libvlc_log_count(self)
-
-    def __len__(self):
-        return libvlc_log_count(self)
-
-    def clear(self):
-        '''This function does nothing.
-        It is only provided for backward compatibility.
-        '''
-        return libvlc_log_clear(self)
-
-    def get_iterator(self):
-        '''This function does nothing useful.
-        It is only provided for backward compatibility.
-        @return: an unique pointer or NULL on error or if the parameter was NULL.
-        '''
-        return libvlc_log_get_iterator(self)
-
-class LogIterator(_Ctype):
-    '''Create a new VLC log iterator.
-
-    '''
-
-    def __new__(cls, ptr=_internal_guard):
-        '''(INTERNAL) ctypes wrapper constructor.
-        '''
-        return _Constructor(cls, ptr)
-
-    def __iter__(self):
-        return self
-
-    def next(self):
-        if self.has_next():
-            b = LogMessage()
-            i = libvlc_log_iterator_next(self, b)
-            return i.contents
-        raise StopIteration
-
-    def __next__(self):
-        return self.next()
-
-
-    def free(self):
-        '''Frees memory allocated by L{log_get_iterator}().
-        '''
-        return libvlc_log_iterator_free(self)
-
-    def has_next(self):
-        '''Always returns zero.
-        This function is only provided for backward compatibility.
-        @return: always zero.
-        '''
-        return libvlc_log_iterator_has_next(self)
-
 class Media(_Ctype):
     '''Create a new Media instance.
 
@@ -1809,11 +1754,13 @@
         This option will be used to determine how the media_player will
         read the media. This allows to use VLC's advanced
         reading/streaming options on a per-media basis.
-        The options are detailed in vlc --long-help, for instance
-        "--sout-all". Note that all options are not usable on medias:
-        specifically, due to architectural issues, video-related options
-        such as text renderer options cannot be set on a single media. They
-        must be set on the whole libvlc instance instead.
+        @note: The options are listed in 'vlc --long-help' from the command line,
+        e.g. "-sout-all". Keep in mind that available options and their semantics
+        vary across LibVLC versions and builds.
+        @warning: Not all options affects L{Media} objects:
+        Specifically, due to architectural issues most audio and video options,
+        such as text renderer options, have no effects on an individual media.
+        These options must be set through L{new}() instead.
         @param ppsz_options: the options (as a string).
         '''
         return libvlc_media_add_option(self, ppsz_options)
@@ -1906,6 +1853,14 @@
         '''
         return libvlc_media_get_stats(self, p_stats)
 
+    def subitems(self):
+        '''Get subitems of media descriptor object. This will increment
+        the reference count of supplied media descriptor object. Use
+        L{list_release}() to decrement the reference counting.
+        @return: list of media descriptor subitems or NULL.
+        '''
+        return libvlc_media_subitems(self)
+
     def event_manager(self):
         '''Get event manager from media descriptor object.
         NOTE: this function doesn't increment reference counting.
@@ -1925,7 +1880,7 @@
         The method is synchronous.
         See L{parse_async}
         See L{get_meta}
-        See L{get_tracks_info}.
+        See libvlc_media_get_tracks_info.
         '''
         return libvlc_media_parse(self)
 
@@ -1939,7 +1894,7 @@
         See L{parse}
         See libvlc_MediaParsedChanged
         See L{get_meta}
-        See L{get_tracks_info}.
+        See libvlc_media_get_tracks_info.
         '''
         return libvlc_media_parse_async(self)
 
@@ -1965,15 +1920,16 @@
         '''
         return libvlc_media_get_user_data(self)
 
-    def get_tracks_info(self):
+    def tracks_get(self, tracks):
         '''Get media descriptor's elementary streams description
         Note, you need to call L{parse}() or play the media at least once
         before calling this function.
         Not doing this will result in an empty array.
-        @param tracks: address to store an allocated array of Elementary Streams descriptions (must be freed by the caller) [OUT].
-        @return: the number of Elementary Streams.
+        @param tracks: address to store an allocated array of Elementary Streams descriptions (must be freed with L{tracks_release}.
+        @return: the number of Elementary Streams (zero on error).
+        @version: LibVLC 2.1.0 and later.
         '''
-        return libvlc_media_get_tracks_info(self)
+        return libvlc_media_tracks_get(self, tracks)
 
     def player_new_from_media(self):
         '''Create a Media Player object from a Media.
@@ -2255,7 +2211,7 @@
         return libvlc_media_list_player_play(self)
 
     def pause(self):
-        '''Pause media list.
+        '''Toggle pause (or resume) media list.
         '''
         return libvlc_media_list_player_pause(self)
 
@@ -2681,13 +2637,14 @@
         return libvlc_media_player_set_time(self, i_time)
 
     def get_position(self):
-        '''Get movie position.
+        '''Get movie position as percentage between 0.0 and 1.0.
         @return: movie position, or -1. in case of error.
         '''
         return libvlc_media_player_get_position(self)
 
     def set_position(self, f_pos):
-        '''Set movie position. This has no effect if playback is not enabled.
+        '''Set movie position as percentage between 0.0 and 1.0.
+        This has no effect if playback is not enabled.
         This might not work depending on the underlying input format and protocol.
         @param f_pos: the position.
         '''
@@ -2968,13 +2925,13 @@
 
     def video_get_track(self):
         '''Get current video track.
-        @return: the video track (int) or -1 if none.
+        @return: the video track ID (int) or -1 if no active input.
         '''
         return libvlc_video_get_track(self)
 
     def video_set_track(self, i_track):
         '''Set video track.
-        @param i_track: the track (int).
+        @param i_track: the track ID (i_id field from track description).
         @return: 0 on success, -1 if out of range.
         '''
         return libvlc_video_set_track(self, i_track)
@@ -3084,33 +3041,30 @@
         return libvlc_video_set_adjust_float(self, option, value)
 
     def audio_output_set(self, psz_name):
-        '''Set the audio output.
-        Change will be applied after stop and play.
+        '''Sets the audio output.
+        @note: Any change will take be effect only after playback is stopped and
+        restarted. Audio output cannot be changed while playing.
         @param psz_name: name of audio output, use psz_name of See L{AudioOutput}.
         @return: 0 if function succeded, -1 on error.
         '''
         return libvlc_audio_output_set(self, psz_name)
 
     def audio_output_device_set(self, psz_audio_output, psz_device_id):
-        '''Set audio output device. Changes are only effective after stop and play.
+        '''Configures an explicit audio output device for a given audio output plugin.
+        A list of possible devices can be obtained with
+        L{audio_output_device_list_get}().
+        @note: This function does not select the specified audio output plugin.
+        L{audio_output_set}() is used for that purpose.
+        @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 psz_audio_output: - name of audio output, See L{AudioOutput}.
         @param psz_device_id: device.
+        @return: Nothing. Errors are ignored.
         '''
         return libvlc_audio_output_device_set(self, psz_audio_output, psz_device_id)
 
-    def audio_output_get_device_type(self):
-        '''Get current audio device type. Device type describes something like
-        character of output sound - stereo sound, 2.1, 5.1 etc.
-        @return: the audio devices type See libvlc_audio_output_device_types_t.
-        '''
-        return libvlc_audio_output_get_device_type(self)
-
-    def audio_output_set_device_type(self, device_type):
-        '''Set current audio device type.
-        @param device_type: the audio device type,
-        '''
-        return libvlc_audio_output_set_device_type(self, device_type)
-
     def audio_toggle_mute(self):
         '''Toggle mute status.
         '''
@@ -3118,13 +3072,13 @@
 
     def audio_get_mute(self):
         '''Get current mute status.
-        @return: the mute status (boolean) \libvlc_return_bool.
+        @return: the mute status (boolean) if defined, -1 if undefined/unapplicable.
         '''
         return libvlc_audio_get_mute(self)
 
     def audio_set_mute(self, status):
         '''Set mute status.
-        @param status: If status is true then mute, otherwise unmute.
+        @param status: If status is true then mute, otherwise unmute @warning This function does not always work. If there are no active audio playback stream, the mute status might not be available. If digital pass-through (S/PDIF, HDMI...) is in use, muting may be unapplicable. Also some audio output plugins do not support muting at all. @note To force silent playback, disable all audio tracks. This is more efficient and reliable than mute.
         '''
         return libvlc_audio_set_mute(self, status)
 
@@ -3149,13 +3103,13 @@
 
     def audio_get_track(self):
         '''Get current audio track.
-        @return: the audio track (int), or -1 if none.
+        @return: the audio track ID or -1 if no active input.
         '''
         return libvlc_audio_get_track(self)
 
     def audio_set_track(self, i_track):
         '''Set current audio track.
-        @param i_track: the track (int).
+        @param i_track: the track ID (i_id field from track description).
         @return: 0 on success, -1 on error.
         '''
         return libvlc_audio_set_track(self, i_track)
@@ -3397,112 +3351,6 @@
                     None, ctypes.c_void_p)
     return f(sub)
 
-def libvlc_get_log_verbosity(p_instance):
-    '''Always returns minus one.
-    This function is only provided for backward compatibility.
-    @param p_instance: ignored.
-    @return: always -1.
-    '''
-    f = _Cfunctions.get('libvlc_get_log_verbosity', None) or \
-        _Cfunction('libvlc_get_log_verbosity', ((1,),), None,
-                    ctypes.c_uint, Instance)
-    return f(p_instance)
-
-def libvlc_set_log_verbosity(p_instance, level):
-    '''This function does nothing.
-    It is only provided for backward compatibility.
-    @param p_instance: ignored.
-    @param level: ignored.
-    '''
-    f = _Cfunctions.get('libvlc_set_log_verbosity', None) or \
-        _Cfunction('libvlc_set_log_verbosity', ((1,), (1,),), None,
-                    None, Instance, ctypes.c_uint)
-    return f(p_instance, level)
-
-def libvlc_log_open(p_instance):
-    '''This function does nothing useful.
-    It is only provided for backward compatibility.
-    @param p_instance: libvlc instance.
-    @return: an unique pointer or NULL on error.
-    '''
-    f = _Cfunctions.get('libvlc_log_open', None) or \
-        _Cfunction('libvlc_log_open', ((1,),), class_result(Log),
-                    ctypes.c_void_p, Instance)
-    return f(p_instance)
-
-def libvlc_log_close(p_log):
-    '''Frees memory allocated by L{libvlc_log_open}().
-    @param p_log: libvlc log instance or NULL.
-    '''
-    f = _Cfunctions.get('libvlc_log_close', None) or \
-        _Cfunction('libvlc_log_close', ((1,),), None,
-                    None, Log)
-    return f(p_log)
-
-def libvlc_log_count(p_log):
-    '''Always returns zero.
-    This function is only provided for backward compatibility.
-    @param p_log: ignored.
-    @return: always zero.
-    '''
-    f = _Cfunctions.get('libvlc_log_count', None) or \
-        _Cfunction('libvlc_log_count', ((1,),), None,
-                    ctypes.c_uint, Log)
-    return f(p_log)
-
-def libvlc_log_clear(p_log):
-    '''This function does nothing.
-    It is only provided for backward compatibility.
-    @param p_log: ignored.
-    '''
-    f = _Cfunctions.get('libvlc_log_clear', None) or \
-        _Cfunction('libvlc_log_clear', ((1,),), None,
-                    None, Log)
-    return f(p_log)
-
-def libvlc_log_get_iterator(p_log):
-    '''This function does nothing useful.
-    It is only provided for backward compatibility.
-    @param p_log: ignored.
-    @return: an unique pointer or NULL on error or if the parameter was NULL.
-    '''
-    f = _Cfunctions.get('libvlc_log_get_iterator', None) or \
-        _Cfunction('libvlc_log_get_iterator', ((1,),), class_result(LogIterator),
-                    ctypes.c_void_p, Log)
-    return f(p_log)
-
-def libvlc_log_iterator_free(p_iter):
-    '''Frees memory allocated by L{libvlc_log_get_iterator}().
-    @param p_iter: libvlc log iterator or NULL.
-    '''
-    f = _Cfunctions.get('libvlc_log_iterator_free', None) or \
-        _Cfunction('libvlc_log_iterator_free', ((1,),), None,
-                    None, LogIterator)
-    return f(p_iter)
-
-def libvlc_log_iterator_has_next(p_iter):
-    '''Always returns zero.
-    This function is only provided for backward compatibility.
-    @param p_iter: ignored.
-    @return: always zero.
-    '''
-    f = _Cfunctions.get('libvlc_log_iterator_has_next', None) or \
-        _Cfunction('libvlc_log_iterator_has_next', ((1,),), None,
-                    ctypes.c_int, LogIterator)
-    return f(p_iter)
-
-def libvlc_log_iterator_next(p_iter, p_buffer):
-    '''Always returns NULL.
-    This function is only provided for backward compatibility.
-    @param p_iter: libvlc log iterator or NULL.
-    @param p_buffer: ignored.
-    @return: always NULL.
-    '''
-    f = _Cfunctions.get('libvlc_log_iterator_next', None) or \
-        _Cfunction('libvlc_log_iterator_next', ((1,), (1,),), None,
-                    ctypes.POINTER(LogMessage), LogIterator, ctypes.POINTER(LogMessage))
-    return f(p_iter, p_buffer)
-
 def libvlc_module_description_list_release(p_list):
     '''Release a list of module descriptions.
     @param p_list: the list to be released.
@@ -3615,11 +3463,13 @@
     This option will be used to determine how the media_player will
     read the media. This allows to use VLC's advanced
     reading/streaming options on a per-media basis.
-    The options are detailed in vlc --long-help, for instance
-    "--sout-all". Note that all options are not usable on medias:
-    specifically, due to architectural issues, video-related options
-    such as text renderer options cannot be set on a single media. They
-    must be set on the whole libvlc instance instead.
+    @note: The options are listed in 'vlc --long-help' from the command line,
+    e.g. "-sout-all". Keep in mind that available options and their semantics
+    vary across LibVLC versions and builds.
+    @warning: Not all options affects L{Media} objects:
+    Specifically, due to architectural issues most audio and video options,
+    such as text renderer options, have no effects on an individual media.
+    These options must be set through L{libvlc_new}() instead.
     @param p_md: the media descriptor.
     @param ppsz_options: the options (as a string).
     '''
@@ -3756,6 +3606,18 @@
                     ctypes.c_int, Media, ctypes.POINTER(MediaStats))
     return f(p_md, p_stats)
 
+def libvlc_media_subitems(p_md):
+    '''Get subitems of media descriptor object. This will increment
+    the reference count of supplied media descriptor object. Use
+    L{libvlc_media_list_release}() to decrement the reference counting.
+    @param p_md: media descriptor object.
+    @return: list of media descriptor subitems or NULL.
+    '''
+    f = _Cfunctions.get('libvlc_media_subitems', None) or \
+        _Cfunction('libvlc_media_subitems', ((1,),), class_result(MediaList),
+                    ctypes.c_void_p, Media)
+    return f(p_md)
+
 def libvlc_media_event_manager(p_md):
     '''Get event manager from media descriptor object.
     NOTE: this function doesn't increment reference counting.
@@ -3783,7 +3645,7 @@
     The method is synchronous.
     See L{libvlc_media_parse_async}
     See L{libvlc_media_get_meta}
-    See L{libvlc_media_get_tracks_info}.
+    See libvlc_media_get_tracks_info.
     @param p_md: media descriptor object.
     '''
     f = _Cfunctions.get('libvlc_media_parse', None) or \
@@ -3801,7 +3663,7 @@
     See L{libvlc_media_parse}
     See libvlc_MediaParsedChanged
     See L{libvlc_media_get_meta}
-    See L{libvlc_media_get_tracks_info}.
+    See libvlc_media_get_tracks_info.
     @param p_md: media descriptor object.
     '''
     f = _Cfunctions.get('libvlc_media_parse_async', None) or \
@@ -3843,19 +3705,31 @@
                     ctypes.c_void_p, Media)
     return f(p_md)
 
-def libvlc_media_get_tracks_info(p_md):
+def libvlc_media_tracks_get(p_md, tracks):
     '''Get media descriptor's elementary streams description
     Note, you need to call L{libvlc_media_parse}() or play the media at least once
     before calling this function.
     Not doing this will result in an empty array.
     @param p_md: media descriptor object.
-    @param tracks: address to store an allocated array of Elementary Streams descriptions (must be freed by the caller) [OUT].
-    @return: the number of Elementary Streams.
-    '''
-    f = _Cfunctions.get('libvlc_media_get_tracks_info', None) or \
-        _Cfunction('libvlc_media_get_tracks_info', ((1,), (2,),), None,
-                    ctypes.c_int, Media, ctypes.POINTER(ctypes.c_void_p))
-    return f(p_md)
+    @param tracks: address to store an allocated array of Elementary Streams descriptions (must be freed with L{libvlc_media_tracks_release}.
+    @return: the number of Elementary Streams (zero on error).
+    @version: LibVLC 2.1.0 and later.
+    '''
+    f = _Cfunctions.get('libvlc_media_tracks_get', None) or \
+        _Cfunction('libvlc_media_tracks_get', ((1,), (1,),), None,
+                    ctypes.c_uint, Media, ctypes.POINTER(ctypes.POINTER(MediaTrack)))
+    return f(p_md, tracks)
+
+def libvlc_media_tracks_release(p_tracks, i_count):
+    '''Release media descriptor's elementary streams description array.
+    @param p_tracks: tracks info array to release.
+    @param i_count: number of elements in the array.
+    @version: LibVLC 2.1.0 and later.
+    '''
+    f = _Cfunctions.get('libvlc_media_tracks_release', None) or \
+        _Cfunction('libvlc_media_tracks_release', ((1,), (1,),), None,
+                    None, ctypes.POINTER(MediaTrack), ctypes.c_uint)
+    return f(p_tracks, i_count)
 
 def libvlc_media_discoverer_new_from_name(p_inst, psz_name):
     '''Discover media service by name.
@@ -4208,7 +4082,7 @@
     return f(p_mlp)
 
 def libvlc_media_list_player_pause(p_mlp):
-    '''Pause media list.
+    '''Toggle pause (or resume) media list.
     @param p_mlp: media list player instance.
     '''
     f = _Cfunctions.get('libvlc_media_list_player_pause', None) or \
@@ -4673,7 +4547,7 @@
     return f(p_mi, i_time)
 
 def libvlc_media_player_get_position(p_mi):
-    '''Get movie position.
+    '''Get movie position as percentage between 0.0 and 1.0.
     @param p_mi: the Media Player.
     @return: movie position, or -1. in case of error.
     '''
@@ -4683,7 +4557,8 @@
     return f(p_mi)
 
 def libvlc_media_player_set_position(p_mi, f_pos):
-    '''Set movie position. This has no effect if playback is not enabled.
+    '''Set movie position as percentage between 0.0 and 1.0.
+    This has no effect if playback is not enabled.
     This might not work depending on the underlying input format and protocol.
     @param p_mi: the Media Player.
     @param f_pos: the position.
@@ -4894,14 +4769,6 @@
                     None, ctypes.POINTER(TrackDescription))
     return f(p_track_description)
 
-def libvlc_track_description_release(p_track_description):
-    '''\deprecated Use L{libvlc_track_description_list_release} instead.
-    '''
-    f = _Cfunctions.get('libvlc_track_description_release', None) or \
-        _Cfunction('libvlc_track_description_release', ((1,),), None,
-                    None, ctypes.POINTER(TrackDescription))
-    return f(p_track_description)
-
 def libvlc_toggle_fullscreen(p_mi):
     '''Toggle fullscreen status on non-embedded video outputs.
     @warning: The same limitations applies to this function
@@ -5219,7 +5086,7 @@
 def libvlc_video_get_track(p_mi):
     '''Get current video track.
     @param p_mi: media player.
-    @return: the video track (int) or -1 if none.
+    @return: the video track ID (int) or -1 if no active input.
     '''
     f = _Cfunctions.get('libvlc_video_get_track', None) or \
         _Cfunction('libvlc_video_get_track', ((1,),), None,
@@ -5229,7 +5096,7 @@
 def libvlc_video_set_track(p_mi, i_track):
     '''Set video track.
     @param p_mi: media player.
-    @param i_track: the track (int).
+    @param i_track: the track ID (i_id field from track description).
     @return: 0 on success, -1 if out of range.
     '''
     f = _Cfunctions.get('libvlc_video_set_track', None) or \
@@ -5394,7 +5261,7 @@
     return f(p_mi, option, value)
 
 def libvlc_audio_output_list_get(p_instance):
-    '''Get the list of available audio outputs.
+    '''Gets the list of available audio outputs.
     @param p_instance: libvlc instance.
     @return: list of available audio outputs. It must be freed it with In case of error, NULL is returned.
     '''
@@ -5404,7 +5271,7 @@
     return f(p_instance)
 
 def libvlc_audio_output_list_release(p_list):
-    '''Free the list of available audio outputs.
+    '''Frees the list of available audio outputs.
     @param p_list: list with audio outputs for release.
     '''
     f = _Cfunctions.get('libvlc_audio_output_list_release', None) or \
@@ -5413,8 +5280,9 @@
     return f(p_list)
 
 def libvlc_audio_output_set(p_mi, psz_name):
-    '''Set the audio output.
-    Change will be applied after stop and play.
+    '''Sets the audio output.
+    @note: Any change will take be effect only after playback is stopped and
+    restarted. Audio output cannot be changed while playing.
     @param p_mi: media player.
     @param psz_name: name of audio output, use psz_name of See L{AudioOutput}.
     @return: 0 if function succeded, -1 on error.
@@ -5424,77 +5292,59 @@
                     ctypes.c_int, MediaPlayer, ctypes.c_char_p)
     return f(p_mi, psz_name)
 
-def libvlc_audio_output_device_count(p_instance, psz_audio_output):
-    '''Get count of devices for audio output, these devices are hardware oriented
-    like analor or digital output of sound card.
-    @param p_instance: libvlc instance.
-    @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-    @return: number of devices.
-    '''
-    f = _Cfunctions.get('libvlc_audio_output_device_count', None) or \
-        _Cfunction('libvlc_audio_output_device_count', ((1,), (1,),), None,
-                    ctypes.c_int, Instance, ctypes.c_char_p)
-    return f(p_instance, psz_audio_output)
-
-def libvlc_audio_output_device_longname(p_instance, psz_audio_output, i_device):
-    '''Get long name of device, if not available short name given.
-    @param p_instance: libvlc instance.
-    @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-    @param i_device: device index.
-    @return: long name of device.
-    '''
-    f = _Cfunctions.get('libvlc_audio_output_device_longname', None) or \
-        _Cfunction('libvlc_audio_output_device_longname', ((1,), (1,), (1,),), string_result,
-                    ctypes.c_void_p, Instance, ctypes.c_char_p, ctypes.c_int)
-    return f(p_instance, psz_audio_output, i_device)
-
-def libvlc_audio_output_device_id(p_instance, psz_audio_output, i_device):
-    '''Get id name of device.
-    @param p_instance: libvlc instance.
-    @param psz_audio_output: - name of audio output, See L{AudioOutput}.
-    @param i_device: device index.
-    @return: id name of device, use for setting device, need to be free after use.
-    '''
-    f = _Cfunctions.get('libvlc_audio_output_device_id', None) or \
-        _Cfunction('libvlc_audio_output_device_id', ((1,), (1,), (1,),), string_result,
-                    ctypes.c_void_p, Instance, ctypes.c_char_p, ctypes.c_int)
-    return f(p_instance, psz_audio_output, i_device)
+def libvlc_audio_output_device_list_get(p_instance, aout):
+    '''Gets a list of audio output devices for a given audio output.
+    See L{libvlc_audio_output_device_set}().
+    @note: Not all audio outputs support this. In particular, an empty (NULL)
+    list of devices does B{not} imply that the specified audio output does
+    not work.
+    @note: The list might not be exhaustive.
+    @warning: Some audio output devices in the list might not actually work in
+    some circumstances. By default, it is recommended to not specify any
+    explicit audio device.
+    @param p_instance: libvlc instance.
+    @param psz_aout: audio output name (as returned by L{libvlc_audio_output_list_get}()).
+    @return: A NULL-terminated linked list of potential audio output devices. It must be freed it with L{libvlc_audio_output_device_list_release}().
+    @version: LibVLC 2.1.0 or later.
+    '''
+    f = _Cfunctions.get('libvlc_audio_output_device_list_get', None) or \
+        _Cfunction('libvlc_audio_output_device_list_get', ((1,), (1,),), None,
+                    ctypes.POINTER(AudioOutputDevice), Instance, ctypes.c_char_p)
+    return f(p_instance, aout)
+
+def libvlc_audio_output_device_list_release(p_list):
+    '''Frees a list of available audio output devices.
+    @param p_list: list with audio outputs for release.
+    @version: LibVLC 2.1.0 or later.
+    '''
+    f = _Cfunctions.get('libvlc_audio_output_device_list_release', None) or \
+        _Cfunction('libvlc_audio_output_device_list_release', ((1,),), None,
+                    None, ctypes.POINTER(AudioOutputDevice))
+    return f(p_list)
 
 def libvlc_audio_output_device_set(p_mi, psz_audio_output, psz_device_id):
-    '''Set audio output device. Changes are only effective after stop and play.
+    '''Configures an explicit audio output device for a given audio output plugin.
+    A list of possible devices can be obtained with
+    L{libvlc_audio_output_device_list_get}().
+    @note: This function does not select the specified audio output plugin.
+    L{libvlc_audio_output_set}() is used for that purpose.
+    @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.
     @param psz_audio_output: - name of audio output, See L{AudioOutput}.
     @param psz_device_id: device.
+    @return: Nothing. Errors are ignored.
     '''
     f = _Cfunctions.get('libvlc_audio_output_device_set', None) or \
         _Cfunction('libvlc_audio_output_device_set', ((1,), (1,), (1,),), None,
                     None, MediaPlayer, ctypes.c_char_p, ctypes.c_char_p)
     return f(p_mi, psz_audio_output, psz_device_id)
 
-def libvlc_audio_output_get_device_type(p_mi):
-    '''Get current audio device type. Device type describes something like
-    character of output sound - stereo sound, 2.1, 5.1 etc.
-    @param p_mi: media player.
-    @return: the audio devices type See libvlc_audio_output_device_types_t.
-    '''
-    f = _Cfunctions.get('libvlc_audio_output_get_device_type', None) or \
-        _Cfunction('libvlc_audio_output_get_device_type', ((1,),), None,
-                    ctypes.c_int, MediaPlayer)
-    return f(p_mi)
-
-def libvlc_audio_output_set_device_type(p_mi, device_type):
-    '''Set current audio device type.
-    @param p_mi: vlc instance.
-    @param device_type: the audio device type,
-    '''
-    f = _Cfunctions.get('libvlc_audio_output_set_device_type', None) or \
-        _Cfunction('libvlc_audio_output_set_device_type', ((1,), (1,),), None,
-                    None, MediaPlayer, ctypes.c_int)
-    return f(p_mi, device_type)
-
 def libvlc_audio_toggle_mute(p_mi):
     '''Toggle mute status.
-    @param p_mi: media player.
+    @param p_mi: media player @warning Toggling mute atomically is not always possible: On some platforms, other processes can mute the VLC audio playback stream asynchronously. Thus, there is a small race condition where toggling will not work. See also the limitations of L{libvlc_audio_set_mute}().
     '''
     f = _Cfunctions.get('libvlc_audio_toggle_mute', None) or \
         _Cfunction('libvlc_audio_toggle_mute', ((1,),), None,
@@ -5504,7 +5354,7 @@
 def libvlc_audio_get_mute(p_mi):
     '''Get current mute status.
     @param p_mi: media player.
-    @return: the mute status (boolean) \libvlc_return_bool.
+    @return: the mute status (boolean) if defined, -1 if undefined/unapplicable.
     '''
     f = _Cfunctions.get('libvlc_audio_get_mute', None) or \
         _Cfunction('libvlc_audio_get_mute', ((1,),), None,
@@ -5514,7 +5364,7 @@
 def libvlc_audio_set_mute(p_mi, status):
     '''Set mute status.
     @param p_mi: media player.
-    @param status: If status is true then mute, otherwise unmute.
+    @param status: If status is true then mute, otherwise unmute @warning This function does not always work. If there are no active audio playback stream, the mute status might not be available. If digital pass-through (S/PDIF, HDMI...) is in use, muting may be unapplicable. Also some audio output plugins do not support muting at all. @note To force silent playback, disable all audio tracks. This is more efficient and reliable than mute.
     '''
     f = _Cfunctions.get('libvlc_audio_set_mute', None) or \
         _Cfunction('libvlc_audio_set_mute', ((1,), (1,),), None,
@@ -5565,7 +5415,7 @@
 def libvlc_audio_get_track(p_mi):
     '''Get current audio track.
     @param p_mi: media player.
-    @return: the audio track (int), or -1 if none.
+    @return: the audio track ID or -1 if no active input.
     '''
     f = _Cfunctions.get('libvlc_audio_get_track', None) or \
         _Cfunction('libvlc_audio_get_track', ((1,),), None,
@@ -5575,7 +5425,7 @@
 def libvlc_audio_set_track(p_mi, i_track):
     '''Set current audio track.
     @param p_mi: media player.
-    @param i_track: the track (int).
+    @param i_track: the track ID (i_id field from track description).
     @return: 0 on success, -1 on error.
     '''
     f = _Cfunctions.get('libvlc_audio_set_track', None) or \
@@ -5933,11 +5783,14 @@
     return f(p_instance)
 
 
-# 2 function(s) blacklisted:
+# 4 function(s) blacklisted:
+#  libvlc_audio_output_get_device_type
+#  libvlc_audio_output_set_device_type
 #  libvlc_printerr
 #  libvlc_set_exit_handler
 
-# 17 function(s) not wrapped as methods:
+# 18 function(s) not wrapped as methods:
+#  libvlc_audio_output_device_list_release
 #  libvlc_audio_output_list_release
 #  libvlc_clearerr
 #  libvlc_clock
@@ -5950,10 +5803,10 @@
 #  libvlc_log_subscribe
 #  libvlc_log_subscribe_file
 #  libvlc_log_unsubscribe
+#  libvlc_media_tracks_release
 #  libvlc_module_description_list_release
 #  libvlc_new
 #  libvlc_track_description_list_release
-#  libvlc_track_description_release
 #  libvlc_vprinterr
 
 # Start of footer.py #
@@ -6075,9 +5928,9 @@
             print('Error: %s file not readable' % movie)
             sys.exit(1)
 
-        instance = Instance()
+        instance = Instance("--sub-source marq")
         try:
-            media = instance.media_new(movie, 'sub-filter=marq')  # load marqee option
+            media = instance.media_new(movie)
         except NameError:
             print('NameError: %s (%s vs LibVLC %s)' % (sys.exc_info()[1],
                                                        __version__,
@@ -6087,13 +5940,12 @@
         player.set_media(media)
         player.play()
 
-        # Some marquee examples.  Marquee requires 'sub-filter=marq' in the
-        # media_new() call above.  See also the Media.add_options method
-        # and <http://www.videolan.org/doc/play-howto/en/ch04.html>
+        # Some marquee examples.  Marquee requires '--sub-source marq' in the
+        # Instance() call above.  See <http://www.videolan.org/doc/play-howto/en/ch04.html>
         player.video_set_marquee_int(VideoMarqueeOption.Enable, 1)
         player.video_set_marquee_int(VideoMarqueeOption.Size, 24)  # pixels
         player.video_set_marquee_int(VideoMarqueeOption.Position, Position.Bottom)
-        if True:  # only one marquee can be specified
+        if False:  # only one marquee can be specified
             player.video_set_marquee_int(VideoMarqueeOption.Timeout, 5000)  # millisec, 0==forever
             t = media.get_mrl()  # movie
         else:  # update marquee text periodically


Follow ups