Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
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-2-2
Commits
65537488
Commit
65537488
authored
Aug 19, 2009
by
Pierre d'Herbemont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
media_list_player: Use stop() so that we don't lock twice.
parent
ce14fcec
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
7 deletions
+28
-7
src/control/media_list_player.c
src/control/media_list_player.c
+28
-7
No files found.
src/control/media_list_player.c
View file @
65537488
...
@@ -76,6 +76,7 @@ static inline void vlc_assert_locked(vlc_mutex_t *mutex)
...
@@ -76,6 +76,7 @@ static inline void vlc_assert_locked(vlc_mutex_t *mutex)
*/
*/
static
void
next
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
);
static
void
next
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
);
static
void
stop
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
);
/*
/*
* Private functions
* Private functions
...
@@ -210,15 +211,19 @@ mlist_item_deleted(const libvlc_event_t * p_event, void * p_user_data)
...
@@ -210,15 +211,19 @@ mlist_item_deleted(const libvlc_event_t * p_event, void * p_user_data)
{
{
libvlc_media_list_player_t
*
p_mlp
=
p_user_data
;
libvlc_media_list_player_t
*
p_mlp
=
p_user_data
;
libvlc_media_list_t
*
p_emitting_mlist
=
p_event
->
p_obj
;
libvlc_media_list_t
*
p_emitting_mlist
=
p_event
->
p_obj
;
libvlc_media_t
*
p_current_md
;
libvlc_media_t
*
p_current_md
=
NULL
;
lock
(
p_mlp
);
if
(
p_mlp
->
current_playing_item_path
)
p_current_md
=
libvlc_media_list_item_at_path
(
p_mlp
->
p_mlist
,
p_mlp
->
current_playing_item_path
);
p_current_md
=
libvlc_media_list_item_at_path
(
p_mlp
->
p_mlist
,
p_mlp
->
current_playing_item_path
);
if
(
p_event
->
u
.
media_list_item_deleted
.
item
==
p_current_md
&&
if
(
p_event
->
u
.
media_list_item_deleted
.
item
==
p_current_md
&&
p_emitting_mlist
==
p_mlp
->
p_mlist
)
p_emitting_mlist
==
p_mlp
->
p_mlist
)
{
{
/* We are playing this item, let's stop */
/* We are playing this item, let's stop */
libvlc_media_list_player_
stop
(
p_mlp
,
NULL
);
stop
(
p_mlp
,
NULL
);
}
}
unlock
(
p_mlp
);
}
}
...
@@ -296,6 +301,9 @@ set_current_playing_item(libvlc_media_list_player_t * p_mlp, libvlc_media_list_p
...
@@ -296,6 +301,9 @@ set_current_playing_item(libvlc_media_list_player_t * p_mlp, libvlc_media_list_p
p_mlp
->
current_playing_item_path
=
path
;
p_mlp
->
current_playing_item_path
=
path
;
}
}
if
(
!
path
)
return
;
libvlc_media_t
*
p_md
;
libvlc_media_t
*
p_md
;
p_md
=
libvlc_media_list_item_at_path
(
p_mlp
->
p_mlist
,
path
);
p_md
=
libvlc_media_list_item_at_path
(
p_mlp
->
p_mlist
,
path
);
if
(
!
p_md
)
if
(
!
p_md
)
...
@@ -508,11 +516,13 @@ void libvlc_media_list_player_play_item(libvlc_media_list_player_t * p_mlp, libv
...
@@ -508,11 +516,13 @@ void libvlc_media_list_player_play_item(libvlc_media_list_player_t * p_mlp, libv
}
}
/**************************************************************************
/**************************************************************************
* Stop (Public)
* Stop (Private)
*
* Lock must be held.
**************************************************************************/
**************************************************************************/
void
libvlc_media_list_player_
stop
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
)
static
void
stop
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
)
{
{
lock
(
p_mlp
);
assert_locked
(
p_mlp
);
if
(
p_mlp
->
p_mi
&&
p_mlp
->
current_playing_item_path
)
if
(
p_mlp
->
p_mi
&&
p_mlp
->
current_playing_item_path
)
{
{
...
@@ -524,11 +534,22 @@ void libvlc_media_list_player_stop(libvlc_media_list_player_t * p_mlp, libvlc_ex
...
@@ -524,11 +534,22 @@ void libvlc_media_list_player_stop(libvlc_media_list_player_t * p_mlp, libvlc_ex
free
(
p_mlp
->
current_playing_item_path
);
free
(
p_mlp
->
current_playing_item_path
);
p_mlp
->
current_playing_item_path
=
NULL
;
p_mlp
->
current_playing_item_path
=
NULL
;
}
/**************************************************************************
* Stop (Public)
**************************************************************************/
void
libvlc_media_list_player_stop
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
)
{
lock
(
p_mlp
);
stop
(
p_mlp
,
p_e
);
unlock
(
p_mlp
);
unlock
(
p_mlp
);
}
}
/**************************************************************************
/**************************************************************************
* Next (Private)
* Next (Private)
*
* Lock must be held.
**************************************************************************/
**************************************************************************/
static
void
next
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
)
static
void
next
(
libvlc_media_list_player_t
*
p_mlp
,
libvlc_exception_t
*
p_e
)
{
{
...
@@ -554,7 +575,7 @@ static void next(libvlc_media_list_player_t * p_mlp, libvlc_exception_t * p_e)
...
@@ -554,7 +575,7 @@ static void next(libvlc_media_list_player_t * p_mlp, libvlc_exception_t * p_e)
if
(
!
path
)
if
(
!
path
)
{
{
libvlc_media_list_unlock
(
p_mlp
->
p_mlist
);
libvlc_media_list_unlock
(
p_mlp
->
p_mlist
);
libvlc_media_list_player_
stop
(
p_mlp
,
p_e
);
stop
(
p_mlp
,
p_e
);
return
;
return
;
}
}
...
...
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