1 /*****************************************************************************
2 * playlist_internal.h : Playlist internals
3 *****************************************************************************
4 * Copyright (C) 1999-2008 VLC authors and VideoLAN
7 * Authors: Samuel Hocevar <sam@zoy.org>
8 * Clément Stenac <zorglub@videolan.org>
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU Lesser General Public License as published by
12 * the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 #ifndef __LIBVLC_PLAYLIST_INTERNAL_H
26 # define __LIBVLC_PLAYLIST_INTERNAL_H 1
30 * This file contain internal structures and function prototypes related
31 * to the playlist in vlc
33 * \defgroup vlc_playlist Playlist
37 #include "input/input_interface.h"
42 #include "preparser.h"
44 typedef struct vlc_sd_internal_t vlc_sd_internal_t
;
46 typedef struct playlist_private_t
48 playlist_t public_data
;
49 playlist_preparser_t
*p_preparser
; /**< Preparser data */
50 playlist_fetcher_t
*p_fetcher
; /**< Meta and art fetcher data */
52 playlist_item_array_t items_to_delete
; /**< Array of items and nodes to
53 delete... At the very end. This sucks. */
55 vlc_sd_internal_t
**pp_sds
;
56 int i_sds
; /**< Number of service discovery modules */
57 input_thread_t
* p_input
; /**< the input thread associated
58 * with the current item */
59 input_resource_t
* p_input_resource
; /**< input resources */
61 /* Current status. These fields are readonly, only the playlist
62 * main loop can touch it*/
63 playlist_status_t i_status
; /**< Current status of playlist */
64 playlist_item_t
* p_item
; /**< Currently playing/active item */
65 playlist_item_t
* p_node
; /**< Current node to play from */
69 /* Request. Use this to give orders to the playlist main loop */
70 playlist_status_t i_status
; /**< requested playlist status */
71 playlist_item_t
* p_node
; /**< requested node to play from */
72 playlist_item_t
* p_item
; /**< requested item to play in the node */
74 int i_skip
; /**< Number of items to skip */
76 bool b_request
;/**< Set to true by the requester
77 The playlist sets it back to false
78 when processing the request */
79 vlc_mutex_t lock
; /**< Lock to protect request */
82 vlc_thread_t thread
; /**< engine thread */
83 vlc_mutex_t lock
; /**< dah big playlist global lock */
84 vlc_cond_t signal
; /**< wakes up the playlist engine thread */
85 bool killed
; /**< playlist is shutting down */
87 int i_last_playlist_id
; /**< Last id to an item */
88 bool b_reset_currently_playing
; /** Reset current item array */
90 bool b_tree
; /**< Display as a tree */
91 bool b_doing_ml
; /**< Doing media library stuff get quicker */
95 #define pl_priv( pl ) ((playlist_private_t *)(pl))
97 /*****************************************************************************
99 *****************************************************************************/
101 /* Creation/Deletion */
102 void playlist_Destroy( playlist_t
* );
103 void playlist_Activate( playlist_t
* );
106 playlist_item_t
*playlist_ItemNewFromInput( playlist_t
*p_playlist
,
107 input_item_t
*p_input
);
110 playlist_item_t
* get_current_status_item( playlist_t
* p_playlist
);
111 playlist_item_t
* get_current_status_node( playlist_t
* p_playlist
);
112 void set_current_status_item( playlist_t
*, playlist_item_t
* );
113 void set_current_status_node( playlist_t
*, playlist_item_t
* );
116 int playlist_MLLoad( playlist_t
*p_playlist
);
117 int playlist_MLDump( playlist_t
*p_playlist
);
119 /**********************************************************************
121 **********************************************************************/
123 void playlist_SendAddNotify( playlist_t
*p_playlist
, int i_item_id
,
124 int i_node_id
, bool b_signal
);
126 playlist_item_t
* playlist_NodeAddInput( playlist_t
*, input_item_t
*,
127 playlist_item_t
*,int , int, bool );
129 int playlist_InsertInputItemTree ( playlist_t
*,
130 playlist_item_t
*, input_item_node_t
*, int, bool );
133 playlist_item_t
*playlist_ItemFindFromInputAndRoot( playlist_t
*p_playlist
,
134 input_item_t
*p_input
, playlist_item_t
*p_root
,
137 int playlist_DeleteFromInputInParent( playlist_t
*, input_item_t
*,
138 playlist_item_t
*, bool );
139 int playlist_DeleteFromItemId( playlist_t
*, int );
140 int playlist_ItemRelease( playlist_item_t
* );
142 int playlist_NodeEmpty( playlist_t
*, playlist_item_t
*, bool );
143 int playlist_DeleteItem( playlist_t
* p_playlist
, playlist_item_t
*, bool);
145 void ResetCurrentlyPlaying( playlist_t
*p_playlist
, playlist_item_t
*p_cur
);
146 void ResyncCurrentIndex( playlist_t
*p_playlist
, playlist_item_t
*p_cur
);
152 #define PLAYLIST_DEBUG 1
153 //#undef PLAYLIST_DEBUG2
155 #ifdef PLAYLIST_DEBUG
156 #define PL_DEBUG( ... ) msg_Dbg( p_playlist, __VA_ARGS__ )
157 #ifdef PLAYLIST_DEBUG2
158 #define PL_DEBUG2( msg, ... ) msg_Dbg( p_playlist, __VA_ARGS__ )
160 #define PL_DEBUG2( msg, ... ) {}
163 #define PL_DEBUG( msg, ... ) {}
164 #define PL_DEBUG2( msg, ... ) {}
167 #define PLI_NAME( p ) p && p->p_input ? p->p_input->psz_name : "null"
169 #define PL_LOCK_IF( cond ) pl_lock_if( p_playlist, cond )
170 static inline void pl_lock_if( playlist_t
* p_playlist
, bool cond
)
172 if( cond
) PL_LOCK
; else PL_ASSERT_LOCKED
;
175 #define PL_UNLOCK_IF( cond ) pl_unlock_if( p_playlist, cond )
176 static inline void pl_unlock_if( playlist_t
* p_playlist
, bool cond
)
178 if( cond
) PL_UNLOCK
;
181 #endif /* !__LIBVLC_PLAYLIST_INTERNAL_H */