playtree.cpp 6.09 KB
Newer Older
1
2
3
4
/*****************************************************************************
 * playtree.cpp
 *****************************************************************************
 * Copyright (C) 2005 VideoLAN
zorglub's avatar
zorglub committed
5
 * $Id$
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
 *
 * Authors: Antoine Cellerier <dionoea@videolan.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
 *****************************************************************************/

#include <vlc/vlc.h>

#include "playtree.hpp"
#include "../utils/ustring.hpp"

#include "charset.h"

31

32
Playtree::Playtree( intf_thread_t *pIntf ): VarTree( pIntf )
33
34
35
36
{
    // Get the VLC playlist object
    m_pPlaylist = pIntf->p_sys->p_playlist;

zorglub's avatar
zorglub committed
37
38
    i_items_to_append = 0;

39
40
41
42
43
44
45
    // Try to guess the current charset
    char *pCharset;
    vlc_current_charset( &pCharset );
    iconvHandle = vlc_iconv_open( "UTF-8", pCharset );
    msg_Dbg( pIntf, "Using character encoding: %s", pCharset );
    free( pCharset );

46
    if( iconvHandle == (vlc_iconv_t) - 1 )
47
48
49
50
51
52
53
54
55
    {
        msg_Warn( pIntf, "Unable to do requested conversion" );
    }

    buildTree();
}

Playtree::~Playtree()
{
56
    if( iconvHandle != (vlc_iconv_t) - 1 ) vlc_iconv_close( iconvHandle );
57
58
59
60
61
    // TODO : check that everything is destroyed
}

void Playtree::delSelected()
{
zorglub's avatar
zorglub committed
62
    Iterator it;
63
    for (it = begin(); it != end() ; it = getNextVisibleItem( it ) )
zorglub's avatar
zorglub committed
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
    {
        if( (*it).m_selected )
        {
            playlist_item_t *p_item = (playlist_item_t *)(it->m_pData);
            if( p_item->i_children == -1 )
            {
                playlist_LockDelete( getIntf()->p_sys->p_playlist,
                                     p_item->input.i_id );
            }
            else
            {
                vlc_mutex_lock( &getIntf()->p_sys->p_playlist->object_lock );
                playlist_NodeDelete( getIntf()->p_sys->p_playlist, p_item,
                                     VLC_TRUE, VLC_FALSE );
                vlc_mutex_unlock( &getIntf()->p_sys->p_playlist->object_lock );
            }
        }
    }
zorglub's avatar
zorglub committed
82
    // TODO: Do this better
83
    buildTree();
zorglub's avatar
zorglub committed
84
85
86
    tree_update descr;
    descr.i_type = 1;
    notify( &descr );
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
}

void Playtree::action( VarTree *pItem )
{
    vlc_mutex_lock( &m_pPlaylist->object_lock );
    VarTree::Iterator it;
    if( pItem->size() )
    {
        it = pItem->begin();
        while( it->size() ) it = it->begin();
    }
    playlist_Control( m_pPlaylist,
                      PLAYLIST_VIEWPLAY,
                      m_pPlaylist->status.i_view,
                      pItem->size()
                          ? (playlist_item_t *)pItem->m_pData
                          : (playlist_item_t *)pItem->parent()->m_pData,
                      pItem->size()
                          ? (playlist_item_t *)it->m_pData
                          : (playlist_item_t *)pItem->m_pData
                    );
    vlc_mutex_unlock( &m_pPlaylist->object_lock );
}

void Playtree::onChange()
{
    buildTree();
zorglub's avatar
zorglub committed
114
115
116
    tree_update descr;
    descr.i_type = 1;
    notify( &descr );
117
118
}

zorglub's avatar
zorglub committed
119
void Playtree::onUpdateItem( int id )
120
{
121
122
    Iterator it = findById( id );
    if( it != end() )
123
    {
124
125
126
127
128
129
130
131
132
133
        // Update the item
        playlist_item_t* pNode = (playlist_item_t*)(it->m_pData);
        UString *pName = new UString( getIntf(), pNode->input.psz_name );
        it->m_cString = UStringPtr( pName );
        it->m_playing = m_pPlaylist->status.p_item == pNode;
    }
    else
    {
        msg_Warn(getIntf(), "Cannot find node with id %d", id );
    }
zorglub's avatar
zorglub committed
134
135
136
137
138
139
140
    tree_update descr;
    descr.i_type = 0;
    notify( &descr );
}

void Playtree::onAppend( playlist_add_t *p_add )
{
zorglub's avatar
zorglub committed
141
142
    i_items_to_append --;

zorglub's avatar
zorglub committed
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
    Iterator node = findById( p_add->i_node );
    if( node != end() )
    {
        Iterator item =  findById( p_add->i_item );
        if( item == end() )
        {
            playlist_item_t *p_item = playlist_ItemGetById(
                                        m_pPlaylist, p_add->i_item );
            if( !p_item ) return;
            UString *pName = new UString( getIntf(), p_item->input.psz_name );
            node->add( p_add->i_item, UStringPtr( pName ),
                      false,false, false, p_item );
        }
    }
    tree_update descr;
    descr.i_id = p_add->i_item;
    descr.i_parent = p_add->i_node;
zorglub's avatar
zorglub committed
160
    descr.b_visible = node->m_expanded;
zorglub's avatar
zorglub committed
161
162
    descr.i_type = 2;
    notify( &descr );
163
164
165
166
167
168
169
170
171
}

void Playtree::buildNode( playlist_item_t *pNode, VarTree &rTree )
{
    for( int i = 0; i < pNode->i_children; i++ )
    {
        UString *pName = new UString( getIntf(),
                                      pNode->pp_children[i]->input.psz_name );
        rTree.add( pNode->pp_children[i]->input.i_id, UStringPtr( pName ),
172
                     false,
173
                     m_pPlaylist->status.p_item == pNode->pp_children[i],
zorglub's avatar
zorglub committed
174
                     false, pNode->pp_children[i] );
175
        if( pNode->pp_children[i]->i_children )
176
        {
177
            buildNode( pNode->pp_children[i], rTree.back() );
178
179
180
181
182
183
184
185
186
        }
    }
}

void Playtree::buildTree()
{
    clear();
    vlc_mutex_lock( &m_pPlaylist->object_lock );

zorglub's avatar
zorglub committed
187
188
    i_items_to_append = 0;

189
190
191
192
193
194
195
196
197
198
199
200
201
202
    playlist_view_t *p_view;
    p_view = playlist_ViewFind( m_pPlaylist, VIEW_CATEGORY );
    /* TODO : let the user chose the view type */

    clear();
    /* XXX : do we need Playlist::clear() instead of VarTree::clear() ? */

    /* Set the root's name */
    UString *pName = new UString( getIntf(), p_view->p_root->input.psz_name );
    m_cString = UStringPtr( pName );

    buildNode( p_view->p_root, *this );

    vlc_mutex_unlock( &m_pPlaylist->object_lock );
203
204
//  What is it ?
//    checkParents( NULL );
205
}
206