Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-1.1
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-1.1
Commits
b94d6502
Commit
b94d6502
authored
Aug 12, 2008
by
Pierre d'Herbemont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
playlist: More warning fix+lock fixes.
parent
8b783e2c
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
4 deletions
+14
-4
src/playlist/item.c
src/playlist/item.c
+14
-4
No files found.
src/playlist/item.c
View file @
b94d6502
...
@@ -231,6 +231,7 @@ static int DeleteFromInput( playlist_t *p_playlist, int i_input_id,
...
@@ -231,6 +231,7 @@ static int DeleteFromInput( playlist_t *p_playlist, int i_input_id,
playlist_item_t
*
p_root
,
bool
b_do_stop
)
playlist_item_t
*
p_root
,
bool
b_do_stop
)
{
{
int
i
;
int
i
;
PL_ASSERT_LOCKED
;
for
(
i
=
0
;
i
<
p_root
->
i_children
;
i
++
)
for
(
i
=
0
;
i
<
p_root
->
i_children
;
i
++
)
{
{
if
(
p_root
->
pp_children
[
i
]
->
i_children
==
-
1
&&
if
(
p_root
->
pp_children
[
i
]
->
i_children
==
-
1
&&
...
@@ -319,6 +320,7 @@ void playlist_Clear( playlist_t * p_playlist, bool b_locked )
...
@@ -319,6 +320,7 @@ void playlist_Clear( playlist_t * p_playlist, bool b_locked )
*/
*/
int
playlist_DeleteFromItemId
(
playlist_t
*
p_playlist
,
int
i_id
)
int
playlist_DeleteFromItemId
(
playlist_t
*
p_playlist
,
int
i_id
)
{
{
PL_ASSERT_LOCKED
;
playlist_item_t
*
p_item
=
playlist_ItemGetById
(
p_playlist
,
i_id
,
playlist_item_t
*
p_item
=
playlist_ItemGetById
(
p_playlist
,
i_id
,
pl_Locked
);
pl_Locked
);
if
(
!
p_item
)
return
VLC_EGENERIC
;
if
(
!
p_item
)
return
VLC_EGENERIC
;
...
@@ -690,6 +692,8 @@ int playlist_TreeMove( playlist_t * p_playlist, playlist_item_t *p_item,
...
@@ -690,6 +692,8 @@ int playlist_TreeMove( playlist_t * p_playlist, playlist_item_t *p_item,
playlist_item_t
*
p_node
,
int
i_newpos
)
playlist_item_t
*
p_node
,
int
i_newpos
)
{
{
int
i_ret
;
int
i_ret
;
PL_ASSERT_LOCKED
;
/* Drop on a top level node. Move in the two trees */
/* Drop on a top level node. Move in the two trees */
if
(
p_node
->
p_parent
==
p_playlist
->
p_root_category
||
if
(
p_node
->
p_parent
==
p_playlist
->
p_root_category
||
p_node
->
p_parent
==
p_playlist
->
p_root_onelevel
)
p_node
->
p_parent
==
p_playlist
->
p_root_onelevel
)
...
@@ -732,7 +736,7 @@ int playlist_TreeMove( playlist_t * p_playlist, playlist_item_t *p_item,
...
@@ -732,7 +736,7 @@ int playlist_TreeMove( playlist_t * p_playlist, playlist_item_t *p_item,
else
else
i_ret
=
TreeMove
(
p_playlist
,
p_item
,
p_node
,
i_newpos
);
i_ret
=
TreeMove
(
p_playlist
,
p_item
,
p_node
,
i_newpos
);
p_playlist
->
b_reset_currently_playing
=
true
;
p_playlist
->
b_reset_currently_playing
=
true
;
vlc_object_signal_
maybe
(
VLC_OBJECT
(
p_playlist
)
);
vlc_object_signal_
unlocked
(
p_playlist
);
return
i_ret
;
return
i_ret
;
}
}
...
@@ -749,6 +753,8 @@ void playlist_SendAddNotify( playlist_t *p_playlist, int i_item_id,
...
@@ -749,6 +753,8 @@ void playlist_SendAddNotify( playlist_t *p_playlist, int i_item_id,
int
i_node_id
,
bool
b_signal
)
int
i_node_id
,
bool
b_signal
)
{
{
vlc_value_t
val
;
vlc_value_t
val
;
PL_ASSERT_LOCKED
;
playlist_add_t
*
p_add
=
(
playlist_add_t
*
)
malloc
(
sizeof
(
playlist_add_t
)
);
playlist_add_t
*
p_add
=
(
playlist_add_t
*
)
malloc
(
sizeof
(
playlist_add_t
)
);
if
(
!
p_add
)
if
(
!
p_add
)
return
;
return
;
...
@@ -758,7 +764,8 @@ void playlist_SendAddNotify( playlist_t *p_playlist, int i_item_id,
...
@@ -758,7 +764,8 @@ void playlist_SendAddNotify( playlist_t *p_playlist, int i_item_id,
val
.
p_address
=
p_add
;
val
.
p_address
=
p_add
;
p_playlist
->
b_reset_currently_playing
=
true
;
p_playlist
->
b_reset_currently_playing
=
true
;
if
(
b_signal
)
if
(
b_signal
)
vlc_object_signal_maybe
(
VLC_OBJECT
(
p_playlist
)
);
vlc_object_signal_unlocked
(
p_playlist
);
var_Set
(
p_playlist
,
"item-append"
,
val
);
var_Set
(
p_playlist
,
"item-append"
,
val
);
free
(
p_add
);
free
(
p_add
);
}
}
...
@@ -793,6 +800,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
...
@@ -793,6 +800,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
playlist_item_t
*
p_item_cat
,
playlist_item_t
*
p_item_cat
,
playlist_item_t
*
p_item_one
)
playlist_item_t
*
p_item_one
)
{
{
PL_ASSERT_LOCKED
;
if
(
(
i_mode
&
PLAYLIST_GO
)
)
if
(
(
i_mode
&
PLAYLIST_GO
)
)
{
{
playlist_item_t
*
p_parent
=
p_item_one
;
playlist_item_t
*
p_parent
=
p_item_one
;
...
@@ -816,7 +824,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
...
@@ -816,7 +824,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
if
(
p_playlist
->
p_input
)
if
(
p_playlist
->
p_input
)
input_StopThread
(
p_playlist
->
p_input
);
input_StopThread
(
p_playlist
->
p_input
);
p_playlist
->
request
.
i_status
=
PLAYLIST_RUNNING
;
p_playlist
->
request
.
i_status
=
PLAYLIST_RUNNING
;
vlc_object_signal_
maybe
(
VLC_OBJECT
(
p_playlist
)
);
vlc_object_signal_
unlocked
(
p_playlist
);
}
}
/* Preparse if PREPARSE or SPREPARSE & not enough meta */
/* Preparse if PREPARSE or SPREPARSE & not enough meta */
char
*
psz_artist
=
input_item_GetArtist
(
p_item_cat
->
p_input
);
char
*
psz_artist
=
input_item_GetArtist
(
p_item_cat
->
p_input
);
...
@@ -838,6 +846,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
...
@@ -838,6 +846,7 @@ static void GoAndPreparse( playlist_t *p_playlist, int i_mode,
static
void
AddItem
(
playlist_t
*
p_playlist
,
playlist_item_t
*
p_item
,
static
void
AddItem
(
playlist_t
*
p_playlist
,
playlist_item_t
*
p_item
,
playlist_item_t
*
p_node
,
int
i_mode
,
int
i_pos
)
playlist_item_t
*
p_node
,
int
i_mode
,
int
i_pos
)
{
{
PL_ASSERT_LOCKED
;
ARRAY_APPEND
(
p_playlist
->
items
,
p_item
);
ARRAY_APPEND
(
p_playlist
->
items
,
p_item
);
ARRAY_APPEND
(
p_playlist
->
all_items
,
p_item
);
ARRAY_APPEND
(
p_playlist
->
all_items
,
p_item
);
...
@@ -870,6 +879,7 @@ static int DeleteInner( playlist_t * p_playlist, playlist_item_t *p_item,
...
@@ -870,6 +879,7 @@ static int DeleteInner( playlist_t * p_playlist, playlist_item_t *p_item,
{
{
int
i
;
int
i
;
int
i_id
=
p_item
->
i_id
;
int
i_id
=
p_item
->
i_id
;
PL_ASSERT_LOCKED
;
if
(
p_item
->
i_children
>
-
1
)
if
(
p_item
->
i_children
>
-
1
)
{
{
...
@@ -897,7 +907,7 @@ static int DeleteInner( playlist_t * p_playlist, playlist_item_t *p_item,
...
@@ -897,7 +907,7 @@ static int DeleteInner( playlist_t * p_playlist, playlist_item_t *p_item,
p_playlist
->
request
.
b_request
=
true
;
p_playlist
->
request
.
b_request
=
true
;
p_playlist
->
request
.
p_item
=
NULL
;
p_playlist
->
request
.
p_item
=
NULL
;
msg_Info
(
p_playlist
,
"stopping playback"
);
msg_Info
(
p_playlist
,
"stopping playback"
);
vlc_object_signal_
maybe
(
VLC_OBJECT
(
p_playlist
)
);
vlc_object_signal_
unlocked
(
VLC_OBJECT
(
p_playlist
)
);
}
}
}
}
...
...
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