]> git.sesse.net Git - vlc/blobdiff - bindings/java/core/src/main/java/org/videolan/jvlc/internal/LibVlc.java
jvlc: LibVlc class updated and code aligned to current native libvlc
[vlc] / bindings / java / core / src / main / java / org / videolan / jvlc / internal / LibVlc.java
index e4add2725fff76629758746ed7e0b969ec20edc9..4528bbf7a3c797b266731763a3dbc0e155374aef 100644 (file)
@@ -1,9 +1,10 @@
 /*****************************************************************************
- * LibVlc.java: VLC Java Bindings JNA Glue
+ * VLC Java Bindings JNA Glue
  *****************************************************************************
- * Copyright (C) 1998-2008 the VideoLAN team
+ * Copyright (C) 1998-2009 the VideoLAN team
  *
  * Authors: Filippo Carone <filippo@carone.org>
+ *          VLC bindings generator
  *
  *
  * $Id $
@@ -29,6 +30,7 @@ import com.sun.jna.Callback;
 import com.sun.jna.Library;
 import com.sun.jna.Native;
 import com.sun.jna.NativeLong;
+import com.sun.jna.Platform;
 import com.sun.jna.Pointer;
 import com.sun.jna.PointerType;
 import com.sun.jna.Structure;
@@ -38,18 +40,20 @@ import com.sun.jna.Union;
 public interface LibVlc extends Library
 {
 
-    LibVlc INSTANCE = (LibVlc) Native.loadLibrary("vlc", LibVlc.class);
+    LibVlc INSTANCE = (LibVlc) Native.loadLibrary(Platform.isWindows() ? "libvlc" : "vlc", LibVlc.class);
 
     LibVlc SYNC_INSTANCE = (LibVlc) Native.synchronizedLibrary(INSTANCE);
-    
+
     public static class libvlc_exception_t extends Structure
     {
 
-        public int raised;
+        public int b_raised;
+    }
 
-        public int code;
+    public static interface LibVlcCallback extends Callback
+    {
 
-        public String message;
+        void callback(libvlc_event_t libvlc_event, Pointer userData);
     }
 
     public static class libvlc_log_message_t extends Structure
@@ -73,7 +77,7 @@ public interface LibVlc extends Library
 
         public int type;
 
-        public Pointer obj;
+        public Pointer p_obj;
 
         public event_type_specific event_type_specific;
 
@@ -82,13 +86,14 @@ public interface LibVlc extends Library
     public class media_meta_changed extends Structure
     {
 
+        // Enum !
         public Pointer meta_type;
     }
 
     public class media_subitem_added extends Structure
     {
 
-        public LibVlcMediaDescriptor new_child;
+        public LibVlcMedia new_child;
     }
 
     public class media_duration_changed extends Structure
@@ -106,7 +111,7 @@ public interface LibVlc extends Library
     public class media_freed extends Structure
     {
 
-        public LibVlcMediaDescriptor md;
+        public LibVlcMedia md;
     }
 
     public class media_state_changed extends Structure
@@ -131,11 +136,29 @@ public interface LibVlc extends Library
         public long new_time;
     }
 
+    public class media_player_title_changed extends Structure
+    {
+
+        public int new_title;
+    }
+
+    public class media_player_seekable_changed extends Structure
+    {
+
+        public NativeLong new_seekable;
+    }
+
+    public class media_player_pausable_changed extends Structure
+    {
+
+        public NativeLong new_pausable;
+    }
+
     /* media list */
     public class media_list_item_added extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -143,7 +166,7 @@ public interface LibVlc extends Library
     public class media_list_will_add_item extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -151,7 +174,7 @@ public interface LibVlc extends Library
     public class media_list_item_deleted extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -159,7 +182,7 @@ public interface LibVlc extends Library
     public class media_list_will_delete_item extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -168,7 +191,7 @@ public interface LibVlc extends Library
     public class media_list_view_item_added extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -176,7 +199,7 @@ public interface LibVlc extends Library
     public class media_list_view_will_add_item extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -184,7 +207,7 @@ public interface LibVlc extends Library
     public class media_list_view_item_deleted extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
@@ -192,22 +215,36 @@ public interface LibVlc extends Library
     public class media_list_view_will_delete_item extends Structure
     {
 
-        public LibVlcMediaDescriptor item;
+        public LibVlcMedia item;
 
         public int index;
     }
 
-    /* media discoverer */
-    public class media_media_discoverer_started extends Structure
+    public class media_list_player_next_item_set extends Structure
+    {
+
+        public LibVlcMedia item;
+    }
+
+    public class media_player_snapshot_taken extends Structure
+    {
+
+        public String psz_filename;
+    }
+
+    public class media_player_length_changed extends Structure
     {
 
-        public Pointer unused;
+        // @todo: check the type
+        public long new_length;
     }
 
-    public class media_media_discoverer_ended extends Structure
+    public class vlm_media_event extends Structure
     {
 
-        public Pointer unused;
+        public String psz_media_name;
+
+        public String psz_instance_name;
     }
 
     public class event_type_specific extends Union
@@ -229,6 +266,12 @@ public interface LibVlc extends Library
 
         public media_player_time_changed media_player_time_changed;
 
+        public media_player_title_changed media_player_title_changed;
+
+        public media_player_seekable_changed media_player_seekable_changed;
+
+        public media_player_pausable_changed media_player_pausable_changed;
+
         public media_list_item_added media_list_item_added;
 
         public media_list_will_add_item media_list_will_add_item;
@@ -244,17 +287,41 @@ public interface LibVlc extends Library
         public media_list_view_item_deleted media_list_view_item_deleted;
 
         public media_list_view_will_delete_item media_list_view_will_delete_item;
+
+        public media_list_player_next_item_set media_list_player_next_item_set;
+
+        public media_player_snapshot_taken media_player_snapshot_taken;
+
+        public media_player_length_changed media_player_length_changed;
+
+        public vlm_media_event vlm_media_event;
+    }
+
+    public class LibVlcLog extends PointerType
+    {
+    }
+
+    public class LibVlcMediaListView extends PointerType
+    {
+    }
+
+    public class LibVlcTrackDescription extends PointerType
+    {
+    }
+
+    public class LibVlcMediaListPlayer extends PointerType
+    {
     }
 
     public class LibVlcInstance extends PointerType
     {
     }
 
-    public class LibVlcMediaDescriptor extends PointerType
+    public class LibVlcEventManager extends PointerType
     {
     }
 
-    public class LibVlcMediaInstance extends PointerType
+    public class LibVlcMediaLibrary extends PointerType
     {
     }
 
@@ -262,15 +329,19 @@ public interface LibVlc extends Library
     {
     }
 
-    public class LibVlcMediaListPlayer extends PointerType
+    public class LibVlcAudioOutput extends PointerType
     {
     }
 
-    public class LibVlcEventManager extends PointerType
+    public class LibVlcMediaPlayer extends PointerType
     {
     }
 
-    public class LibVlcLog extends PointerType
+    public class LibVlcMedia extends PointerType
+    {
+    }
+
+    public class LibVlcMediaDiscoverer extends PointerType
     {
     }
 
@@ -278,238 +349,409 @@ public interface LibVlc extends Library
     {
     }
 
-    // exception handling
-    void libvlc_exception_init(libvlc_exception_t exception);
+    void libvlc_exception_init(libvlc_exception_t p_exception);
+
+    void libvlc_exception_clear(libvlc_exception_t p_exception);
 
     int libvlc_exception_raised(final libvlc_exception_t exception);
+    
+    String libvlc_errmsg();
 
-    void libvlc_exception_raise(libvlc_exception_t exception, String format, Object... args);
+    void libvlc_clearerr();
 
-    void libvlc_exception_clear(libvlc_exception_t exception);
+    LibVlcInstance libvlc_new(int argc, String[] argv, libvlc_exception_t p_e);
 
-    String libvlc_exception_get_message(libvlc_exception_t exception);
+    void libvlc_release(LibVlcInstance p_instance);
 
-    // core
-    LibVlcInstance libvlc_new(int argc, String[] argv, libvlc_exception_t exception);
+    void libvlc_retain(LibVlcInstance p_instance);
+
+    int libvlc_add_intf(LibVlcInstance p_instance, String name, libvlc_exception_t p_exception);
+
+    void libvlc_wait(LibVlcInstance p_instance);
 
-    void libvlc_release(LibVlcInstance libvlc_instance_t);
-    
     String libvlc_get_version();
-    
+
     String libvlc_get_compiler();
-    
+
     String libvlc_get_changeset();
 
-    // video
+    void libvlc_free(Pointer ptr);
+
+    void libvlc_event_attach(LibVlcEventManager p_event_manager, int i_event_type, LibVlcCallback f_callback,
+        Pointer user_data, libvlc_exception_t p_e);
+
+    void libvlc_event_detach(LibVlcEventManager p_event_manager, int i_event_type, LibVlcCallback f_callback,
+        Pointer p_user_data, libvlc_exception_t p_e);
 
-    void libvlc_video_set_parent(LibVlcInstance libvlc_instance, long drawable, libvlc_exception_t exception);
+    String libvlc_event_type_name(int event_type);
 
-    void libvlc_toggle_fullscreen(LibVlcMediaInstance libvlc_instance);
+    int libvlc_get_log_verbosity(LibVlcInstance p_instance);
 
-    void libvlc_set_fullscreen(LibVlcMediaInstance instance, int fullscreen, libvlc_exception_t exception);
+    void libvlc_set_log_verbosity(LibVlcInstance p_instance, int level);
 
-    int libvlc_get_fullscreen(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcLog libvlc_log_open(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_log_close(LibVlcLog p_log);
 
-    int libvlc_video_get_height(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_log_count(LibVlcLog p_log);
 
-    int libvlc_video_get_width(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_log_clear(LibVlcLog p_log);
 
-    String libvlc_video_get_aspect_ration(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcLogIterator libvlc_log_get_iterator(LibVlcLog p_log, libvlc_exception_t p_e);
 
-    void libvlc_video_set_aspect_ration(LibVlcMediaInstance instance, String ratio, libvlc_exception_t exception);
+    void libvlc_log_iterator_free(LibVlcLogIterator p_iter);
 
-    int libvlc_video_get_spu(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    int libvlc_log_iterator_has_next(LibVlcLogIterator p_iter);
 
-    int libvlc_video_set_spu(LibVlcMediaInstance instance, int spu, libvlc_exception_t exception);
+    libvlc_log_message_t libvlc_log_iterator_next(LibVlcLogIterator p_iter, libvlc_log_message_t p_buffer,
+        libvlc_exception_t p_e);
 
-    String libvlc_video_get_crop_geometry(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcMediaDiscoverer libvlc_media_discoverer_new_from_name(LibVlcInstance p_inst, String psz_name,
+        libvlc_exception_t p_e);
 
-    void libvlc_video_set_crop_geometry(LibVlcMediaInstance instance, String geometry, libvlc_exception_t exception);
+    void libvlc_media_discoverer_release(LibVlcMediaDiscoverer p_mdis);
 
-    void libvlc_video_take_snapshot(LibVlcMediaInstance instance, String filename, int width, int height,
-        libvlc_exception_t exception);
+    String libvlc_media_discoverer_localized_name(LibVlcMediaDiscoverer p_mdis);
 
-    void libvlc_video_destroy(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcMediaList libvlc_media_discoverer_media_list(LibVlcMediaDiscoverer p_mdis);
 
-    void libvlc_video_resize(LibVlcMediaInstance instance, int width, int height, libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_discoverer_event_manager(LibVlcMediaDiscoverer p_mdis);
 
-    void libvlc_video_reparent(LibVlcMediaInstance instance, long drawable, libvlc_exception_t exception);
+    int libvlc_media_discoverer_is_running(LibVlcMediaDiscoverer p_mdis);
 
-    void libvlc_video_set_size(LibVlcInstance instance, int width, int height, libvlc_exception_t exception);
+    LibVlcMedia libvlc_media_new(LibVlcInstance p_instance, String psz_mrl, libvlc_exception_t p_e);
 
-    // audio
+    LibVlcMedia libvlc_media_new_as_node(LibVlcInstance p_instance, String psz_name, libvlc_exception_t p_e);
 
-    void libvlc_audio_toggle_mute(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_add_option(LibVlcMedia p_md, String ppsz_options, libvlc_exception_t p_e);
 
-    void libvlc_audio_set_mute(LibVlcInstance instance, int mute, libvlc_exception_t exception);
+    void libvlc_media_add_option_flag(LibVlcMedia p_md, String ppsz_options, MediaOption i_flags, libvlc_exception_t p_e);
 
-    int libvlc_audio_get_mute(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_retain(LibVlcMedia p_meta_desc);
 
-    int libvlc_audio_get_volume(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_release(LibVlcMedia p_meta_desc);
 
-    int libvlc_audio_set_volume(LibVlcInstance instance, int volume, libvlc_exception_t exception);
+    String libvlc_media_get_mrl(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    int libvlc_audio_get_track_count(LibVlcMediaInstance mediaInstance, libvlc_exception_t exception);
+    LibVlcMedia libvlc_media_duplicate(LibVlcMedia p_meta_desc);
 
-    int libvlc_audio_get_track(LibVlcMediaInstance mediaInstance, libvlc_exception_t exception);
+    String libvlc_media_get_meta(LibVlcMedia p_meta_desc, Meta e_meta, libvlc_exception_t p_e);
 
-    void libvlc_audio_set_track(LibVlcMediaInstance mediaInstance, int channel, libvlc_exception_t exception);
+    int libvlc_media_get_state(LibVlcMedia p_meta_desc, libvlc_exception_t p_e);
 
-    int libvlc_audio_get_channel(LibVlcInstance instance, libvlc_exception_t exception);
+    LibVlcMediaList libvlc_media_subitems(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    void libvlc_audio_set_channel(LibVlcInstance instance, int channel, libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_event_manager(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    // playlist
+    long libvlc_media_get_duration(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    void libvlc_playlist_loop(LibVlcInstance instance, int loop, libvlc_exception_t exception);
+    int libvlc_media_is_preparsed(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    void libvlc_playlist_play(LibVlcInstance instance, int itemIndex, int optionsCount, String[] options,
-        libvlc_exception_t exception);
+    void libvlc_media_set_user_data(LibVlcMedia p_md, Pointer p_new_user_data, libvlc_exception_t p_e);
 
-    void libvlc_playlist_pause(LibVlcInstance instance, libvlc_exception_t exception);
+    Pointer libvlc_media_get_user_data(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    void libvlc_playlist_stop(LibVlcInstance instance, libvlc_exception_t exception);
+    LibVlcMediaLibrary libvlc_media_library_new(LibVlcInstance p_inst, libvlc_exception_t p_e);
 
-    int libvlc_playlist_isplaying(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_library_release(LibVlcMediaLibrary p_mlib);
 
-    int libvlc_playlist_items_count(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_library_retain(LibVlcMediaLibrary p_mlib);
 
-    void libvlc_playlist_next(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_library_load(LibVlcMediaLibrary p_mlib, libvlc_exception_t p_e);
 
-    void libvlc_playlist_prev(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_library_save(LibVlcMediaLibrary p_mlib, libvlc_exception_t p_e);
 
-    void libvlc_playlist_clear(LibVlcInstance instance, libvlc_exception_t exception);
+    LibVlcMediaList libvlc_media_library_media_list(LibVlcMediaLibrary p_mlib, libvlc_exception_t p_e);
 
-    int libvlc_playlist_add(LibVlcInstance instance, String uri, String name, libvlc_exception_t exception);
+    LibVlcMediaList libvlc_media_list_new(LibVlcInstance p_libvlc, libvlc_exception_t p_e);
 
-    int libvlc_playlist_delete_item(LibVlcInstance instance, int itemIndex, libvlc_exception_t exception);
+    void libvlc_media_list_release(LibVlcMediaList p_ml);
 
-    LibVlcMediaInstance libvlc_playlist_get_media_player(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_list_retain(LibVlcMediaList p_ml);
 
-    int libvlc_media_player_is_seekable(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_list_set_media(LibVlcMediaList p_ml, LibVlcMedia p_mi, libvlc_exception_t p_e);
 
-    int libvlc_media_player_can_pause(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcMedia libvlc_media_list_media(LibVlcMediaList p_ml, libvlc_exception_t p_e);
 
-    // media descriptor
+    void libvlc_media_list_add_media(LibVlcMediaList p_ml, LibVlcMedia p_mi, libvlc_exception_t p_e);
 
-    LibVlcMediaDescriptor libvlc_media_new(LibVlcInstance libvlc_instance, String mrl, libvlc_exception_t exception);
+    void libvlc_media_list_insert_media(LibVlcMediaList p_ml, LibVlcMedia p_mi, int i_pos, libvlc_exception_t p_e);
 
-    void libvlc_media_add_option(LibVlcMediaDescriptor media, String option, libvlc_exception_t exception);
+    void libvlc_media_list_remove_index(LibVlcMediaList p_ml, int i_pos, libvlc_exception_t p_e);
 
-    String libvlc_media_get_mrl(LibVlcMediaDescriptor media);
+    int libvlc_media_list_count(LibVlcMediaList p_mlist, libvlc_exception_t p_e);
 
-    void libvlc_media_release(LibVlcMediaDescriptor media);
+    LibVlcMedia libvlc_media_list_item_at_index(LibVlcMediaList p_ml, int i_pos, libvlc_exception_t p_e);
 
-    LibVlcEventManager libvlc_media_event_manager(LibVlcMediaDescriptor media, libvlc_exception_t exception);
+    int libvlc_media_list_index_of_item(LibVlcMediaList p_ml, LibVlcMedia p_mi, libvlc_exception_t p_e);
 
-    // media instance
+    int libvlc_media_list_is_readonly(LibVlcMediaList p_mlist);
 
-    LibVlcMediaInstance libvlc_media_player_new(LibVlcInstance instance, libvlc_exception_t exception);
+    void libvlc_media_list_lock(LibVlcMediaList p_ml);
 
-    LibVlcMediaInstance libvlc_media_player_new_from_media(LibVlcMediaDescriptor media, libvlc_exception_t exception);
+    void libvlc_media_list_unlock(LibVlcMediaList p_ml);
 
-    void libvlc_media_player_play(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    LibVlcMediaListView libvlc_media_list_flat_view(LibVlcMediaList p_ml, libvlc_exception_t p_ex);
 
-    void libvlc_media_player_pause(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    LibVlcMediaListView libvlc_media_list_hierarchical_view(LibVlcMediaList p_ml, libvlc_exception_t p_ex);
 
-    void libvlc_media_player_stop(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    LibVlcMediaListView libvlc_media_list_hierarchical_node_view(LibVlcMediaList p_ml, libvlc_exception_t p_ex);
 
-    void libvlc_media_player_set_drawable(LibVlcMediaInstance libvlc_media_player, int drawable,
-        libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_list_event_manager(LibVlcMediaList p_ml, libvlc_exception_t p_ex);
 
-    long libvlc_media_player_get_length(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcMediaListPlayer libvlc_media_list_player_new(LibVlcInstance p_instance, libvlc_exception_t p_e);
 
-    long libvlc_media_player_get_time(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_list_player_release(LibVlcMediaListPlayer p_mlp);
 
-    void libvlc_media_player_set_time(LibVlcMediaInstance instance, long time, libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_list_player_event_manager(LibVlcMediaListPlayer p_mlp);
 
-    float libvlc_media_player_get_position(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_list_player_set_media_player(LibVlcMediaListPlayer p_mlp, LibVlcMediaPlayer p_mi,
+        libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_set_media_list(LibVlcMediaListPlayer p_mlp, LibVlcMediaList p_mlist,
+        libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_play(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_pause(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    int libvlc_media_list_player_is_playing(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    int libvlc_media_list_player_get_state(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_play_item_at_index(LibVlcMediaListPlayer p_mlp, int i_index, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_play_item(LibVlcMediaListPlayer p_mlp, LibVlcMedia p_md, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_stop(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_next(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_previous(LibVlcMediaListPlayer p_mlp, libvlc_exception_t p_e);
+
+    void libvlc_media_list_player_set_playback_mode(LibVlcMediaListPlayer p_mlp, PlaybackMode e_mode,
+        libvlc_exception_t p_e);
+
+    void libvlc_media_list_view_retain(LibVlcMediaListView p_mlv);
+
+    void libvlc_media_list_view_release(LibVlcMediaListView p_mlv);
+
+    LibVlcEventManager libvlc_media_list_view_event_manager(LibVlcMediaListView p_mlv);
+
+    int libvlc_media_list_view_count(LibVlcMediaListView p_mlv, libvlc_exception_t p_e);
+
+    LibVlcMedia libvlc_media_list_view_item_at_index(LibVlcMediaListView p_mlv, int i_index, libvlc_exception_t p_e);
+
+    LibVlcMediaListView libvlc_media_list_view_children_at_index(LibVlcMediaListView p_mlv, int index,
+        libvlc_exception_t p_e);
+
+    LibVlcMediaListView libvlc_media_list_view_children_for_item(LibVlcMediaListView p_mlv, LibVlcMedia p_md,
+        libvlc_exception_t p_e);
 
-    void libvlc_media_player_set_position(LibVlcMediaInstance instance, float position, libvlc_exception_t exception);
+    LibVlcMediaList libvlc_media_list_view_parent_media_list(LibVlcMediaListView p_mlv, libvlc_exception_t p_e);
 
-    int libvlc_media_player_will_play(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    LibVlcMediaPlayer libvlc_media_player_new(LibVlcInstance p_libvlc_instance, libvlc_exception_t p_e);
 
-    void libvlc_media_player_set_rate(LibVlcMediaInstance instance, float rate, libvlc_exception_t exception);
+    LibVlcMediaPlayer libvlc_media_player_new_from_media(LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    float libvlc_media_player_get_rate(LibVlcMediaInstance instance, libvlc_exception_t exception);
+    void libvlc_media_player_release(LibVlcMediaPlayer p_mi);
 
-    int libvlc_media_player_has_vout(LibVlcMediaInstance instance2, libvlc_exception_t exception);
+    void libvlc_media_player_retain(LibVlcMediaPlayer p_mi);
 
-    float libvlc_media_player_get_fps(LibVlcMediaInstance instance2, libvlc_exception_t exception);
+    void libvlc_media_player_set_media(LibVlcMediaPlayer p_mi, LibVlcMedia p_md, libvlc_exception_t p_e);
 
-    void libvlc_media_player_release(LibVlcMediaInstance instance);
+    LibVlcMedia libvlc_media_player_get_media(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    LibVlcEventManager libvlc_media_player_event_manager(LibVlcMediaInstance media_player, libvlc_exception_t exception);
+    LibVlcEventManager libvlc_media_player_event_manager(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    // media list
+    int libvlc_media_player_is_playing(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    LibVlcMediaList libvlc_media_list_new(LibVlcInstance libvlc_instance, libvlc_exception_t exception);
+    void libvlc_media_player_play(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_release(LibVlcMediaList libVlcMediaList);
+    void libvlc_media_player_pause(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_add_file_content(LibVlcMediaList libvlc_media_list, String fileName,
-        libvlc_exception_t exception);
+    void libvlc_media_player_stop(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_set_media(LibVlcMediaList libvlc_media_list, LibVlcMediaDescriptor libvlc_media,
-        libvlc_exception_t exception);
+    void libvlc_media_player_set_nsobject(LibVlcMediaPlayer p_mi, Pointer drawable, libvlc_exception_t p_e);
 
-    LibVlcMediaDescriptor libvlc_media_list_media(LibVlcMediaList libvlc_media_list, libvlc_exception_t exception);
+    Pointer libvlc_media_player_get_nsobject(LibVlcMediaPlayer p_mi);
 
-    void libvlc_media_list_add_media(LibVlcMediaList libvlc_media_list, LibVlcMediaDescriptor libvlc_media,
-        libvlc_exception_t exception);
+    void libvlc_media_player_set_agl(LibVlcMediaPlayer p_mi, long drawable, libvlc_exception_t p_e);
 
-    void libvlc_media_list_insert_media(LibVlcMediaList libvlc_media_list, LibVlcMediaDescriptor libvlc_media,
-        int position, libvlc_exception_t exception);
+    long libvlc_media_player_get_agl(LibVlcMediaPlayer p_mi);
 
-    void libvlc_media_list_remove_index(LibVlcMediaList libvlc_media_list, int position, libvlc_exception_t exception);
+    void libvlc_media_player_set_xwindow(LibVlcMediaPlayer p_mi, long drawable, libvlc_exception_t p_e);
 
-    int libvlc_media_list_count(LibVlcMediaList libvlc_media_list, libvlc_exception_t exception);
+    long libvlc_media_player_get_xwindow(LibVlcMediaPlayer p_mi);
 
-    LibVlcMediaDescriptor libvlc_media_list_item_at_index(LibVlcMediaList libvlc_media_list, int position,
-        libvlc_exception_t exception);
+    void libvlc_media_player_set_hwnd(LibVlcMediaPlayer p_mi, long drawable, libvlc_exception_t p_e);
 
-    int libvlc_media_list_index_of_item(LibVlcMediaList libvlc_media_list, LibVlcMediaDescriptor libvlc_media,
-        libvlc_exception_t exception);
+    Pointer libvlc_media_player_get_hwnd(LibVlcMediaPlayer p_mi);
 
-    int libvlc_media_list_is_readonly(LibVlcMediaList libvlc_media_list);
+    long libvlc_media_player_get_length(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    LibVlcEventManager libvlc_media_list_event_manager(LibVlcMediaList libvlc_media_list, libvlc_exception_t exception);
+    long libvlc_media_player_get_time(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    // libvlc_media_list_player
+    void libvlc_media_player_set_time(LibVlcMediaPlayer p_mi, long the, libvlc_exception_t p_e);
 
-    LibVlcMediaListPlayer libvlc_media_list_player_new(LibVlcInstance libvlc_media_player, libvlc_exception_t exception);
+    float libvlc_media_player_get_position(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_release(LibVlcMediaListPlayer libvlc_media_list_player);
+    void libvlc_media_player_set_position(LibVlcMediaPlayer p_mi, float f_pos, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_set_media_player(LibVlcMediaListPlayer libvlc_media_list_player,
-        LibVlcMediaInstance libvlc_media_player, libvlc_exception_t exception);
+    void libvlc_media_player_set_chapter(LibVlcMediaPlayer p_mi, int i_chapter, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_set_media_list(LibVlcMediaListPlayer libvlc_media_list_player,
-        LibVlcMediaList libvlc_media_list, libvlc_exception_t exception);
+    int libvlc_media_player_get_chapter(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_play(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    int libvlc_media_player_get_chapter_count(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_pause(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    int libvlc_media_player_will_play(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    int libvlc_media_list_player_is_playing(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    int libvlc_media_player_get_chapter_count_for_title(LibVlcMediaPlayer p_mi, int i_title, libvlc_exception_t p_e);
 
-    int libvlc_media_list_player_get_state(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    void libvlc_media_player_set_title(LibVlcMediaPlayer p_mi, int i_title, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_play_item_at_index(LibVlcMediaListPlayer libvlc_media_list_player, int position,
-        libvlc_exception_t exception);
+    int libvlc_media_player_get_title(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_play_item(LibVlcMediaListPlayer libvlc_media_list_player,
-        LibVlcMediaDescriptor libvlc_media, libvlc_exception_t exception);
+    int libvlc_media_player_get_title_count(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_stop(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    void libvlc_media_player_previous_chapter(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    void libvlc_media_list_player_next(LibVlcMediaListPlayer libvlc_media_list_player, libvlc_exception_t exception);
+    void libvlc_media_player_next_chapter(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
 
-    // VLM
+    float libvlc_media_player_get_rate(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    void libvlc_media_player_set_rate(LibVlcMediaPlayer p_mi, float movie, libvlc_exception_t p_e);
+
+    int libvlc_media_player_get_state(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    float libvlc_media_player_get_fps(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    int libvlc_media_player_has_vout(LibVlcMediaPlayer p_md, libvlc_exception_t p_e);
+
+    int libvlc_media_player_is_seekable(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    int libvlc_media_player_can_pause(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    void libvlc_media_player_next_frame(LibVlcMediaPlayer p_input, libvlc_exception_t p_e);
+
+    void libvlc_track_description_release(LibVlcTrackDescription p_track_description);
+
+    void libvlc_toggle_fullscreen(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_set_fullscreen(LibVlcMediaPlayer p_mediaplayer, int b_fullscreen, libvlc_exception_t p_e);
+
+    int libvlc_get_fullscreen(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    int libvlc_video_get_height(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    int libvlc_video_get_width(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    float libvlc_video_get_scale(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_video_set_scale(LibVlcMediaPlayer p_mediaplayer, float i_factor, libvlc_exception_t p_e);
+
+    String libvlc_video_get_aspect_ratio(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_video_set_aspect_ratio(LibVlcMediaPlayer p_mediaplayer, String psz_aspect, libvlc_exception_t p_e);
+
+    int libvlc_video_get_spu(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    int libvlc_video_get_spu_count(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    LibVlcTrackDescription libvlc_video_get_spu_description(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_video_set_spu(LibVlcMediaPlayer p_mediaplayer, int i_spu, libvlc_exception_t p_e);
+
+    int libvlc_video_set_subtitle_file(LibVlcMediaPlayer p_mediaplayer, String psz_subtitle, libvlc_exception_t p_e);
+
+    LibVlcTrackDescription libvlc_video_get_title_description(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    LibVlcTrackDescription libvlc_video_get_chapter_description(LibVlcMediaPlayer p_mediaplayer, int i_title,
+        libvlc_exception_t p_e);
+
+    String libvlc_video_get_crop_geometry(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_video_set_crop_geometry(LibVlcMediaPlayer p_mediaplayer, String psz_geometry, libvlc_exception_t p_e);
+
+    void libvlc_toggle_teletext(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    int libvlc_video_get_teletext(LibVlcMediaPlayer p_mediaplayer, libvlc_exception_t p_e);
+
+    void libvlc_video_set_teletext(LibVlcMediaPlayer p_mediaplayer, int i_page, libvlc_exception_t p_e);
+
+    int libvlc_video_get_track_count(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    LibVlcTrackDescription libvlc_video_get_track_description(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    int libvlc_video_get_track(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    void libvlc_video_set_track(LibVlcMediaPlayer p_mi, int i_track, libvlc_exception_t p_e);
+
+    void libvlc_video_take_snapshot(LibVlcMediaPlayer p_mi, String psz_filepath, int i_width, int i_height,
+        libvlc_exception_t p_e);
+
+    void libvlc_video_set_deinterlace(LibVlcMediaPlayer p_mi, int b_enable, String psz_mode, libvlc_exception_t p_e);
+
+    int libvlc_video_get_marquee_option_as_int(LibVlcMediaPlayer p_mi, VideoMarqueeIntOption option,
+        libvlc_exception_t p_e);
+
+    String libvlc_video_get_marquee_option_as_string(LibVlcMediaPlayer p_mi, VideoMarqueeStringOption option,
+        libvlc_exception_t p_e);
+
+    void libvlc_video_set_marquee_option_as_int(LibVlcMediaPlayer p_mi, VideoMarqueeIntOption option, int i_val,
+        libvlc_exception_t p_e);
+
+    void libvlc_video_set_marquee_option_as_string(LibVlcMediaPlayer p_mi, VideoMarqueeStringOption option,
+        String psz_text, libvlc_exception_t p_e);
+
+    LibVlcAudioOutput libvlc_audio_output_list_get(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_audio_output_list_release(LibVlcAudioOutput p_list);
+
+    int libvlc_audio_output_set(LibVlcInstance p_instance, String psz_name);
+
+    int libvlc_audio_output_device_count(LibVlcInstance p_instance, String psz_audio_output);
+
+    String libvlc_audio_output_device_longname(LibVlcInstance p_instance, String psz_audio_output, int i_device);
+
+    String libvlc_audio_output_device_id(LibVlcInstance p_instance, String psz_audio_output, int i_device);
+
+    void libvlc_audio_output_device_set(LibVlcInstance p_instance, String psz_audio_output, String psz_device_id);
+
+    int libvlc_audio_output_get_device_type(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_audio_output_set_device_type(LibVlcInstance p_instance, int device_type, libvlc_exception_t p_e);
+
+    void libvlc_audio_toggle_mute(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    int libvlc_audio_get_mute(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_audio_set_mute(LibVlcInstance p_instance, int status, libvlc_exception_t p_e);
+
+    int libvlc_audio_get_volume(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_audio_set_volume(LibVlcInstance p_instance, int i_volume, libvlc_exception_t p_e);
+
+    int libvlc_audio_get_track_count(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    LibVlcTrackDescription libvlc_audio_get_track_description(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    int libvlc_audio_get_track(LibVlcMediaPlayer p_mi, libvlc_exception_t p_e);
+
+    void libvlc_audio_set_track(LibVlcMediaPlayer p_mi, int i_track, libvlc_exception_t p_e);
+
+    int libvlc_audio_get_channel(LibVlcInstance p_instance, libvlc_exception_t p_e);
+
+    void libvlc_audio_set_channel(LibVlcInstance p_instance, int channel, libvlc_exception_t p_e);
+
+    void libvlc_vlm_release(LibVlcInstance p_instance, libvlc_exception_t p_e);
 
     void libvlc_vlm_add_broadcast(LibVlcInstance p_instance, String psz_name, String psz_input, String psz_output,
         int i_options, String[] ppsz_options, int b_enabled, int b_loop, libvlc_exception_t p_e);
 
+    void libvlc_vlm_add_vod(LibVlcInstance p_instance, String psz_name, String psz_input, int i_options,
+        String[] ppsz_options, int b_enabled, String psz_mux, libvlc_exception_t p_e);
+
     void libvlc_vlm_del_media(LibVlcInstance p_instance, String psz_name, libvlc_exception_t p_e);
 
     void libvlc_vlm_set_enabled(LibVlcInstance p_instance, String psz_name, int b_enabled, libvlc_exception_t p_e);
@@ -522,6 +764,8 @@ public interface LibVlc extends Library
 
     void libvlc_vlm_set_loop(LibVlcInstance p_instance, String psz_name, int b_loop, libvlc_exception_t p_e);
 
+    void libvlc_vlm_set_mux(LibVlcInstance p_instance, String psz_name, String psz_mux, libvlc_exception_t p_e);
+
     void libvlc_vlm_change_media(LibVlcInstance p_instance, String psz_name, String psz_input, String psz_output,
         int i_options, String[] ppsz_options, int b_enabled, int b_loop, libvlc_exception_t p_e);
 
@@ -535,45 +779,27 @@ public interface LibVlc extends Library
 
     String libvlc_vlm_show_media(LibVlcInstance p_instance, String psz_name, libvlc_exception_t p_e);
 
-    void libvlc_vlm_release(LibVlcInstance p_instance, libvlc_exception_t p_e);
-    
-    // event manager
-
-    public static interface LibVlcCallback extends Callback
-    {
-
-        void callback(libvlc_event_t libvlc_event, Pointer userData);
-    }
-
-    void libvlc_event_attach(LibVlcEventManager event_manager, int event_type, LibVlcCallback callback,
-        Pointer userData, libvlc_exception_t exception);
-
-    void libvlc_event_detach(LibVlcEventManager event_manager, int event_type, LibVlcCallback callback,
-        Pointer userData, libvlc_exception_t excecption);
-
-    void libvlc_toggle_fullscreen(LibVlcMediaInstance instance, libvlc_exception_t exception);
-
-    // logging
-
-    int libvlc_get_log_verbosity(LibVlcInstance p_instance, libvlc_exception_t p_e);
-
-    void libvlc_set_log_verbosity(LibVlcInstance p_instance, int level, libvlc_exception_t p_e);
-
-    LibVlcLog libvlc_log_open(LibVlcInstance p_instance, libvlc_exception_t p_e);
-
-    void libvlc_log_close(LibVlcLog p_log, libvlc_exception_t p_e);
+    float libvlc_vlm_get_media_instance_position(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    int libvlc_log_count(LibVlcLog p_log, libvlc_exception_t p_e);
+    int libvlc_vlm_get_media_instance_time(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    void libvlc_log_clear(LibVlcLog p_log, libvlc_exception_t p_e);
+    int libvlc_vlm_get_media_instance_length(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    LibVlcLogIterator libvlc_log_get_iterator(LibVlcLog p_log, libvlc_exception_t p_e);
+    int libvlc_vlm_get_media_instance_rate(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    void libvlc_log_iterator_free(LibVlcLogIterator p_iter, libvlc_exception_t p_e);
+    int libvlc_vlm_get_media_instance_title(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    int libvlc_log_iterator_has_next(LibVlcLogIterator p_iter, libvlc_exception_t p_e);
+    int libvlc_vlm_get_media_instance_chapter(LibVlcInstance p_instance, String psz_name, int i_instance,
+        libvlc_exception_t p_e);
 
-    libvlc_log_message_t libvlc_log_iterator_next(LibVlcLogIterator p_iter, libvlc_log_message_t p_buffer,
+    int libvlc_vlm_get_media_instance_seekable(LibVlcInstance p_instance, String psz_name, int i_instance,
         libvlc_exception_t p_e);
 
+    LibVlcEventManager libvlc_vlm_get_event_manager(LibVlcInstance p_instance, libvlc_exception_t p_exception);
+
 }