Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-gpu
Commits
848c006a
Commit
848c006a
authored
Sep 07, 2009
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move LibVLC error messages to libvlc_printerr().
parent
9deb8f56
Changes
15
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
239 additions
and
214 deletions
+239
-214
include/vlc/libvlc.h
include/vlc/libvlc.h
+2
-5
src/control/audio.c
src/control/audio.c
+32
-28
src/control/core.c
src/control/core.c
+3
-17
src/control/event.c
src/control/event.c
+11
-12
src/control/hierarchical_node_media_list_view.c
src/control/hierarchical_node_media_list_view.c
+2
-1
src/control/libvlc_internal.h
src/control/libvlc_internal.h
+4
-2
src/control/media.c
src/control/media.c
+12
-6
src/control/media_discoverer.c
src/control/media_discoverer.c
+6
-3
src/control/media_library.c
src/control/media_library.c
+11
-11
src/control/media_list.c
src/control/media_list.c
+8
-4
src/control/media_list_player.c
src/control/media_list_player.c
+6
-9
src/control/media_list_view.c
src/control/media_list_view.c
+4
-2
src/control/media_player.c
src/control/media_player.c
+15
-12
src/control/video.c
src/control/video.c
+65
-54
src/control/vlm.c
src/control/vlm.c
+58
-48
No files found.
include/vlc/libvlc.h
View file @
848c006a
...
@@ -88,15 +88,12 @@ VLC_PUBLIC_API int
...
@@ -88,15 +88,12 @@ VLC_PUBLIC_API int
libvlc_exception_raised
(
const
libvlc_exception_t
*
p_exception
);
libvlc_exception_raised
(
const
libvlc_exception_t
*
p_exception
);
/**
/**
* Raise an exception
using a user-provided message
.
* Raise an exception.
*
*
* \param p_exception the exception to raise
* \param p_exception the exception to raise
* \param psz_format the exception message format string
* \param ... the format string arguments
*/
*/
VLC_PUBLIC_API
void
VLC_PUBLIC_API
void
libvlc_exception_raise
(
libvlc_exception_t
*
p_exception
,
libvlc_exception_raise
(
libvlc_exception_t
*
p_exception
);
const
char
*
psz_format
,
...
);
/**
/**
* Clear an exception object so it can be reused.
* Clear an exception object so it can be reused.
...
...
src/control/audio.c
View file @
848c006a
...
@@ -52,7 +52,8 @@ static aout_instance_t *GetAOut( libvlc_instance_t *p_instance,
...
@@ -52,7 +52,8 @@ static aout_instance_t *GetAOut( libvlc_instance_t *p_instance,
p_aout
=
vlc_object_find
(
p_instance
->
p_libvlc_int
,
VLC_OBJECT_AOUT
,
FIND_CHILD
);
p_aout
=
vlc_object_find
(
p_instance
->
p_libvlc_int
,
VLC_OBJECT_AOUT
,
FIND_CHILD
);
if
(
!
p_aout
)
if
(
!
p_aout
)
{
{
libvlc_exception_raise
(
p_exception
,
"No active audio output"
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"No active audio output"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -84,7 +85,8 @@ libvlc_audio_output_t *
...
@@ -84,7 +85,8 @@ libvlc_audio_output_t *
malloc
(
sizeof
(
libvlc_audio_output_t
)
);
malloc
(
sizeof
(
libvlc_audio_output_t
)
);
if
(
p_actual
==
NULL
)
if
(
p_actual
==
NULL
)
{
{
libvlc_exception_raise
(
p_e
,
"Not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
libvlc_audio_output_list_release
(
p_list
);
libvlc_audio_output_list_release
(
p_list
);
module_list_free
(
module_list
);
module_list_free
(
module_list
);
return
NULL
;
return
NULL
;
...
@@ -287,7 +289,6 @@ int libvlc_audio_output_get_device_type( libvlc_instance_t *p_instance,
...
@@ -287,7 +289,6 @@ int libvlc_audio_output_get_device_type( libvlc_instance_t *p_instance,
vlc_object_release
(
p_aout
);
vlc_object_release
(
p_aout
);
return
i_device_type
;
return
i_device_type
;
}
}
libvlc_exception_raise
(
p_e
,
"Unable to get audio output"
);
return
libvlc_AudioOutputDevice_Error
;
return
libvlc_AudioOutputDevice_Error
;
}
}
...
@@ -299,12 +300,14 @@ void libvlc_audio_output_set_device_type( libvlc_instance_t *p_instance,
...
@@ -299,12 +300,14 @@ void libvlc_audio_output_set_device_type( libvlc_instance_t *p_instance,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
if
(
p_aout
)
if
(
!
p_aout
)
return
;
if
(
var_SetInteger
(
p_aout
,
"audio-device"
,
device_type
)
<
0
)
{
{
if
(
var_SetInteger
(
p_aout
,
"audio-device"
,
device_type
)
<
0
)
libvlc_exception_raise
(
p_e
);
libvlc_exception_raise
(
p_e
,
"Failed setting audio device"
);
libvlc_printerr
(
"Error setting audio device"
);
vlc_object_release
(
p_aout
);
}
}
vlc_object_release
(
p_aout
);
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -363,7 +366,8 @@ void libvlc_audio_set_volume( libvlc_instance_t *p_instance, int i_volume,
...
@@ -363,7 +366,8 @@ void libvlc_audio_set_volume( libvlc_instance_t *p_instance, int i_volume,
}
}
else
else
{
{
libvlc_exception_raise
(
p_e
,
"Volume out of range"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Volume out of range"
);
}
}
}
}
...
@@ -414,8 +418,9 @@ int libvlc_audio_get_track( libvlc_media_player_t *p_mi,
...
@@ -414,8 +418,9 @@ int libvlc_audio_get_track( libvlc_media_player_t *p_mi,
i_ret
=
var_Get
(
p_input_thread
,
"audio-es"
,
&
val
);
i_ret
=
var_Get
(
p_input_thread
,
"audio-es"
,
&
val
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
{
{
libvlc_exception_raise
(
p_e
,
"Getting Audio track information failed"
);
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Audio track information not found"
);
return
i_ret
;
return
i_ret
;
}
}
...
@@ -450,14 +455,18 @@ void libvlc_audio_set_track( libvlc_media_player_t *p_mi, int i_track,
...
@@ -450,14 +455,18 @@ void libvlc_audio_set_track( libvlc_media_player_t *p_mi, int i_track,
var_Change
(
p_input_thread
,
"audio-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
var_Change
(
p_input_thread
,
"audio-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
if
(
(
i_track
<
0
)
||
(
i_track
>
val_list
.
p_list
->
i_count
)
)
if
(
(
i_track
<
0
)
||
(
i_track
>
val_list
.
p_list
->
i_count
)
)
{
{
libvlc_exception_raise
(
p_e
,
"Audio track out of range"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Audio track out of range"
);
goto
end
;
goto
end
;
}
}
newval
=
val_list
.
p_list
->
p_values
[
i_track
];
newval
=
val_list
.
p_list
->
p_values
[
i_track
];
i_ret
=
var_Set
(
p_input_thread
,
"audio-es"
,
newval
);
i_ret
=
var_Set
(
p_input_thread
,
"audio-es"
,
newval
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
libvlc_exception_raise
(
p_e
,
"Setting audio track failed"
);
{
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Audio track out of range"
);
/* Race... */
}
end:
end:
var_FreeList
(
&
val_list
,
NULL
);
var_FreeList
(
&
val_list
,
NULL
);
...
@@ -471,16 +480,12 @@ int libvlc_audio_get_channel( libvlc_instance_t *p_instance,
...
@@ -471,16 +480,12 @@ int libvlc_audio_get_channel( libvlc_instance_t *p_instance,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
if
(
p_aout
)
if
(
!
p_aout
)
{
return
0
;
vlc_value_t
val
;
var_Get
(
p_aout
,
"audio-channels"
,
&
val
);
int
val
=
var_GetInteger
(
p_aout
,
"audio-channels"
);
vlc_object_release
(
p_aout
);
vlc_object_release
(
p_aout
);
return
val
.
i_int
;
return
val
;
}
libvlc_exception_raise
(
p_e
,
"Unable to get audio output"
);
return
libvlc_AudioChannel_Error
;
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -491,14 +496,13 @@ void libvlc_audio_set_channel( libvlc_instance_t *p_instance,
...
@@ -491,14 +496,13 @@ void libvlc_audio_set_channel( libvlc_instance_t *p_instance,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
aout_instance_t
*
p_aout
=
GetAOut
(
p_instance
,
p_e
);
if
(
p_aout
)
if
(
!
p_aout
)
{
return
;
vlc_value_t
val
;
val
.
i_int
=
channel
;
if
(
var_Set
(
p_aout
,
"audio-channels"
,
val
)
<
0
)
libvlc_exception_raise
(
p_e
,
"Failed setting audio channel"
);
vlc_object_release
(
p_aout
);
if
(
var_SetInteger
(
p_aout
,
"audio-channels"
,
channel
)
<
0
)
{
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Audio channel out of range"
);
}
}
vlc_object_release
(
p_aout
);
}
}
src/control/core.c
View file @
848c006a
...
@@ -65,23 +65,8 @@ static void libvlc_exception_not_handled( const char *psz )
...
@@ -65,23 +65,8 @@ static void libvlc_exception_not_handled( const char *psz )
abort
();
abort
();
}
}
void
libvlc_exception_raise
(
libvlc_exception_t
*
p_exception
,
void
libvlc_exception_raise
(
libvlc_exception_t
*
p_exception
)
const
char
*
psz_format
,
...
)
{
{
va_list
args
;
/* Make sure that there is no unnoticed previous exception */
if
(
p_exception
&&
p_exception
->
b_raised
)
{
libvlc_exception_not_handled
(
libvlc_errmsg
()
);
libvlc_exception_clear
(
p_exception
);
}
/* Unformat-ize the message */
va_start
(
args
,
psz_format
);
libvlc_vprinterr
(
psz_format
,
args
);
va_end
(
args
);
/* Does caller care about exceptions ? */
/* Does caller care about exceptions ? */
if
(
p_exception
==
NULL
)
{
if
(
p_exception
==
NULL
)
{
/* Print something, so that lazy third-parties can easily
/* Print something, so that lazy third-parties can easily
...
@@ -187,7 +172,8 @@ int libvlc_add_intf( libvlc_instance_t *p_i, const char *name,
...
@@ -187,7 +172,8 @@ int libvlc_add_intf( libvlc_instance_t *p_i, const char *name,
{
{
if
(
libvlc_InternalAddIntf
(
p_i
->
p_libvlc_int
,
name
)
)
if
(
libvlc_InternalAddIntf
(
p_i
->
p_libvlc_int
,
name
)
)
{
{
libvlc_exception_raise
(
p_e
,
"Interface initialization failed"
);
libvlc_printerr
(
"Interface initialization failed"
);
libvlc_exception_raise
(
p_e
);
return
-
1
;
return
-
1
;
}
}
return
0
;
return
0
;
...
...
src/control/event.c
View file @
848c006a
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
#include "libvlc_internal.h"
#include "libvlc_internal.h"
#include "event_internal.h"
#include "event_internal.h"
#include <assert.h>
typedef
struct
libvlc_event_listeners_group_t
typedef
struct
libvlc_event_listeners_group_t
{
{
...
@@ -74,7 +75,8 @@ libvlc_event_manager_new( void * p_obj, libvlc_instance_t * p_libvlc_inst,
...
@@ -74,7 +75,8 @@ libvlc_event_manager_new( void * p_obj, libvlc_instance_t * p_libvlc_inst,
p_em
=
malloc
(
sizeof
(
libvlc_event_manager_t
));
p_em
=
malloc
(
sizeof
(
libvlc_event_manager_t
));
if
(
!
p_em
)
if
(
!
p_em
)
{
{
libvlc_exception_raise
(
p_e
,
"No Memory left"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -134,7 +136,8 @@ void libvlc_event_manager_register_event_type(
...
@@ -134,7 +136,8 @@ void libvlc_event_manager_register_event_type(
listeners_group
=
malloc
(
sizeof
(
libvlc_event_listeners_group_t
));
listeners_group
=
malloc
(
sizeof
(
libvlc_event_listeners_group_t
));
if
(
!
listeners_group
)
if
(
!
listeners_group
)
{
{
libvlc_exception_raise
(
p_e
,
"No Memory left"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
;
return
;
}
}
...
@@ -287,7 +290,8 @@ void event_attach( libvlc_event_manager_t * p_event_manager,
...
@@ -287,7 +290,8 @@ void event_attach( libvlc_event_manager_t * p_event_manager,
listener
=
malloc
(
sizeof
(
libvlc_event_listener_t
));
listener
=
malloc
(
sizeof
(
libvlc_event_listener_t
));
if
(
!
listener
)
if
(
!
listener
)
{
{
libvlc_exception_raise
(
p_e
,
"No Memory left"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
;
return
;
}
}
...
@@ -310,9 +314,9 @@ void event_attach( libvlc_event_manager_t * p_event_manager,
...
@@ -310,9 +314,9 @@ void event_attach( libvlc_event_manager_t * p_event_manager,
vlc_mutex_unlock
(
&
p_event_manager
->
object_lock
);
vlc_mutex_unlock
(
&
p_event_manager
->
object_lock
);
free
(
listener
);
free
(
listener
);
libvlc_exception_raise
(
p_e
,
fprintf
(
stderr
,
"This object event manager doesn't know about '%s' events"
,
"This object event manager doesn't know about '%s' events"
,
libvlc_event_type_name
(
event_type
)
);
libvlc_event_type_name
(
event_type
)
);
assert
(
0
);
}
}
/**************************************************************************
/**************************************************************************
...
@@ -399,10 +403,5 @@ void libvlc_event_detach( libvlc_event_manager_t *p_event_manager,
...
@@ -399,10 +403,5 @@ void libvlc_event_detach( libvlc_event_manager_t *p_event_manager,
libvlc_event_async_ensure_listener_removal
(
p_event_manager
,
&
listener_to_remove
);
libvlc_event_async_ensure_listener_removal
(
p_event_manager
,
&
listener_to_remove
);
if
(
!
found
)
assert
(
found
);
{
libvlc_exception_raise
(
p_e
,
"This object event manager doesn't know about '%s,%p,%p' event observer"
,
libvlc_event_type_name
(
event_type
),
pf_callback
,
p_user_data
);
}
}
}
src/control/hierarchical_node_media_list_view.c
View file @
848c006a
...
@@ -105,7 +105,8 @@ hierarch_node_media_list_view_item_at_index( libvlc_media_list_view_t * p_mlv,
...
@@ -105,7 +105,8 @@ hierarch_node_media_list_view_item_at_index( libvlc_media_list_view_t * p_mlv,
libvlc_media_release
(
p_md
);
libvlc_media_release
(
p_md
);
}
}
libvlc_exception_raise
(
p_e
,
"Index out of bound in Media List View"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Index out of bound in Media List View"
);
return
NULL
;
return
NULL
;
}
}
...
...
src/control/libvlc_internal.h
View file @
848c006a
...
@@ -104,9 +104,11 @@ void libvlc_event_attach_async( libvlc_event_manager_t * p_event_manager,
...
@@ -104,9 +104,11 @@ void libvlc_event_attach_async( libvlc_event_manager_t * p_event_manager,
/* Exception shorcuts */
/* Exception shorcuts */
#define RAISENULL( ... ) { libvlc_exception_raise( p_e, __VA_ARGS__ ); \
#define RAISENULL( ... ) { libvlc_printerr(__VA_ARGS__); \
libvlc_exception_raise( p_e ); \
return NULL; }
return NULL; }
#define RAISEZERO( ... ) { libvlc_exception_raise( p_e, __VA_ARGS__ ); \
#define RAISEZERO( ... ) { libvlc_printerr(__VA_ARGS__); \
libvlc_exception_raise( p_e ); \
return 0; }
return 0; }
#endif
#endif
src/control/media.c
View file @
848c006a
...
@@ -245,14 +245,16 @@ libvlc_media_t * libvlc_media_new_from_input_item(
...
@@ -245,14 +245,16 @@ libvlc_media_t * libvlc_media_new_from_input_item(
if
(
!
p_input_item
)
if
(
!
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"No input item given"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No input item given"
);
return
NULL
;
return
NULL
;
}
}
p_md
=
malloc
(
sizeof
(
libvlc_media_t
)
);
p_md
=
malloc
(
sizeof
(
libvlc_media_t
)
);
if
(
!
p_md
)
if
(
!
p_md
)
{
{
libvlc_exception_raise
(
p_e
,
"Not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -302,7 +304,8 @@ libvlc_media_t * libvlc_media_new(
...
@@ -302,7 +304,8 @@ libvlc_media_t * libvlc_media_new(
if
(
!
p_input_item
)
if
(
!
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"Can't create md's input_item"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -330,7 +333,8 @@ libvlc_media_t * libvlc_media_new_as_node(
...
@@ -330,7 +333,8 @@ libvlc_media_t * libvlc_media_new_as_node(
if
(
!
p_input_item
)
if
(
!
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"Can't create md's input_item"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -545,7 +549,8 @@ libvlc_media_get_duration( libvlc_media_t * p_md,
...
@@ -545,7 +549,8 @@ libvlc_media_get_duration( libvlc_media_t * p_md,
if
(
!
p_md
||
!
p_md
->
p_input_item
)
if
(
!
p_md
||
!
p_md
->
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"No input item"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No input item"
);
return
-
1
;
return
-
1
;
}
}
...
@@ -563,7 +568,8 @@ libvlc_media_is_preparsed( libvlc_media_t * p_md,
...
@@ -563,7 +568,8 @@ libvlc_media_is_preparsed( libvlc_media_t * p_md,
if
(
!
p_md
||
!
p_md
->
p_input_item
)
if
(
!
p_md
||
!
p_md
->
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"No input item"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No input item"
);
return
false
;
return
false
;
}
}
...
...
src/control/media_discoverer.c
View file @
848c006a
...
@@ -178,7 +178,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
...
@@ -178,7 +178,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
p_mdis
=
malloc
(
sizeof
(
libvlc_media_discoverer_t
));
p_mdis
=
malloc
(
sizeof
(
libvlc_media_discoverer_t
));
if
(
!
p_mdis
)
if
(
!
p_mdis
)
{
{
libvlc_exception_raise
(
p_e
,
"Not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
...
@@ -202,7 +203,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
...
@@ -202,7 +203,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
if
(
!
p_mdis
->
p_sd
)
if
(
!
p_mdis
->
p_sd
)
{
{
libvlc_media_list_release
(
p_mdis
->
p_mlist
);
libvlc_media_list_release
(
p_mdis
->
p_mlist
);
libvlc_exception_raise
(
p_e
,
"Can't find the services_discovery module named '%s'"
,
psz_name
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"%s: no such discovery module found"
,
psz_name
);
free
(
p_mdis
);
free
(
p_mdis
);
return
NULL
;
return
NULL
;
}
}
...
@@ -228,7 +230,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
...
@@ -228,7 +230,8 @@ libvlc_media_discoverer_new_from_name( libvlc_instance_t * p_inst,
if
(
!
vlc_sd_Start
(
p_mdis
->
p_sd
,
psz_name
)
)
if
(
!
vlc_sd_Start
(
p_mdis
->
p_sd
,
psz_name
)
)
{
{
libvlc_media_list_release
(
p_mdis
->
p_mlist
);
libvlc_media_list_release
(
p_mdis
->
p_mlist
);
libvlc_exception_raise
(
p_e
,
"Can't start the services_discovery module named '%s'"
,
psz_name
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"%s: internal module error"
,
psz_name
);
free
(
p_mdis
);
free
(
p_mdis
);
return
NULL
;
return
NULL
;
}
}
...
...
src/control/media_library.c
View file @
848c006a
...
@@ -111,20 +111,19 @@ libvlc_media_library_load( libvlc_media_library_t * p_mlib,
...
@@ -111,20 +111,19 @@ libvlc_media_library_load( libvlc_media_library_t * p_mlib,
char
*
psz_datadir
=
config_GetUserDir
(
VLC_DATA_DIR
);
char
*
psz_datadir
=
config_GetUserDir
(
VLC_DATA_DIR
);
char
*
psz_uri
;
char
*
psz_uri
;
if
(
!
psz_datadir
)
/* XXX: i doubt that this can ever happen */
if
(
psz_datadir
==
NULL
{
||
asprintf
(
&
psz_uri
,
"file/xspf-open://%s"
DIR_SEP
"ml.xsp"
,
libvlc_exception_raise
(
p_e
,
"Can't get data directory"
);
return
;
}
if
(
asprintf
(
&
psz_uri
,
"file/xspf-open://%s"
DIR_SEP
"ml.xsp"
,
psz_datadir
)
==
-
1
)
psz_datadir
)
==
-
1
)
psz_uri
=
NULL
;
free
(
psz_datadir
);
if
(
psz_uri
==
NULL
);
{
{
free
(
psz_datadir
);
libvlc_exception_raise
(
p_e
);
libvlc_
exception_raise
(
p_e
,
"Can't get create the path
"
);
libvlc_
printerr
(
"Not enough memory
"
);
return
;
return
;
}
}
free
(
psz_datadir
);
if
(
p_mlib
->
p_mlist
)
if
(
p_mlib
->
p_mlist
)
libvlc_media_list_release
(
p_mlib
->
p_mlist
);
libvlc_media_list_release
(
p_mlib
->
p_mlist
);
...
@@ -145,7 +144,8 @@ libvlc_media_library_save( libvlc_media_library_t * p_mlib,
...
@@ -145,7 +144,8 @@ libvlc_media_library_save( libvlc_media_library_t * p_mlib,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
(
void
)
p_mlib
;
(
void
)
p_mlib
;
libvlc_exception_raise
(
p_e
,
"Not supported"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Function not implemented"
);
}
}
/**************************************************************************
/**************************************************************************
...
...
src/control/media_list.c
View file @
848c006a
...
@@ -134,7 +134,8 @@ int mlist_is_writable( libvlc_media_list_t *p_mlist, libvlc_exception_t *p_e )
...
@@ -134,7 +134,8 @@ int mlist_is_writable( libvlc_media_list_t *p_mlist, libvlc_exception_t *p_e )
if
(
!
p_mlist
||
p_mlist
->
b_read_only
)
if
(
!
p_mlist
||
p_mlist
->
b_read_only
)
{
{
/* We are read-only from user side */
/* We are read-only from user side */
libvlc_exception_raise
(
p_e
,
"Cannot write to read-only media list."
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Attempt to write a read-only media list"
);
return
0
;
return
0
;
}
}
return
1
;
return
1
;
...
@@ -259,7 +260,8 @@ libvlc_media_list_add_file_content( libvlc_media_list_t * p_mlist,
...
@@ -259,7 +260,8 @@ libvlc_media_list_add_file_content( libvlc_media_list_t * p_mlist,
if
(
!
p_input_item
)
if
(
!
p_input_item
)
{
{
libvlc_exception_raise
(
p_e
,
"Can't create an input item"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
;
return
;
}
}
...
@@ -417,7 +419,8 @@ void _libvlc_media_list_remove_index( libvlc_media_list_t * p_mlist,
...
@@ -417,7 +419,8 @@ void _libvlc_media_list_remove_index( libvlc_media_list_t * p_mlist,
if
(
index
<
0
||
index
>=
vlc_array_count
(
&
p_mlist
->
items
))
if
(
index
<
0
||
index
>=
vlc_array_count
(
&
p_mlist
->
items
))
{
{
libvlc_exception_raise
(
p_e
,
"Index out of bounds"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Index out of bounds"
);
return
;
return
;
}
}
...
@@ -444,7 +447,8 @@ libvlc_media_list_item_at_index( libvlc_media_list_t * p_mlist,
...
@@ -444,7 +447,8 @@ libvlc_media_list_item_at_index( libvlc_media_list_t * p_mlist,
if
(
index
<
0
||
index
>=
vlc_array_count
(
&
p_mlist
->
items
))
if
(
index
<
0
||
index
>=
vlc_array_count
(
&
p_mlist
->
items
))
{
{
libvlc_exception_raise
(
p_e
,
"Index out of bounds"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Index out of bounds"
);
return
NULL
;
return
NULL
;
}
}
...
...
src/control/media_list_player.c
View file @
848c006a
...
@@ -566,14 +566,9 @@ void libvlc_media_list_player_set_media_player(libvlc_media_list_player_t * p_ml
...
@@ -566,14 +566,9 @@ void libvlc_media_list_player_set_media_player(libvlc_media_list_player_t * p_ml
**************************************************************************/
**************************************************************************/
void
libvlc_media_list_player_set_media_list
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_media_list_t
*
p_mlist
,
libvlc_exception_t
*
p_e
)
void
libvlc_media_list_player_set_media_list
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_media_list_t
*
p_mlist
,
libvlc_exception_t
*
p_e
)
{
{
lock
(
p_mlp
);
assert
(
p_mlist
);
if
(
!
p_mlist
)
lock
(
p_mlp
);
{
libvlc_exception_raise
(
p_e
,
"No media list provided"
);
unlock
(
p_mlp
);
return
;
}
if
(
p_mlp
->
p_mlist
)
if
(
p_mlp
->
p_mlist
)
{
{
uninstall_playlist_observer
(
p_mlp
);
uninstall_playlist_observer
(
p_mlp
);
...
@@ -668,7 +663,8 @@ void libvlc_media_list_player_play_item(libvlc_media_list_player_t * p_mlp, libv
...
@@ -668,7 +663,8 @@ void libvlc_media_list_player_play_item(libvlc_media_list_player_t * p_mlp, libv
libvlc_media_list_path_t
path
=
libvlc_media_list_path_of_item
(
p_mlp
->
p_mlist
,
p_md
);
libvlc_media_list_path_t
path
=
libvlc_media_list_path_of_item
(
p_mlp
->
p_mlist
,
p_md
);
if
(
!
path
)
if
(
!
path
)
{
{
libvlc_exception_raise
(
p_e
,
"No such item in media list"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Item not found in media list"
);
unlock
(
p_mlp
);
unlock
(
p_mlp
);
return
;
return
;
}
}
...
@@ -726,7 +722,8 @@ static void set_relative_playlist_position_and_play(
...
@@ -726,7 +722,8 @@ static void set_relative_playlist_position_and_play(
if
(
!
p_mlp
->
p_mlist
)
if
(
!
p_mlp
->
p_mlist
)
{
{
libvlc_exception_raise
(
p_e
,
"No media list"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No media list"
);
return
;
return
;
}
}
...
...
src/control/media_list_view.c
View file @
848c006a
...
@@ -475,7 +475,8 @@ libvlc_media_list_view_children_for_item( libvlc_media_list_view_t * p_mlv,
...
@@ -475,7 +475,8 @@ libvlc_media_list_view_children_for_item( libvlc_media_list_view_t * p_mlv,
{ \
{ \
if( p_mlv->pf_##name ) \
if( p_mlv->pf_##name ) \
return p_mlv->pf_##name ARGS(__VA_ARGS__) ; \
return p_mlv->pf_##name ARGS(__VA_ARGS__) ; \
libvlc_exception_raise( p_e, "No '" #name "' method in this media_list_view" ); \
libvlc_exception_raise( p_e ); \
libvlc_printerr( "No '" #name "' method in this media_list_view" ); \
return default_ret_value;\
return default_ret_value;\
}
}
...
@@ -490,7 +491,8 @@ libvlc_media_list_view_children_for_item( libvlc_media_list_view_t * p_mlv,
...
@@ -490,7 +491,8 @@ libvlc_media_list_view_children_for_item( libvlc_media_list_view_t * p_mlv,
p_mlv->pf_##name ARGS(__VA_ARGS__) ; \
p_mlv->pf_##name ARGS(__VA_ARGS__) ; \
return; \
return; \
} \
} \
libvlc_exception_raise( p_e, "No '" #name "' method in this media_list_view" ); \
libvlc_exception_raise( p_e ); \
libvlc_printerr( "No '" #name "' method in this media_list_view" ); \
}
}
...
...
src/control/media_player.c
View file @
848c006a
...
@@ -275,16 +275,13 @@ libvlc_media_player_new( libvlc_instance_t * p_libvlc_instance,
...
@@ -275,16 +275,13 @@ libvlc_media_player_new( libvlc_instance_t * p_libvlc_instance,
{
{
libvlc_media_player_t
*
p_mi
;
libvlc_media_player_t
*
p_mi
;
if
(
!
p_libvlc_instance
)
assert
(
p_libvlc_instance
);
{
libvlc_exception_raise
(
p_e
,
"invalid libvlc instance"
);
return
NULL
;
}
p_mi
=
malloc
(
sizeof
(
libvlc_media_player_t
)
);
p_mi
=
malloc
(
sizeof
(
libvlc_media_player_t
)
);
if
(
!
p_mi
)
if
(
!
p_mi
)
{
{
libvlc_exception_raise
(
p_e
,
"not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
return
NULL
;
}
}
p_mi
->
p_md
=
NULL
;
p_mi
->
p_md
=
NULL
;
...
@@ -558,8 +555,9 @@ void libvlc_media_player_play( libvlc_media_player_t *p_mi,
...
@@ -558,8 +555,9 @@ void libvlc_media_player_play( libvlc_media_player_t *p_mi,
if
(
!
p_mi
->
p_md
)
if
(
!
p_mi
->
p_md
)
{
{
libvlc_exception_raise
(
p_e
,
"no associated media descriptor"
);
vlc_mutex_unlock
(
&
p_mi
->
object_lock
);
vlc_mutex_unlock
(
&
p_mi
->
object_lock
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No associated media descriptor"
);
return
;
return
;
}
}
...
@@ -1038,7 +1036,8 @@ void libvlc_media_player_set_rate(
...
@@ -1038,7 +1036,8 @@ void libvlc_media_player_set_rate(
if
(
(
rate
<
0
.
0
)
&&
!
b_can_rewind
)
if
(
(
rate
<
0
.
0
)
&&
!
b_can_rewind
)
{
{
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
libvlc_exception_raise
(
p_e
,
"Rate value is invalid"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Invalid playback rate"
);
return
;
return
;
}
}
...
@@ -1063,7 +1062,6 @@ float libvlc_media_player_get_rate(
...
@@ -1063,7 +1062,6 @@ float libvlc_media_player_get_rate(
if
(
i_rate
<
0
&&
!
b_can_rewind
)
if
(
i_rate
<
0
&&
!
b_can_rewind
)
{
{
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
libvlc_exception_raise
(
p_e
,
"invalid rate"
);
return
0
.
0
;
return
0
.
0
;
}
}
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
...
@@ -1143,7 +1141,8 @@ libvlc_track_description_t *
...
@@ -1143,7 +1141,8 @@ libvlc_track_description_t *
malloc
(
sizeof
(
libvlc_track_description_t
)
);
malloc
(
sizeof
(
libvlc_track_description_t
)
);
if
(
!
p_track_description
)
if
(
!
p_track_description
)
{
{
libvlc_exception_raise
(
p_e
,
"not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
goto
end
;
goto
end
;
}
}
p_actual
=
p_track_description
;
p_actual
=
p_track_description
;
...
@@ -1157,7 +1156,8 @@ libvlc_track_description_t *
...
@@ -1157,7 +1156,8 @@ libvlc_track_description_t *
if
(
!
p_actual
)
if
(
!
p_actual
)
{
{
libvlc_track_description_release
(
p_track_description
);
libvlc_track_description_release
(
p_track_description
);
libvlc_exception_raise
(
p_e
,
"not enough memory"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Not enough memory"
);
goto
end
;
goto
end
;
}
}
}
}
...
@@ -1220,5 +1220,8 @@ void libvlc_media_player_next_frame( libvlc_media_player_t *p_mi, libvlc_excepti
...
@@ -1220,5 +1220,8 @@ void libvlc_media_player_next_frame( libvlc_media_player_t *p_mi, libvlc_excepti
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
}
}
else
else
libvlc_exception_raise
(
p_e
,
"Input thread is NULL"
);
{
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"No active input"
);
}
}
}
src/control/video.c
View file @
848c006a
...
@@ -39,6 +39,7 @@
...
@@ -39,6 +39,7 @@
#include "media_player_internal.h"
#include "media_player_internal.h"
#include <vlc_osd.h>
#include <vlc_osd.h>
#include <assert.h>
/*
/*
* Remember to release the returned vout_thread_t.
* Remember to release the returned vout_thread_t.
...
@@ -54,7 +55,8 @@ static vout_thread_t *GetVout( libvlc_media_player_t *p_mi,
...
@@ -54,7 +55,8 @@ static vout_thread_t *GetVout( libvlc_media_player_t *p_mi,
p_vout
=
input_GetVout
(
p_input
);
p_vout
=
input_GetVout
(
p_input
);
if
(
!
p_vout
)
if
(
!
p_vout
)
{
{
libvlc_exception_raise
(
p_exception
,
"No active video output"
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"No active video output"
);
}
}
vlc_object_release
(
p_input
);
vlc_object_release
(
p_input
);
}
}
...
@@ -116,16 +118,13 @@ libvlc_video_take_snapshot( libvlc_media_player_t *p_mi, const char *psz_filepat
...
@@ -116,16 +118,13 @@ libvlc_video_take_snapshot( libvlc_media_player_t *p_mi, const char *psz_filepat
{
{
vout_thread_t
*
p_vout
;
vout_thread_t
*
p_vout
;
/* The filepath must be not NULL */
assert
(
psz_filepath
);
if
(
!
psz_filepath
)
{
libvlc_exception_raise
(
p_e
,
"filepath is null"
);
return
;
}
/* We must have an input */
/* We must have an input */
if
(
!
p_mi
->
p_input_thread
)
if
(
!
p_mi
->
p_input_thread
)
{
{
libvlc_exception_raise
(
p_e
,
"Input does not exist"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Input does not exist"
);
return
;
return
;
}
}
...
@@ -243,11 +242,12 @@ void libvlc_video_set_aspect_ratio( libvlc_media_player_t *p_mi,
...
@@ -243,11 +242,12 @@ void libvlc_video_set_aspect_ratio( libvlc_media_player_t *p_mi,
if
(
!
p_vout
)
return
;
if
(
!
p_vout
)
return
;
i_ret
=
var_SetString
(
p_vout
,
"aspect-ratio"
,
psz_aspect
);
i_ret
=
var_SetString
(
p_vout
,
"aspect-ratio"
,
psz_aspect
);
if
(
i_ret
)
libvlc_exception_raise
(
p_e
,
"Unexpected error while setting aspect-ratio value"
);
vlc_object_release
(
p_vout
);
vlc_object_release
(
p_vout
);
if
(
i_ret
)
{
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Bad or unsupported aspect ratio"
);
}
}
}
int
libvlc_video_get_spu
(
libvlc_media_player_t
*
p_mi
,
int
libvlc_video_get_spu
(
libvlc_media_player_t
*
p_mi
,
...
@@ -265,8 +265,9 @@ int libvlc_video_get_spu( libvlc_media_player_t *p_mi,
...
@@ -265,8 +265,9 @@ int libvlc_video_get_spu( libvlc_media_player_t *p_mi,
i_ret
=
var_Get
(
p_input_thread
,
"spu-es"
,
&
val
);
i_ret
=
var_Get
(
p_input_thread
,
"spu-es"
,
&
val
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
{
{
libvlc_exception_raise
(
p_e
,
"Getting subtitle information failed"
);
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Subtitle informations not found"
);
return
i_ret
;
return
i_ret
;
}
}
...
@@ -318,15 +319,11 @@ void libvlc_video_set_spu( libvlc_media_player_t *p_mi, int i_spu,
...
@@ -318,15 +319,11 @@ void libvlc_video_set_spu( libvlc_media_player_t *p_mi, int i_spu,
var_Change
(
p_input_thread
,
"spu-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
var_Change
(
p_input_thread
,
"spu-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
if
(
val_list
.
p_list
->
i_count
==
0
)
if
(
(
val_list
.
p_list
->
i_count
==
0
)
||
(
i_spu
<
0
)
||
(
i_spu
>
val_list
.
p_list
->
i_count
)
)
{
{
libvlc_exception_raise
(
p_e
,
"Subtitle value out of range"
);
libvlc_exception_raise
(
p_e
);
goto
end
;
libvlc_printerr
(
"Subtitle number out of range"
);
}
if
(
(
i_spu
<
0
)
||
(
i_spu
>
val_list
.
p_list
->
i_count
)
)
{
libvlc_exception_raise
(
p_e
,
"Subtitle value out of range"
);
goto
end
;
goto
end
;
}
}
...
@@ -334,7 +331,8 @@ void libvlc_video_set_spu( libvlc_media_player_t *p_mi, int i_spu,
...
@@ -334,7 +331,8 @@ void libvlc_video_set_spu( libvlc_media_player_t *p_mi, int i_spu,
i_ret
=
var_Set
(
p_input_thread
,
"spu-es"
,
newval
);
i_ret
=
var_Set
(
p_input_thread
,
"spu-es"
,
newval
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
{
{
libvlc_exception_raise
(
p_e
,
"Setting subtitle value failed"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Subtitle selection error"
);
}
}
end:
end:
...
@@ -397,16 +395,19 @@ void libvlc_video_set_crop_geometry( libvlc_media_player_t *p_mi,
...
@@ -397,16 +395,19 @@ void libvlc_video_set_crop_geometry( libvlc_media_player_t *p_mi,
if
(
!
p_vout
)
return
;
if
(
!
p_vout
)
return
;
i_ret
=
var_SetString
(
p_vout
,
"crop"
,
psz_geometry
);
i_ret
=
var_SetString
(
p_vout
,
"crop"
,
psz_geometry
);
if
(
i_ret
)
libvlc_exception_raise
(
p_e
,
"Unexpected error while setting crop geometry"
);
vlc_object_release
(
p_vout
);
vlc_object_release
(
p_vout
);
if
(
i_ret
)
{
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Bad or unsupported cropping geometry"
);
}
}
}
int
libvlc_video_get_teletext
(
libvlc_media_player_t
*
p_mi
,
int
libvlc_video_get_teletext
(
libvlc_media_player_t
*
p_mi
,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
#if 0
vout_thread_t *p_vout = GetVout( p_mi, p_e );
vout_thread_t *p_vout = GetVout( p_mi, p_e );
vlc_object_t *p_vbi;
vlc_object_t *p_vbi;
int i_ret = -1;
int i_ret = -1;
...
@@ -423,11 +424,15 @@ int libvlc_video_get_teletext( libvlc_media_player_t *p_mi,
...
@@ -423,11 +424,15 @@ int libvlc_video_get_teletext( libvlc_media_player_t *p_mi,
vlc_object_release( p_vout );
vlc_object_release( p_vout );
return i_ret;
return i_ret;
#else
return
-
1
;
#endif
}
}
void
libvlc_video_set_teletext
(
libvlc_media_player_t
*
p_mi
,
int
i_page
,
void
libvlc_video_set_teletext
(
libvlc_media_player_t
*
p_mi
,
int
i_page
,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
#if 0
vout_thread_t *p_vout = GetVout( p_mi, p_e );
vout_thread_t *p_vout = GetVout( p_mi, p_e );
vlc_object_t *p_vbi;
vlc_object_t *p_vbi;
int i_ret = -1;
int i_ret = -1;
...
@@ -445,13 +450,13 @@ void libvlc_video_set_teletext( libvlc_media_player_t *p_mi, int i_page,
...
@@ -445,13 +450,13 @@ void libvlc_video_set_teletext( libvlc_media_player_t *p_mi, int i_page,
"Unexpected error while setting teletext page" );
"Unexpected error while setting teletext page" );
}
}
vlc_object_release( p_vout );
vlc_object_release( p_vout );
#endif
}
}
void
libvlc_toggle_teletext
(
libvlc_media_player_t
*
p_mi
,
void
libvlc_toggle_teletext
(
libvlc_media_player_t
*
p_mi
,
libvlc_exception_t
*
p_e
)
libvlc_exception_t
*
p_e
)
{
{
input_thread_t
*
p_input_thread
;
input_thread_t
*
p_input_thread
;
vlc_object_t
*
p_vbi
;
int
i_ret
;
int
i_ret
;
p_input_thread
=
libvlc_get_input_thread
(
p_mi
,
p_e
);
p_input_thread
=
libvlc_get_input_thread
(
p_mi
,
p_e
);
...
@@ -463,7 +468,8 @@ void libvlc_toggle_teletext( libvlc_media_player_t *p_mi,
...
@@ -463,7 +468,8 @@ void libvlc_toggle_teletext( libvlc_media_player_t *p_mi,
return
;
return
;
}
}
const
bool
b_selected
=
var_GetInteger
(
p_input_thread
,
"teletext-es"
)
>=
0
;
const
bool
b_selected
=
var_GetInteger
(
p_input_thread
,
"teletext-es"
)
>=
0
;
#if 0
vlc_object_t *p_vbi;
p_vbi = (vlc_object_t *)vlc_object_find_name( p_input_thread, "zvbi",
p_vbi = (vlc_object_t *)vlc_object_find_name( p_input_thread, "zvbi",
FIND_CHILD );
FIND_CHILD );
if( p_vbi )
if( p_vbi )
...
@@ -488,7 +494,9 @@ void libvlc_toggle_teletext( libvlc_media_player_t *p_mi,
...
@@ -488,7 +494,9 @@ void libvlc_toggle_teletext( libvlc_media_player_t *p_mi,
}
}
vlc_object_release( p_vbi );
vlc_object_release( p_vbi );
}
}
else
if
(
b_selected
)
else
#endif
if
(
b_selected
)
{
{
var_SetInteger
(
p_input_thread
,
"spu-es"
,
-
1
);
var_SetInteger
(
p_input_thread
,
"spu-es"
,
-
1
);
}
}
...
@@ -544,7 +552,8 @@ int libvlc_video_get_track( libvlc_media_player_t *p_mi,
...
@@ -544,7 +552,8 @@ int libvlc_video_get_track( libvlc_media_player_t *p_mi,
i_ret
=
var_Get
(
p_input_thread
,
"video-es"
,
&
val
);
i_ret
=
var_Get
(
p_input_thread
,
"video-es"
,
&
val
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
{
{
libvlc_exception_raise
(
p_e
,
"Getting Video track information failed"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Video track information not found"
);
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
return
i_ret
;
return
i_ret
;
}
}
...
@@ -577,17 +586,16 @@ void libvlc_video_set_track( libvlc_media_player_t *p_mi, int i_track,
...
@@ -577,17 +586,16 @@ void libvlc_video_set_track( libvlc_media_player_t *p_mi, int i_track,
var_Change
(
p_input_thread
,
"video-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
var_Change
(
p_input_thread
,
"video-es"
,
VLC_VAR_GETCHOICES
,
&
val_list
,
NULL
);
for
(
i
=
0
;
i
<
val_list
.
p_list
->
i_count
;
i
++
)
for
(
i
=
0
;
i
<
val_list
.
p_list
->
i_count
;
i
++
)
{
{
vlc_value_t
val
=
val_list
.
p_list
->
p_values
[
i
];
if
(
i_track
==
val_list
.
p_list
->
p_values
[
i
].
i_int
)
if
(
i_track
==
val
.
i_int
)
{
{
i_ret
=
var_Set
(
p_input_thread
,
"video-es"
,
val
);
i_ret
=
var_Set
Integer
(
p_input_thread
,
"video-es"
,
i_track
);
if
(
i_ret
<
0
)
if
(
i_ret
<
0
)
libvlc_exception_raise
(
p_e
,
"Setting video track failed"
)
;
break
;
goto
end
;
goto
end
;
}
}
}
}
libvlc_exception_raise
(
p_e
,
"Video track out of range"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Video track number out of range"
);
end:
end:
var_FreeList
(
&
val_list
,
NULL
);
var_FreeList
(
&
val_list
,
NULL
);
vlc_object_release
(
p_input_thread
);
vlc_object_release
(
p_input_thread
);
...
@@ -603,10 +611,7 @@ void libvlc_video_set_deinterlace( libvlc_media_player_t *p_mi, int b_enable,
...
@@ -603,10 +611,7 @@ void libvlc_video_set_deinterlace( libvlc_media_player_t *p_mi, int b_enable,
vout_thread_t
*
p_vout
=
GetVout
(
p_mi
,
p_e
);
vout_thread_t
*
p_vout
=
GetVout
(
p_mi
,
p_e
);
if
(
!
p_vout
)
if
(
!
p_vout
)
{
libvlc_exception_raise
(
p_e
,
"Unable to get video output"
);
return
;
return
;
}
if
(
b_enable
)
if
(
b_enable
)
{
{
...
@@ -620,7 +625,8 @@ void libvlc_video_set_deinterlace( libvlc_media_player_t *p_mi, int b_enable,
...
@@ -620,7 +625,8 @@ void libvlc_video_set_deinterlace( libvlc_media_player_t *p_mi, int b_enable,
}
}
else
else
{
{
libvlc_exception_raise
(
p_e
,
"Unsuported or bad deinterlace filter name"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Bad or unsuported deinterlacing mode"
);
}
}
}
}
else
else
...
@@ -691,7 +697,8 @@ int libvlc_video_get_marquee_option_as_int( libvlc_media_player_t *p_mi,
...
@@ -691,7 +697,8 @@ int libvlc_video_get_marquee_option_as_int( libvlc_media_player_t *p_mi,
const
char
*
identifier
=
get_marquee_int_option_identifier
(
option
);
const
char
*
identifier
=
get_marquee_int_option_identifier
(
option
);
if
(
!
identifier
)
if
(
!
identifier
)
{
{
libvlc_exception_raise
(
p_e
,
"This option is not available"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Unknown marquee option"
);
return
0
;
return
0
;
}
}
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
...
@@ -707,9 +714,11 @@ int libvlc_video_get_marquee_option_as_int( libvlc_media_player_t *p_mi,
...
@@ -707,9 +714,11 @@ int libvlc_video_get_marquee_option_as_int( libvlc_media_player_t *p_mi,
/* Generic case */
/* Generic case */
if
(
!
identifier
)
if
(
!
identifier
)
{
{
libvlc_exception_raise
(
p_e
,
"Marquee is not enabled"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Marquee not enabled"
);
return
0
;
return
0
;
}
}
#warning This and the next function may crash due to type checking!
int
ret
=
var_GetInteger
(
marquee
,
identifier
);
int
ret
=
var_GetInteger
(
marquee
,
identifier
);
vlc_object_release
(
marquee
);
vlc_object_release
(
marquee
);
return
ret
;
return
ret
;
...
@@ -725,15 +734,17 @@ char * libvlc_video_get_marquee_option_as_string( libvlc_media_player_t *p_mi,
...
@@ -725,15 +734,17 @@ char * libvlc_video_get_marquee_option_as_string( libvlc_media_player_t *p_mi,
const
char
*
identifier
=
get_marquee_string_option_identifier
(
option
);
const
char
*
identifier
=
get_marquee_string_option_identifier
(
option
);
if
(
!
identifier
)
if
(
!
identifier
)
{
{
libvlc_exception_raise
(
p_e
,
"This option is not available"
);
libvlc_exception_raise
(
p_e
);
return
0
;
libvlc_printerr
(
"Unknown marquee option"
);
return
NULL
;
}
}
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
if
(
!
marquee
)
if
(
!
marquee
)
{
{
libvlc_exception_raise
(
p_e
,
"Marquee is not enabled"
);
libvlc_exception_raise
(
p_e
);
return
0
;
libvlc_printerr
(
"Marquee not enabled"
);
return
NULL
;
}
}
char
*
ret
=
var_GetString
(
marquee
,
identifier
);
char
*
ret
=
var_GetString
(
marquee
,
identifier
);
vlc_object_release
(
marquee
);
vlc_object_release
(
marquee
);
...
@@ -750,7 +761,8 @@ void libvlc_video_set_marquee_option_as_int( libvlc_media_player_t *p_mi,
...
@@ -750,7 +761,8 @@ void libvlc_video_set_marquee_option_as_int( libvlc_media_player_t *p_mi,
const
char
*
identifier
=
get_marquee_int_option_identifier
(
option
);
const
char
*
identifier
=
get_marquee_int_option_identifier
(
option
);
if
(
!
identifier
)
if
(
!
identifier
)
{
{
libvlc_exception_raise
(
p_e
,
"This option is not available"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Unknown marquee option"
);
return
;
return
;
}
}
...
@@ -766,17 +778,14 @@ void libvlc_video_set_marquee_option_as_int( libvlc_media_player_t *p_mi,
...
@@ -766,17 +778,14 @@ void libvlc_video_set_marquee_option_as_int( libvlc_media_player_t *p_mi,
vout_EnableFilter
(
vout
,
identifier
,
value
,
false
);
vout_EnableFilter
(
vout
,
identifier
,
value
,
false
);
vlc_object_release
(
vout
);
vlc_object_release
(
vout
);
}
}
else
{
libvlc_exception_raise
(
p_e
,
"No Vout"
);
}
return
;
return
;
}
}
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
if
(
!
marquee
)
if
(
!
marquee
)
{
{
libvlc_exception_raise
(
p_e
,
"Marquee is not enabled"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Marquee not enabled"
);
return
;
return
;
}
}
var_SetInteger
(
marquee
,
identifier
,
value
);
var_SetInteger
(
marquee
,
identifier
,
value
);
...
@@ -794,13 +803,15 @@ void libvlc_video_set_marquee_option_as_string( libvlc_media_player_t *p_mi,
...
@@ -794,13 +803,15 @@ void libvlc_video_set_marquee_option_as_string( libvlc_media_player_t *p_mi,
const
char
*
identifier
=
get_marquee_string_option_identifier
(
option
);
const
char
*
identifier
=
get_marquee_string_option_identifier
(
option
);
if
(
!
identifier
)
if
(
!
identifier
)
{
{
libvlc_exception_raise
(
p_e
,
"This option is not available"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Unknown marquee option"
);
return
;
return
;
}
}
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
vlc_object_t
*
marquee
=
get_marquee_object
(
p_mi
);
if
(
!
marquee
)
if
(
!
marquee
)
{
{
libvlc_exception_raise
(
p_e
,
"Marquee is not enabled"
);
libvlc_exception_raise
(
p_e
);
libvlc_printerr
(
"Marquee not enabled"
);
return
;
return
;
}
}
var_SetString
(
marquee
,
identifier
,
value
);
var_SetString
(
marquee
,
identifier
,
value
);
...
...
src/control/vlm.c
View file @
848c006a
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
#include <vlc_es.h>
#include <vlc_es.h>
#include <vlc_input.h>
#include <vlc_input.h>
#include <vlc_vlm.h>
#include <vlc_vlm.h>
#include <assert.h>
#include "libvlc_internal.h"
#include "libvlc_internal.h"
...
@@ -166,8 +167,8 @@ static int libvlc_vlm_init( libvlc_instance_t *p_instance,
...
@@ -166,8 +167,8 @@ static int libvlc_vlm_init( libvlc_instance_t *p_instance,
p_instance
->
libvlc_vlm
.
p_vlm
=
vlm_New
(
p_instance
->
p_libvlc_int
);
p_instance
->
libvlc_vlm
.
p_vlm
=
vlm_New
(
p_instance
->
p_libvlc_int
);
if
(
!
p_instance
->
libvlc_vlm
.
p_vlm
)
if
(
!
p_instance
->
libvlc_vlm
.
p_vlm
)
{
{
libvlc_exception_raise
(
p_exception
,
libvlc_exception_raise
(
p_exception
);
"Unable to create VLM.
"
);
libvlc_printerr
(
"VLM not supported or out of memory
"
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
var_AddCallback
(
(
vlc_object_t
*
)
p_instance
->
libvlc_vlm
.
p_vlm
,
var_AddCallback
(
(
vlc_object_t
*
)
p_instance
->
libvlc_vlm
.
p_vlm
,
...
@@ -209,8 +210,8 @@ libvlc_vlm_get_media_instance( libvlc_instance_t *p_instance,
...
@@ -209,8 +210,8 @@ libvlc_vlm_get_media_instance( libvlc_instance_t *p_instance,
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_INSTANCES
,
id
,
&
pp_minstance
,
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_INSTANCES
,
id
,
&
pp_minstance
,
&
i_minstance
)
)
&
i_minstance
)
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to get %s instances"
,
libvlc_exception_raise
(
p_exception
);
psz_name
);
libvlc_printerr
(
"%s: media instances not found"
,
psz_name
);
return
NULL
;
return
NULL
;
}
}
p_minstance
=
NULL
;
p_minstance
=
NULL
;
...
@@ -355,44 +356,41 @@ const char* libvlc_vlm_show_media( libvlc_instance_t *p_instance,
...
@@ -355,44 +356,41 @@ const char* libvlc_vlm_show_media( libvlc_instance_t *p_instance,
VLM_RET
(
p_vlm
,
NULL
);
VLM_RET
(
p_vlm
,
NULL
);
if
(
psz_name
==
NULL
)
assert
(
psz_name
);
if
(
asprintf
(
&
psz_message
,
"show %s"
,
psz_name
)
==
-
1
)
{
{
libvlc_exception_raise
(
p_exception
,
"No media name supplied"
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Not enough memory"
);
return
NULL
;
}
}
else
if
(
asprintf
(
&
psz_message
,
"show %s"
,
psz_name
)
==
-
1
)
vlm_ExecuteCommand
(
p_vlm
,
psz_message
,
&
answer
);
if
(
answer
->
psz_value
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to call show %s"
,
libvlc_exception_raise
(
p_exception
);
psz_name
);
libvlc_printerr
(
"Unable to call show %s: %s"
,
psz_name
,
answer
->
psz_value
);
}
}
else
else
if
(
answer
->
child
)
{
{
/* in case everything was requested */
vlm_ExecuteCommand
(
p_vlm
,
psz_message
,
&
answer
);
if
(
strcmp
(
psz_name
,
""
)
==
0
)
if
(
answer
->
psz_value
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to call show %s: %s"
,
psz_fmt
=
"{
\n\t
%s
\n
}
\n
"
;
psz_name
,
answer
->
psz_value
);
psz_delimiter
=
"
\n\t
"
;
i_list
=
0
;
}
}
else
if
(
answer
->
child
)
{
else
/* in case everything was requested */
{
if
(
strcmp
(
psz_name
,
""
)
==
0
)
psz_fmt
=
"%s
\n
"
;
{
psz_delimiter
=
"
\n
"
;
psz_fmt
=
"{
\n\t
%s
\n
}
\n
"
;
i_list
=
1
;
psz_delimiter
=
"
\n\t
"
;
}
i_list
=
0
;
if
(
asprintf
(
&
psz_response
,
psz_fmt
,
}
recurse_answer
(
answer
,
psz_delimiter
,
i_list
)
)
==
-
1
)
else
{
{
libvlc_exception_raise
(
p_exception
);
psz_fmt
=
"%s
\n
"
;
libvlc_printerr
(
"Out of memory"
);
psz_delimiter
=
"
\n
"
;
i_list
=
1
;
}
if
(
asprintf
(
&
psz_response
,
psz_fmt
,
recurse_answer
(
answer
,
psz_delimiter
,
i_list
)
)
==
-
1
)
{
libvlc_exception_raise
(
p_exception
,
"Error in show %s"
,
psz_name
);
}
}
}
}
}
free
(
psz_message
);
free
(
psz_message
);
...
@@ -429,8 +427,10 @@ void libvlc_vlm_add_broadcast( libvlc_instance_t *p_instance,
...
@@ -429,8 +427,10 @@ void libvlc_vlm_add_broadcast( libvlc_instance_t *p_instance,
n
=
vlm_Control
(
p_vlm
,
VLM_ADD_MEDIA
,
&
m
,
NULL
);
n
=
vlm_Control
(
p_vlm
,
VLM_ADD_MEDIA
,
&
m
,
NULL
);
vlm_media_Clean
(
&
m
);
vlm_media_Clean
(
&
m
);
if
(
n
)
if
(
n
)
libvlc_exception_raise
(
p_exception
,
"Media %s creation failed"
,
{
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Media %s creation failed"
,
psz_name
);
}
}
}
void
libvlc_vlm_add_vod
(
libvlc_instance_t
*
p_instance
,
const
char
*
psz_name
,
void
libvlc_vlm_add_vod
(
libvlc_instance_t
*
p_instance
,
const
char
*
psz_name
,
...
@@ -457,8 +457,10 @@ void libvlc_vlm_add_vod( libvlc_instance_t *p_instance, const char *psz_name,
...
@@ -457,8 +457,10 @@ void libvlc_vlm_add_vod( libvlc_instance_t *p_instance, const char *psz_name,
n
=
vlm_Control
(
p_vlm
,
VLM_ADD_MEDIA
,
&
m
,
NULL
);
n
=
vlm_Control
(
p_vlm
,
VLM_ADD_MEDIA
,
&
m
,
NULL
);
vlm_media_Clean
(
&
m
);
vlm_media_Clean
(
&
m
);
if
(
n
)
if
(
n
)
libvlc_exception_raise
(
p_exception
,
"Media %s creation failed"
,
{
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Media %s creation failed"
,
psz_name
);
}
}
}
void
libvlc_vlm_del_media
(
libvlc_instance_t
*
p_instance
,
const
char
*
psz_name
,
void
libvlc_vlm_del_media
(
libvlc_instance_t
*
p_instance
,
const
char
*
psz_name
,
...
@@ -472,7 +474,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
...
@@ -472,7 +474,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
vlm_Control
(
p_vlm
,
VLM_DEL_MEDIA
,
id
)
)
vlm_Control
(
p_vlm
,
VLM_DEL_MEDIA
,
id
)
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to delete %s"
,
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Unable to delete %s"
,
psz_name
);
}
}
}
}
...
@@ -483,7 +486,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
...
@@ -483,7 +486,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
VLM(p_vlm); \
VLM(p_vlm); \
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) || \
if( vlm_Control( p_vlm, VLM_GET_MEDIA_ID, psz_name, &id ) || \
vlm_Control( p_vlm, VLM_GET_MEDIA, id, &p_media ) ) { \
vlm_Control( p_vlm, VLM_GET_MEDIA, id, &p_media ) ) { \
libvlc_exception_raise( p_exception, psz_error, psz_name ); \
libvlc_exception_raise( p_exception ); \
libvlc_printerr( psz_error, psz_name ); \
return; \
return; \
} \
} \
if( !p_media ) goto error; \
if( !p_media ) goto error; \
...
@@ -497,7 +501,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
...
@@ -497,7 +501,8 @@ void libvlc_vlm_del_media( libvlc_instance_t *p_instance, const char *psz_name,
vlm_media_Delete( p_media ); \
vlm_media_Delete( p_media ); \
return; \
return; \
error: \
error: \
libvlc_exception_raise( p_exception, psz_error, psz_name );\
libvlc_exception_raise( p_exception ); \
libvlc_printerr( psz_error, psz_name ); \
} while(0)
} while(0)
void
libvlc_vlm_set_enabled
(
libvlc_instance_t
*
p_instance
,
void
libvlc_vlm_set_enabled
(
libvlc_instance_t
*
p_instance
,
...
@@ -598,7 +603,8 @@ void libvlc_vlm_play_media( libvlc_instance_t *p_instance,
...
@@ -598,7 +603,8 @@ void libvlc_vlm_play_media( libvlc_instance_t *p_instance,
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
vlm_Control
(
p_vlm
,
VLM_START_MEDIA_BROADCAST_INSTANCE
,
id
,
NULL
,
0
)
)
vlm_Control
(
p_vlm
,
VLM_START_MEDIA_BROADCAST_INSTANCE
,
id
,
NULL
,
0
)
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to play %s"
,
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Unable to play %s"
,
psz_name
);
}
}
}
}
...
@@ -614,7 +620,8 @@ void libvlc_vlm_stop_media( libvlc_instance_t *p_instance,
...
@@ -614,7 +620,8 @@ void libvlc_vlm_stop_media( libvlc_instance_t *p_instance,
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
vlm_Control
(
p_vlm
,
VLM_STOP_MEDIA_INSTANCE
,
id
,
NULL
)
)
vlm_Control
(
p_vlm
,
VLM_STOP_MEDIA_INSTANCE
,
id
,
NULL
)
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to stop %s"
,
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Unable to stop %s"
,
psz_name
);
}
}
}
}
...
@@ -630,7 +637,8 @@ void libvlc_vlm_pause_media( libvlc_instance_t *p_instance,
...
@@ -630,7 +637,8 @@ void libvlc_vlm_pause_media( libvlc_instance_t *p_instance,
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
vlm_Control
(
p_vlm
,
VLM_PAUSE_MEDIA_INSTANCE
,
id
,
NULL
)
)
vlm_Control
(
p_vlm
,
VLM_PAUSE_MEDIA_INSTANCE
,
id
,
NULL
)
)
{
{
libvlc_exception_raise
(
p_exception
,
"Unable to pause %s"
,
psz_name
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Unable to pause %s"
,
psz_name
);
}
}
}
}
...
@@ -646,8 +654,10 @@ void libvlc_vlm_seek_media( libvlc_instance_t *p_instance,
...
@@ -646,8 +654,10 @@ void libvlc_vlm_seek_media( libvlc_instance_t *p_instance,
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
if
(
vlm_Control
(
p_vlm
,
VLM_GET_MEDIA_ID
,
psz_name
,
&
id
)
||
vlm_Control
(
p_vlm
,
VLM_SET_MEDIA_INSTANCE_POSITION
,
id
,
NULL
,
vlm_Control
(
p_vlm
,
VLM_SET_MEDIA_INSTANCE_POSITION
,
id
,
NULL
,
f_percentage
)
)
f_percentage
)
)
libvlc_exception_raise
(
p_exception
,
"Unable to seek %s to %f"
,
{
psz_name
,
f_percentage
);
libvlc_exception_raise
(
p_exception
);
libvlc_printerr
(
"Unable to seek %s to %f%%"
,
psz_name
,
f_percentage
);
}
}
}
float
libvlc_vlm_get_media_instance_position
(
libvlc_instance_t
*
p_instance
,
float
libvlc_vlm_get_media_instance_position
(
libvlc_instance_t
*
p_instance
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment