Commit ffae5a48 authored by Rafaël Carré's avatar Rafaël Carré

dbus: adds some playlist locking, finish [22423]

parent dcc2727f
...@@ -104,6 +104,7 @@ DBUS_METHOD( PositionGet ) ...@@ -104,6 +104,7 @@ DBUS_METHOD( PositionGet )
dbus_int32_t i_pos; dbus_int32_t i_pos;
playlist_t *p_playlist = pl_Yield( ((vlc_object_t*) p_this) ); playlist_t *p_playlist = pl_Yield( ((vlc_object_t*) p_this) );
PL_LOCK;
input_thread_t *p_input = p_playlist->p_input; input_thread_t *p_input = p_playlist->p_input;
if( !p_input ) if( !p_input )
...@@ -113,6 +114,7 @@ DBUS_METHOD( PositionGet ) ...@@ -113,6 +114,7 @@ DBUS_METHOD( PositionGet )
var_Get( p_input, "time", &position ); var_Get( p_input, "time", &position );
i_pos = position.i_time / 1000; i_pos = position.i_time / 1000;
} }
PL_UNLOCK;
pl_Release( ((vlc_object_t*) p_this) ); pl_Release( ((vlc_object_t*) p_this) );
ADD_INT32( &i_pos ); ADD_INT32( &i_pos );
REPLY_SEND; REPLY_SEND;
...@@ -141,6 +143,7 @@ DBUS_METHOD( PositionSet ) ...@@ -141,6 +143,7 @@ DBUS_METHOD( PositionSet )
return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
} }
p_playlist = pl_Yield( ((vlc_object_t*) p_this) ); p_playlist = pl_Yield( ((vlc_object_t*) p_this) );
PL_LOCK;
input_thread_t *p_input = p_playlist->p_input; input_thread_t *p_input = p_playlist->p_input;
if( p_input ) if( p_input )
...@@ -148,6 +151,7 @@ DBUS_METHOD( PositionSet ) ...@@ -148,6 +151,7 @@ DBUS_METHOD( PositionSet )
position.i_time = i_pos * 1000; position.i_time = i_pos * 1000;
var_Set( p_input, "time", position ); var_Set( p_input, "time", position );
} }
PL_UNLOCK;
pl_Release( ((vlc_object_t*) p_this) ); pl_Release( ((vlc_object_t*) p_this) );
REPLY_SEND; REPLY_SEND;
} }
...@@ -229,6 +233,7 @@ DBUS_METHOD( GetStatus ) ...@@ -229,6 +233,7 @@ DBUS_METHOD( GetStatus )
vlc_value_t val; vlc_value_t val;
playlist_t *p_playlist = pl_Yield( (vlc_object_t*) p_this ); playlist_t *p_playlist = pl_Yield( (vlc_object_t*) p_this );
PL_LOCK;
input_thread_t *p_input = p_playlist->p_input; input_thread_t *p_input = p_playlist->p_input;
i_status = 2; i_status = 2;
...@@ -241,6 +246,7 @@ DBUS_METHOD( GetStatus ) ...@@ -241,6 +246,7 @@ DBUS_METHOD( GetStatus )
i_status = 0; i_status = 0;
} }
PL_UNLOCK;
pl_Release( p_playlist ); pl_Release( p_playlist );
ADD_INT32( &i_status ); ADD_INT32( &i_status );
...@@ -270,10 +276,10 @@ DBUS_METHOD( GetCurrentMetadata ) ...@@ -270,10 +276,10 @@ DBUS_METHOD( GetCurrentMetadata )
REPLY_INIT; REPLY_INIT;
OUT_ARGUMENTS; OUT_ARGUMENTS;
playlist_t* p_playlist = pl_Yield( (vlc_object_t*) p_this ); playlist_t* p_playlist = pl_Yield( (vlc_object_t*) p_this );
PL_LOCK;
if( p_playlist->status.p_item ) if( p_playlist->status.p_item )
GetInputMeta( p_playlist->status.p_item->p_input, &args ); GetInputMeta( p_playlist->status.p_item->p_input, &args );
PL_UNLOCK;
pl_Release( p_playlist ); pl_Release( p_playlist );
REPLY_SEND; REPLY_SEND;
} }
...@@ -330,20 +336,9 @@ DBUS_METHOD( GetCurrentTrack ) ...@@ -330,20 +336,9 @@ DBUS_METHOD( GetCurrentTrack )
{ {
REPLY_INIT; REPLY_INIT;
OUT_ARGUMENTS; OUT_ARGUMENTS;
/* FIXME 0 indicates the first item,
* what to do if we're stopped, or empty ? */
dbus_int32_t i_position = 0;
playlist_t *p_playlist = pl_Yield( (vlc_object_t*) p_this );
playlist_item_t* p_tested_item = p_playlist->p_root_onelevel;
if( p_playlist->status.p_item ) playlist_t *p_playlist = pl_Yield( (vlc_object_t*) p_this );
while ( p_tested_item && p_tested_item->p_input->i_id != dbus_int32_t i_position = p_playlist->i_current_index;
p_playlist->status.p_item->p_input->i_id )
{
i_position++;
TEST_NEXT_ITEM;
}
/* FIXME if p_tested_item is NULL at that point, what do we do ? */
pl_Release( p_playlist ); pl_Release( p_playlist );
ADD_INT32( &i_position ); ADD_INT32( &i_position );
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment