Mercurial > mplayer.hg
annotate gui/dialog/playlist.c @ 36010:5c720c434d56
Silence "warning: unused parameter".
author | ib |
---|---|
date | Sat, 30 Mar 2013 15:09:51 +0000 |
parents | d154d0035cb0 |
children | 277882d42938 |
rev | line source |
---|---|
33572 | 1 /* |
2 * This file is part of MPlayer. | |
3 * | |
4 * MPlayer is free software; you can redistribute it and/or modify | |
5 * it under the terms of the GNU General Public License as published by | |
6 * the Free Software Foundation; either version 2 of the License, or | |
7 * (at your option) any later version. | |
8 * | |
9 * MPlayer is distributed in the hope that it will be useful, | |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 * GNU General Public License for more details. | |
13 * | |
14 * You should have received a copy of the GNU General Public License along | |
15 * with MPlayer; if not, write to the Free Software Foundation, Inc., | |
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | |
17 */ | |
18 | |
19 #include <sys/types.h> | |
20 #include <sys/stat.h> | |
21 #include <string.h> | |
22 #include <dirent.h> | |
23 #include <unistd.h> | |
24 #include <stdio.h> | |
25 #include <stdlib.h> | |
26 | |
27 #include <gdk/gdkkeysyms.h> | |
28 #include <gtk/gtk.h> | |
29 | |
30 #include "help_mp.h" | |
31 #include "stream/stream.h" | |
32 | |
35525 | 33 #include "gui/app/cfg.h" |
34 #include "gui/app/gui.h" | |
35381
746e2e0577b2
Without current playlist item, reset guiInfo's Filename and StreamType.
ib
parents:
34681
diff
changeset
|
35 #include "gui/interface.h" |
35529 | 36 #include "dialog.h" |
33742
e1539e14d60f
Move purely list related parts of gtkSet() from interface.c to list.c.
ib
parents:
33740
diff
changeset
|
37 #include "gui/util/list.h" |
33739 | 38 #include "gui/util/mem.h" |
35461 | 39 #include "gui/util/string.h" |
33572 | 40 #include "playlist.h" |
41 #include "tools.h" | |
42 | |
35526 | 43 #include "pixmaps/open2.xpm" |
44 #include "pixmaps/dir2.xpm" | |
33572 | 45 |
35872
93ab56bda68a
Utilize new cfg_old_filename_from_utf8() in playlist code.
ib
parents:
35578
diff
changeset
|
46 #define CFG_OLD_PLAYLIST 1 |
93ab56bda68a
Utilize new cfg_old_filename_from_utf8() in playlist code.
ib
parents:
35578
diff
changeset
|
47 #include "gui/app/cfg-old.c" |
93ab56bda68a
Utilize new cfg_old_filename_from_utf8() in playlist code.
ib
parents:
35578
diff
changeset
|
48 |
35981 | 49 GtkWidget * Playlist = NULL; |
33572 | 50 static GtkWidget * CTDirTree; |
51 static GtkWidget * CLFiles; | |
52 static GtkWidget * CLSelected; | |
53 static GtkWidget * Add; | |
54 static GtkWidget * Remove; | |
55 static GtkWidget * Ok; | |
56 static GtkWidget * Cancel; | |
57 static GdkPixmap * pxOpenedBook; | |
58 static GdkPixmap * pxClosedBook; | |
59 static GdkBitmap * msOpenedBook; | |
60 static GdkBitmap * msClosedBook; | |
61 | |
62 static int NrOfEntrys = 0; | |
63 static int NrOfSelected = 0; | |
64 static int * CLFileSelected = NULL; | |
65 static int * CLListSelected = NULL; | |
66 | |
67 static int sigSel; | |
68 static int sigUnsel; | |
69 static int sigEvent; | |
70 | |
71 typedef struct | |
72 { | |
73 int scaned; | |
74 char * path; | |
75 } DirNodeType; | |
76 | |
77 static GtkCTreeNode * sibling; | |
78 static GtkCTreeNode * parent; | |
79 static gchar * current_path; | |
80 static gchar * old_path = NULL; | |
81 | |
82 static int compare_func(const void *a, const void *b) | |
83 { | |
84 char * tmp; | |
85 int i; | |
86 if ( !a || !b || !( (DirNodeType *)a )->path ) return -1; | |
87 tmp=strdup( (char *)b ); tmp[strlen( tmp )-1]=0; | |
88 i=strcmp( ( (DirNodeType *)a )->path,tmp ); | |
89 free( tmp ); | |
90 return i; | |
91 } | |
92 | |
93 static void plRowSelect( GtkCList * clist,gint row,gint column,GdkEvent * event,gpointer user_data ) | |
94 { | |
36010 | 95 (void) clist; |
96 (void) column; | |
97 (void) event; | |
98 | |
33572 | 99 switch ( (int) user_data ) |
100 { | |
35493 | 101 case 0: CLFileSelected[row]=True; break; |
102 case 1: CLListSelected[row]=True; break; | |
33572 | 103 } |
104 } | |
105 | |
106 static void plUnRowSelect( GtkCList * clist,gint row,gint column,GdkEvent * event,gpointer user_data ) | |
107 { | |
36010 | 108 (void) clist; |
109 (void) column; | |
110 (void) event; | |
111 | |
33572 | 112 switch ( (int) user_data ) |
113 { | |
35493 | 114 case 0: CLFileSelected[row]=False; break; |
115 case 1: CLListSelected[row]=False; break; | |
33572 | 116 } |
117 } | |
118 | |
119 static void plButtonReleased( GtkButton * button,gpointer user_data ) | |
120 { | |
36010 | 121 (void) button; |
122 | |
33572 | 123 switch ( (int) user_data ) |
124 { | |
125 case 1: // ok | |
126 { | |
35572
0827fa4c3401
While playing, allow extensive editing of the playlist without stopping.
ib
parents:
35554
diff
changeset
|
127 int i; |
35461 | 128 plItem curr, * item, * old; |
129 item = listMgr( PLAYLIST_ITEM_GET_CURR,0 ); | |
130 if (item) | |
131 { | |
132 curr.path = gstrdup(item->path); | |
133 curr.name = gstrdup(item->name); | |
134 } | |
35573 | 135 else |
136 { | |
137 curr.path = NULL; | |
138 curr.name = NULL; | |
139 } | |
34666 | 140 listMgr( PLAYLIST_DELETE,0 ); |
33572 | 141 for ( i=0;i<NrOfSelected;i++ ) |
142 { | |
35927 | 143 char * text[2]; |
33572 | 144 item=calloc( 1,sizeof( plItem ) ); |
35927 | 145 gtk_clist_get_text( GTK_CLIST( CLSelected ),i,2,&text[0] ); |
146 gtk_clist_get_text( GTK_CLIST( CLSelected ),i,3,&text[1] ); | |
147 item->name = strdup( text[0] ); | |
148 item->path = strdup( text[1] ); | |
34681 | 149 listMgr( PLAYLIST_ITEM_APPEND,item ); |
33572 | 150 } |
35461 | 151 item = listMgr( PLAYLIST_GET,0 ); |
34664
4df4d842d5fb
Remove global variable pointing to current playlist item.
ib
parents:
34663
diff
changeset
|
152 if ( item ) |
33572 | 153 { |
35578 | 154 if ( guiInfo.Playing ) |
35461 | 155 { |
156 old = listMgr( PLAYLIST_ITEM_FIND,&curr ); | |
35572
0827fa4c3401
While playing, allow extensive editing of the playlist without stopping.
ib
parents:
35554
diff
changeset
|
157 if ( old ) |
35461 | 158 { |
159 listMgr( PLAYLIST_ITEM_SET_CURR,old ); | |
35572
0827fa4c3401
While playing, allow extensive editing of the playlist without stopping.
ib
parents:
35554
diff
changeset
|
160 guiInfo.Track = (int) listMgr( PLAYLIST_ITEM_GET_POS,old ); |
35461 | 161 item = NULL; |
162 } | |
163 } | |
164 if ( item ) | |
165 { | |
166 uiSetFile( item->path,item->name,STREAMTYPE_FILE ); | |
167 guiInfo.NewPlay = GUI_FILE_NEW; | |
35577 | 168 guiInfo.PlaylistNext = !guiInfo.Playing; |
35461 | 169 guiInfo.Track = 1; |
170 } | |
33572 | 171 } |
35455
c9c79a011f6f
Fix bug with wrong track number after playlist has been cleared.
ib
parents:
35452
diff
changeset
|
172 else if (isPlaylistStreamtype && !guiInfo.Playing) uiUnsetFile(); |
35554 | 173 guiInfo.Tracks = (int) listMgr( PLAYLIST_ITEM_GET_POS,0 ); |
35461 | 174 free(curr.path); |
175 free(curr.name); | |
33572 | 176 } |
177 case 0: // cancel | |
36000 | 178 NrOfSelected=NrOfEntrys=0; |
179 nfree( CLListSelected ); | |
180 nfree( CLFileSelected ); | |
181 free( old_path ); | |
182 old_path=strdup( current_path ); | |
183 gtk_widget_destroy( Playlist ); | |
33572 | 184 break; |
185 case 2: // remove | |
186 { | |
35522 | 187 int i; int j; |
33572 | 188 |
189 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigSel ); | |
190 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigUnsel ); | |
191 gtk_signal_handler_block( GTK_OBJECT( CLSelected ),sigEvent ); | |
192 | |
193 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); | |
35522 | 194 i = 0; |
195 while ( i<NrOfSelected ) | |
196 { | |
33572 | 197 if ( CLListSelected[i] ) |
198 { | |
35522 | 199 gtk_clist_remove( GTK_CLIST( CLSelected ),i ); |
200 NrOfSelected--; | |
201 for ( j=i;j<NrOfSelected;j++ ) | |
202 CLListSelected[j] = CLListSelected[j+1]; | |
33572 | 203 } |
35522 | 204 else i++; |
205 } | |
33572 | 206 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); |
207 | |
208 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigSel ); | |
209 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigUnsel ); | |
210 gtk_signal_handler_unblock( GTK_OBJECT( CLSelected ),sigEvent ); | |
211 | |
212 } | |
213 break; | |
214 case 3: // add | |
215 { | |
216 int i; | |
217 void *p; | |
35927 | 218 char * itext[2]; |
219 char * text[1][5]; text[0][4]=""; | |
33572 | 220 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); |
221 for ( i=0;i<NrOfEntrys;i++ ) | |
222 { | |
223 if ( CLFileSelected[i] ) | |
224 { | |
225 NrOfSelected++; | |
226 p=realloc( CLListSelected,NrOfSelected * sizeof( int ) ); | |
227 if ( !p ) NrOfSelected--; | |
228 else | |
229 { | |
230 CLListSelected=p; | |
35493 | 231 CLListSelected[NrOfSelected - 1]=False; |
35927 | 232 gtk_clist_get_text( GTK_CLIST( CLFiles ),i,0,&itext[0] ); |
233 gtk_clist_get_text( GTK_CLIST( CLFiles ),i,1,&itext[1] ); | |
234 text[0][0]=itext[0]; text[0][1]=g_filename_display_name( current_path ); | |
235 text[0][2]=itext[1]; text[0][3]=current_path; | |
33572 | 236 gtk_clist_append( GTK_CLIST( CLSelected ),text[0] ); |
35927 | 237 g_free( text[0][1] ); |
33572 | 238 } |
239 } | |
240 } | |
241 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); | |
242 } | |
243 break; | |
244 } | |
245 } | |
246 | |
34348 | 247 static gboolean plKeyReleased( GtkWidget * widget, |
248 GdkEventKey * event, | |
249 gpointer user_data ) | |
250 { | |
34349 | 251 if (event->keyval == GDK_Return) |
252 { | |
253 if ( GTK_WIDGET_TYPE( widget ) == GTK_TYPE_BUTTON ) plButtonReleased( NULL, user_data ); | |
254 else | |
255 { | |
256 switch ( (int) user_data ) | |
257 { | |
258 case 0: | |
259 plButtonReleased( NULL, (void *) 3 ); | |
260 break; | |
261 case 1: | |
262 plButtonReleased( NULL, (void *) 2 ); | |
263 break; | |
264 } | |
265 } | |
266 } | |
34348 | 267 return FALSE; |
268 } | |
269 | |
33572 | 270 static gboolean plEvent ( GtkWidget * widget, |
271 GdkEvent * event, | |
272 gpointer user_data ) | |
273 { | |
274 GdkEventButton *bevent; | |
275 gint row, col; | |
276 | |
277 bevent = (GdkEventButton *) event; | |
278 | |
279 if ( event->type == GDK_BUTTON_RELEASE && bevent->button == 2 ) | |
280 { | |
281 if ( gtk_clist_get_selection_info( GTK_CLIST( widget ), bevent->x, bevent->y, &row, &col ) ) | |
282 { | |
283 switch ( (int) user_data ) | |
284 { | |
285 case 0: | |
35493 | 286 CLFileSelected[row] = True; |
33572 | 287 plButtonReleased( NULL, (void *) 3 ); |
35493 | 288 CLFileSelected[row] = False; |
33572 | 289 return TRUE; |
290 | |
291 case 1: | |
35493 | 292 CLListSelected[row] = True; |
33572 | 293 plButtonReleased( NULL, (void *) 2 ); |
294 return TRUE; | |
295 } | |
296 } | |
297 } | |
298 | |
299 return FALSE; | |
300 } | |
301 | |
302 static int check_for_subdir( gchar * path ) | |
303 { | |
304 DIR * dir; | |
305 struct dirent * dirent; | |
306 struct stat statbuf; | |
307 gchar * npath; | |
308 | |
309 if ( (dir=opendir( path )) ) | |
310 { | |
311 while ( (dirent=readdir( dir )) ) | |
312 { | |
313 if ( dirent->d_name[0] != '.' ) | |
314 { | |
315 npath=calloc( 1,strlen( path ) + strlen( dirent->d_name ) + 3 ); | |
316 sprintf( npath,"%s/%s",path,dirent->d_name ); | |
317 if ( stat( npath,&statbuf ) != -1 && S_ISDIR( statbuf.st_mode ) ) | |
35493 | 318 { free( npath ); closedir( dir ); return True; } |
33572 | 319 free( npath ); |
320 } | |
321 } | |
322 closedir( dir ); | |
323 } | |
35493 | 324 return False; |
33572 | 325 } |
326 | |
327 static void plCTree( GtkCTree * ctree,GtkCTreeNode * parent_node,gpointer user_data ) | |
328 { | |
329 GtkCTreeNode * node; | |
330 DirNodeType * DirNode; | |
35938
8515446e81c6
Cosmetic: Rename variables holding data in UTF-8 encoding.
ib
parents:
35927
diff
changeset
|
331 gchar * text, * utf8name = NULL; |
33572 | 332 gchar * dummy = "dummy"; |
35493 | 333 int subdir = True; |
33572 | 334 DIR * dir = NULL; |
335 struct dirent * dirent; | |
336 gchar * path; | |
337 struct stat statbuf; | |
338 | |
36010 | 339 (void) user_data; |
340 | |
33572 | 341 DirNode=gtk_ctree_node_get_row_data( ctree,parent_node ); |
342 if ( !DirNode->scaned ) | |
343 { | |
35493 | 344 DirNode->scaned=True; current_path=DirNode->path; |
33572 | 345 gtk_clist_freeze( GTK_CLIST( ctree ) ); |
346 node=gtk_ctree_find_by_row_data( ctree,parent_node,NULL ); | |
347 gtk_ctree_remove_node( ctree,node ); | |
348 | |
349 if ( (dir=opendir( DirNode->path ) ) ) | |
350 { | |
351 while( (dirent=readdir( dir )) ) | |
352 { | |
353 path=calloc( 1,strlen( DirNode->path ) + strlen( dirent->d_name ) + 2 ); | |
354 if ( !strcmp( current_path,"/" ) ) sprintf( path,"/%s",dirent->d_name ); | |
355 else sprintf( path,"%s/%s",current_path,dirent->d_name ); | |
356 text=dirent->d_name; | |
35938
8515446e81c6
Cosmetic: Rename variables holding data in UTF-8 encoding.
ib
parents:
35927
diff
changeset
|
357 g_free( utf8name ); |
8515446e81c6
Cosmetic: Rename variables holding data in UTF-8 encoding.
ib
parents:
35927
diff
changeset
|
358 utf8name=g_filename_display_name( text ); |
33572 | 359 |
360 if ( stat( path,&statbuf ) != -1 && S_ISDIR( statbuf.st_mode ) && dirent->d_name[0] != '.' ) | |
361 { | |
35493 | 362 DirNode=malloc( sizeof( DirNodeType ) ); DirNode->scaned=False; DirNode->path=strdup( path ); |
33572 | 363 subdir=check_for_subdir( path ); |
35938
8515446e81c6
Cosmetic: Rename variables holding data in UTF-8 encoding.
ib
parents:
35927
diff
changeset
|
364 node=gtk_ctree_insert_node( ctree,parent_node,NULL,&utf8name,4,pxOpenedBook,msOpenedBook,pxClosedBook,msClosedBook,!subdir,FALSE ); |
33572 | 365 gtk_ctree_node_set_row_data_full( ctree,node,DirNode,NULL ); |
35403 | 366 if ( subdir ) gtk_ctree_insert_node( ctree,node,NULL,&dummy,4,NULL,NULL,NULL,NULL,FALSE,FALSE ); |
33572 | 367 } |
368 free( path ); path=NULL; | |
369 } | |
370 closedir( dir ); | |
371 } | |
372 | |
373 gtk_ctree_sort_node( ctree,parent_node ); | |
374 gtk_clist_thaw( GTK_CLIST( ctree ) ); | |
375 } | |
376 | |
35938
8515446e81c6
Cosmetic: Rename variables holding data in UTF-8 encoding.
ib
parents:
35927
diff
changeset
|
377 g_free( utf8name ); |
33572 | 378 } |
379 | |
380 static void scan_dir( char * path ) | |
381 { | |
382 DIR * dir = NULL; | |
383 char * curr; | |
384 struct dirent * dirent; | |
385 struct stat statbuf; | |
35927 | 386 char * text[1][3]; text[0][2]=""; |
33572 | 387 |
388 gtk_clist_clear( GTK_CLIST( CLFiles ) ); | |
389 if ( (dir=opendir( path )) ) | |
390 { | |
391 NrOfEntrys=0; | |
392 while( (dirent=readdir( dir )) ) | |
393 { | |
394 curr=calloc( 1,strlen( path ) + strlen( dirent->d_name ) + 3 ); sprintf( curr,"%s/%s",path,dirent->d_name ); | |
395 if ( stat( curr,&statbuf ) != -1 && ( S_ISREG( statbuf.st_mode ) || S_ISLNK( statbuf.st_mode ) ) ) | |
396 { | |
35927 | 397 text[0][0]=g_filename_display_name( dirent->d_name ); |
398 text[0][1]=dirent->d_name; | |
33572 | 399 gtk_clist_append( GTK_CLIST( CLFiles ), text[0] ); |
35927 | 400 g_free( text[0][0] ); |
33572 | 401 NrOfEntrys++; |
402 } | |
403 free( curr ); | |
404 } | |
405 closedir( dir ); | |
406 gtk_clist_sort( GTK_CLIST( CLFiles ) ); | |
407 } | |
408 } | |
409 | |
34466
a650895d50a5
Use correct data types and common variable names in GTK callback functions.
ib
parents:
34349
diff
changeset
|
410 static void plCTRow(GtkCList * clist, gint row, gint column, GdkEvent * event, gpointer user_data) |
33572 | 411 { |
412 DirNodeType * DirNode; | |
413 GtkCTreeNode * node; | |
36010 | 414 |
415 (void) column; | |
416 (void) event; | |
417 (void) user_data; | |
418 | |
34466
a650895d50a5
Use correct data types and common variable names in GTK callback functions.
ib
parents:
34349
diff
changeset
|
419 node=gtk_ctree_node_nth( GTK_CTREE( clist ),row ); |
a650895d50a5
Use correct data types and common variable names in GTK callback functions.
ib
parents:
34349
diff
changeset
|
420 DirNode=gtk_ctree_node_get_row_data( GTK_CTREE( clist ),node ); |
33572 | 421 current_path=DirNode->path; |
34466
a650895d50a5
Use correct data types and common variable names in GTK callback functions.
ib
parents:
34349
diff
changeset
|
422 gtk_ctree_expand( GTK_CTREE( clist ),node ); |
33572 | 423 scan_dir( DirNode->path ); |
424 free( CLFileSelected ); | |
425 CLFileSelected=calloc( 1,NrOfEntrys * sizeof( int ) ); | |
426 } | |
427 | |
35996 | 428 static GtkWidget * CreatePlaylist( void ) |
33572 | 429 { |
430 GtkWidget * vbox1; | |
431 GtkWidget * hbox1; | |
432 GtkWidget * scrolledwindow1; | |
433 GtkWidget * vbox2; | |
434 GtkWidget * scrolledwindow2; | |
435 GtkWidget * scrolledwindow3; | |
436 GtkWidget * hbuttonbox1; | |
437 GtkAccelGroup * accel_group; | |
438 GdkColor transparent = { 0,0,0,0 }; | |
439 gchar * root = "/"; | |
440 gchar * dummy = "dummy"; | |
441 DirNodeType * DirNode; | |
35963
db72a3183d41
Preselect current playlist directory from last playlist entry.
ib
parents:
35938
diff
changeset
|
442 plItem * last; |
33572 | 443 |
444 accel_group=gtk_accel_group_new(); | |
445 | |
35981 | 446 Playlist=gtk_window_new( GTK_WINDOW_TOPLEVEL ); |
447 gtk_object_set_data( GTK_OBJECT( Playlist ),"PlayList",Playlist ); | |
448 gtk_widget_set_usize( Playlist,512,384 ); | |
449 gtk_window_set_title( GTK_WINDOW( Playlist ),MSGTR_PlayList ); | |
450 gtk_window_set_position( GTK_WINDOW( Playlist ),GTK_WIN_POS_CENTER ); | |
451 // gtk_window_set_policy( GTK_WINDOW( Playlist ),FALSE,FALSE,FALSE ); | |
452 gtk_window_set_wmclass( GTK_WINDOW( Playlist ),"Playlist","MPlayer" ); | |
33572 | 453 |
35981 | 454 gtk_widget_realize( Playlist ); |
455 gtkAddIcon( Playlist ); | |
33572 | 456 |
35981 | 457 vbox1=AddVBox( AddDialogFrame( Playlist ),0 ); |
33572 | 458 hbox1=AddHBox( NULL,1 ); |
459 gtk_box_pack_start( GTK_BOX( vbox1 ),hbox1,TRUE,TRUE,0 ); | |
460 | |
461 scrolledwindow1=gtk_scrolled_window_new( NULL,NULL ); | |
462 gtk_widget_show( scrolledwindow1 ); | |
463 gtk_container_add( GTK_CONTAINER( | |
464 AddFrame( NULL,0,hbox1,1 ) ),scrolledwindow1 ); | |
465 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow1 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
466 | |
467 CTDirTree=gtk_ctree_new( 1,0 ); | |
468 gtk_signal_connect( GTK_OBJECT( CTDirTree ),"tree_expand",GTK_SIGNAL_FUNC( plCTree ),(void*)0 ); | |
469 gtk_signal_connect( GTK_OBJECT( CTDirTree ),"select_row",GTK_SIGNAL_FUNC( plCTRow ),(void *)0 ); | |
470 gtk_container_add( GTK_CONTAINER( scrolledwindow1 ),CTDirTree ); | |
471 gtk_clist_set_column_auto_resize( GTK_CLIST( CTDirTree ),0,TRUE ); | |
472 gtk_clist_set_column_width( GTK_CLIST( CTDirTree ),0,80 ); | |
473 gtk_clist_set_selection_mode( GTK_CLIST( CTDirTree ),GTK_SELECTION_SINGLE ); | |
474 gtk_ctree_set_line_style( GTK_CTREE( CTDirTree ),GTK_CTREE_LINES_SOLID ); | |
475 gtk_clist_column_titles_show( GTK_CLIST( CTDirTree ) ); | |
476 gtk_clist_set_shadow_type( GTK_CLIST( CTDirTree ),GTK_SHADOW_NONE ); | |
477 | |
35981 | 478 if ( !pxOpenedBook ) pxOpenedBook=gdk_pixmap_create_from_xpm_d( Playlist->window,&msOpenedBook,&transparent,(gchar **)dir2_xpm ); |
479 if ( !pxClosedBook ) pxClosedBook=gdk_pixmap_create_from_xpm_d( Playlist->window,&msClosedBook,&transparent,(gchar **)open2_xpm ); | |
33572 | 480 |
481 parent=gtk_ctree_insert_node( GTK_CTREE( CTDirTree ),NULL,NULL,&root,4,pxOpenedBook,msOpenedBook,pxClosedBook,msClosedBook,FALSE,FALSE ); | |
482 DirNode=malloc( sizeof( DirNodeType ) ); | |
35493 | 483 DirNode->scaned=False; DirNode->path=strdup( root ); |
33572 | 484 gtk_ctree_node_set_row_data_full(GTK_CTREE( CTDirTree ),parent,DirNode,NULL ); |
485 sibling=gtk_ctree_insert_node( GTK_CTREE( CTDirTree ),parent,NULL,&dummy,4,NULL,NULL,NULL,NULL,TRUE,TRUE ); | |
486 gtk_ctree_expand( GTK_CTREE( CTDirTree ),parent ); | |
487 gtk_widget_show( CTDirTree ); | |
488 | |
35963
db72a3183d41
Preselect current playlist directory from last playlist entry.
ib
parents:
35938
diff
changeset
|
489 last=listMgr( PLAYLIST_ITEM_GET_LAST,0 ); |
db72a3183d41
Preselect current playlist directory from last playlist entry.
ib
parents:
35938
diff
changeset
|
490 |
db72a3183d41
Preselect current playlist directory from last playlist entry.
ib
parents:
35938
diff
changeset
|
491 if ( last && last->path ) old_path = strdup( last->path ); |
db72a3183d41
Preselect current playlist directory from last playlist entry.
ib
parents:
35938
diff
changeset
|
492 else if ( fsHistory[0] ) old_path = strdup( cfg_old_filename_from_utf8( fsHistory[0] ) ); |
33572 | 493 |
494 gtk_clist_set_column_widget( GTK_CLIST( CTDirTree ),0, | |
495 AddLabel( MSGTR_PLAYLIST_DirectoryTree,NULL ) ); | |
496 | |
34347 | 497 gtk_clist_column_title_passive( GTK_CLIST( CTDirTree ),0 ); |
498 | |
33572 | 499 vbox2=AddVBox( |
500 AddFrame( NULL,1,hbox1,1 ),0 ); | |
501 | |
502 scrolledwindow2=gtk_scrolled_window_new( NULL,NULL ); | |
503 gtk_widget_show( scrolledwindow2 ); | |
504 gtk_box_pack_start( GTK_BOX( vbox2 ),scrolledwindow2,TRUE,TRUE,0 ); | |
505 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow2 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
506 | |
35927 | 507 CLFiles=gtk_clist_new( 2 ); |
33572 | 508 gtk_widget_show( CLFiles ); |
509 gtk_container_add( GTK_CONTAINER( scrolledwindow2 ),CLFiles ); | |
510 gtk_clist_set_column_width( GTK_CLIST( CLFiles ),0,80 ); | |
35927 | 511 gtk_clist_set_column_visibility( GTK_CLIST( CLFiles ),1,FALSE ); |
33572 | 512 gtk_clist_set_selection_mode( GTK_CLIST( CLFiles ),GTK_SELECTION_EXTENDED ); |
513 gtk_clist_column_titles_show( GTK_CLIST( CLFiles ) ); | |
514 gtk_clist_set_shadow_type( GTK_CLIST( CLFiles ),GTK_SHADOW_NONE ); | |
515 | |
516 gtk_clist_set_column_widget( GTK_CLIST( CLFiles ),0, | |
517 AddLabel( MSGTR_PLAYLIST_Files,NULL ) ); | |
518 | |
34347 | 519 gtk_clist_column_title_passive( GTK_CLIST( CLFiles ),0 ); |
520 | |
33572 | 521 AddHSeparator( vbox2 ); |
522 | |
523 scrolledwindow3=gtk_scrolled_window_new( NULL,NULL ); | |
524 gtk_widget_show( scrolledwindow3 ); | |
525 gtk_box_pack_start( GTK_BOX( vbox2 ),scrolledwindow3,TRUE,TRUE,0 ); | |
526 gtk_scrolled_window_set_policy( GTK_SCROLLED_WINDOW( scrolledwindow3 ),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC ); | |
527 | |
35927 | 528 CLSelected=gtk_clist_new( 4 ); |
33572 | 529 gtk_widget_show( CLSelected ); |
530 gtk_container_add( GTK_CONTAINER( scrolledwindow3 ),CLSelected ); | |
531 gtk_clist_set_column_width( GTK_CLIST( CLSelected ),0,295 ); | |
532 gtk_clist_set_column_width( GTK_CLIST( CLSelected ),1,295 ); | |
35927 | 533 gtk_clist_set_column_visibility( GTK_CLIST( CLSelected ),2,FALSE ); |
534 gtk_clist_set_column_visibility( GTK_CLIST( CLSelected ),3,FALSE ); | |
33572 | 535 gtk_clist_set_selection_mode( GTK_CLIST( CLSelected ),GTK_SELECTION_MULTIPLE ); |
536 gtk_clist_column_titles_show( GTK_CLIST( CLSelected ) ); | |
537 gtk_clist_set_shadow_type( GTK_CLIST( CLSelected ),GTK_SHADOW_NONE ); | |
538 | |
539 gtk_clist_set_column_widget( GTK_CLIST( CLSelected ),0, | |
540 AddLabel( MSGTR_PLAYLIST_Selected,NULL ) ); | |
541 | |
542 gtk_clist_set_column_widget( GTK_CLIST( CLSelected ),1, | |
543 AddLabel( MSGTR_PLAYLIST_Path,NULL ) ); | |
544 | |
34347 | 545 gtk_clist_column_title_passive( GTK_CLIST( CLSelected ),0 ); |
546 | |
33572 | 547 AddHSeparator( vbox1 ); |
548 | |
549 hbuttonbox1=AddHButtonBox( vbox1 ); | |
550 gtk_button_box_set_layout( GTK_BUTTON_BOX( hbuttonbox1 ),GTK_BUTTONBOX_END ); | |
551 gtk_button_box_set_spacing( GTK_BUTTON_BOX( hbuttonbox1 ),10 ); | |
552 | |
553 Add=AddButton( MSGTR_Add,hbuttonbox1 ); | |
554 Remove=AddButton( MSGTR_Remove,hbuttonbox1 ); | |
555 Ok=AddButton( MSGTR_Ok,hbuttonbox1 ); | |
556 Cancel=AddButton( MSGTR_Cancel,hbuttonbox1 ); | |
557 | |
558 gtk_widget_add_accelerator( Cancel,"clicked",accel_group,GDK_Escape,0,GTK_ACCEL_VISIBLE ); | |
559 | |
36008 | 560 gtk_signal_connect( GTK_OBJECT( Playlist ),"destroy",GTK_SIGNAL_FUNC( gtk_widget_destroyed ),&Playlist ); |
33572 | 561 |
562 gtk_signal_connect( GTK_OBJECT( CLFiles ),"select_row",GTK_SIGNAL_FUNC( plRowSelect ),(void *)0 ); | |
563 gtk_signal_connect( GTK_OBJECT( CLFiles ),"unselect_row",GTK_SIGNAL_FUNC( plUnRowSelect ),(void *)0 ); | |
564 gtk_signal_connect( GTK_OBJECT( CLFiles ),"event",GTK_SIGNAL_FUNC( plEvent ),(void *)0 ); | |
34349 | 565 gtk_signal_connect( GTK_OBJECT( CLFiles ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void *)0 ); |
33572 | 566 sigSel=gtk_signal_connect( GTK_OBJECT( CLSelected ),"select_row",GTK_SIGNAL_FUNC( plRowSelect ),(void*)1 ); |
567 sigUnsel=gtk_signal_connect( GTK_OBJECT( CLSelected ),"unselect_row",GTK_SIGNAL_FUNC( plUnRowSelect ),(void*)1 ); | |
568 sigEvent=gtk_signal_connect( GTK_OBJECT( CLSelected ),"event",GTK_SIGNAL_FUNC( plEvent ),(void *)1 ); | |
34349 | 569 gtk_signal_connect( GTK_OBJECT( CLSelected ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void *)1 ); |
33572 | 570 |
34348 | 571 gtk_signal_connect( GTK_OBJECT( Add ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)3 ); |
572 gtk_signal_connect( GTK_OBJECT( Add ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)3 ); | |
573 gtk_signal_connect( GTK_OBJECT( Remove ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)2 ); | |
574 gtk_signal_connect( GTK_OBJECT( Remove ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)2 ); | |
575 gtk_signal_connect( GTK_OBJECT( Ok ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)1 ); | |
576 gtk_signal_connect( GTK_OBJECT( Ok ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)1 ); | |
577 gtk_signal_connect( GTK_OBJECT( Cancel ),"released",GTK_SIGNAL_FUNC( plButtonReleased ),(void*)0 ); | |
578 gtk_signal_connect( GTK_OBJECT( Cancel ),"key_release_event",GTK_SIGNAL_FUNC( plKeyReleased ),(void*)0 ); | |
33572 | 579 |
35981 | 580 gtk_window_add_accel_group( GTK_WINDOW( Playlist ),accel_group ); |
33572 | 581 |
35981 | 582 return Playlist; |
33572 | 583 } |
35982 | 584 |
585 void ShowPlaylist( void ) | |
586 { | |
587 plItem * next; | |
588 | |
589 if ( Playlist ) gtkActive( Playlist ); | |
35996 | 590 else Playlist=CreatePlaylist(); |
35982 | 591 |
592 if ( old_path && *old_path ) | |
593 { | |
594 char * currentdir = strdup( old_path ); | |
595 char * tpath,* pos; | |
596 GtkCTreeNode * node,* nextnode; | |
597 gboolean leaf; | |
598 tpath=strdup( "/" ); | |
599 pos=strtok( currentdir,"/" ); | |
600 node=gtk_ctree_find_by_row_data_custom( GTK_CTREE( CTDirTree ),NULL,"/",compare_func ); | |
601 do | |
602 { | |
603 char * tpathnew = g_strconcat( tpath,pos,"/",NULL ); | |
604 free( tpath ); tpath=tpathnew; | |
605 nextnode=gtk_ctree_find_by_row_data_custom( GTK_CTREE( CTDirTree ),node,tpath,compare_func ); | |
606 if ( !nextnode ) break; | |
607 node=nextnode; | |
608 pos=strtok( NULL,"/" ); | |
609 gtk_ctree_get_node_info( GTK_CTREE( CTDirTree ),node,NULL,NULL,NULL,NULL,NULL,NULL,&leaf,NULL ); | |
610 if ( !leaf && pos ) gtk_ctree_expand( GTK_CTREE( CTDirTree ),node ); | |
611 else | |
612 { | |
613 DirNodeType * DirNode; | |
614 gtk_ctree_select( GTK_CTREE( CTDirTree ),node ); | |
615 DirNode=gtk_ctree_node_get_row_data( GTK_CTREE( CTDirTree ),node ); | |
616 current_path=DirNode->path; | |
617 scan_dir( DirNode->path ); | |
618 free( CLFileSelected ); | |
619 CLFileSelected=calloc( 1,NrOfEntrys * sizeof( int ) ); | |
620 break; | |
621 } | |
622 } while( pos ); | |
623 free( tpath ); | |
624 free( currentdir ); | |
625 } | |
626 else gtk_ctree_select( GTK_CTREE( CTDirTree ),parent ); | |
627 | |
628 gtk_clist_freeze( GTK_CLIST( CLSelected ) ); | |
629 gtk_clist_clear( GTK_CLIST( CLSelected ) ); | |
630 next = listMgr( PLAYLIST_GET,0 ); | |
631 if ( next ) | |
632 { | |
633 while ( next || next->next ) | |
634 { | |
635 char * text[1][5]; text[0][4]=""; | |
636 text[0][0]=g_filename_display_name( next->name ); | |
637 text[0][1]=g_filename_display_name( next->path ); | |
638 text[0][2]=next->name; | |
639 text[0][3]=next->path; | |
640 gtk_clist_append( GTK_CLIST( CLSelected ),text[0] ); | |
641 g_free( text[0][0] ); | |
642 g_free( text[0][1] ); | |
643 NrOfSelected++; | |
644 if ( next->next ) next=next->next; else break; | |
645 } | |
646 CLListSelected=calloc( 1,NrOfSelected * sizeof( int ) ); | |
647 } | |
648 gtk_clist_thaw( GTK_CLIST( CLSelected ) ); | |
649 | |
650 gtk_widget_show( Playlist ); | |
651 } |